/* ====================================================================
   ATELIER VAREN — Thème enfant
   Direction : luxe éditorial français, ivoire & émeraude
   ==================================================================== */

/* ----- 1. Variables ----- */
:root {
	/* Fond principal : beige sable luxe très léger (chaleur sans surcharge).
	   Avant : #fff8f5 (ivoire rosé presque blanc).
	   Après : #f7f1e8 (beige doux). Seul le fond change ; les autres niveaux
	   conservent leurs valeurs pour préserver les contrastes existants. */
	--av-surface:           #f7f1e8;
	--av-surface-low:       #fcf2eb;
	--av-surface-med:       #f6ece6;
	--av-surface-high:      #f0e6e0;
	--av-surface-stone:     #eae1da;
	--av-surface-dim:       #e2d8d2;
	--av-surface-white:     #ffffff;
	--av-on-surface:        #1f1b17;
	--av-on-surface-mute:   #404944;
	--av-outline:           #707974;
	--av-outline-variant:   #bfc9c3;
	--av-primary:           #003527;
	--av-primary-container: #064e3b;
	--av-on-primary:        #ffffff;
	--av-secondary:         #735c00;
	--av-secondary-soft:    #c9a227;
	--av-secondary-fixed:   #ffe088;
	--av-error:             #ba1a1a;

	--av-font-serif:        "Bodoni Moda", "Playfair Display", Georgia, serif;
	--av-font-sans:         "Hanken Grotesk", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;

	--av-fs-display:        clamp(40px, 6vw, 64px);
	--av-fs-h1:             clamp(32px, 4vw, 40px);
	--av-fs-h2:             clamp(28px, 3vw, 32px);
	--av-fs-h3:             24px;
	--av-fs-body-lg:        18px;
	--av-fs-body:           16px;
	--av-fs-label:          14px;
	--av-fs-label-sm:       12px;

	--av-margin-mobile:     24px;
	--av-margin-desktop:    80px;
	--av-gutter:            24px;
	--av-max-width:         1440px;
	--av-breathe:           120px;

	--av-radius:            0;
	--av-transition:        300ms cubic-bezier(.25,.46,.45,.94);
}

/* ----- 2. Reset éditorial ----- */
* { box-sizing: border-box; }
html {
	scroll-behavior: smooth;
	/* Empêche le scroll horizontal accidentel sur mobile (décor ::after, etc.) */
	overflow-x: hidden;
}
body.av-theme {
	background: var(--av-surface);
	color: var(--av-on-surface);
	font-family: var(--av-font-sans);
	font-size: var(--av-fs-body);
	font-weight: 400;
	line-height: 1.5;
	-webkit-font-smoothing: antialiased;
	letter-spacing: 0;
	overflow-x: hidden;
	/* Anti-débordement : tout élément déborde max au viewport, jamais au-delà */
	max-width: 100%;
}

/* Sécurité supplémentaire : aucun media ne doit forcer la largeur de la page */
.av-theme img,
.av-theme video,
.av-theme iframe { max-width: 100%; }

.av-theme h1, .av-theme h2, .av-theme h3, .av-theme h4 {
	font-family: var(--av-font-serif);
	font-weight: 400;
	color: var(--av-primary);
	line-height: 1.2;
	letter-spacing: -0.01em;
	margin: 0 0 .5em;
}

.av-theme h1 { font-size: var(--av-fs-h1); }
.av-theme h2 { font-size: var(--av-fs-h2); }
.av-theme h3 { font-size: var(--av-fs-h3); }
.av-theme h4 { font-size: 18px; font-weight: 500; }

.av-theme a {
	color: inherit;
	text-decoration: none;
	transition: color var(--av-transition);
}

.av-theme p { margin: 0 0 1em; color: var(--av-on-surface-mute); }
.av-theme img { max-width: 100%; height: auto; display: block; }

/* ----- 3. Conteneurs ----- */
.av-container {
	max-width: var(--av-max-width);
	margin: 0 auto;
	padding: 0 var(--av-margin-mobile);
}
@media (min-width: 768px) {
	.av-container { padding: 0 var(--av-margin-desktop); }
}

.av-breathe { padding-block: var(--av-breathe); }
@media (max-width: 767px) {
	.av-breathe { padding-block: 64px; }
}

.av-label {
	font-family: var(--av-font-sans);
	font-size: var(--av-fs-label-sm);
	font-weight: 500;
	text-transform: uppercase;
	letter-spacing: 0.2em;
	color: var(--av-outline);
	display: inline-block;
	margin-bottom: 16px;
}

.av-divider {
	width: 48px;
	height: 1px;
	background: var(--av-secondary-soft);
	border: none;
	margin: 24px auto;
}

/* ----- 4. Header ----- */
.av-theme header.site-header,
.av-theme .site-header,
.av-theme #masthead {
	background: rgba(255, 248, 245, 0.85) !important;
	backdrop-filter: blur(20px);
	border-bottom: 1px solid rgba(191, 201, 195, 0.3);
	position: sticky;
	top: 0;
	z-index: 100;
	box-shadow: none !important;
	padding: 0;
}

.av-header-inner {
	max-width: var(--av-max-width);
	margin: 0 auto;
	display: flex;
	align-items: center;
	justify-content: space-between;
	/* padding: top right bottom left
	   padding-left réduit pour décaler le logo vers la gauche.
	   padding-right inchangé pour laisser les icônes Compte/Panier à droite. */
	padding: 16px 16px 16px 6px;
	gap: 8px;
}
@media (min-width: 600px) {
	.av-header-inner {
		padding: 20px 24px 20px 10px; /* 24 → 10 à gauche */
		gap: 16px;
	}
}
@media (min-width: 900px) {
	.av-header-inner {
		padding: 24px var(--av-margin-desktop) 24px 32px; /* 80 → 32 à gauche */
		gap: 24px;
	}
}

