/**
 * Shopified — couche UI moderne
 * S'appuie sur les variables CSS injectées par modern_ui_inc.php
 */

/* ─── Base ─────────────────────────────────────────────── */
.sf-modern {
	font-family: var(--sf-font);
	color: var(--sf-text);
	background: var(--sf-bg);
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}

.sf-modern html,
.sf-modern body,
.sf-modern div,
.sf-modern span,
.sf-modern p,
.sf-modern a,
.sf-modern li,
.sf-modern td,
.sf-modern th,
.sf-modern label,
.sf-modern input,
.sf-modern select,
.sf-modern textarea,
.sf-modern button {
	font-family: var(--sf-font);
}

.sf-modern body {
	color: var(--sf-text);
	background: var(--sf-bg);
	line-height: 1.6;
}

/* Bandeau décoratif au-dessus du pied de page */
#barre_deco {
	position: absolute;
	bottom: 100%;
	left: 0;
	right: 0;
	width: 100%;
	height: min(42vh, 380px);
	z-index: 0;
	pointer-events: none;
	background-repeat: no-repeat;
	background-size: cover;
	background-position: center bottom;
	opacity: var(--sf-deco-opacity, 0.48);
	transition: opacity var(--sf-duration) var(--sf-ease);
}

[data-sf-theme="dark"] #barre_deco {
	opacity: var(--sf-deco-opacity, 0.36);
}

@media (max-width: 767px) {
	#barre_deco {
		height: min(32vh, 260px);
		opacity: calc(var(--sf-deco-opacity, 0.48) * 0.88);
	}
}

.sf-modern a {
	color: var(--sf-accent-dark);
	transition: color var(--sf-duration) var(--sf-ease);
}

.sf-modern a:focus-visible,
.sf-modern a:hover {
	color: var(--sf-accent);
	text-decoration: none;
}

.sf-modern h1,
.sf-modern h2,
.sf-modern h3,
.sf-modern h4 {
	color: var(--sf-text);
	font-weight: 600;
	letter-spacing: -0.02em;
	line-height: 1.25;
}

.sf-modern h1 { font-size: clamp(1.5rem, 2.5vw, 2rem); margin-bottom: var(--sf-space-md); }
.sf-modern h2 { font-size: clamp(1.25rem, 2vw, 1.625rem); margin-bottom: var(--sf-space); }
.sf-modern h3 { font-size: 1.125rem; margin-bottom: var(--sf-space-sm); }

/* Étoiles FontAwesome — la règle globale sur div écrase font-family */
.sf-modern .stars,
.sf-modern .stars:before,
.sf-modern .stars:after {
	font-family: FontAwesome !important;
}

.sf-modern .stars {
	display: inline-block;
	position: relative;
	letter-spacing: 0.2em;
	font-size: 120%;
	vertical-align: middle;
}

.sf-modern .stars:after {
	position: absolute;
	left: 0;
	top: 0;
}

.sf-modern .fa,
.sf-modern button .fa,
.sf-modern .btn .fa {
	font-family: FontAwesome !important;
}

/* ─── Layout & sections aérées ─────────────────────────── */
.sf-modern #content.subpage {
	margin-top: var(--sf-space-md);
	margin-bottom: var(--sf-space-xl);
}

.sf-modern .sub_content {
	padding: var(--sf-space-lg) 0;
}

.sf-modern .sub_repeat {
	background: var(--sf-surface);
	border-radius: var(--sf-radius-lg);
	box-shadow: var(--sf-shadow-sm);
	padding: var(--sf-space-md) var(--sf-space-lg);
	margin-bottom: var(--sf-space-md);
}

.sf-modern .sidebar_sub {
	padding-top: var(--sf-space-md);
}

.sf-modern .la_page-supp {
	padding-bottom: var(--sf-space-lg);
}

/* ─── Header & navigation ──────────────────────────────── */
.sf-modern #header {
	padding: var(--sf-space-sm) 0;
}

.sf-modern #logo img {
	max-height: 100px;
	padding: var(--sf-space-sm);
	transition: transform var(--sf-duration) var(--sf-ease);
}

.sf-modern #logo img:hover {
	transform: scale(1.02);
}

.sf-modern .navbar-default {
	background: var(--sf-surface);
	border: none;
	box-shadow: var(--sf-shadow-sm);
	border-radius: 0 0 var(--sf-radius) var(--sf-radius);
	margin-bottom: 0;
	transition: box-shadow var(--sf-duration) var(--sf-ease);
}

.sf-modern .navbar-default.affix {
	box-shadow: var(--sf-shadow);
}

.sf-modern .navbar-default .navbar-nav > li > a {
	color: var(--sf-text);
	font-weight: 500;
	padding: 14px 16px;
	transition: color var(--sf-duration) var(--sf-ease), background var(--sf-duration) var(--sf-ease);
	border-radius: var(--sf-radius-sm);
	margin: 4px 2px;
}

.sf-modern .navbar-default .navbar-nav > .active > a,
.sf-modern .navbar-default .navbar-nav > .active > a:hover,
.sf-modern .navbar-default .navbar-nav > .active > a:focus,
.sf-modern .navbar-default .navbar-nav > li > a:hover,
.sf-modern .navbar-default .navbar-nav > li > a:focus {
	color: var(--sf-accent);
	background: rgba(30, 171, 227, 0.08);
}

.sf-modern #cart .btn-secondary,
.sf-modern #cart a.btn {
	border-radius: var(--sf-radius-pill);
	padding: 8px 18px;
	font-weight: 600;
	box-shadow: var(--sf-shadow-sm);
	transition: transform var(--sf-duration) var(--sf-ease), box-shadow var(--sf-duration) var(--sf-ease), background var(--sf-duration) var(--sf-ease);
}

.sf-modern #cart .btn-secondary:hover {
	transform: translateY(-1px);
	box-shadow: var(--sf-shadow);
}

/* ─── Boutons & CTA ────────────────────────────────────── */
.sf-modern .btn {
	border-radius: var(--sf-radius-pill);
	font-weight: 600;
	letter-spacing: 0.01em;
	padding: 10px 22px;
	border-width: 2px;
	transition: transform var(--sf-duration) var(--sf-ease),
		box-shadow var(--sf-duration) var(--sf-ease),
		background-color var(--sf-duration) var(--sf-ease),
		border-color var(--sf-duration) var(--sf-ease),
		color var(--sf-duration) var(--sf-ease);
}

.sf-modern .btn:active {
	transform: translateY(0);
}

.sf-modern .btn-lg {
	padding: 14px 28px;
	font-size: 1.05rem;
}

.sf-modern .btn-sm,
.sf-modern .btn-xs {
	border-radius: var(--sf-radius-pill);
}

.sf-modern .btn-secondary {
	background: linear-gradient(135deg, var(--sf-cta) 0%, #c41a65 100%);
	border-color: transparent;
	box-shadow: 0 4px 14px rgba(230, 35, 121, 0.35);
}

.sf-modern .btn-secondary:hover,
.sf-modern .btn-secondary:focus {
	background: linear-gradient(135deg, var(--sf-cta-hover) 0%, var(--sf-cta) 100%);
	border-color: transparent;
	box-shadow: 0 6px 20px rgba(230, 35, 121, 0.4);
	transform: translateY(-2px);
}

.sf-modern .btn-primary {
	background: linear-gradient(135deg, var(--sf-accent) 0%, var(--sf-accent-dark) 100%);
	border-color: transparent;
	box-shadow: 0 4px 14px rgba(30, 171, 227, 0.3);
}

.sf-modern .btn-primary:hover,
.sf-modern .btn-primary:focus {
	background: linear-gradient(135deg, var(--sf-accent-light) 0%, var(--sf-accent) 100%);
	border-color: transparent;
	transform: translateY(-2px);
	box-shadow: 0 6px 20px rgba(30, 171, 227, 0.35);
}

.sf-modern .btn-secondary-reverse {
	border-color: var(--sf-cta);
	color: var(--sf-cta);
	background: transparent;
}

.sf-modern .btn-secondary-reverse:hover {
	background: var(--sf-cta);
	border-color: var(--sf-cta);
	color: #fff;
	transform: translateY(-2px);
}

.sf-modern .btn-primary-reverse {
	border-color: var(--sf-accent);
	color: var(--sf-accent);
}

.sf-modern .btn-primary-reverse:hover {
	background: var(--sf-accent);
	border-color: var(--sf-accent);
	color: #fff;
	transform: translateY(-2px);
}

/* ─── Cartes produits ──────────────────────────────────── */
.sf-modern .item_listing .item {
	background: var(--sf-surface);
	border: 1px solid var(--sf-border);
	border-radius: var(--sf-radius-lg);
	padding: var(--sf-space-md);
	margin-bottom: var(--sf-space-md);
	box-shadow: var(--sf-shadow-sm);
	transition: transform var(--sf-duration) var(--sf-ease),
		box-shadow var(--sf-duration) var(--sf-ease),
		border-color var(--sf-duration) var(--sf-ease);
	height: 100%;
	display: flex;
	flex-direction: column;
	animation: sf-fade-up 0.55s var(--sf-ease) both;
}

.sf-modern .item_listing > div:nth-child(1) .item { animation-delay: 0.04s; }
.sf-modern .item_listing > div:nth-child(2) .item { animation-delay: 0.08s; }
.sf-modern .item_listing > div:nth-child(3) .item { animation-delay: 0.12s; }
.sf-modern .item_listing > div:nth-child(4) .item { animation-delay: 0.16s; }
.sf-modern .item_listing > div:nth-child(5) .item { animation-delay: 0.2s; }
.sf-modern .item_listing > div:nth-child(6) .item { animation-delay: 0.24s; }

.sf-modern .item_listing .item:hover {
	transform: translateY(-4px);
	box-shadow: var(--sf-shadow-lg);
	border-color: rgba(30, 171, 227, 0.25);
}

.sf-modern .item_listing .thumb_pdt {
	min-height: 140px;
	line-height: 140px;
	border-radius: var(--sf-radius);
	overflow: hidden;
	background: var(--sf-bg);
	margin-bottom: var(--sf-space-sm);
}

.sf-modern .item_listing .thumb_pdt img {
	transition: transform 0.4s var(--sf-ease);
	border-radius: var(--sf-radius-sm);
}

.sf-modern .item_listing .item:hover .thumb_pdt img {
	transform: scale(1.04);
}

.sf-modern .title_pdt {
	border: none;
	border-bottom: 1px solid var(--sf-border);
	padding: var(--sf-space-sm) 0;
	height: auto;
	min-height: 3rem;
	font-size: 1rem;
	font-weight: 600;
	margin-bottom: var(--sf-space-sm);
}

.sf-modern .title_pdt a {
	color: var(--sf-text);
}

.sf-modern .title_pdt a:hover {
	color: var(--sf-accent);
}

.sf-modern .item .text-right[style*="1eabe3"],
.sf-modern .item .price2 {
	color: var(--sf-accent-dark) !important;
	font-size: 1.1rem;
}

.sf-modern .item > .text-center:last-of-type {
	margin-top: auto;
	padding-top: var(--sf-space-sm);
}

.sf-modern .item .btn-secondary-reverse {
	width: 100%;
	max-width: 220px;
}

/* ─── Fiche produit ────────────────────────────────────── */
body.single-products .sidebar_sub,
.sf-modern.single-products .sidebar_sub {
	display: none !important;
}

.sf-modern .single_item {
	background: var(--sf-surface);
	border-radius: var(--sf-radius-lg);
	padding: var(--sf-space-lg);
	box-shadow: var(--sf-shadow-sm);
}

.sf-modern .single_item .nav-tabs {
	border-bottom: 2px solid var(--sf-border);
	margin-bottom: var(--sf-space-md);
}

.sf-modern .single_item .nav-tabs > li > a {
	border: none;
	border-radius: var(--sf-radius-sm) var(--sf-radius-sm) 0 0;
	color: var(--sf-text-muted);
	font-weight: 500;
	padding: 12px 20px;
	transition: color var(--sf-duration) var(--sf-ease), background var(--sf-duration) var(--sf-ease);
}

.sf-modern .single_item .nav-tabs > li.active > a {
	color: var(--sf-accent);
	background: rgba(30, 171, 227, 0.08);
	border-bottom: 2px solid var(--sf-accent);
}

.sf-modern #bloc-pdt {
	background: var(--sf-surface);
	border: 1px solid var(--sf-border);
	border-radius: var(--sf-radius-lg);
	padding: var(--sf-space-md);
	box-shadow: var(--sf-shadow);
}

.sf-modern .sf-product-related-zone {
	clear: both;
	width: 100%;
	margin-top: var(--sf-space-xl);
	padding-top: var(--sf-space-lg);
	border-top: 1px solid var(--sf-border);
}

.sf-modern .sf-related-products {
	margin-bottom: var(--sf-space-xl);
}

.sf-modern .sf-related-products__title,
.sf-modern .sf-related-tutos__title {
	font-size: clamp(1.25rem, 2vw, 1.5rem);
	margin: 0 0 var(--sf-space-md);
	padding-bottom: var(--sf-space-sm);
	border-bottom: 2px solid var(--sf-border);
	color: var(--sf-text);
}

.sf-modern .sf-related-products .item_listing > [class*="col-"] {
	display: flex;
	margin-bottom: var(--sf-space-md);
}

.sf-modern .sf-related-products .item_listing .item {
	width: 100%;
}

.sf-modern .sf-related-tutos__list {
	list-style: none;
	padding: 0;
	margin: 0;
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
	gap: var(--sf-space);
}

.sf-modern .sf-related-tutos__item {
	background: var(--sf-surface);
	border: 1px solid var(--sf-border);
	border-radius: var(--sf-radius);
	padding: var(--sf-space);
	box-shadow: var(--sf-shadow-sm);
}