.av-logo {
	font-family: var(--av-font-serif);
	font-size: 16px;
	font-weight: 400;
	text-transform: uppercase;
	letter-spacing: 0.18em;
	color: var(--av-primary);
	white-space: nowrap;
	display: inline-flex;
	align-items: center;
	line-height: 1;
	/* Décalage du logo vers la gauche sans déplacer le burger, la nav ou les icones.
	   Le margin négatif fait sortir le logo de son flex-start naturel, en gardant
	   tous les autres éléments à leur position actuelle. */
	margin-left: -73px;
}
@media (min-width: 600px) {
	.av-logo {
		font-size: 20px;
		letter-spacing: 0.22em;
		margin-left: -105px; /* tablette : décalage triplé */
	}
}
@media (min-width: 900px) {
	.av-logo {
		font-size: clamp(22px, 2vw, 28px);
		letter-spacing: 0.25em;
		margin-left: -150px; /* desktop : décalage triplé */
	}
}
.av-logo a { color: inherit; display: inline-flex; align-items: center; }

/* Logo image — uploadé via WP custom_logo. On contraint la hauteur pour qu'il s'aligne avec le header.
   Le PNG fourni a un format vertical (texte ATELIER + VAREN + ligne) : on limite la hauteur. */
.av-logo .custom-logo-link,
.av-theme .custom-logo-link {
	display: inline-block;
	line-height: 1;
}
.av-logo img.custom-logo,
.av-theme .custom-logo {
	display: block;
	max-height: 44px;
	width: auto;
	height: auto;
	object-fit: contain;
}
@media (min-width: 600px) {
	.av-logo img.custom-logo,
	.av-theme .custom-logo { max-height: 52px; }
}
@media (min-width: 900px) {
	.av-logo img.custom-logo,
	.av-theme .custom-logo { max-height: 64px; }
}

.av-nav {
	display: none;
	gap: 36px;
	align-items: center;
}
@media (min-width: 900px) {
	.av-nav { display: flex; }
}
.av-nav a {
	font-family: var(--av-font-sans);
	font-size: var(--av-fs-label);
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	color: var(--av-on-surface-mute);
	padding-bottom: 4px;
	border-bottom: 2px solid transparent;
	transition: all var(--av-transition);
}
.av-nav a:hover,
.av-nav .current-menu-item > a,
.av-nav .current_page_item > a {
	color: var(--av-primary);
	border-bottom-color: var(--av-secondary-soft);
}

.av-nav ul,
.av-nav .sub-menu { list-style: none; padding: 0; margin: 0; }

.av-header-icons {
	display: flex;
	align-items: center;
	gap: 4px;
	color: var(--av-primary);
	flex-shrink: 0;
}
@media (min-width: 600px) { .av-header-icons { gap: 12px; } }
.av-header-icons a,
.av-header-icons button {
	background: none;
	border: none;
	cursor: pointer;
	color: inherit;
	padding: 8px 4px;
	display: inline-flex;
	align-items: center;
	gap: 6px;
	font-size: var(--av-fs-label-sm);
	font-family: var(--av-font-sans);
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	transition: color var(--av-transition);
	white-space: nowrap;
}
@media (min-width: 600px) {
	.av-header-icons a,
	.av-header-icons button { padding: 8px; letter-spacing: 0.1em; }
}
.av-header-icons a:hover { color: var(--av-secondary); }

/* Mobile : on cache le libellé "Compte" (accessible via menu burger).
   Le panier reste visible avec son compteur. */
@media (max-width: 599px) {
	.av-header-icons a[aria-label="Mon compte"] { display: none; }
}

.av-cart-count {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 18px;
	height: 18px;
	background: var(--av-primary);
	color: var(--av-on-primary);
	font-size: 10px;
	font-weight: 600;
	margin-left: 6px;
	padding: 0 5px;
	flex-shrink: 0;
}

/* Burger : un peu plus compact sur mobile */
.av-burger { padding: 8px 4px; flex-shrink: 0; }
@media (min-width: 600px) { .av-burger { padding: 8px; } }

.av-burger {
	display: inline-flex;
	flex-direction: column;
	gap: 4px;
	background: none;
	border: none;
	cursor: pointer;
	padding: 8px;
}
@media (min-width: 900px) { .av-burger { display: none; } }
.av-burger span {
	width: 22px;
	height: 1px;
	background: var(--av-primary);
}

.av-mobile-nav {
	display: none;
	background: var(--av-surface);
	border-top: 1px solid var(--av-outline-variant);
	padding: 24px var(--av-margin-mobile);
}
.av-mobile-nav.is-open { display: block; }
.av-mobile-nav ul { list-style: none; padding: 0; margin: 0; }
.av-mobile-nav li { margin-bottom: 12px; }
.av-mobile-nav a {
	font-family: var(--av-font-sans);
	font-size: 18px;
	font-weight: 500;
	color: var(--av-primary);
	text-transform: uppercase;
	letter-spacing: 0.1em;
}
.av-mobile-nav li.av-mobile-divider {
	margin-top: 16px;
	padding-top: 16px;
	border-top: 1px solid var(--av-outline-variant);
}

/* ----- 5. Buttons ----- */
.av-theme .av-btn,
.av-theme .button.alt,
.av-theme .woocommerce-button.button,
.av-theme button.single_add_to_cart_button,
.av-theme .wc-block-components-button,
a.av-btn {
	display: inline-flex !important;
	align-items: center;
	justify-content: center;
	gap: 10px;
	background: var(--av-primary-container) !important;
	/* Texte BLANC par défaut, OR au survol */
	color: #ffffff !important;
	font-family: var(--av-font-sans);
	font-size: var(--av-fs-label);
	font-weight: 600;
	letter-spacing: 0.15em;
	text-transform: uppercase;
	padding: 16px 32px;
	border: none;
	border-radius: 0;
	cursor: pointer;
	transition: all var(--av-transition);
	line-height: 1.2;
	text-decoration: none !important;
}
.av-theme .av-btn:hover,
.av-theme .button.alt:hover,
.av-theme button.single_add_to_cart_button:hover,
.av-theme .wc-block-components-button:hover,
a.av-btn:hover {
	background: #053d2e !important;
	color: var(--av-secondary-fixed) !important; /* or au survol */
}

.av-theme .av-btn.av-btn-secondary,
.av-theme .button:not(.alt):not(.add_to_cart_button),
a.av-btn.av-btn-secondary {
	background: transparent !important;
	color: var(--av-primary) !important;
	border: 1px solid var(--av-primary) !important;
	padding: 14px 30px;
}
/* Bouton secondaire (clair sur hero) : texte + bordure OR au survol, fond inchangé */
.av-theme .av-btn.av-btn-secondary:hover,
.av-theme .button:not(.alt):not(.add_to_cart_button):hover,
a.av-btn.av-btn-secondary:hover {
	color: var(--av-secondary-soft) !important;
	border-color: var(--av-secondary-soft) !important;
	/* Sur le hero, le bouton secondaire a un style inline background ivoire translucide
	   — on ne le surcharge pas pour garder la lisibilité du texte au survol. */
}