.sf-modern .sf-related-tutos__item a {
	font-weight: 600;
	color: var(--sf-text);
}

.sf-modern .sf-related-tutos__item a:hover {
	color: var(--sf-accent);
}

.sf-modern .sf-related-tutos__excerpt {
	display: block;
	margin-top: 0.35rem;
	color: var(--sf-text-muted);
	font-size: 0.875rem;
	line-height: 1.45;
}

@media (max-width: 767px) {
	.sf-modern .sf-related-products .item_listing > [class*="col-"] {
		margin-bottom: var(--sf-space-sm);
	}

	.sf-modern .sf-related-tutos__list {
		grid-template-columns: 1fr;
	}
}

/* ─── Tunnel checkout ──────────────────────────────────── */
.sf-modern nav.step,
.sf-modern .step {
	margin-bottom: var(--sf-space-lg);
}

.sf-modern .step .row {
	display: flex;
	flex-wrap: wrap;
	gap: var(--sf-space-xs);
	background: var(--sf-surface);
	border-radius: var(--sf-radius-lg);
	padding: var(--sf-space-xs);
	box-shadow: var(--sf-shadow-sm);
	border: 1px solid var(--sf-border);
}

.sf-modern .step .row > div {
	flex: 1 1 30%;
	border: none !important;
	border-radius: var(--sf-radius);
	line-height: 1.4;
	padding: var(--sf-space-sm) var(--sf-space);
	font-size: 0.875rem;
	font-weight: 500;
	color: var(--sf-text-muted);
	transition: background var(--sf-duration) var(--sf-ease), color var(--sf-duration) var(--sf-ease);
}

.sf-modern .step div.active,
.sf-modern .step .row > div[aria-current="step"],
.sf-modern .step .bg-info,
.sf-modern .step .active {
	font-size: 0.9rem !important;
	font-weight: 700 !important;
	color: var(--sf-cta) !important;
	background: rgba(230, 35, 121, 0.08) !important;
	border: none !important;
}

.sf-modern .step .bg-success {
	color: var(--sf-success) !important;
	background: rgba(13, 159, 110, 0.08) !important;
}

.sf-modern .checkout .table,
.sf-modern .step_three .table {
	border-radius: var(--sf-radius);
	overflow: hidden;
	border: 1px solid var(--sf-border);
}

.sf-modern .checkout .table thead,
.sf-modern .table thead.thead-dark {
	background: var(--sf-text);
	color: #fff;
}

.sf-modern .bs-callout {
	background: var(--sf-surface);
	border-left: 4px solid var(--sf-accent);
	border-radius: var(--sf-radius);
	padding: var(--sf-space-md) var(--sf-space-lg);
	margin-bottom: var(--sf-space-md);
	box-shadow: var(--sf-shadow-sm);
	border-top: 1px solid var(--sf-border);
	border-right: 1px solid var(--sf-border);
	border-bottom: 1px solid var(--sf-border);
}

.sf-modern .register .form-control,
.sf-modern .checkout .form-control,
.sf-modern #send_order .form-control {
	border: 1px solid var(--sf-border);
	border-radius: var(--sf-radius-sm);
	padding: 10px 14px;
	box-shadow: none;
	transition: border-color var(--sf-duration) var(--sf-ease), box-shadow var(--sf-duration) var(--sf-ease);
}

.sf-modern .form-control:focus {
	border-color: var(--sf-accent);
	box-shadow: 0 0 0 3px rgba(30, 171, 227, 0.15);
}

.sf-modern .register .form-group {
	margin-bottom: var(--sf-space-md);
}

.sf-modern .register .error.alert-danger,
.sf-modern .payment .error.alert-danger {
	border-radius: var(--sf-radius-sm);
	border: none;
	background: #fef2f4;
	color: #9b1c31;
}

.sf-modern .moy_pay.radio label {
	display: flex;
	align-items: flex-start;
	gap: var(--sf-space-sm);
	padding: var(--sf-space-sm) var(--sf-space);
	border: 2px solid var(--sf-border);
	border-radius: var(--sf-radius);
	margin-bottom: var(--sf-space-sm);
	cursor: pointer;
	transition: border-color var(--sf-duration) var(--sf-ease), background var(--sf-duration) var(--sf-ease);
}

.sf-modern .moy_pay.radio label:hover {
	border-color: var(--sf-accent);
	background: rgba(30, 171, 227, 0.04);
}

.sf-modern .moy_pay.radio input:checked + .payment_info,
.sf-modern .moy_pay.radio input:focus + .payment_info {
	outline: none;
}

.sf-modern .moy_pay.is-selected label {
	border-color: var(--sf-accent);
	background: rgba(30, 171, 227, 0.06);
}

/* ─── Filtres catalogue ─────────────────────────────────── */
.sf-modern .panel.panel-default {
	border: 1px solid var(--sf-border);
	border-radius: var(--sf-radius-lg);
	box-shadow: var(--sf-shadow-sm);
	overflow: hidden;
	margin-bottom: var(--sf-space-lg);
}

.sf-modern .panel.panel-default .panel-heading {
	background: var(--sf-surface);
	border-bottom: 1px solid var(--sf-border);
	padding: var(--sf-space-sm) var(--sf-space-md);
	transition: background var(--sf-duration) var(--sf-ease);
}

.sf-modern .panel.panel-default .panel-heading:hover {
	background: rgba(30, 171, 227, 0.04);
}

.sf-modern .panel.panel-default .panel-body {
	padding: var(--sf-space-md);
	background: var(--sf-bg);
}

.sf-modern .category-filter-btn {
	border-radius: var(--sf-radius-pill) !important;
	font-weight: 500 !important;
	transition: transform var(--sf-duration) var(--sf-ease), box-shadow var(--sf-duration) var(--sf-ease) !important;
}

.sf-modern .category-filter-btn:hover {
	transform: translateY(-1px);
	box-shadow: var(--sf-shadow-sm);
}

.sf-modern .category-filter-btn.active {
	box-shadow: 0 4px 12px rgba(0, 81, 119, 0.35);
}

.sf-modern .product-filters,
.sf-modern .filters-panel {
	background: var(--sf-surface);
	border: 1px solid var(--sf-border);
	border-radius: var(--sf-radius-lg);
	padding: var(--sf-space-md);
	margin-bottom: var(--sf-space-lg);
}

.sf-modern .badge {
	background: var(--sf-accent);
	border-radius: var(--sf-radius-pill);
	font-weight: 500;
	padding: 4px 10px;
}

/* ─── Pagination ───────────────────────────────────────── */
.sf-modern .pagination a,
.sf-modern .pagination span {
	border-radius: var(--sf-radius-sm);
	margin: 0 2px;
	transition: background var(--sf-duration) var(--sf-ease), color var(--sf-duration) var(--sf-ease);
}

.sf-modern .pagination a:hover {
	background: var(--sf-accent);
	color: #fff;
}