.av-btn-tertiary {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	font-family: var(--av-font-sans);
	font-size: var(--av-fs-label);
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.15em;
	color: var(--av-primary);
	padding-bottom: 4px;
	border-bottom: 1px solid var(--av-primary);
	transition: all var(--av-transition);
}
.av-btn-tertiary:hover {
	color: var(--av-secondary);
	border-bottom-color: var(--av-secondary);
	gap: 14px;
}

/* ----- 6. Homepage Sections ----- */

/* Hero */
.av-hero {
	position: relative;
	min-height: 600px;
	height: 85vh;
	max-height: 819px;
	display: flex;
	align-items: center;
	/* Sur mobile : centré. Sur desktop : justifié à gauche pour ne pas empiéter
	   sur le flacon de parfum à droite de l'image. */
	justify-content: center;
	overflow: hidden;
	background: var(--av-surface-stone);
}
@media (min-width: 768px) {
	.av-hero {
		justify-content: flex-start;
		padding-left: 6vw;
	}
}
@media (min-width: 1280px) {
	.av-hero {
		padding-left: 8vw;
	}
}

.av-hero-bg {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	z-index: 0;
}
.av-hero-overlay {
	position: absolute;
	inset: 0;
	background: rgba(255, 248, 245, 0.25);
	mix-blend-mode: multiply;
	z-index: 1;
}
.av-hero-content {
	position: relative;
	z-index: 2;
	text-align: center;
	padding: 0 var(--av-margin-mobile);
	max-width: 800px;
}
@media (min-width: 768px) {
	.av-hero-content {
		text-align: left;
		padding: 0;
		/* La div se ramasse à la largeur de son enfant le plus large (le H1 nowrap)
		   pour que le centrage des CTAs en dessous soit calculé par rapport au H1, pas
		   par rapport au viewport. */
		width: fit-content;
		max-width: min(100%, 880px);
	}
}
.av-hero h1 {
	font-size: var(--av-fs-display);
	color: var(--av-primary);
	margin-bottom: 32px;
	letter-spacing: -0.02em;
	text-shadow: 0 1px 2px rgba(255,255,255,0.3);
}
/* Sur desktop, le titre tient sur une seule ligne (la maquette le veut ainsi). */
@media (min-width: 768px) {
	.av-hero h1 { white-space: nowrap; }
}
.av-hero-ctas {
	display: flex;
	gap: 16px;
	/* Centré sous le titre quel que soit le viewport */
	justify-content: center;
	flex-wrap: wrap;
}

/* Brand Story */
.av-story {
	background: var(--av-surface-white);
	text-align: center;
}
.av-story-inner {
	max-width: 720px;
	margin: 0 auto;
}
.av-story h2 {
	font-size: clamp(24px, 3vw, 32px);
	color: var(--av-primary);
}

/* Categories Bento */
.av-bento {
	padding-block: 32px;
}
.av-bento-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--av-gutter);
	min-height: 480px;
}
@media (min-width: 768px) {
	.av-bento-grid { grid-template-columns: 1fr 1fr; height: 600px; }
}
.av-bento-card {
	position: relative;
	overflow: hidden;
	display: flex;
	align-items: flex-end;
	padding: 32px;
	min-height: 360px;
	background: var(--av-surface-stone);
	color: var(--av-on-primary);
}
.av-bento-card img {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform 700ms cubic-bezier(.25,.46,.45,.94);
	z-index: 0;
}
.av-bento-card::after {
	content: "";
	position: absolute;
	inset: 0;
	background: linear-gradient(to top, rgba(0, 53, 39, 0.7) 0%, transparent 60%);
	z-index: 1;
}
.av-bento-card:hover img { transform: scale(1.05); }
.av-bento-content {
	position: relative;
	z-index: 2;
}
.av-bento-content h3 {
	font-family: var(--av-font-serif);
	font-size: clamp(28px, 3vw, 40px);
	color: var(--av-on-primary);
	margin-bottom: 12px;
}
.av-bento-content .av-btn-tertiary {
	color: var(--av-secondary-fixed);
	border-bottom-color: var(--av-secondary-fixed);
}

/* Products grid */
.av-products {
	text-align: center;
}
.av-products-header { margin-bottom: 64px; }
.av-products-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 48px var(--av-gutter);
	text-align: left;
}
@media (min-width: 640px) { .av-products-grid { grid-template-columns: 1fr 1fr; } }
@media (min-width: 900px) { .av-products-grid { grid-template-columns: 1fr 1fr 1fr; } }

.av-product-card {
	display: flex;
	flex-direction: column;
}
.av-product-card .av-product-media {
	position: relative;
	/* Aspect-ratio 2/3 = ratio de référence de l'image Z.K Signature.
	   WC crop désormais toutes les images produit dans ce ratio à l'upload,
	   donc les 3 cartes de la grille sont visuellement parfaitement
	   harmonisées. */
	aspect-ratio: 2 / 3;
	overflow: hidden;
	background: var(--av-surface);
	margin-bottom: 24px;
}
.av-product-card img {
	width: 100%;
	height: 100%;
	/* cover + center : si une future image n'est pas exactement en 2/3, le CSS
	   prend le relais pour cropper de façon équilibrée et garder l'harmonie. */
	object-fit: cover;
	object-position: center;
	transition: transform 500ms cubic-bezier(.25,.46,.45,.94);
}
.av-product-card:hover img { transform: scale(1.03); }

/* Badge "Prochainement" — affiché à la place du prix sur les parfums à venir.
   Reprend la même typo que .av-product-price (uppercase, letter-spacing, or). */