/* ─── Footer ───────────────────────────────────────────── */
.sf-modern #bas_footer,
.sf-modern .sf-site-footer {
	border-top: 15px solid var(--sf-nav-border);
	padding: 0;
	position: relative;
	z-index: 1;
	clear: both;
	overflow: visible;
}

.sf-modern .sf-site-footer__inner {
	width: 100%;
	background: rgba(8, 8, 8, 0.72);
	padding: var(--sf-space-lg) 0 var(--sf-space-md);
	position: relative;
	z-index: 1;
}

.sf-modern .footer_container {
	margin-top: 0;
	margin-bottom: 0;
}

.sf-modern .footer_nav {
	padding: var(--sf-space-sm) 0 var(--sf-space-md);
	line-height: 1.65;
}

.sf-modern .footer_nav a {
	color: rgba(255, 255, 255, 0.88);
	padding: 0.4em var(--sf-space-sm) 0.4em 0;
	margin-right: var(--sf-space-sm);
	font-size: 0.8125rem;
	font-weight: 500;
	line-height: 1.5;
	display: inline-block;
	border-right: 1px solid rgba(255, 255, 255, 0.22);
	transition: color var(--sf-duration) var(--sf-ease);
}

.sf-modern .footer_nav a:last-child {
	border-right: none;
	margin-right: 0;
	padding-right: 0;
}

.sf-modern .footer_nav a:hover {
	color: var(--sf-accent-light);
	text-decoration: none;
}

.sf-modern .copy {
	float: none;
	margin: 0;
	text-align: center;
	overflow: visible;
}

.sf-modern .copy p {
	color: rgba(255, 255, 255, 0.55);
	font-size: 0.875rem;
	margin: 0;
}

.sf-modern .sf-site-footer__meta {
	text-align: center;
	color: rgba(255, 255, 255, 0.35);
	font-size: 0.75rem;
	margin: var(--sf-space-sm) 0 0;
}

/* ─── Badges confiance ─────────────────────────────────── */
.sf-modern .sf-trust-badges {
	margin: var(--sf-space-md) 0;
}

.sf-modern .sf-trust-badges__list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: var(--sf-space-sm);
}

.sf-modern .sf-trust-badges__item {
	display: flex;
	align-items: center;
	gap: 8px;
	min-height: 40px;
	padding: 8px 10px;
	background: rgba(30, 171, 227, 0.06);
	border: 1px solid rgba(30, 171, 227, 0.18);
	border-radius: var(--sf-radius-sm);
	font-size: 0.75rem;
	font-weight: 600;
	line-height: 1.25;
	color: var(--sf-text);
}

.sf-modern .sf-trust-badges__item .fa {
	flex-shrink: 0;
	width: 1.25rem;
	text-align: center;
	font-family: FontAwesome !important;
	font-size: 0.95rem;
	color: var(--sf-accent-dark);
}

.sf-modern .sf-trust-badges__item--payment {
	background: rgba(58, 64, 73, 0.05);
	border-color: var(--sf-border);
}

.sf-modern .sf-trust-badges__item--payment .fa {
	color: var(--sf-text-muted);
}

.sf-modern .sf-trust-badges--checkout,
.sf-modern .sf-trust-badges--pay {
	margin: var(--sf-space) 0 var(--sf-space-md);
	padding: var(--sf-space);
	background: var(--sf-surface);
	border: 1px solid var(--sf-border);
	border-radius: var(--sf-radius);
	box-shadow: var(--sf-shadow-sm);
}

.sf-modern .sf-trust-badges--checkout .sf-trust-badges__list,
.sf-modern .sf-trust-badges--pay .sf-trust-badges__list {
	grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
}

.sf-modern #bloc-pdt .sf-trust-badges {
	margin-top: var(--sf-space-sm);
}

.sf-modern #bloc-pdt .sf-trust-badges__list {
	grid-template-columns: 1fr;
}

@media (min-width: 992px) {
	.sf-modern #bloc-pdt .sf-trust-badges__list {
		grid-template-columns: 1fr;
	}
}

@media (max-width: 767px) {
	.sf-modern .sf-trust-badges__list {
		grid-template-columns: 1fr;
	}
}

.sf-modern .animated-background {
	background: linear-gradient(-45deg, #ee7752, #e73c7e, #23a6d5, #23d5ab);
	background-size: 400% 400%;
	animation: gradientAnimation var(--sf-gradient-duration, 28s) ease infinite;
}

.sf-modern .sf-home-promo.animated-background {
	background-image: var(--sf-promo-bg), var(--sf-promo-bg), linear-gradient(-45deg, #ee7752, #e73c7e, #23a6d5, #23d5ab);
	background-size: auto, auto, 400% 400%;
	animation: snow 25s linear infinite, gradientAnimation var(--sf-gradient-duration, 28s) ease infinite;
}

.sf-modern .sf-site-footer.animated-background .sf-site-footer__inner {
	background: rgba(8, 8, 8, 0.58);
}

@media (max-width: 767px) {
	.sf-modern .footer_nav a {
		white-space: normal;
		border-right: none;
		margin-right: 0;
		padding: 0.35em 0.5em;
	}
}

/* ─── Skeleton loading ─────────────────────────────────── */
@keyframes sf-shimmer {
	0% { background-position: -200% 0; }
	100% { background-position: 200% 0; }
}

@keyframes sf-fade-up {
	from {
		opacity: 0;
		transform: translateY(12px);
	}
	to {
		opacity: 1;
		transform: translateY(0);
	}
}

.sf-skeleton {
	background: linear-gradient(90deg, #eef1f5 25%, #f8f9fb 50%, #eef1f5 75%);
	background-size: 200% 100%;
	animation: sf-shimmer 1.4s ease-in-out infinite;
	border-radius: var(--sf-radius-sm);
}

.sf-modern .sf-img-wrap {
	position: relative;
	display: block;
	overflow: hidden;
	border-radius: var(--sf-radius-sm);
}

.sf-modern .sf-img-wrap.sf-loading::before {
	content: "";
	position: absolute;
	inset: 0;
	z-index: 1;
	background: linear-gradient(90deg, #eef1f5 25%, #f8f9fb 50%, #eef1f5 75%);
	background-size: 200% 100%;
	animation: sf-shimmer 1.4s ease-in-out infinite;
}

.sf-modern .sf-img-wrap.sf-loading img {
	opacity: 0;
}

.sf-modern .sf-img-wrap img {
	transition: opacity 0.35s var(--sf-ease);
}

.sf-modern .loader,
.sf-modern .register .loader,
.sf-modern .step_three .loader {
	display: flex;
	align-items: center;
	justify-content: center;
	min-height: 80px;
	padding: var(--sf-space-lg);
}

.sf-modern .loader::before {
	content: "";
	width: 40px;
	height: 40px;
	border: 3px solid var(--sf-border);
	border-top-color: var(--sf-accent);
	border-radius: 50%;
	animation: sf-spin 0.7s linear infinite;
}

.sf-modern .loader .loader_text {
	position: absolute;
	width: 1px;
	height: 1px;
	overflow: hidden;
	clip: rect(0, 0, 0, 0);
}

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

/* ─── Micro-interactions ───────────────────────────────── */
.sf-modern .alert {
	border-radius: var(--sf-radius);
	border: none;
}

.sf-modern .alert-info {
	background: rgba(30, 171, 227, 0.1);
	color: var(--sf-accent-dark);
}

.sf-modern .jumbotron {
	background: linear-gradient(135deg, rgba(30, 171, 227, 0.06) 0%, rgba(230, 35, 121, 0.04) 100%);
	border-radius: var(--sf-radius-lg);
	border: 1px solid var(--sf-border);
	padding: var(--sf-space-lg);
}

.sf-modern .sf-fade-in {
	opacity: 0;
	transform: translateY(16px);
	transition: opacity 0.5s var(--sf-ease), transform 0.5s var(--sf-ease);
}

.sf-modern .sf-fade-in.sf-visible {
	opacity: 1;
	transform: translateY(0);
}

.sf-modern .login_form {
	border-radius: var(--sf-radius-lg);
	box-shadow: var(--sf-shadow-lg);
}

/* ─── Responsive ───────────────────────────────────────── */
@media (max-width: 991px) {
	.sf-modern .sub_repeat {
		padding: var(--sf-space);
		border-radius: var(--sf-radius);
	}

	.sf-modern .step .row > div {
		flex: 1 1 100%;
		text-align: center !important;
		font-size: 0.8rem;
	}
}

@media (max-width: 767px) {
	.sf-modern .item_listing .item {
		padding: var(--sf-space-sm);
	}

	.sf-modern .btn-lg {
		width: 100%;
		margin-bottom: var(--sf-space-xs);
	}

	.sf-modern .single_item {
		padding: var(--sf-space);
	}

	.sf-modern #logo img {
		max-height: 72px;
	}
}

@media (min-width: 1200px) {
	.sf-modern .wrapper.container {
		max-width: var(--sf-content-max);
	}
}

@media (min-width: 1800px) {
	body.sf-modern {
		--sf-content-max: 1800px;
	}

	body.sf-modern .wrapper.container,
	body.sf-modern .container,
	body.sf-modern div.container {
		max-width: 1800px;
		width: 100%;
	}
}

/* ─── Accueil hero ─────────────────────────────────────── */
.sf-modern .sf-hero {
	margin-bottom: var(--sf-space-lg);
}

/* Annule style.css legacy (.carousel padding, controls hors cadre, .item .btn:after) */
.sf-modern .sf-hero-carousel.carousel {
	padding: 0 !important;
	margin-bottom: 0;
}

.sf-modern .sf-hero-carousel {
	background: var(--sf-surface);
	border: 1px solid var(--sf-border);
	border-radius: var(--sf-radius-lg);
	box-shadow: var(--sf-shadow);
	overflow: hidden;
	position: relative;
}

.sf-modern .sf-hero-carousel .carousel-inner {
	margin-top: 0;
	min-height: 300px;
	background: transparent !important;
	padding: var(--sf-space-md) 52px var(--sf-space-xl) 92px;
}

.sf-modern .sf-hero-carousel .carousel-inner .item_div {
	margin-left: 0 !important;
}

.sf-modern .sf-hero-carousel .carousel-inner img.img-responsive {
	height: auto;
	max-height: 200px;
	width: auto;
	max-width: 100%;
	margin: 0 auto;
	object-fit: contain;
}

.sf-modern .sf-hero-carousel .item .btn:after {
	content: none !important;
}

.sf-modern .sf-hero-slide__inner {
	display: grid;
	grid-template-columns: minmax(140px, 220px) 1fr;
	align-items: center;
	gap: var(--sf-space-lg);
	padding: var(--sf-space-sm) 0;
}

.sf-modern .sf-hero-slide__media {
	display: flex;
	align-items: center;
	justify-content: center;
	background: var(--sf-bg);
	border-radius: var(--sf-radius);
	padding: var(--sf-space-sm);
	min-height: 180px;
}

.sf-modern .sf-hero-slide__body {
	display: flex;
	flex-direction: column;
	justify-content: center;
	min-width: 0;
	text-align: left;
}

.sf-modern .sf-hero-slide__title {
	border: none !important;
	height: auto !important;
	padding: 0 !important;
	font-size: clamp(1.15rem, 2.2vw, 1.65rem);
	font-weight: 700;
	margin: 0 0 var(--sf-space-sm);
	line-height: 1.3;
	display: block !important;
}

.sf-modern .sf-hero-slide__title a {
	color: var(--sf-text);
	text-decoration: none;
}

.sf-modern .sf-hero-slide__title a:hover {
	color: var(--sf-accent);
}

.sf-modern .sf-hero-slide__excerpt {
	color: var(--sf-text-muted);
	margin: 0 0 var(--sf-space-md);
	line-height: 1.55;
	font-size: 0.95rem;
}

.sf-modern .sf-hero-slide__footer {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: space-between;
	gap: var(--sf-space-sm);
	padding-top: var(--sf-space-sm);
	border-top: 1px solid var(--sf-border);
	margin-top: auto;
}

.sf-modern .sf-hero-slide__rating .stars {
	display: inline-block !important;
	position: relative;
	vertical-align: middle;
}

.sf-modern .sf-hero-slide__actions {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: flex-end;
	gap: var(--sf-space-sm);
	margin-left: auto;
}

.sf-modern .sf-hero-slide__price {
	font-size: 1.35rem;
	font-weight: 700;
	color: var(--sf-accent-dark);
	white-space: nowrap;
}

.sf-modern .sf-hero-slide__cta {
	font-weight: 600;
	white-space: nowrap;
}

.sf-modern .sf-hero-carousel .carousel-indicators,
.sf-modern .sf-hero-carousel__indicators {
	position: absolute;
	left: 92px;
	right: 52px;
	bottom: 14px;
	top: auto !important;
	margin: 0 !important;
	width: auto !important;
	text-align: center;
	z-index: 3;
}

.sf-modern .sf-hero-carousel .carousel-indicators li {
	width: 10px;
	height: 10px;
	border-radius: 50%;
	border: none;
	background: var(--sf-border);
	margin: 0 5px !important;
	transition: transform var(--sf-duration) var(--sf-ease), background var(--sf-duration) var(--sf-ease);
}

.sf-modern .sf-hero-carousel .carousel-indicators .active {
	background: var(--sf-cta) !important;
	transform: scale(1.15);
}

.sf-modern .sf-hero-carousel .carousel-control,
.sf-modern .sf-hero-carousel__control {
	position: absolute !important;
	top: 50% !important;
	margin-top: 0 !important;
	width: 40px !important;
	height: 40px !important;
	border: none !important;
	border-radius: 50% !important;
	background: rgba(26, 29, 33, 0.55) !important;
	opacity: 1;
	z-index: 4;
	display: flex;
	align-items: center;
	justify-content: center;
	color: #fff;
	text-shadow: none;
	transform: translateY(-50%);
	transition: background var(--sf-duration) var(--sf-ease);
}

.sf-modern .sf-hero-carousel__control:hover,
.sf-modern .sf-hero-carousel__control:focus {
	background: rgba(26, 29, 33, 0.85) !important;
	color: #fff;
}

.sf-modern .sf-hero-carousel__control--prev {
	left: 96px !important;
	right: auto !important;
	top: 50% !important;
	bottom: auto !important;
	transform: translateY(-50%) !important;
	width: 40px !important;
	height: 40px !important;
}

.sf-modern .sf-hero-carousel__control--next {
	right: 12px !important;
	left: auto !important;
	top: 50% !important;
	bottom: auto !important;
	transform: translateY(-50%) !important;
}

.sf-modern .sf-hero-quicknav {
	position: absolute;
	left: 0;
	top: 0;
	bottom: 0;
	width: 84px;
	display: flex;
	flex-direction: column;
	z-index: 5;
	border-radius: var(--sf-radius-lg) 0 0 var(--sf-radius-lg);
	overflow: hidden;
}

.sf-modern .sf-hero-quicknav__item {
	flex: 1;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	color: #fff;
	text-decoration: none;
	font-size: 0.62rem;
	font-weight: 600;
	line-height: 1.25;
	padding: 6px 4px;
	text-align: center;
	gap: 6px;
	transition: filter var(--sf-duration) var(--sf-ease);
}

.sf-modern .sf-hero-quicknav__item i {
	font-size: 1.15rem;
	line-height: 1;
	display: block;
}

.sf-modern .sf-hero-quicknav__item span {
	display: block;
	max-width: 100%;
	overflow: hidden;
	text-overflow: ellipsis;
}

.sf-modern .sf-hero-quicknav__item:hover {
	filter: brightness(1.08);
	color: #fff;
}

.sf-modern .sf-hero-quicknav__item--pink { background: var(--sf-cta); }
.sf-modern .sf-hero-quicknav__item--dark { background: #3a404a; }
.sf-modern .sf-hero-quicknav__item--blue { background: var(--sf-accent); }

/* ─── Bandeau promo accueil ────────────────────────────── */
.sf-modern .sf-home-promo {
	border-bottom: 10px solid var(--sf-nav-border);
	padding: var(--sf-space-xl) 0;
	position: relative;
	overflow: hidden;
}

.sf-modern .sf-home-promo__inner,
.sf-modern #info_home {
	text-align: center;
	max-width: 820px;
	margin: 0 auto;
	float: none;
	position: relative;
	z-index: 1;
}

.sf-modern .sf-home-promo__eyebrow {
	color: rgba(255, 255, 255, 0.55);
	font-style: italic;
	margin-bottom: var(--sf-space-sm);
}

.sf-modern .sf-home-promo__title {
	color: #fff;
	font-size: clamp(1.5rem, 3vw, 2.375rem);
	line-height: 1.2;
	margin-bottom: var(--sf-space);
	text-shadow: 0 0 20px rgba(0, 0, 0, 0.45);
}

.sf-modern .sf-home-promo__text {
	color: #bbbfc3;
	font-size: clamp(1rem, 2vw, 1.25rem);
	line-height: 1.5;
	margin-bottom: var(--sf-space-md);
}

.sf-modern .sf-home-promo__cta {
	box-shadow: var(--sf-shadow-lg);
}

/* ─── Grille widgets accueil ───────────────────────────── */
.sf-modern .sf-home-layout {
	padding-bottom: var(--sf-space-xl);
}

.sf-modern .sf-home-grid__main,
.sf-modern .sf-home-grid__side {
	margin-bottom: var(--sf-space-md);
}

.sf-modern .sf-home-widget-zone {
	background: var(--sf-surface);
	border: 1px solid var(--sf-border);
	border-radius: var(--sf-radius-lg);
	padding: var(--sf-space-md);
	box-shadow: var(--sf-shadow-sm);
	min-height: 120px;
}

/* ─── Carousel accueil legacy ──────────────────────────── */
.sf-modern #carousel-module-shop.sf-home-carousel.carousel {
	position: relative;
	margin-bottom: var(--sf-space-md);
	padding: 0 0 var(--sf-space-sm);
	overflow: hidden;
}

.sf-modern .sf-home-carousel__wrap {
	display: flex;
	align-items: stretch;
	min-height: 220px;
}

.sf-modern .sf-home-carousel__quicknav {
	flex: 0 0 112px;
	display: flex;
	flex-direction: column;
	z-index: 3;
	box-shadow: var(--sf-shadow-sm);
}

.sf-modern .sf-home-carousel__vignette {
	flex: 1;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	gap: 6px;
	padding: 10px 6px;
	color: #fff;
	text-decoration: none;
	font-size: 0.6875rem;
	font-weight: 700;
	line-height: 1.2;
	text-transform: uppercase;
	text-align: center;
	letter-spacing: 0.03em;
	transition: filter var(--sf-duration) var(--sf-ease), transform var(--sf-duration) var(--sf-ease);
}

.sf-modern .sf-home-carousel__vignette .fa {
	font-family: FontAwesome !important;
	font-size: 1.35rem;
}

.sf-modern .sf-home-carousel__vignette:hover,
.sf-modern .sf-home-carousel__vignette:focus {
	color: #fff;
	text-decoration: none;
	filter: brightness(1.08);
	transform: translateX(2px);
}

.sf-modern .sf-home-carousel__vignette--modules { background: #df0067; }
.sf-modern .sf-home-carousel__vignette--promos { background: #3a404a; }
.sf-modern .sf-home-carousel__vignette--account { background: #1eabe3; }

.sf-modern .sf-home-carousel__stage {
	flex: 1;
	min-width: 0;
	position: relative;
	background: var(--sf-surface);
	padding: var(--sf-space-sm) var(--sf-space-sm) 40px;
}

.sf-modern .sf-home-carousel__indicators {
	position: absolute;
	left: 0;
	right: 0;
	bottom: 10px;
	top: auto;
	width: auto;
	margin: 0;
	padding: 0;
	display: flex;
	justify-content: center;
	align-items: center;
	gap: 8px;
	z-index: 4;
}

.sf-modern .sf-home-carousel__indicators li {
	display: block;
	width: 10px;
	height: 10px;
	margin: 0;
	border: none;
	border-radius: 50%;
	background: #cecece;
	text-indent: -9999px;
	overflow: hidden;
	cursor: pointer;
	transition: background var(--sf-duration) var(--sf-ease), transform var(--sf-duration) var(--sf-ease);
}

.sf-modern .sf-home-carousel__indicators li.active {
	background: var(--sf-accent);
	transform: scale(1.15);
}

.sf-modern #carousel-module-shop .carousel-inner {
	margin-top: 0;
	width: 100%;
}

.sf-modern #carousel-module-shop .carousel-inner .item_div {
	margin-left: 0;
	padding: 0;
}

.sf-modern #carousel-module-shop .carousel-inner img.img-responsive {
	height: auto;
	max-height: 180px;
	width: auto;
	object-fit: contain;
}

.sf-modern #carousel-module-shop .info3 {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: space-between;
	gap: var(--sf-space-sm);
	clear: both;
}

.sf-modern #carousel-module-shop .info3 > .text-left {
	float: none !important;
	width: auto !important;
	margin-left: 0 !important;
}