.av-coming-soon-tag {
	font-family: var(--av-font-sans);
	font-size: var(--av-fs-label-sm);
	font-weight: 600;
	letter-spacing: 0.2em;
	color: var(--av-secondary);
	text-transform: uppercase;
	display: inline-block;
}
.av-product-card h4 {
	font-family: var(--av-font-sans);
	font-size: var(--av-fs-label);
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.15em;
	color: var(--av-primary);
	margin-bottom: 8px;
}
.av-product-card .av-product-meta {
	font-family: var(--av-font-sans);
	font-size: var(--av-fs-body);
	color: var(--av-on-surface-mute);
	margin-bottom: 16px;
}
.av-product-card .av-product-price {
	font-family: var(--av-font-sans);
	font-size: var(--av-fs-label-sm);
	font-weight: 600;
	letter-spacing: 0.2em;
	color: var(--av-secondary);
	text-transform: uppercase;
}

/* Focus signature parfum */
.av-focus-signature {
	background: var(--av-surface-high);
}
.av-focus-grid {
	display: grid;
	grid-template-columns: 1fr;
}
@media (min-width: 768px) {
	.av-focus-grid { grid-template-columns: 1fr 1fr; }
}
.av-focus-img {
	min-height: 480px;
	background-size: cover;
	background-position: center;
}
@media (min-width: 768px) {
	.av-focus-img { min-height: 720px; }
}
.av-focus-content {
	padding: 64px var(--av-margin-mobile);
	display: flex;
	flex-direction: column;
	justify-content: center;
}
@media (min-width: 768px) {
	.av-focus-content { padding: 64px 80px; }
}
.av-focus-content h2 { font-size: var(--av-fs-h1); margin-bottom: 32px; }
.av-focus-content p { font-size: var(--av-fs-body-lg); max-width: 440px; margin-bottom: 40px; }

/* Focus vêtements asymétrique */
.av-focus-clothing { }
.av-focus-clothing-inner {
	display: flex;
	flex-direction: column-reverse;
	gap: 48px;
}
@media (min-width: 768px) {
	.av-focus-clothing-inner {
		flex-direction: row;
		align-items: center;
		gap: 96px;
	}
}
.av-focus-clothing-text { flex: 0 0 41.66%; }
.av-focus-clothing-img {
	flex: 0 0 58.33%;
	position: relative;
}
.av-focus-clothing-img .av-img-wrap {
	aspect-ratio: 4 / 3;
	overflow: hidden;
	background: var(--av-surface-stone);
}
.av-focus-clothing-img .av-img-wrap img { width: 100%; height: 100%; object-fit: cover; }
/* Décor : caché sur mobile pour éviter le débordement horizontal */
.av-focus-clothing-img::after {
	content: "";
	position: absolute;
	bottom: -32px;
	left: -32px;
	width: 192px;
	height: 192px;
	border: 1px solid rgba(191, 201, 195, 0.5);
	z-index: -1;
	display: none;
}
@media (min-width: 1024px) {
	.av-focus-clothing-img::after { display: block; }
}

/* Réassurance */
.av-reassurance {
	background: var(--av-surface-white);
	border-top: 1px solid rgba(191, 201, 195, 0.3);
	padding: 64px 0;
}
.av-reassurance-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 48px;
	text-align: center;
}
@media (min-width: 768px) {
	.av-reassurance-grid {
		grid-template-columns: repeat(3, 1fr);
		gap: 0;
	}
	.av-reassurance-item + .av-reassurance-item {
		border-left: 1px solid rgba(191, 201, 195, 0.3);
		padding-left: 32px;
	}
	.av-reassurance-item + .av-reassurance-item ~ .av-reassurance-item {
		padding-left: 32px;
	}
}
.av-reassurance-item h5 {
	font-family: var(--av-font-sans);
	font-size: var(--av-fs-label);
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.15em;
	color: var(--av-primary);
	margin-bottom: 8px;
}
.av-reassurance-item .av-icon {
	font-family: var(--av-font-serif);
	font-size: 32px;
	color: var(--av-secondary-soft);
	margin-bottom: 16px;
	display: block;
}

/* Newsletter */
.av-newsletter {
	background: var(--av-surface-med);
	text-align: center;
}
.av-newsletter form {
	max-width: 520px;
	margin: 24px auto 0;
	display: flex;
	gap: 8px;
	flex-wrap: wrap;
}
.av-newsletter input[type="email"] {
	flex: 1 1 240px;
	border: none;
	border-bottom: 1px solid var(--av-outline-variant);
	background: transparent;
	padding: 12px 4px;
	font-family: var(--av-font-sans);
	font-size: var(--av-fs-body);
	color: var(--av-primary);
}
.av-newsletter input[type="email"]:focus {
	outline: none;
	border-bottom-color: var(--av-primary);
}
.av-newsletter input[type="email"]::placeholder { color: var(--av-outline); letter-spacing: 0.05em; }

/* ----- 7. Footer ----- */
.av-theme footer.site-footer,
.av-theme #colophon {
	background: var(--av-surface);
	border-top: 1px solid rgba(191, 201, 195, 0.5);
	padding: 80px 0 40px;
	text-align: center;
	color: var(--av-on-surface-mute);
}
.av-footer-logo {
	display: block;
	font-family: var(--av-font-serif);
	font-size: 28px;
	letter-spacing: 0.25em;
	text-transform: uppercase;
	color: var(--av-primary);
	margin-bottom: 32px;
}
.av-footer-nav {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 24px 40px;
	margin-bottom: 32px;
	list-style: none;
	padding: 0;
}
.av-footer-nav a {
	font-family: var(--av-font-sans);
	font-size: var(--av-fs-label-sm);
	font-weight: 500;
	text-transform: uppercase;
	letter-spacing: 0.15em;
	color: var(--av-on-surface-mute);
	opacity: 0.8;
	transition: all var(--av-transition);
}
.av-footer-nav a:hover { opacity: 1; color: var(--av-secondary); }
.av-footer-copy {
	font-size: var(--av-fs-body);
	color: var(--av-outline);
	margin-top: 32px;
}

/* ====================================================================
   WOOCOMMERCE
   ==================================================================== */

/* Breadcrumb */
.av-breadcrumb {
	padding: 24px 0;
	font-family: var(--av-font-sans);
	font-size: var(--av-fs-label-sm);
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color: var(--av-outline);
	border-bottom: 1px solid rgba(191, 201, 195, 0.2);
}
.av-breadcrumb a { color: var(--av-on-surface-mute); }
.av-breadcrumb a:hover { color: var(--av-primary); }