.sf-modern #carousel-module-shop .info3 > .text-right {
	float: none !important;
	width: auto;
	margin-left: auto;
}

@media (max-width: 991px) {
	.sf-modern #carousel-module-shop.sf-home-carousel.carousel {
		padding: 0 var(--sf-space) var(--sf-space-sm);
	}

	.sf-modern .sf-home-carousel__wrap {
		min-height: 0;
	}

	.sf-modern .sf-home-carousel__stage {
		padding-bottom: 44px;
	}
}

@media (max-width: 767px) {
	.sf-modern #carousel-module-shop.sf-home-carousel.carousel {
		padding: 0 var(--sf-space-sm) var(--sf-space-sm);
	}

	.sf-modern .sf-home-carousel__wrap {
		flex-direction: column;
	}

	.sf-modern .sf-home-carousel__stage {
		padding: var(--sf-space-sm) var(--sf-space-sm) 40px;
	}

	.sf-modern #carousel-module-shop .title_pdt,
	.sf-modern #carousel-module-shop .info2 {
		text-align: center !important;
		height: auto;
		min-height: 0;
	}

	.sf-modern #carousel-module-shop .info3 {
		justify-content: center;
	}

	.sf-modern #carousel-module-shop .item:hover {
		transform: none;
	}
}

@media (max-width: 480px) {
	.sf-modern #carousel-module-shop .carousel-inner img.img-responsive {
		max-height: 140px;
	}

	.sf-modern #carousel-module-shop .title_pdt {
		font-size: 1.05rem;
	}
}

@media (max-width: 991px) {
	.sf-modern .sf-home-grid {
		display: flex;
		flex-direction: column;
	}

	.sf-modern .sf-home-grid__main { order: 1; }
	.sf-modern .sf-home-grid__side#sidebar_home_left { order: 2; }
	.sf-modern .sf-home-grid__side#sidebar_home_right { order: 3; }

	.sf-modern .sf-home-promo {
		padding: var(--sf-space-lg) var(--sf-space-sm);
	}

	.sf-modern .sf-home-promo__inner,
	.sf-modern #info_home {
		padding: var(--sf-space) var(--sf-space-sm);
	}

	.sf-modern .sf-home-widget-zone {
		padding: var(--sf-space);
	}
}

/* ─── Mini-panier ──────────────────────────────────────── */
.sf-modern .sf-mini-cart {
	position: relative;
}

.sf-modern .sf-mini-cart__trigger {
	background: transparent;
	border: none;
	padding: 0;
	cursor: pointer;
	color: var(--sf-accent);
	font-weight: 600;
	line-height: 1.3;
	transition: color var(--sf-duration) var(--sf-ease), transform var(--sf-duration) var(--sf-ease);
}

.sf-modern .sf-mini-cart__trigger .cart,
.sf-modern #cart_appear.cart {
	display: inline-flex;
	flex-direction: column;
	align-items: center;
	position: relative;
}

.sf-modern .sf-mini-cart__icon-wrap {
	position: relative;
	display: inline-block;
	line-height: 1;
}

.sf-modern .sf-mini-cart__trigger .fa-shopping-cart {
	font-size: 1.75rem;
	display: block;
}

.sf-modern .sf-mini-cart__label {
	display: block;
	font-size: 0.8rem;
	text-transform: capitalize;
	margin-top: 2px;
}

.sf-modern .sf-mini-cart .badge,
.sf-modern .sf-mini-cart__badge {
	position: absolute;
	top: -6px;
	right: -12px;
	left: auto;
	margin: 0 !important;
	background: var(--sf-cta);
	min-width: 20px;
	padding: 2px 6px;
	font-size: 0.7rem;
	line-height: 1.2;
	z-index: 1;
}

.sf-modern .sf-mini-cart__trigger:hover,
.sf-modern .sf-mini-cart__trigger:focus-visible {
	color: var(--sf-accent-dark);
	transform: translateY(-1px);
}

.sf-modern .sf-mini-cart__panel {
	position: absolute;
	top: calc(100% + 8px);
	right: 0;
	width: min(320px, 92vw);
	z-index: 10050;
	background: var(--sf-surface);
	border: 1px solid var(--sf-border);
	border-radius: var(--sf-radius-lg);
	box-shadow: var(--sf-shadow-lg);
	overflow: hidden;
	text-align: left;
}

.sf-modern .sf-mini-cart__header {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: var(--sf-space-sm) var(--sf-space);
	border-bottom: 1px solid var(--sf-border);
	background: var(--sf-bg);
}

.sf-modern .sf-mini-cart__close {
	background: transparent;
	border: none;
	font-size: 1.5rem;
	line-height: 1;
	color: var(--sf-text-muted);
	cursor: pointer;
	padding: 0 4px;
}

.sf-modern .sf-mini-cart__item {
	font-size: 0.85rem;
	border-color: var(--sf-border) !important;
}

.sf-modern .sf-mini-cart__item a {
	color: var(--sf-text);
	font-weight: 500;
}

.sf-modern .sf-mini-cart__item .price {
	display: block;
	color: var(--sf-text-muted);
	margin-top: 2px;
}

.sf-modern .sf-mini-cart__total {
	font-size: 0.95rem;
}

.sf-modern .sf-mini-cart__actions .btn-block {
	width: 100%;
}

.sf-modern .sf-mini-cart__empty {
	color: var(--sf-text-muted);
	text-align: center;
}

.sf-modern .sf-mini-cart__backdrop {
	display: none;
}

.sf-modern .sf-a11y-dock {
	position: fixed;
	left: 0;
	top: 50%;
	transform: translateY(-50%);
	z-index: 10050;
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 8px;
	padding: 8px;
	background: var(--sf-surface);
	border: 1px solid var(--sf-border);
	border-left: none;
	border-radius: 0 var(--sf-radius) var(--sf-radius) 0;
	box-shadow: var(--sf-shadow-md);
	pointer-events: auto;
}

.sf-modern .sf-a11y-dock .sf-a11y-btn {
	position: relative;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	background: var(--sf-surface);
	border: 1px solid var(--sf-border);
	border-radius: var(--sf-radius-pill);
	min-width: 44px;
	width: 44px;
	height: 44px;
	padding: 0;
	cursor: pointer;
	color: var(--sf-text);
	font-size: 0.875rem;
	font-weight: 600;
	line-height: 1;
	box-shadow: var(--sf-shadow-sm);
	transition: background var(--sf-duration) var(--sf-ease), border-color var(--sf-duration) var(--sf-ease), color var(--sf-duration) var(--sf-ease);
}