/* Archive header */
.av-archive-hero {
	padding: 80px var(--av-margin-mobile) 64px;
	text-align: center;
	background: var(--av-surface-low);
}
@media (min-width: 768px) {
	.av-archive-hero { padding: 120px var(--av-margin-desktop) 80px; }
}
.av-archive-hero h1 {
	font-size: var(--av-fs-h1);
	margin-bottom: 16px;
}
.av-archive-hero p {
	max-width: 540px;
	margin: 0 auto;
	font-size: var(--av-fs-body-lg);
	color: var(--av-on-surface-mute);
}

/* Shop loop */
.av-theme.woocommerce ul.products,
.av-theme .woocommerce ul.products {
	display: grid;
	grid-template-columns: 1fr;
	gap: 64px var(--av-gutter);
	list-style: none;
	padding: 64px var(--av-margin-mobile);
	margin: 0;
	max-width: var(--av-max-width);
	margin-inline: auto;
}
@media (min-width: 640px) {
	.av-theme.woocommerce ul.products,
	.av-theme .woocommerce ul.products { grid-template-columns: 1fr 1fr; }
}
@media (min-width: 900px) {
	.av-theme.woocommerce ul.products,
	.av-theme .woocommerce ul.products {
		grid-template-columns: repeat(3, 1fr);
		padding: 80px var(--av-margin-desktop);
	}
}

.av-theme.woocommerce ul.products li.product,
.av-theme .woocommerce ul.products li.product {
	width: 100% !important;
	margin: 0 !important;
	padding: 0 !important;
	text-align: left;
	float: none !important;
}

.av-theme.woocommerce ul.products li.product a {
	color: inherit;
	text-decoration: none;
	display: block;
}

.av-theme.woocommerce ul.products li.product img {
	/* Aspect-ratio 2/3 : plus portrait, garantit que la hauteur entière de
	   l'image est visible quel que soit son ratio natif. Les images plus
	   carrées (ex: ratio 4/5) seront légèrement rognées sur les côtés pour
	   harmoniser, mais jamais en hauteur. */
	aspect-ratio: 2 / 3;
	width: 100%;
	height: auto;
	object-fit: cover;
	background: var(--av-surface);
	margin-bottom: 20px;
	transition: transform 500ms;
}
.av-theme.woocommerce ul.products li.product:hover img { transform: scale(1.03); }

.av-theme.woocommerce ul.products li.product .woocommerce-loop-product__title {
	font-family: var(--av-font-sans) !important;
	font-size: var(--av-fs-label) !important;
	font-weight: 600 !important;
	text-transform: uppercase;
	letter-spacing: 0.15em;
	color: var(--av-primary);
	padding: 0 !important;
	margin-bottom: 8px !important;
}

.av-theme.woocommerce ul.products li.product .price {
	font-family: var(--av-font-sans) !important;
	font-size: var(--av-fs-label-sm) !important;
	font-weight: 600;
	color: var(--av-secondary) !important;
	letter-spacing: 0.2em;
	text-transform: uppercase;
	margin: 0 0 12px !important;
}
.av-theme.woocommerce ul.products li.product .price del { color: var(--av-outline) !important; opacity: 0.6; margin-right: 8px; }
.av-theme.woocommerce ul.products li.product .price ins { background: none; font-weight: 600; }

.av-theme.woocommerce ul.products li.product .button {
	background: transparent !important;
	color: var(--av-primary) !important;
	padding: 8px 0 !important;
	border-bottom: 1px solid var(--av-primary) !important;
	font-size: var(--av-fs-label-sm) !important;
	margin-top: 8px !important;
	display: inline-flex !important;
	border-radius: 0 !important;
}
.av-theme.woocommerce ul.products li.product .button:hover {
	color: var(--av-secondary) !important;
	border-bottom-color: var(--av-secondary) !important;
}

.av-theme .onsale,
.av-theme .av-sale {
	position: absolute;
	top: 16px;
	left: 16px;
	background: var(--av-primary) !important;
	color: var(--av-secondary-fixed) !important;
	font-family: var(--av-font-sans) !important;
	font-size: 10px !important;
	font-weight: 600 !important;
	letter-spacing: 0.2em;
	text-transform: uppercase;
	padding: 6px 12px !important;
	border-radius: 0 !important;
	min-height: auto !important;
	min-width: auto !important;
	line-height: 1 !important;
	z-index: 5;
}

/* Result count + ordering */
.av-theme .woocommerce-result-count,
.av-theme .woocommerce-ordering {
	font-family: var(--av-font-sans);
	font-size: var(--av-fs-label-sm);
	color: var(--av-outline);
	letter-spacing: 0.05em;
	max-width: var(--av-max-width);
	margin-inline: auto;
	padding-inline: var(--av-margin-mobile);
}
@media (min-width: 768px) {
	.av-theme .woocommerce-result-count,
	.av-theme .woocommerce-ordering { padding-inline: var(--av-margin-desktop); }
}
.av-theme .woocommerce-ordering select {
	font-family: var(--av-font-sans);
	font-size: var(--av-fs-label-sm);
	border: 1px solid var(--av-outline-variant);
	background: transparent;
	padding: 6px 12px;
	border-radius: 0;
}

/* ----- Single product ----- */
.av-theme.single-product div.product {
	max-width: var(--av-max-width);
	margin: 0 auto;
	padding: 32px var(--av-margin-mobile) 64px;
	display: grid;
	gap: 64px;
	grid-template-columns: 1fr;
}
@media (min-width: 768px) {
	.av-theme.single-product div.product {
		grid-template-columns: 1fr 1fr;
		padding: 32px var(--av-margin-desktop) var(--av-breathe);
		gap: 80px;
	}
}

.av-theme.single-product .product .images,
.av-theme.single-product div.product .woocommerce-product-gallery {
	width: 100% !important;
	float: none !important;
	margin: 0 !important;
}

.av-theme.single-product .product .summary,
.av-theme.single-product div.product .summary {
	width: 100% !important;
	float: none !important;
	margin: 0 !important;
	padding-top: 24px;
}

.av-theme.single-product .product_title {
	font-size: var(--av-fs-h1);
	margin-bottom: 16px;
}

.av-theme.single-product .av-product-subtitle {
	font-family: var(--av-font-sans);
	font-size: var(--av-fs-body-lg);
	color: var(--av-on-surface-mute);
	margin-bottom: 24px;
	letter-spacing: 0.02em;
}