.sf-modern .sf-a11y-dock .sf-a11y-btn .fa {
	font-family: FontAwesome !important;
	font-size: 1.05rem;
}

.sf-modern .sf-a11y-btn:hover,
.sf-modern .sf-a11y-btn:focus-visible {
	border-color: var(--sf-accent);
	color: var(--sf-accent);
	outline: none;
}

.sf-modern .sf-a11y-btn[aria-pressed="true"],
.sf-modern .sf-font-btn--reset[aria-pressed="true"] {
	background: rgba(30, 171, 227, 0.12);
	border-color: var(--sf-accent);
	color: var(--sf-accent-dark);
}

.sf-modern .sf-a11y-btn:disabled {
	opacity: 0.45;
	cursor: not-allowed;
	transform: none;
}

.sf-modern .sf-theme-toggle {
	padding: 0;
}

.sf-modern .sf-theme-icon--light { display: none; }
html[data-sf-theme="dark"] .sf-theme-icon--dark { display: none; }
html[data-sf-theme="dark"] .sf-theme-icon--light { display: inline; }

.sf-modern .sf-a11y-popover {
	position: absolute;
	left: calc(100% + 10px);
	top: 50%;
	transform: translateY(-50%) translateX(-4px);
	padding: 6px 10px;
	background: var(--sf-text);
	color: #fff;
	font-size: 0.75rem;
	font-weight: 500;
	line-height: 1.3;
	white-space: nowrap;
	border-radius: var(--sf-radius-sm);
	box-shadow: var(--sf-shadow);
	opacity: 0;
	visibility: hidden;
	pointer-events: none;
	transition: opacity var(--sf-duration) var(--sf-ease), transform var(--sf-duration) var(--sf-ease), visibility var(--sf-duration) var(--sf-ease);
	z-index: 2;
}

.sf-modern .sf-a11y-popover::before {
	content: '';
	position: absolute;
	right: 100%;
	top: 50%;
	transform: translateY(-50%);
	border: 5px solid transparent;
	border-right-color: var(--sf-text);
}

.sf-modern .sf-a11y-btn:hover .sf-a11y-popover,
.sf-modern .sf-a11y-btn:focus-visible .sf-a11y-popover,
.sf-modern .sf-a11y-btn.is-tip-visible .sf-a11y-popover {
	opacity: 1;
	visibility: visible;
	transform: translateY(-50%) translateX(0);
}

@media (max-width: 991px) {
	.sf-modern .sf-a11y-dock {
		top: auto;
		bottom: calc(12px + env(safe-area-inset-bottom, 0px));
		left: max(8px, env(safe-area-inset-left, 0px));
		transform: none;
		flex-direction: row;
		flex-wrap: wrap;
		justify-content: center;
		max-width: min(280px, calc(100vw - 24px));
		border-left: 1px solid var(--sf-border);
		border-radius: var(--sf-radius);
	}

	.sf-modern .sf-a11y-popover {
		left: 50%;
		top: auto;
		bottom: calc(100% + 8px);
		transform: translateX(-50%) translateY(4px);
	}

	.sf-modern .sf-a11y-popover::before {
		right: auto;
		left: 50%;
		top: 100%;
		transform: translateX(-50%);
		border: 5px solid transparent;
		border-top-color: var(--sf-text);
		border-right-color: transparent;
	}

	.sf-modern .sf-a11y-btn:hover .sf-a11y-popover,
	.sf-modern .sf-a11y-btn:focus-visible .sf-a11y-popover,
	.sf-modern .sf-a11y-btn.is-tip-visible .sf-a11y-popover {
		transform: translateX(-50%) translateY(0);
	}
}

/* ─── Mode sombre composants ───────────────────────────── */
[data-sf-theme="dark"] .sf-modern body,
[data-sf-theme="dark"].sf-modern body {
	background: var(--sf-bg);
	color: var(--sf-text);
}

[data-sf-theme="dark"] .sf-modern .navbar-default {
	background: var(--sf-header-bg);
	border-color: var(--sf-border);
}

[data-sf-theme="dark"] .sf-modern .navbar-default .navbar-nav > li > a {
	color: var(--sf-text);
}

[data-sf-theme="dark"] .sf-modern .sub_repeat,
[data-sf-theme="dark"] .sf-modern .item_listing .item,
[data-sf-theme="dark"] .sf-modern .sf-home-widget-zone,
[data-sf-theme="dark"] .sf-modern .sf-hero-carousel,
[data-sf-theme="dark"] .sf-modern .sf-mini-cart__panel {
	background: var(--sf-surface);
	border-color: var(--sf-border);
}

[data-sf-theme="dark"] .sf-modern .table-striped > tbody > tr:nth-of-type(odd) {
	background: rgba(255, 255, 255, 0.03);
}

[data-sf-theme="dark"] .sf-modern .form-control {
	background: #12161d;
	border-color: var(--sf-border);
	color: var(--sf-text);
}

[data-sf-theme="dark"] .sf-modern .sf-img-wrap.sf-loading::before,
[data-sf-theme="dark"] .sf-skeleton {
	background: linear-gradient(90deg, #1f2632 25%, #2a3342 50%, #1f2632 75%);
	background-size: 200% 100%;
}

@media (max-width: 991px) {
	.sf-modern .sf-mini-cart__panel {
		position: fixed;
		top: auto;
		bottom: 0;
		left: 0;
		right: 0;
		width: 100%;
		max-height: 75vh;
		border-radius: var(--sf-radius-lg) var(--sf-radius-lg) 0 0;
		transform: translateY(0);
	}

	.sf-modern .sf-mini-cart__backdrop {
		display: block;
		position: fixed;
		inset: 0;
		background: rgba(0, 0, 0, 0.45);
		z-index: 10040;
		opacity: 0;
		pointer-events: none;
		transition: opacity var(--sf-duration) var(--sf-ease);
	}

	.sf-modern .sf-mini-cart__backdrop.is-visible {
		opacity: 1;
		pointer-events: auto;
	}

	.sf-modern body.sf-cart-open {
		overflow: hidden;
	}

	.sf-modern .sf-hero-carousel .carousel-inner {
		padding: var(--sf-space) 48px var(--sf-space-xl) var(--sf-space);
		min-height: 0;
	}

	.sf-modern .sf-hero-slide__inner {
		grid-template-columns: 1fr;
		gap: var(--sf-space);
		padding: 0;
	}

	.sf-modern .sf-hero-slide__media {
		min-height: 140px;
	}

	.sf-modern .sf-hero-slide__actions {
		width: 100%;
		justify-content: space-between;
	}

	.sf-modern .sf-hero-carousel .carousel-indicators,
	.sf-modern .sf-hero-carousel__indicators {
		left: 0;
		right: 0;
	}

	.sf-modern .sf-hero-carousel__control--prev {
		left: 8px !important;
	}

	.sf-modern .sf-hero-carousel__control--next {
		right: 8px !important;
	}
}