.av-theme.single-product .price {
	font-family: var(--av-font-sans);
	font-size: 22px !important;
	color: var(--av-primary) !important;
	font-weight: 500;
	letter-spacing: 0.05em;
	margin: 24px 0 32px !important;
	padding-bottom: 24px;
	border-bottom: 1px solid var(--av-outline-variant);
}
.av-theme.single-product .price del { color: var(--av-outline) !important; margin-right: 12px; opacity: 0.5; }
.av-theme.single-product .price ins { background: none; font-weight: 600; }

.av-theme.single-product .woocommerce-product-details__short-description {
	font-size: var(--av-fs-body-lg);
	color: var(--av-on-surface-mute);
	margin-bottom: 32px;
	line-height: 1.7;
}

.av-theme.single-product .quantity {
	margin-right: 16px;
}
.av-theme.single-product .quantity .qty {
	width: 80px;
	height: 52px;
	border: 1px solid var(--av-outline-variant);
	background: transparent;
	font-family: var(--av-font-sans);
	font-size: var(--av-fs-body);
	color: var(--av-primary);
	text-align: center;
	border-radius: 0;
	padding: 0;
}

.av-theme.single-product .single_add_to_cart_button {
	min-width: 240px;
	padding: 16px 32px;
}

.av-theme.single-product form.cart {
	margin-bottom: 24px !important;
	display: flex;
	align-items: stretch;
	flex-wrap: wrap;
	gap: 12px;
}

/* Variations */
.av-theme.single-product .variations_form .variations {
	margin-bottom: 24px;
	border: none;
}
.av-theme.single-product .variations_form .variations th,
.av-theme.single-product .variations_form .variations td {
	background: none;
	padding: 12px 0;
	border: none;
}
.av-theme.single-product .variations_form .variations th {
	font-family: var(--av-font-sans);
	font-size: var(--av-fs-label-sm);
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.15em;
	color: var(--av-primary);
	width: 100px;
	vertical-align: middle;
}
.av-theme.single-product .variations_form .variations select {
	border: 1px solid var(--av-outline-variant);
	border-radius: 0;
	padding: 12px 16px;
	font-family: var(--av-font-sans);
	background: transparent;
	min-width: 200px;
}
.av-theme.single-product .reset_variations {
	font-size: var(--av-fs-label-sm);
	letter-spacing: 0.1em;
	text-transform: uppercase;
	margin-left: 12px;
	color: var(--av-outline);
}

.av-theme.single-product .product_meta {
	margin-top: 32px;
	padding-top: 24px;
	border-top: 1px solid var(--av-outline-variant);
	font-family: var(--av-font-sans);
	font-size: var(--av-fs-label-sm);
	color: var(--av-outline);
	letter-spacing: 0.05em;
}
.av-theme.single-product .product_meta a { color: var(--av-on-surface-mute); }

/* Galerie produit — image principale au même ratio 2/3 que les vignettes pour
   garantir une harmonie visuelle entre fiche produit et catégorie/accueil. */
.av-theme.single-product .woocommerce-product-gallery__image,
.av-theme.single-product .woocommerce-product-gallery__image--placeholder {
	aspect-ratio: 2 / 3;
	overflow: hidden;
	background: var(--av-surface);
}
.av-theme.single-product .woocommerce-product-gallery__image img,
.av-theme.single-product .woocommerce-product-gallery__image--placeholder img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center;
}
.av-theme.single-product .woocommerce-product-gallery__wrapper { margin: 0; }
.av-theme.single-product .flex-control-thumbs {
	margin-top: 12px;
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 8px;
}
.av-theme.single-product .flex-control-thumbs li { width: 100%; margin: 0; }
.av-theme.single-product .flex-control-thumbs img {
	width: 100%;
	height: auto;
	aspect-ratio: 1;
	object-fit: cover;
	opacity: 0.6;
	transition: opacity var(--av-transition);
}
.av-theme.single-product .flex-control-thumbs img:hover,
.av-theme.single-product .flex-control-thumbs .flex-active { opacity: 1; }

/* Réassurance fiche produit */
.av-single-reassurance {
	list-style: none;
	padding: 24px;
	margin: 24px 0 0;
	background: var(--av-surface-low);
	display: flex;
	flex-direction: column;
	gap: 10px;
}
.av-single-reassurance li {
	font-family: var(--av-font-sans);
	font-size: var(--av-fs-label);
	color: var(--av-on-surface-mute);
	display: flex;
	align-items: center;
	gap: 12px;
}
.av-single-reassurance span {
	color: var(--av-secondary-soft);
	font-size: 10px;
}

/* Accordéons */
.av-accordions {
	grid-column: 1 / -1;
	max-width: 800px;
	margin: 64px auto 0;
	width: 100%;
}
.av-accordion {
	border-bottom: 1px solid var(--av-outline-variant);
}
.av-accordion summary {
	list-style: none;
	cursor: pointer;
	padding: 24px 0;
	display: flex;
	align-items: center;
	justify-content: space-between;
	font-family: var(--av-font-sans);
	font-size: var(--av-fs-label);
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.15em;
	color: var(--av-primary);
}
.av-accordion summary::-webkit-details-marker { display: none; }
.av-accordion summary i {
	display: inline-block;
	width: 16px;
	height: 16px;
	position: relative;
}
.av-accordion summary i::before,
.av-accordion summary i::after {
	content: "";
	position: absolute;
	background: var(--av-primary);
	transition: transform var(--av-transition);
}
.av-accordion summary i::before { top: 50%; left: 0; right: 0; height: 1px; }
.av-accordion summary i::after { left: 50%; top: 0; bottom: 0; width: 1px; }
.av-accordion[open] summary i::after { transform: scaleY(0); }
.av-accordion-body {
	padding: 0 0 32px;
	font-family: var(--av-font-sans);
	color: var(--av-on-surface-mute);
	line-height: 1.7;
}

.av-notes {
	list-style: none;
	padding: 0;
	margin: 0;
	display: flex;
	flex-direction: column;
	gap: 16px;
}
.av-notes li {
	display: grid;
	grid-template-columns: 160px 1fr;
	gap: 24px;
	padding-bottom: 12px;
	border-bottom: 1px solid rgba(191, 201, 195, 0.4);
}
.av-notes li:last-child { border-bottom: none; }
.av-notes li span {
	font-family: var(--av-font-sans);
	font-size: var(--av-fs-label-sm);
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.15em;
	color: var(--av-secondary);
}
.av-notes li strong {
	font-family: var(--av-font-serif);
	font-size: 18px;
	color: var(--av-primary);
	font-weight: 400;
}

/* Related products */
.av-theme .related.products,
.av-theme .up-sells {
	grid-column: 1 / -1;
	max-width: var(--av-max-width);
	margin: 64px auto 0;
	padding: 64px 0 0;
	border-top: 1px solid var(--av-outline-variant);
}
.av-theme .related.products > h2,
.av-theme .up-sells > h2 {
	text-align: center;
	font-size: var(--av-fs-h2);
	margin-bottom: 48px;
}
.av-theme .related.products ul.products,
.av-theme .up-sells ul.products { padding: 0; }

/* ====================================================================
   PANIER & CHECKOUT — Approche HYBRIDE
   On laisse Astra/WC gérer la structure interne (forms, select2, payment
   boxes, tables). On ne touche que :
   - Wrapper + max-width + padding
   - Titre custom remplaçant le H1 natif
   - Typo des H2/H3 (serif Bodoni Moda)
   - Bouton "place_order" et "checkout-button" en couleurs Atelier Varen
   - Bloc réassurance custom (av-cart-reassurance)
   - Notices WooCommerce — couleurs marque
   ==================================================================== */

/* ----- Wrapper commun panier + checkout ----- */
.av-theme.woocommerce-cart .site-content,
.av-theme.woocommerce-checkout .site-content {
	background: var(--av-surface);
}

.av-theme.woocommerce-cart .woocommerce,
.av-theme.woocommerce-checkout .woocommerce {
	max-width: 1200px;
	margin: 0 auto;
	padding: 32px var(--av-margin-mobile) 64px;
}
@media (min-width: 768px) {
	.av-theme.woocommerce-cart .woocommerce,
	.av-theme.woocommerce-checkout .woocommerce {
		padding: 48px 40px 96px;
	}
}

/* Titres personnalisés via ::before sur le wrapper */
.av-theme.woocommerce-cart .woocommerce::before {
	content: "Votre panier";
	display: block;
	font-family: var(--av-font-serif);
	font-size: var(--av-fs-h1);
	font-weight: 400;
	color: var(--av-primary);
	margin-bottom: 40px;
	text-align: center;
	letter-spacing: -0.01em;
}
.av-theme.woocommerce-checkout .woocommerce::before {
	content: "Commande";
	display: block;
	font-family: var(--av-font-serif);
	font-size: var(--av-fs-h1);
	font-weight: 400;
	color: var(--av-primary);
	margin-bottom: 40px;
	text-align: center;
	letter-spacing: -0.01em;
}
.av-theme.woocommerce-cart h1.entry-title,
.av-theme.woocommerce-checkout h1.entry-title { display: none; }

/* ----- Titres H2/H3 panier/checkout en serif ----- */
.av-theme.woocommerce-cart .cart_totals h2,
.av-theme.woocommerce-cart .cross-sells h2,
.av-theme.woocommerce-checkout #order_review_heading,
.av-theme.woocommerce-checkout #customer_details h3,
.av-theme.woocommerce-checkout .woocommerce-billing-fields h3,
.av-theme.woocommerce-checkout .woocommerce-shipping-fields h3,
.av-theme.woocommerce-checkout .woocommerce-additional-fields h3 {
	font-family: var(--av-font-serif);
	color: var(--av-primary);
	font-weight: 400;
	letter-spacing: -0.005em;
}

/* ----- Boutons principaux : Atelier Varen ----- */
.av-theme .checkout-button.button,
.av-theme .wc-proceed-to-checkout .checkout-button,
.av-theme #place_order,
.av-theme .av-cart-form button[name="update_cart"]:not([disabled]) {
	background: var(--av-primary-container) !important;
	color: var(--av-secondary-fixed) !important;
	font-family: var(--av-font-sans) !important;
	font-weight: 600 !important;
	letter-spacing: 0.15em !important;
	text-transform: uppercase !important;
	border: none !important;
	border-radius: 0 !important;
	padding: 16px 32px !important;
	transition: background 200ms ease !important;
}
.av-theme .checkout-button.button:hover,
.av-theme #place_order:hover {
	background: #053d2e !important;
	color: var(--av-secondary-fixed) !important;
}

/* ----- Bloc réassurance custom ----- */
.av-cart-reassurance {
	max-width: 1200px;
	margin: 48px auto 0;
	padding: 0 var(--av-margin-mobile);
	clear: both;
}
@media (min-width: 768px) { .av-cart-reassurance { padding: 0 40px; margin-top: 64px; } }

.av-cart-reassurance ul {
	display: grid;
	/* Auto-fit : la grille s'adapte naturellement à la largeur disponible.
	   Si le bloc se retrouve dans une zone étroite (ex: colonne checkout étroite),
	   il s'affichera en 1 ou 2 colonnes sans déborder. */
	grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
	gap: 16px;
	background: var(--av-surface-white);
	padding: 28px 32px;
	border: 1px solid var(--av-outline-variant);
	list-style: none;
	margin: 0;
}
.av-cart-reassurance li {
	font-family: var(--av-font-sans);
	font-size: var(--av-fs-label-sm);
	text-transform: uppercase;
	letter-spacing: 0.08em;
	color: var(--av-on-surface-mute);
	display: flex;
	align-items: center;
	gap: 10px;
	min-width: 0;
}
.av-cart-reassurance span { color: var(--av-secondary-soft); font-size: 10px; flex-shrink: 0; }

/* ----- Notices WooCommerce (success/info/error) ----- */
.av-theme .woocommerce-message,
.av-theme .woocommerce-info,
.av-theme .woocommerce-error,
.av-theme .woocommerce-notice {
	border-radius: 0 !important;
	border-top: 2px solid var(--av-primary) !important;
	background: var(--av-surface-low) !important;
	color: var(--av-on-surface) !important;
	font-family: var(--av-font-sans);
}
.av-theme .woocommerce-error { border-top-color: var(--av-error) !important; }
.av-theme .woocommerce-message::before,
.av-theme .woocommerce-info::before { color: var(--av-primary) !important; }
.av-theme .woocommerce-error::before { color: var(--av-error) !important; }

/* Tabs (au cas où on n'a pas dégagé) */
.av-theme .woocommerce-tabs { display: none; }

/* Page Maison & Contact */
.av-page-hero {
	background: var(--av-surface-low);
	padding: 96px var(--av-margin-mobile);
	text-align: center;
}
@media (min-width: 768px) { .av-page-hero { padding: 120px var(--av-margin-desktop); } }
.av-page-hero h1 {
	font-size: var(--av-fs-display);
	margin-bottom: 16px;
}
.av-page-content {
	max-width: 720px;
	margin: 0 auto;
	padding: 80px var(--av-margin-mobile);
	font-size: var(--av-fs-body-lg);
	color: var(--av-on-surface-mute);
	line-height: 1.8;
}

/* ----- Page Vêtements — bientôt disponible (coming soon) ----- */
.av-coming-soon {
	padding: 0 var(--av-margin-mobile) 80px;
}
@media (min-width: 768px) {
	.av-coming-soon { padding: 0 var(--av-margin-desktop) 120px; }
}
.av-coming-soon-inner {
	max-width: var(--av-max-width);
	margin: 0 auto;
	display: grid;
	grid-template-columns: 1fr;
	gap: 0;
	align-items: stretch;
	background: var(--av-surface-white);
	border: 1px solid var(--av-outline-variant);
}
@media (min-width: 900px) {
	.av-coming-soon-inner {
		grid-template-columns: 1fr 1fr;
		min-height: 560px;
	}
}
.av-coming-soon-img {
	position: relative;
	min-height: 320px;
	overflow: hidden;
	background: var(--av-surface-stone);
}
@media (min-width: 900px) { .av-coming-soon-img { min-height: 100%; } }
.av-coming-soon-img img {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	filter: grayscale(0.15) brightness(0.95);
}
.av-coming-soon-img-veil {
	position: absolute;
	inset: 0;
	background: linear-gradient(to right, rgba(0, 53, 39, 0.35), rgba(0, 53, 39, 0.05));
	z-index: 1;
}
.av-coming-soon-message {
	display: flex;
	flex-direction: column;
	justify-content: center;
	padding: 64px 32px;
	text-align: center;
}
@media (min-width: 900px) { .av-coming-soon-message { padding: 80px 64px; } }
.av-coming-soon-message .av-label { margin-bottom: 24px; }
.av-coming-soon-message h2 {
	font-family: var(--av-font-serif);
	font-size: clamp(26px, 3vw, 36px);
	font-weight: 400;
	color: var(--av-primary);
	letter-spacing: -0.01em;
	line-height: 1.25;
	margin: 0 0 20px;
}
.av-coming-soon-tagline {
	font-family: var(--av-font-serif);
	font-style: italic;
	font-size: clamp(18px, 2vw, 22px);
	color: var(--av-secondary);
	margin: 0;
	letter-spacing: 0.02em;
}
.av-coming-soon-message .av-divider {
	margin: 32px auto;
	width: 64px;
	background: var(--av-secondary-soft);
}
.av-coming-soon-sub {
	font-family: var(--av-font-sans);
	font-size: var(--av-fs-body);
	color: var(--av-on-surface-mute);
	max-width: 360px;
	margin: 0 auto 32px;
	line-height: 1.6;
}
.av-coming-soon-message .av-btn { align-self: center; }

/* ----- Page Maison : logo séparateur + 4 piliers ----- */
.av-maison-logo {
	text-align: center;
	margin: 80px auto 64px;
	padding-top: 64px;
	border-top: 1px solid rgba(191, 201, 195, 0.4);
}
.av-maison-logo img {
	display: inline-block;
	max-height: 120px;
	width: auto;
	height: auto;
	opacity: 0.85;
}
@media (min-width: 768px) {
	.av-maison-logo { margin: 96px auto 72px; padding-top: 72px; }
	.av-maison-logo img { max-height: 140px; }
}
.av-maison-logo-text span {
	font-family: var(--av-font-serif);
	font-size: clamp(28px, 4vw, 40px);
	letter-spacing: 0.25em;
	text-transform: uppercase;
	color: var(--av-primary);
}

.av-maison-pillars {
	display: grid;
	grid-template-columns: 1fr;
	gap: 40px 32px;
	text-align: center;
	margin-top: 16px;
}
@media (min-width: 600px) {
	.av-maison-pillars { grid-template-columns: 1fr 1fr; }
}
@media (min-width: 900px) {
	.av-maison-pillars { grid-template-columns: repeat(4, 1fr); gap: 48px 24px; }
}
.av-maison-pillars > div {
	position: relative;
}
.av-maison-pillars .av-label {
	margin-bottom: 12px;
}
.av-maison-pillars h3 {
	font-family: var(--av-font-serif);
	font-size: 20px;
	font-weight: 400;
	color: var(--av-primary);
	letter-spacing: 0.01em;
	line-height: 1.3;
	margin: 0;
}

/* Wrappers Astra : on neutralise UNIQUEMENT sur la home, archive et single product
   où on a notre propre layout full-width. On laisse Astra gérer les autres pages
   (panier, checkout, mon compte, pages éditoriales) pour bénéficier de son intégration. */
.home.av-theme .ast-container,
.av-theme.archive.tax-product_cat .ast-container,
.av-theme.post-type-archive-product .ast-container,
.av-theme.single-product .ast-container { max-width: 100%; padding: 0; }

.home.av-theme .site-main,
.av-theme.archive.tax-product_cat .site-main,
.av-theme.post-type-archive-product .site-main,
.av-theme.single-product .site-main { padding-top: 0 !important; padding-bottom: 0 !important; }

/* Hide Astra default page heading on shop/single product */
.av-theme.woocommerce-page .entry-header,
.av-theme.single-product .entry-header { display: none; }

/* Accessibility */
.av-theme *:focus-visible {
	outline: 2px solid var(--av-secondary-soft);
	outline-offset: 2px;
}
.av-skip-link {
	position: absolute;
	top: -40px;
	left: 0;
	background: var(--av-primary);
	color: var(--av-on-primary);
	padding: 8px 16px;
	z-index: 1000;
}
.av-skip-link:focus { top: 0; }
