/* =========================================================================
   Relais — main stylesheet
   Estetica mediterranea calda · minimal editoriale · responsive
   ========================================================================= */

/* -------------------------------------------------------------------------
   1. Design tokens
   ---------------------------------------------------------------------- */
:root {
	/* Palette minimal: carta bianca, inchiostro quasi nero, accento blu elettrico.
	   I nomi storici sono mantenuti per non rompere i riferimenti esistenti. */
	--sand:          #f4f4f2;  /* superficie chiara / sezioni alternate */
	--sand-deep:     #e8e8e4;  /* superficie un filo più scura */
	--cream:         #ffffff;  /* carta / testo su fondo scuro */
	--white:         #ffffff;
	--ink:           #0e0f11;  /* near-black */
	--ink-soft:      #6c6f76;  /* grigio testo secondario */
	--terracotta:    #1b45e0;  /* ACCENTO blu elettrico (sovrascritto dal pannello) */
	--terracotta-dk: #1235b8;  /* accento hover */
	--accent-rgb:    27, 69, 224; /* accento in formato rgb per le trasparenze */
	--sale:          #d8362a;  /* rosso saldo, indipendente dall'accento */
	--sea:           #16181c;  /* charcoal per placeholder eleganti */
	--sea-dk:        #0e0f11;
	--line:          rgba(14, 15, 17, 0.10);
	--line-strong:   rgba(14, 15, 17, 0.22);

	--font-display: "Trirong", Georgia, "Times New Roman", serif;
	--font-body:    "Trirong", Georgia, "Times New Roman", serif;

	--container:     1280px;
	--container-narrow: 780px;
	--gutter:        clamp(18px, 4vw, 48px);

	--radius:        2px;
	--radius-lg:     6px;

	--header-h:      78px;

	--ease:          cubic-bezier(0.22, 0.61, 0.36, 1);
	--transition:    0.4s var(--ease);

	--shadow:        0 18px 50px -28px rgba(42, 36, 31, 0.55);
}

/* -------------------------------------------------------------------------
   2. Reset & base
   ---------------------------------------------------------------------- */
*,
*::before,
*::after { box-sizing: border-box; }

html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }

body {
	margin: 0;
	background: var(--white);
	color: var(--ink);
	font-family: var(--font-body);
	font-size: 16px;
	line-height: 1.65;
	font-weight: 400;
	-webkit-font-smoothing: antialiased;
	text-rendering: optimizeLegibility;
	overflow-x: hidden;
}

img,
video,
svg { max-width: 100%; height: auto; display: block; }

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

h1, h2, h3, h4, h5 {
	font-family: var(--font-display);
	font-weight: 400;
	line-height: 1.05;
	letter-spacing: -0.01em;
	margin: 0 0 0.4em;
	color: var(--ink);
}

p { margin: 0 0 1em; }

ul, ol { margin: 0; padding: 0; }

button { font-family: inherit; cursor: pointer; }

::selection { background: var(--terracotta); color: var(--cream); }

:focus-visible {
	outline: 2px solid var(--terracotta);
	outline-offset: 3px;
}

/* -------------------------------------------------------------------------
   3. Layout helpers
   ---------------------------------------------------------------------- */
.container {
	width: 100%;
	max-width: var(--container);
	margin-inline: auto;
	padding-inline: var(--gutter);
}

.container--narrow { max-width: var(--container-narrow); }

.section { padding-block: clamp(56px, 9vw, 120px); }

.section__head {
	display: flex;
	align-items: flex-end;
	justify-content: space-between;
	gap: 24px;
	margin-bottom: clamp(28px, 4vw, 52px);
	flex-wrap: wrap;
}

.section__title {
	font-size: clamp(1.9rem, 4vw, 3rem);
	margin: 0;
}

.section__link {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	font-size: 0.85rem;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	font-weight: 500;
	color: var(--ink);
	white-space: nowrap;
}
.section__link svg { transition: transform var(--transition); }
.section__link:hover { color: var(--terracotta); }
.section__link:hover svg { transform: translateX(5px); }

.screen-reader-text {
	border: 0;
	clip: rect(1px, 1px, 1px, 1px);
	clip-path: inset(50%);
	height: 1px;
	width: 1px;
	margin: -1px;
	overflow: hidden;
	padding: 0;
	position: absolute;
}

.skip-link {
	position: fixed;
	top: -120px;
	left: 16px;
	z-index: 1000;
	background: var(--ink);
	color: var(--cream);
	padding: 12px 18px;
	border-radius: var(--radius);
	transition: top 0.3s var(--ease);
}
.skip-link:focus { top: 16px; }

/* -------------------------------------------------------------------------
   4. Buttons
   ---------------------------------------------------------------------- */
.btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 10px;
	padding: 15px 30px;
	font-family: var(--font-body);
	font-size: 0.82rem;
	font-weight: 600;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	border: 1px solid transparent;
	border-radius: 100px;
	cursor: pointer;
	transition: background var(--transition), color var(--transition), border-color var(--transition), transform 0.25s var(--ease);
	line-height: 1;
}
.btn:hover { transform: translateY(-2px); }
.btn:active { transform: translateY(0); }

.btn--dark { background: var(--ink); color: var(--cream); }
.btn--dark:hover { background: var(--terracotta); color: var(--cream); }

.btn--light { background: var(--cream); color: var(--ink); }
.btn--light:hover { background: var(--terracotta); color: var(--cream); }

.btn--outline { background: transparent; color: var(--ink); border-color: var(--line-strong); }
.btn--outline:hover { background: var(--ink); color: var(--cream); border-color: var(--ink); }

/* -------------------------------------------------------------------------
   5. Header
   ---------------------------------------------------------------------- */
.site-header {
	position: sticky;
	top: 0;
	z-index: 100;
	background: var(--cream);
	border-bottom: 1px solid var(--line);
	transition: background var(--transition), border-color var(--transition), transform 0.4s var(--ease);
}

.site-header__inner {
	display: grid;
	grid-template-columns: auto 1fr auto;
	align-items: center;
	gap: 24px;
	min-height: var(--header-h);
}

.site-branding { justify-self: start; }
.site-header__inner .main-navigation { justify-self: center; }
.site-header__actions { justify-self: end; }

.site-title {
	font-family: var(--font-display);
	font-size: 1.6rem;
	font-weight: 500;
	letter-spacing: 0.02em;
}
.custom-logo { max-height: 48px; width: auto; }

/* Doppio logo: chiaro sul video, scuro altrove/allo scroll */
.site-branding__link { display: inline-flex; align-items: center; }
.site-logo { max-height: 48px; width: auto; display: block; }
span.site-logo { line-height: 1; }
.site-logo--light { display: none; }   /* di default (header solido / pagine interne) si vede lo scuro */
.site-logo--dark  { display: block; }

/* Header trasparente sopra il video (non ancora scrollato): mostra il chiaro */
.has-transparent-header .site-header:not(.is-scrolled) .site-logo--light { display: block; }
.has-transparent-header .site-header:not(.is-scrolled) .site-logo--dark  { display: none; }

/* Primary nav */
.main-navigation .nav-menu {
	display: flex;
	align-items: center;
	gap: clamp(18px, 2.4vw, 40px);
	list-style: none;
}
.main-navigation .nav-menu a {
	position: relative;
	font-size: 0.9rem;
	font-weight: 500;
	letter-spacing: 0.02em;
	padding: 6px 0;
}
.main-navigation .nav-menu > li > a::after {
	content: "";
	position: absolute;
	left: 0;
	bottom: 0;
	width: 0;
	height: 1.5px;
	background: var(--terracotta);
	transition: width var(--transition);
}
.main-navigation .nav-menu > li > a:hover::after,
.main-navigation .nav-menu > li.current-menu-item > a::after { width: 100%; }

/* Sub menu */
.main-navigation .sub-menu {
	position: absolute;
	top: 100%;
	left: 0;
	min-width: 200px;
	background: var(--cream);
	border: 1px solid var(--line);
	box-shadow: var(--shadow);
	list-style: none;
	padding: 10px 0;
	opacity: 0;
	visibility: hidden;
	transform: translateY(8px);
	transition: all var(--transition);
	z-index: 50;
}
.main-navigation .menu-item-has-children { position: relative; }
.main-navigation .menu-item-has-children:hover > .sub-menu {
	opacity: 1;
	visibility: visible;
	transform: translateY(0);
}
.main-navigation .sub-menu a { display: block; padding: 8px 22px; font-size: 0.88rem; }
.main-navigation .sub-menu a:hover { color: var(--terracotta); }

/* Header actions */
.site-header__actions {
	display: flex;
	align-items: center;
	gap: clamp(12px, 1.6vw, 22px);
}
.header-action {
	position: relative;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	color: var(--ink);
	transition: color var(--transition), transform 0.25s var(--ease);
}
.header-action:hover { color: var(--terracotta); transform: translateY(-1px); }

.header-action--cart .cart-count {
	position: absolute;
	top: -8px;
	right: -10px;
	min-width: 18px;
	height: 18px;
	padding: 0 5px;
	border-radius: 100px;
	background: var(--terracotta);
	color: var(--cream);
	font-size: 0.65rem;
	font-weight: 600;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	line-height: 1;
}
.header-action--cart .cart-count.is-empty { display: none; }

/* Pulsante di ricerca disattivato (desktop e mobile) */
.header-action--search { display: none; }

/* Transparent header over hero (homepage) */
.has-transparent-header .site-header {
	position: fixed;
	left: 0;
	right: 0;
	background: transparent;
	border-bottom-color: transparent;
	color: var(--cream);
}
.has-transparent-header .site-header .site-title,
.has-transparent-header .site-header .main-navigation a,
.has-transparent-header .site-header .header-action,
.has-transparent-header .site-header .nav-toggle__bar { color: var(--cream); }
.has-transparent-header .site-header .nav-toggle__bar { background: var(--cream); }
.has-transparent-header .site-header .main-navigation .nav-menu > li > a::after { background: var(--cream); }

/* Header turns solid on scroll */
.has-transparent-header .site-header.is-scrolled {
	position: fixed;
	background: var(--cream);
	border-bottom-color: var(--line);
	color: var(--ink);
}
.has-transparent-header .site-header.is-scrolled .site-title,
.has-transparent-header .site-header.is-scrolled .main-navigation a,
.has-transparent-header .site-header.is-scrolled .header-action,
.has-transparent-header .site-header.is-scrolled .nav-toggle__bar { color: var(--ink); }
.has-transparent-header .site-header.is-scrolled .nav-toggle__bar { background: var(--ink); }

/* Hide-on-scroll-down behaviour */
.site-header.is-hidden { transform: translateY(-100%); }

/* Hamburger */
.nav-toggle {
	display: none;
	flex-direction: column;
	justify-content: center;
	gap: 5px;
	width: 40px;
	height: 40px;
	background: none;
	border: 0;
	padding: 8px;
	margin-left: -8px;
}
.nav-toggle__bar {
	display: block;
	width: 22px;
	height: 1.8px;
	background: var(--ink);
	transition: transform 0.35s var(--ease), opacity 0.2s var(--ease);
}
.nav-open .nav-toggle__bar:nth-child(1) { transform: translateY(6.8px) rotate(45deg); }
.nav-open .nav-toggle__bar:nth-child(2) { opacity: 0; }
.nav-open .nav-toggle__bar:nth-child(3) { transform: translateY(-6.8px) rotate(-45deg); }

.nav-backdrop {
	position: fixed;
	inset: 0;
	background: rgba(14, 15, 17, 0.4);
	-webkit-backdrop-filter: blur(4px);
	backdrop-filter: blur(4px);
	z-index: 90;
	opacity: 0;
	transition: opacity var(--transition);
}
.nav-open .nav-backdrop { opacity: 1; }

/* -------------------------------------------------------------------------
   6. Hero (video)
   ---------------------------------------------------------------------- */
.hero {
	position: relative;
	min-height: 100svh;
	display: flex;
	align-items: flex-end;
	color: var(--cream);
	overflow: hidden;
}
.hero__media { position: absolute; inset: 0; z-index: 0; }
.hero__video,
.hero__poster {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

/* Animated CSS placeholder — minimal: charcoal scuro con un'onda blu elettrico */
.hero__placeholder {
	position: absolute;
	inset: 0;
	overflow: hidden;
	background: linear-gradient(180deg, #16181c 0%, #101216 55%, #0a0c10 100%);
}
.hero__sun {
	position: absolute;
	top: 18%;
	left: 50%;
	width: 320px;
	height: 320px;
	margin-left: -160px;
	border-radius: 50%;
	background: radial-gradient(circle, rgba(var(--accent-rgb), 0.45) 0%, rgba(var(--accent-rgb), 0.12) 45%, rgba(var(--accent-rgb), 0) 70%);
	animation: heroSun 8s var(--ease) infinite alternate;
}
.hero__wave {
	position: absolute;
	left: -10%;
	right: -10%;
	bottom: 0;
	height: 46%;
	border-radius: 44% 56% 0 0 / 100% 100% 0 0;
	transform-origin: center bottom;
}
.hero__wave--1 { background: rgba(var(--accent-rgb), 0.22); height: 40%; animation: heroWave 9s ease-in-out infinite; }
.hero__wave--2 { background: rgba(20, 24, 32, 0.7); height: 32%; animation: heroWave 7s ease-in-out infinite reverse; }
.hero__wave--3 { background: rgba(10, 12, 16, 0.95); height: 22%; animation: heroWave 11s ease-in-out infinite; }
@keyframes heroWave {
	0%, 100% { transform: translateX(-3%) scaleY(1); }
	50%      { transform: translateX(3%) scaleY(1.08); }
}
@keyframes heroSun {
	0%   { transform: translateY(0) scale(1); opacity: 0.9; }
	100% { transform: translateY(-14px) scale(1.05); opacity: 1; }
}
.hero__overlay {
	position: absolute;
	inset: 0;
	background:
		linear-gradient(180deg, rgba(8, 9, 11, 0.45) 0%, rgba(8, 9, 11, 0) 28%),
		linear-gradient(0deg, rgba(8, 9, 11, 0.72) 0%, rgba(8, 9, 11, 0.05) 55%);
}

.hero__content {
	position: relative;
	z-index: 2;
	padding-bottom: clamp(60px, 9vh, 120px);
	max-width: 920px;
}
.hero__overline {
	font-size: 0.8rem;
	letter-spacing: 0.28em;
	text-transform: uppercase;
	margin-bottom: 18px;
	opacity: 0.92;
	font-weight: 500;
}
.hero__title {
	color: var(--cream);
	font-size: clamp(2.8rem, 8vw, 6.5rem);
	line-height: 0.98;
	margin: 0 0 22px;
	font-weight: 300;
}
.hero__subtitle {
	font-size: clamp(1rem, 1.6vw, 1.25rem);
	max-width: 540px;
	margin-bottom: 34px;
	opacity: 0.95;
	line-height: 1.55;
}

.hero__scroll {
	position: absolute;
	bottom: 28px;
	left: 50%;
	transform: translateX(-50%);
	z-index: 2;
}
.hero__scroll-line {
	display: block;
	width: 1px;
	height: 54px;
	background: linear-gradient(var(--cream), transparent);
	position: relative;
	overflow: hidden;
}
.hero__scroll-line::after {
	content: "";
	position: absolute;
	top: -100%;
	left: 0;
	width: 100%;
	height: 100%;
	background: var(--cream);
	animation: scrollLine 2s var(--ease) infinite;
}
@keyframes scrollLine {
	0%   { top: -100%; }
	60%  { top: 100%; }
	100% { top: 100%; }
}

/* -------------------------------------------------------------------------
   7. Values band (marquee)
   ---------------------------------------------------------------------- */
.values-band {
	background: var(--ink);
	color: var(--cream);
	overflow: hidden;
	padding-block: 16px;
}
.values-band__track {
	display: flex;
	width: max-content;
	animation: marquee 28s linear infinite;
}
.values-band__list {
	display: flex;
	align-items: center;
	gap: 56px;
	list-style: none;
	padding-right: 56px;
}
.values-band__list li {
	font-size: 0.78rem;
	letter-spacing: 0.16em;
	text-transform: uppercase;
	white-space: nowrap;
	position: relative;
}
.values-band__list li::after {
	content: "·";
	position: absolute;
	right: -32px;
	opacity: 0.5;
}
@keyframes marquee {
	from { transform: translateX(0); }
	to   { transform: translateX(-50%); }
}
.values-band:hover .values-band__track { animation-play-state: paused; }

/* -------------------------------------------------------------------------
   8. Product grid + cards (placeholder + WooCommerce)
   ---------------------------------------------------------------------- */
.section--products { background: var(--cream); }

.product-grid,
ul.products {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: clamp(20px, 2.4vw, 40px);
	list-style: none;
	margin: 0;
	padding: 0;
}
/* WooCommerce aggiunge ::before/::after (clearfix) che in un grid diventano
   celle vuote: la prima cella vuota era il ::before. Li disattivo. */
.woocommerce ul.products::before,
.woocommerce ul.products::after,
ul.products::before,
ul.products::after { content: none !important; display: none !important; }

/* Placeholder card */
.product-card { display: flex; flex-direction: column; }
.product-card__media {
	position: relative;
	aspect-ratio: 4 / 5;
	background: linear-gradient(135deg, var(--sand-deep), var(--sand));
	border-radius: var(--radius-lg);
	display: flex;
	align-items: center;
	justify-content: center;
	overflow: hidden;
}
.product-card__ph-label {
	font-size: 0.72rem;
	letter-spacing: 0.2em;
	text-transform: uppercase;
	color: var(--ink-soft);
}
.product-card__body { padding-top: 16px; }
.product-card__title { font-size: 1.05rem; margin: 0 0 4px; }
.product-card__price { color: var(--ink-soft); font-size: 0.95rem; }

/* WooCommerce loop cards */
ul.products li.product {
	text-align: left;
	margin: 0 !important;
	width: auto !important;
	float: none !important;
	position: relative;
}
ul.products li.product a img {
	width: 100%;
	aspect-ratio: 4 / 5;
	object-fit: cover;
	border-radius: var(--radius-lg);
	margin-bottom: 14px;
	transition: transform 0.6s var(--ease);
}
ul.products li.product:hover a img { transform: scale(1.03); }
ul.products li.product .woocommerce-loop-product__title {
	font-family: var(--font-display);
	font-size: 1.1rem !important;
	font-weight: 400;
	padding: 0 !important;
	margin: 0 0 4px !important;
	line-height: 1.2;
}
ul.products li.product .price {
	color: var(--ink) !important;
	font-size: 0.95rem !important;
	font-weight: 500;
}
ul.products li.product .price del { color: var(--ink-soft); opacity: 0.6; margin-right: 6px; }
ul.products li.product .price ins { text-decoration: none; color: var(--terracotta); }

ul.products li.product .button,
ul.products li.product .added_to_cart {
	display: inline-block;
	margin-top: 10px !important;
	background: transparent !important;
	color: var(--ink) !important;
	border: 1px solid var(--line-strong) !important;
	border-radius: 100px !important;
	padding: 9px 20px !important;
	font-size: 0.74rem !important;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	font-weight: 600;
	transition: all var(--transition);
}
ul.products li.product .button:hover,
ul.products li.product .added_to_cart:hover {
	background: var(--ink) !important;
	color: var(--cream) !important;
	border-color: var(--ink) !important;
}

/* Sale / new badges */
.badge,
ul.products li.product .onsale,
.woocommerce span.onsale {
	position: absolute;
	top: 12px;
	left: 12px;
	z-index: 3;
	background: var(--sale) !important;
	color: #fff !important;
	font-size: 0.66rem;
	font-weight: 600;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	padding: 6px 12px !important;
	border-radius: 100px;
	margin: 0 !important;
	min-height: auto !important;
	min-width: auto !important;
	line-height: 1 !important;
}

.notice-soft {
	grid-column: 1 / -1;
	text-align: center;
	color: var(--ink-soft);
	font-size: 0.9rem;
	padding-top: 12px;
}

/* -------------------------------------------------------------------------
   8a. Shop card (loop prodotti — design boutique)
   ---------------------------------------------------------------------- */
ul.products li.product.shop-card {
	display: flex;
	flex-direction: column;
	text-align: left;
}
.shop-card__media {
	position: relative;
	aspect-ratio: 4 / 5;
	border-radius: var(--radius-lg);
	overflow: hidden;
	background: var(--sand);
}
.shop-card__imglink {
	position: absolute;
	inset: 0;
	display: block;
}
.shop-card .shop-card__img {
	position: absolute !important;
	inset: 0;
	width: 100% !important;
	height: 100% !important;
	margin: 0 !important;
	border-radius: 0 !important;
	aspect-ratio: auto !important;
	object-fit: cover;
	transition: opacity 0.6s var(--ease), transform 0.9s var(--ease);
}
.shop-card__img--hover { opacity: 0; }
.shop-card__media:hover .shop-card__img { transform: scale(1.05); }
.shop-card__media:hover .shop-card__img--hover { opacity: 1; }

/* Badge saldo dentro la card */
.shop-card__badge { top: 14px; left: 14px; }

/* CTA "Aggiungi" che appare al passaggio */
.shop-card__cta {
	position: absolute;
	left: 12px;
	right: 12px;
	bottom: 12px;
	z-index: 4;
	opacity: 0;
	transform: translateY(14px);
	transition: opacity 0.35s var(--ease), transform 0.35s var(--ease);
}
.shop-card__media:hover .shop-card__cta { opacity: 1; transform: none; }
ul.products li.product .shop-card__cta .button,
ul.products li.product .shop-card__cta .added_to_cart {
	display: block !important;
	width: 100%;
	margin: 0 !important;
	text-align: center;
	background: var(--ink) !important;
	color: var(--cream) !important;
	border: 0 !important;
	border-radius: 100px !important;
	padding: 14px 18px !important;
	font-size: 0.72rem !important;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	font-weight: 600;
	box-shadow: 0 8px 24px rgba(14, 15, 17, 0.18);
}
ul.products li.product .shop-card__cta .button:hover { background: var(--terracotta) !important; }
ul.products li.product .shop-card__cta .added_to_cart { margin-top: 8px !important; background: var(--terracotta) !important; }

/* Info sotto l'immagine */
.shop-card__info {
	display: block;
	padding-top: 15px;
}
.shop-card__title {
	font-family: var(--font-display);
	font-size: 1.12rem;
	font-weight: 400;
	line-height: 1.25;
	margin: 0 0 4px;
	color: var(--ink);
	transition: color 0.2s var(--ease);
}
.shop-card__info:hover .shop-card__title { color: var(--terracotta); }
.shop-card .shop-card__price,
.shop-card .price {
	color: var(--ink) !important;
	font-size: 0.95rem !important;
	font-weight: 500;
}
.shop-card .price del { color: var(--ink-soft); opacity: 0.6; margin-right: 6px; font-weight: 400; }
.shop-card .price ins { text-decoration: none; color: var(--sale); }

/* Card promozionale "New Collection" (solo desktop) */
.shop-card--promo { display: none; }
@media (min-width: 769px) {
	.shop-card--promo { display: flex; }
	.shop-card--promo .shop-card__promo {
		position: relative;
		display: flex;
		flex-direction: column;
		justify-content: center;
		align-items: flex-start;
		gap: 16px;
		aspect-ratio: 4 / 5;
		width: 100%;
		padding: clamp(24px, 2.4vw, 40px);
		border-radius: var(--radius-lg);
		background: #efe7e2;
		color: var(--ink);
		overflow: hidden;
		transition: background 0.4s var(--ease);
	}
	.shop-card--promo .shop-card__promo:hover { background: var(--ink); color: var(--cream); }
	.shop-card__promo-overline {
		font-size: 0.74rem;
		letter-spacing: 0.24em;
		text-transform: uppercase;
		opacity: 0.7;
	}
	.shop-card__promo-title {
		font-family: var(--font-display);
		font-size: clamp(1.9rem, 2.6vw, 2.7rem);
		line-height: 1.04;
		font-weight: 400;
	}
	.shop-card__promo-cta {
		margin-top: 4px;
		font-size: 0.78rem;
		letter-spacing: 0.14em;
		text-transform: uppercase;
		font-weight: 600;
		padding-bottom: 3px;
		border-bottom: 1px solid currentColor;
	}
}

/* -------------------------------------------------------------------------
   8b. Featured carousel (Pezzi in evidenza)
   ---------------------------------------------------------------------- */
.section__head-actions { display: flex; align-items: center; gap: 18px; }
.section__head--end { justify-content: flex-end; }
.section__foot { display: flex; justify-content: center; margin-top: clamp(20px, 3vw, 36px); }

.carousel-nav { display: flex; gap: 8px; }
.carousel-nav__btn {
	width: 44px;
	height: 44px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	border: 1px solid var(--line-strong);
	background: transparent;
	color: var(--ink);
	border-radius: 50%;
	cursor: pointer;
	transition: background var(--transition), color var(--transition), border-color var(--transition), opacity var(--transition);
}
.carousel-nav__btn:hover { background: var(--ink); color: var(--cream); border-color: var(--ink); }
.carousel-nav__btn[disabled] { opacity: 0.3; cursor: default; pointer-events: none; }

/* Override della griglia: diventa scroller orizzontale con snap */
.products.featured-carousel {
	display: flex;
	flex-wrap: nowrap;
	gap: clamp(16px, 2vw, 28px);
	overflow-x: auto;
	scroll-snap-type: x mandatory;
	scroll-behavior: smooth;
	-webkit-overflow-scrolling: touch;
	scrollbar-width: none;
	padding-bottom: 6px;
	/* sfora leggermente il container per far intravedere il peek a destra */
	margin-right: calc(var(--gutter) * -1);
	padding-right: var(--gutter);
}
.products.featured-carousel::-webkit-scrollbar { display: none; }

/* Card più grandi: ~3 visibili su desktop */
.products.featured-carousel > li.product,
.products.featured-carousel > .product-card {
	flex: 0 0 auto;
	width: clamp(260px, 30%, 380px) !important;
	margin: 0 !important;
	scroll-snap-align: start;
}

/* Immagini più grandi e a tutto riquadro nel carosello */
.products.featured-carousel > li.product a.featured-product__media,
.products.featured-carousel > .product-card .product-card__media {
	aspect-ratio: 3 / 4;
	margin-bottom: 18px;
}
/* L'immagine riempie completamente il riquadro, senza bordi grigi */
.products.featured-carousel > li.product a.featured-product__media img {
	display: block;
	width: 100%;
	height: auto;
	aspect-ratio: 3 / 4;
	margin: 0 !important;
	border-radius: 0 !important;
	object-fit: cover;
}
.products.featured-carousel > li.product .woocommerce-loop-product__title {
	font-size: 1.25rem !important;
}
.products.featured-carousel > li.product .price { font-size: 1.05rem !important; }

/* Card del carosello: nome prodotto sovrapposto all'immagine */
.featured-product { display: flex; flex-direction: column; }
.featured-product__media {
	display: block;
	position: relative;
	border-radius: var(--radius-lg);
	overflow: hidden;
}
.featured-product__grad {
	position: absolute;
	inset: 0;
	z-index: 1;
	pointer-events: none;
	background: linear-gradient(0deg, rgba(8, 9, 11, 0.3) 0%, rgba(8, 9, 11, 0.12) 40%, rgba(8, 9, 11, 0.28) 100%);
}
.featured-product__name {
	position: absolute;
	inset: 0;
	z-index: 2;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 0 20px;
	text-align: center;
	color: var(--cream);
	font-family: var(--font-display);
	font-size: clamp(1.2rem, 1.9vw, 1.7rem);
	line-height: 1.18;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	text-shadow: 0 2px 14px rgba(0, 0, 0, 0.5);
}

/* Trascinamento col mouse su desktop */
.products.featured-carousel { cursor: grab; }
.products.featured-carousel.is-dragging { cursor: grabbing; scroll-behavior: auto; }
.products.featured-carousel.is-dragging a { pointer-events: none; }

/* -------------------------------------------------------------------------
   9. Category showcase
   ---------------------------------------------------------------------- */
.section--cats { background: var(--sand); }
.cat-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: clamp(14px, 1.8vw, 24px);
}
.cat-card {
	position: relative;
	aspect-ratio: 3 / 4;
	border-radius: var(--radius-lg);
	overflow: hidden;
	display: flex;
	align-items: flex-end;
	color: var(--cream);
}
.cat-card__media {
	position: absolute;
	inset: 0;
	background: linear-gradient(135deg, var(--sea), var(--sea-dk));
	background-size: cover;
	background-position: center;
	transition: transform 0.7s var(--ease);
}
.cat-card:hover .cat-card__media { transform: scale(1.05); }
.cat-card__overlay {
	position: absolute;
	inset: 0;
	background: linear-gradient(0deg, rgba(42, 36, 31, 0.72) 0%, rgba(42, 36, 31, 0) 60%);
}
.cat-card__body { position: relative; z-index: 2; padding: 26px; }
.cat-card__count {
	font-size: 0.72rem;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	opacity: 0.85;
}
.cat-card__title { color: var(--cream); font-size: clamp(1.4rem, 2.4vw, 2rem); margin: 6px 0 0; }

/* -------------------------------------------------------------------------
   10. Editorial section
   ---------------------------------------------------------------------- */
.section--editorial { background: #efe7e2; }
.editorial {
	display: grid;
	grid-template-columns: 1fr 1fr;
	align-items: center;
	gap: clamp(32px, 6vw, 80px);
}
.editorial__media {
	aspect-ratio: 4 / 5;
	border-radius: var(--radius-lg);
	background:
		radial-gradient(120% 120% at 20% 10%, rgba(var(--accent-rgb), 0.3), transparent 55%),
		linear-gradient(135deg, var(--sea), var(--sea-dk));
}
.editorial__media--photo {
	background-size: cover;
	background-position: center;
}
.editorial__overline {
	font-size: 0.78rem;
	letter-spacing: 0.2em;
	text-transform: uppercase;
	color: var(--terracotta);
	margin-bottom: 16px;
	font-weight: 600;
}
.editorial__title {
	font-size: clamp(2rem, 4vw, 3.2rem);
	margin-bottom: 20px;
}
.editorial__text p { color: var(--ink-soft); max-width: 46ch; margin-bottom: 28px; }

/* -------------------------------------------------------------------------
   11. CTA band
   ---------------------------------------------------------------------- */
.section--cta { background: var(--sand); padding-block: clamp(64px, 10vw, 140px); }
.cta-band {
	text-align: center;
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 28px;
}
.cta-band h2 { font-size: clamp(2.4rem, 6vw, 5rem); margin: 0; max-width: 14ch; }

/* Banner "Nuova Stagione" (full-width, foto di sfondo) */
.season-banner {
	position: relative;
	display: flex;
	align-items: center;
	justify-content: center;
	min-height: clamp(360px, 50vw, 560px);
	padding: clamp(48px, 8vw, 96px) 0;
	background-color: var(--ink);
	background-size: cover;
	background-position: center;
	overflow: hidden;
	isolation: isolate;
}
.season-banner__overlay {
	position: absolute;
	inset: 0;
	z-index: -1;
	background:
		radial-gradient(ellipse at center, rgba(14, 15, 17, 0.5) 0%, rgba(14, 15, 17, 0.2) 55%, rgba(14, 15, 17, 0) 80%),
		linear-gradient(180deg, rgba(14, 15, 17, 0.35), rgba(14, 15, 17, 0.6));
}
.season-banner:not(.season-banner--photo) .season-banner__overlay { background: none; }
.season-banner__inner {
	text-align: center;
	color: var(--cream);
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 18px;
	max-width: 640px;
}
.season-banner__overline {
	font-size: 0.78rem;
	letter-spacing: 0.24em;
	text-transform: uppercase;
	opacity: 0.85;
	text-shadow: 0 1px 12px rgba(14, 15, 17, 0.45);
}
.season-banner__title {
	font-family: var(--font-display);
	font-size: clamp(2.4rem, 6vw, 4.6rem);
	line-height: 1.02;
	margin: 0;
	color: var(--cream);
	text-shadow: 0 2px 22px rgba(14, 15, 17, 0.55), 0 1px 4px rgba(14, 15, 17, 0.4);
}
.season-banner__text {
	font-size: 1.05rem;
	line-height: 1.6;
	color: rgba(250, 245, 236, 0.92);
	max-width: 48ch;
	margin: 0;
	text-shadow: 0 1px 14px rgba(14, 15, 17, 0.5);
}
.season-banner .btn--light { margin-top: 8px; }

/* -------------------------------------------------------------------------
   12. Reveal animation
   ---------------------------------------------------------------------- */
[data-reveal] {
	opacity: 0;
	transform: translateY(28px);
	transition: opacity 0.8s var(--ease), transform 0.8s var(--ease);
}
[data-reveal].is-visible { opacity: 1; transform: none; }

/* -------------------------------------------------------------------------
   13. Page heads, blog grid, single
   ---------------------------------------------------------------------- */
.page-head {
	padding-block: clamp(110px, 14vh, 170px) clamp(28px, 4vw, 52px);
	text-align: center;
}
.page-head__eyebrow,
.page-head .posted-on {
	display: block;
	font-size: 0.78rem;
	letter-spacing: 0.2em;
	text-transform: uppercase;
	color: var(--terracotta);
	margin-bottom: 14px;
	font-weight: 600;
}
.page-head__title { font-size: clamp(2.2rem, 5vw, 4rem); margin: 0; }
.page-head__desc { color: var(--ink-soft); max-width: 60ch; margin: 18px auto 0; }
.page-head__search { max-width: 480px; margin: 26px auto 0; }
.page-head__overline {
	display: block;
	font-size: 0.75rem;
	letter-spacing: 0.22em;
	text-transform: uppercase;
	color: var(--terracotta);
	font-weight: 600;
	margin-bottom: 14px;
}
.page-head--shop {
	text-align: center;
	padding-top: clamp(24px, 5vw, 56px);
	padding-bottom: clamp(20px, 3vw, 36px);
}
.page-head--shop .page-head__desc { margin-inline: auto; }

.post-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: clamp(20px, 3vw, 40px);
	padding-bottom: clamp(56px, 9vw, 110px);
}
.post-card__media {
	aspect-ratio: 3 / 2;
	border-radius: var(--radius-lg);
	overflow: hidden;
	margin-bottom: 16px;
}
.post-card__media img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.6s var(--ease); }
.post-card:hover .post-card__media img { transform: scale(1.04); }
.post-card__title { font-size: 1.3rem; margin: 8px 0 8px; }
.post-card__excerpt { color: var(--ink-soft); font-size: 0.95rem; }

.single-post__media,
.single-page__media {
	margin-block: clamp(20px, 4vw, 44px);
	border-radius: var(--radius-lg);
	overflow: hidden;
}
.entry-content { padding-bottom: clamp(56px, 9vw, 110px); font-size: 1.06rem; }
.entry-content h2 { font-size: clamp(1.6rem, 3vw, 2.4rem); margin-top: 1.5em; }
.entry-content h3 { font-size: 1.4rem; margin-top: 1.3em; }
.entry-content a { color: var(--terracotta); text-decoration: underline; text-underline-offset: 3px; }
.entry-content img { border-radius: var(--radius-lg); margin-block: 1.5em; }
.entry-content blockquote {
	border-left: 3px solid var(--terracotta);
	padding-left: 24px;
	margin: 1.6em 0;
	font-family: var(--font-display);
	font-size: 1.4rem;
	font-style: italic;
	color: var(--ink);
}

.pagination { padding-bottom: clamp(56px, 9vw, 110px); }
.pagination .nav-links {
	display: flex;
	gap: 8px;
	justify-content: center;
	flex-wrap: wrap;
}
.pagination .page-numbers {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 44px;
	height: 44px;
	padding: 0 12px;
	border: 1px solid var(--line);
	border-radius: 100px;
	font-size: 0.9rem;
	transition: all var(--transition);
}
.pagination .page-numbers.current { background: var(--ink); color: var(--cream); border-color: var(--ink); }
.pagination .page-numbers:hover:not(.current) { border-color: var(--ink); }

.no-results { text-align: center; padding-block: 80px; color: var(--ink-soft); }

/* Post navigation */
.post-navigation { padding-block: 40px; border-top: 1px solid var(--line); }
.post-navigation .nav-subtitle { font-size: 0.72rem; letter-spacing: 0.16em; text-transform: uppercase; color: var(--terracotta); }
.post-navigation .nav-title { font-family: var(--font-display); font-size: 1.2rem; }

/* -------------------------------------------------------------------------
   14. Search form
   ---------------------------------------------------------------------- */
.search-form { display: flex; gap: 10px; }
.search-field {
	flex: 1;
	padding: 14px 18px;
	border: 1px solid var(--line-strong);
	border-radius: 100px;
	background: var(--white);
	font-family: inherit;
	font-size: 0.95rem;
	color: var(--ink);
}
.search-field:focus { outline: none; border-color: var(--sea); }

/* -------------------------------------------------------------------------
   15. Footer
   ---------------------------------------------------------------------- */
.site-footer { background: var(--ink); color: var(--sand); padding-block: clamp(56px, 8vw, 96px) 40px; }
.site-footer .container { display: block; }

.footer-newsletter {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 40px;
	align-items: center;
	padding-bottom: clamp(40px, 6vw, 72px);
	border-bottom: 1px solid rgba(250, 245, 236, 0.16);
}
.footer-newsletter h2 { color: var(--cream); font-size: clamp(1.8rem, 4vw, 3rem); margin: 0 0 10px; }
.footer-newsletter p { color: rgba(250, 245, 236, 0.7); margin: 0; }
.footer-newsletter__form { display: flex; gap: 10px; }
.footer-newsletter__form input[type="email"] {
	flex: 1;
	padding: 15px 20px;
	border: 1px solid rgba(250, 245, 236, 0.3);
	border-radius: 100px;
	background: transparent;
	color: var(--cream);
	font-family: inherit;
	font-size: 0.95rem;
}
.footer-newsletter__form input::placeholder { color: rgba(250, 245, 236, 0.5); }
.footer-newsletter__form input:focus { outline: none; border-color: var(--terracotta); }
.footer-newsletter__form .btn--dark { background: var(--terracotta); }
.footer-newsletter__form .btn--dark:hover { background: var(--cream); color: var(--ink); }

.footer-grid {
	display: grid;
	grid-template-columns: 1.8fr 1fr 1fr;
	gap: clamp(32px, 5vw, 72px);
	padding-block: clamp(48px, 6vw, 80px);
	border-bottom: 1px solid rgba(250, 245, 236, 0.12);
}
.footer-logo { font-family: var(--font-display); font-size: 1.7rem; color: var(--cream); }
.footer-tagline { color: rgba(250, 245, 236, 0.7); max-width: 36ch; margin-top: 14px; }
.footer-business {
	font-style: normal;
	margin-top: 22px;
	display: flex;
	flex-direction: column;
	gap: 4px;
	font-size: 0.85rem;
	line-height: 1.6;
	color: rgba(250, 245, 236, 0.55);
}
.footer-col__title {
	color: var(--cream);
	font-family: var(--font-body);
	font-size: 0.74rem;
	letter-spacing: 0.16em;
	text-transform: uppercase;
	margin: 0 0 18px;
	opacity: 0.9;
}
.footer-col__note { color: rgba(250, 245, 236, 0.5); font-size: 0.8rem; margin: 14px 0 0; max-width: 26ch; }
.footer-payments {
	display: block;
	max-width: 100%;
	width: auto;
	height: auto;
	max-height: 30px;
}
.footer-menu { list-style: none; display: flex; flex-direction: column; gap: 12px; }
.footer-menu a { color: rgba(250, 245, 236, 0.78); font-size: 0.92rem; transition: color 0.2s var(--ease); }
.footer-menu a:hover { color: var(--terracotta); }
.footer-business__line { line-height: 1.6; }

.footer-bottom {
	display: flex;
	justify-content: center;
	gap: 16px;
	flex-wrap: wrap;
	padding-block: 26px;
	font-size: 0.78rem;
	letter-spacing: 0.03em;
	color: rgba(250, 245, 236, 0.5);
}
.footer-bottom p { margin: 0; }
.footer-copy { text-align: center; }
.footer-powered { flex-basis: 100%; text-align: center; opacity: 0.8; }
.footer-powered a { color: inherit; text-decoration: underline; text-underline-offset: 2px; transition: color var(--transition); }
.footer-powered a:hover { color: var(--cream); }
@media (max-width: 600px) {
	.footer-copy { text-align: center; }
}

/* -------------------------------------------------------------------------
   16. 404
   ---------------------------------------------------------------------- */
.error-404 { text-align: center; padding-block: clamp(140px, 18vh, 220px) clamp(80px, 12vw, 140px); }
.error-404__code { font-family: var(--font-display); font-size: clamp(5rem, 18vw, 12rem); line-height: 1; color: var(--terracotta); margin: 0; }
.error-404__title { font-size: clamp(1.8rem, 4vw, 3rem); margin: 0 0 12px; }
.error-404__text { color: var(--ink-soft); margin-bottom: 28px; }
.error-404__actions { display: flex; gap: 14px; justify-content: center; flex-wrap: wrap; margin-bottom: 36px; }
.error-404__search { max-width: 460px; margin-inline: auto; }

/* -------------------------------------------------------------------------
   17. WooCommerce general
   ---------------------------------------------------------------------- */
.woocommerce .woo-wrap {
	display: grid;
	grid-template-columns: 1fr;
	gap: clamp(28px, 4vw, 56px);
	padding-block: clamp(20px, 4vw, 48px) clamp(64px, 10vw, 120px);
}
.woocommerce .woo-wrap:has(.woo-wrap__sidebar) { grid-template-columns: 1fr 280px; }
.no-shop-sidebar .woocommerce .woo-wrap { grid-template-columns: 1fr; }

/* Toolbar shop: conteggio + ordinamento su una riga pulita */
.woocommerce .woo-wrap__content > .woocommerce-result-count,
.woocommerce .woo-wrap__content > .woocommerce-ordering {
	margin: 0 0 22px;
}
.woocommerce .woocommerce-result-count {
	color: var(--ink-soft);
	font-size: 0.84rem;
	letter-spacing: 0.04em;
	float: left;
	padding-top: 12px;
}
.woocommerce .woocommerce-ordering { float: right; }
.woocommerce .woo-wrap__content::after { content: ""; display: table; clear: both; }
.woocommerce .woocommerce-ordering select {
	padding: 10px 18px;
	border: 1px solid var(--line-strong);
	border-radius: 100px;
	background: var(--white);
	font-family: inherit;
	font-size: 0.84rem;
	cursor: pointer;
}

/* Single product */
.woocommerce div.product { display: grid; grid-template-columns: 1.1fr 1fr; gap: clamp(28px, 5vw, 72px); }
.woocommerce div.product .woocommerce-product-gallery { margin-bottom: 0; }
.woocommerce div.product .woocommerce-product-gallery img { border-radius: var(--radius-lg); }
.woocommerce div.product .product_title { font-size: clamp(2rem, 4vw, 3.2rem); margin-bottom: 12px; }
.woocommerce div.product p.price,
.woocommerce div.product span.price { color: var(--ink); font-size: 1.4rem; font-weight: 500; }
.woocommerce div.product p.price ins { text-decoration: none; color: var(--terracotta); }
.woocommerce .woocommerce-product-rating { margin-bottom: 16px; }

.woocommerce div.product form.cart { margin-top: 24px; display: flex; gap: 14px; align-items: center; flex-wrap: wrap; }
.woocommerce .quantity .qty {
	width: 72px;
	padding: 14px 10px;
	text-align: center;
	border: 1px solid var(--line-strong);
	border-radius: 100px;
	font-family: inherit;
}
.woocommerce div.product form.cart .button,
.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button,
.woocommerce #respond input#submit {
	background: var(--ink) !important;
	color: var(--cream) !important;
	border: 1px solid var(--ink) !important;
	border-radius: 100px !important;
	padding: 15px 32px !important;
	font-size: 0.8rem !important;
	font-weight: 600;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	transition: all var(--transition);
}
.woocommerce div.product form.cart .button:hover,
.woocommerce a.button:hover,
.woocommerce button.button:hover,
.woocommerce input.button:hover,
.woocommerce #respond input#submit:hover {
	background: var(--terracotta) !important;
	border-color: var(--terracotta) !important;
}
.woocommerce a.button.alt,
.woocommerce button.button.alt {
	background: var(--terracotta) !important;
	border-color: var(--terracotta) !important;
}
.woocommerce a.button.alt:hover,
.woocommerce button.button.alt:hover { background: var(--terracotta-dk) !important; border-color: var(--terracotta-dk) !important; }

/* Tabs */
.woocommerce div.product .woocommerce-tabs { grid-column: 1 / -1; margin-top: clamp(40px, 6vw, 72px); }
.woocommerce div.product .woocommerce-tabs ul.tabs { padding: 0; border-bottom: 1px solid var(--line); }
.woocommerce div.product .woocommerce-tabs ul.tabs::before { border-color: var(--line); }
.woocommerce div.product .woocommerce-tabs ul.tabs li {
	background: transparent;
	border: 0;
	border-radius: 0;
	margin: 0 20px 0 0;
	padding: 0 0 12px;
}
.woocommerce div.product .woocommerce-tabs ul.tabs li::before,
.woocommerce div.product .woocommerce-tabs ul.tabs li::after { display: none; }
.woocommerce div.product .woocommerce-tabs ul.tabs li a {
	padding: 0;
	font-family: var(--font-display);
	font-size: 1.15rem;
	color: var(--ink-soft);
}
.woocommerce div.product .woocommerce-tabs ul.tabs li.active a { color: var(--ink); }

/* -------------------------------------------------------------------------
   13b. Scheda prodotto immersiva (PDP)
   ---------------------------------------------------------------------- */
.pdp-wrap { width: 100%; }
/* Annulla la griglia a due colonne del prodotto standard */
.woocommerce div.product.pdp { display: block; grid-template-columns: none; gap: 0; }

/* Hero a tutto schermo con galleria scorrevole */
.pdp-hero {
	position: relative;
	width: 100%;
	height: 100svh;
	overflow: hidden;
	background: #0b0c0e;
}
.pdp-hero__track {
	display: flex;
	height: 100%;
	overflow-x: auto;
	scroll-snap-type: x mandatory;
	scroll-behavior: smooth;
	-webkit-overflow-scrolling: touch;
	scrollbar-width: none;
}
.pdp-hero__track::-webkit-scrollbar { display: none; }
.pdp-hero__slide {
	flex: 0 0 100%;
	width: 100%;
	height: 100%;
	scroll-snap-align: start;
}
.woocommerce .pdp-hero__img,
.pdp-hero__img {
	width: 100% !important;
	height: 100% !important;
	max-width: none !important;
	object-fit: cover !important;
	display: block;
	margin: 0 !important;
	border-radius: 0 !important;
}
.pdp-hero__badge { position: absolute; top: calc(var(--header-h) + 14px); left: 18px; z-index: 5; }

/* Nome prodotto in overlay, in basso sull'immagine */
.pdp-hero__caption {
	position: absolute;
	left: 0;
	right: 0;
	bottom: 0;
	z-index: 4;
	padding: clamp(70px, 16vh, 150px) clamp(20px, 5vw, 48px) clamp(26px, 4vh, 40px);
	background: linear-gradient(0deg, rgba(8, 9, 11, 0.72) 0%, rgba(8, 9, 11, 0.28) 42%, rgba(8, 9, 11, 0) 100%);
	pointer-events: none;
}
.pdp-hero__title {
	margin: 0;
	max-width: 16ch;
	color: #fff;
	font-family: var(--font-display);
	font-size: clamp(1.9rem, 7vw, 3.4rem);
	font-weight: 500;
	line-height: 1.04;
	letter-spacing: -0.01em;
	text-shadow: 0 2px 22px rgba(0, 0, 0, 0.45);
}

/* Dots indicatore immagini (in basso a destra) */
.pdp-hero__dots {
	position: absolute;
	right: clamp(20px, 5vw, 48px);
	bottom: clamp(30px, 4vh, 46px);
	z-index: 5;
	display: flex;
	justify-content: flex-end;
	gap: 8px;
	pointer-events: none;
}
.pdp-hero__dot {
	width: 7px;
	height: 7px;
	border-radius: 50%;
	background: rgba(255, 255, 255, 0.5);
	transition: all 0.3s var(--ease);
}
.pdp-hero__dot.is-active { background: #fff; width: 22px; border-radius: 100px; }

/* Corpo della scheda */
.pdp-body { padding-top: clamp(28px, 4vw, 44px); padding-bottom: 8px; }
.pdp-summary { max-width: 640px; margin: 0 auto; text-align: center; }
/* Su mobile il nome è in overlay sull'immagine: nascondo quello del riepilogo */
.pdp-summary__title { display: none; }
.woocommerce div.product.pdp .woocommerce-product-rating { text-align: center; margin-bottom: 14px; }

/* Prezzo: originale barrato + sconto, in evidenza */
.woocommerce div.product.pdp p.price,
.woocommerce div.product.pdp span.price {
	display: flex;
	align-items: baseline;
	justify-content: center;
	gap: 12px;
	color: var(--ink);
	font-size: 1.6rem;
	font-weight: 600;
	margin: 0 0 20px;
}
.woocommerce div.product.pdp p.price del,
.woocommerce div.product.pdp span.price del {
	color: var(--ink-soft);
	opacity: 0.7;
	font-weight: 400;
	font-size: 1.15rem;
	text-decoration: line-through;
}
.woocommerce div.product.pdp p.price ins,
.woocommerce div.product.pdp span.price ins {
	text-decoration: none;
	color: var(--sale);
}

/* Descrizione breve */
.woocommerce div.product.pdp .woocommerce-product-details__short-description {
	max-width: 56ch;
	margin: 0 auto 24px;
	color: var(--ink-soft);
	line-height: 1.6;
}

/* Form acquisto */
.woocommerce div.product.pdp form.cart {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 18px;
	margin: 0 auto;
	max-width: 460px;
}
.woocommerce div.product.pdp form.cart .woocommerce-variation-add-to-cart,
.woocommerce div.product.pdp form.cart .single_variation { width: 100%; }
.woocommerce div.product.pdp form.cart .single_variation .price {
	justify-content: center;
	font-size: 1.4rem;
	margin-bottom: 14px;
}
.woocommerce div.product.pdp form.cart .quantity,
.woocommerce div.product.pdp form.cart .quantity .qty { display: none !important; } /* quantità nascosta: look pulito */
.woocommerce div.product.pdp form.cart .button {
	width: 100%;
	max-width: 360px;
	padding: 17px 32px !important;
}
.woocommerce div.product.pdp .product_meta {
	margin-top: 26px;
	font-size: 0.82rem;
	color: var(--ink-soft);
}

/* ---- Selettori taglie / varianti moderni (swatch) ---- */
.pdp-swatch-group { margin: 0 0 6px; text-align: center; }
.pdp-swatch-group__label {
	display: block;
	font-size: 0.74rem;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: var(--ink-soft);
	margin-bottom: 10px;
}
.pdp-swatches {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 9px;
}
.pdp-swatch {
	min-width: 50px;
	padding: 11px 16px;
	border: 1px solid var(--line-strong);
	border-radius: 100px;
	background: #fff;
	color: var(--ink);
	font-size: 0.85rem;
	font-weight: 500;
	letter-spacing: 0.02em;
	cursor: pointer;
	transition: all 0.18s var(--ease);
}
.pdp-swatch:hover { border-color: var(--ink); }
.pdp-swatch.is-active {
	background: var(--ink);
	border-color: var(--ink);
	color: var(--cream);
}
.pdp-swatch:disabled,
.pdp-swatch.is-disabled {
	opacity: 0.35;
	cursor: not-allowed;
	text-decoration: line-through;
}
/* Nasconde i select originali quando ci sono gli swatch */
.woocommerce div.product.pdp .variations { margin: 0 auto 4px; border: 0; }
/* Tabella varianti resa a blocchi: niente altezza riga/spaziature da <table> */
.woocommerce div.product.pdp .variations,
.woocommerce div.product.pdp .variations tbody,
.woocommerce div.product.pdp .variations tr { display: block; }
.woocommerce div.product.pdp .variations td,
.woocommerce div.product.pdp .variations th { display: block; padding: 0; border: 0; text-align: center; }
.woocommerce div.product.pdp .variations .label { display: none; }
.woocommerce div.product.pdp .variations select.enhanced-hidden { display: none !important; }
.woocommerce div.product.pdp .reset_variations {
	display: inline-block;
	margin-top: 6px;
	font-size: 0.8rem;
	color: var(--ink-soft);
}

/* Compatta lo spazio tra taglie e azioni (mobile) */
.woocommerce div.product.pdp form.cart { gap: 0px; }
.woocommerce div.product.pdp .single_variation_wrap { margin: 0; }
.woocommerce div.product.pdp .single_variation { margin: 0; }
.woocommerce div.product.pdp .single_variation:empty { display: none; }
.woocommerce div.product.pdp .woocommerce-variation-add-to-cart {
	margin: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	align-items: center;
}
.woocommerce div.product.pdp .woocommerce-variation-add-to-cart .button { width: 100%; }

/* Rassicurazioni sotto il pulsante acquisto */
.pdp-reassure {
	list-style: none;
	margin: 18px auto 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: 11px;
	max-width: 360px;
}
.pdp-reassure__item {
	display: flex;
	align-items: center;
	gap: 10px;
	font-size: 0.86rem;
	color: var(--ink-soft);
	line-height: 1.4;
}
.pdp-reassure__item svg { flex: 0 0 auto; color: var(--ink); }
.pdp-reassure__item--urgent { color: var(--sale); font-weight: 500; }
.pdp-reassure__item--urgent svg { color: var(--sale); }

/* Guida alle taglie — trigger minimale (testo + icona, niente linee) */
.pdp-sizeguide { margin: 2px 0 4px; }
.pdp-sizeguide__toggle {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	padding: 6px 0;
	background: none;
	border: 0;
	cursor: pointer;
	color: var(--ink);
	font-size: 0.86rem;
	letter-spacing: 0.01em;
}
.pdp-sizeguide__toggle svg { flex: 0 0 auto; color: var(--ink-soft); }
.pdp-sizeguide__toggle span {
	text-decoration: underline;
	text-underline-offset: 4px;
	text-decoration-thickness: 1px;
}
.pdp-sizeguide__toggle:hover span,
.pdp-sizeguide__toggle:hover svg { color: var(--terracotta); }

/* Blocco scroll quando una finestra modale è aperta */
body.no-scroll { overflow: hidden; }

/* Modale / bottom-sheet */
.pdp-sizeguide__modal {
	position: fixed;
	inset: 0;
	z-index: 1000;
	display: flex;
	align-items: flex-end;
	justify-content: center;
	opacity: 0;
	visibility: hidden;
	pointer-events: none;
	transition: opacity 0.3s var(--ease), visibility 0.3s var(--ease);
}
.pdp-sizeguide__modal.is-open { opacity: 1; visibility: visible; pointer-events: auto; }
.pdp-sizeguide__backdrop {
	position: absolute;
	inset: 0;
	background: rgba(8, 9, 11, 0.55);
	-webkit-backdrop-filter: blur(2px);
	backdrop-filter: blur(2px);
}
.pdp-sizeguide__dialog {
	position: relative;
	width: 100%;
	max-width: 560px;
	max-height: 88vh;
	overflow-y: auto;
	-webkit-overflow-scrolling: touch;
	background: var(--cream);
	border-radius: 20px 20px 0 0;
	padding: 30px clamp(20px, 5vw, 34px) 36px;
	transform: translateY(100%);
	transition: transform 0.4s var(--ease);
	box-shadow: 0 -20px 60px -24px rgba(0, 0, 0, 0.5);
}
.pdp-sizeguide__modal.is-open .pdp-sizeguide__dialog { transform: translateY(0); }
.pdp-sizeguide__close {
	position: absolute;
	top: 16px;
	right: 16px;
	width: 38px;
	height: 38px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	border: 0;
	border-radius: 50%;
	background: rgba(14, 15, 17, 0.06);
	color: var(--ink);
	cursor: pointer;
	transition: background 0.2s var(--ease);
}
.pdp-sizeguide__close:hover { background: rgba(14, 15, 17, 0.12); }

@media (min-width: 769px) {
	.pdp-sizeguide__modal { align-items: center; }
	.pdp-sizeguide__dialog {
		border-radius: 18px;
		transform: translateY(12px) scale(0.97);
		box-shadow: 0 30px 80px -30px rgba(0, 0, 0, 0.55);
	}
	.pdp-sizeguide__modal.is-open .pdp-sizeguide__dialog { transform: none; }
}

.pdp-sizeguide__heading {
	text-align: center;
	font-family: var(--font-display);
	font-size: 1rem;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: var(--ink);
	margin: 8px 0 18px;
}
.pdp-sizeguide__group { margin-bottom: 18px; }
.pdp-sizeguide__group:last-child { margin-bottom: 6px; }
.pdp-sizeguide__group-title {
	font-size: 0.72rem;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: var(--ink-soft);
	margin: 0 0 8px;
}
.pdp-sizetable {
	width: 100%;
	border-collapse: collapse;
	font-size: 0.84rem;
}
.pdp-sizetable th,
.pdp-sizetable td {
	padding: 9px 8px;
	text-align: left;
	border: 0;
	border-bottom: 1px solid var(--line);
	color: var(--ink-soft);
	font-weight: 400;
}
.pdp-sizetable thead th {
	font-size: 0.68rem;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color: var(--ink);
	font-weight: 600;
	border-bottom-color: var(--line-strong);
}
.pdp-sizetable tbody th[scope="row"] {
	color: var(--ink);
	font-weight: 600;
}
.pdp-sizetable tbody tr:last-child th,
.pdp-sizetable tbody tr:last-child td { border-bottom: 0; }

/* Descrizione prodotto (senza titolo "Descrizione") */
.pdp-description {
	margin-top: clamp(34px, 5vw, 60px);
	padding: clamp(36px, 6vw, 72px) var(--gutter);
	border-top: 1px solid var(--line);
}
.pdp-description__inner {
	max-width: 660px;
	margin: 0 auto;
	text-align: left;
	color: var(--ink-soft);
	font-size: 1.03rem;
	line-height: 1.8;
}
.pdp-description__inner > :first-child { margin-top: 0; }
.pdp-description__inner > :last-child { margin-bottom: 0; }
.pdp-description__inner p { margin: 0 0 1.1em; }
.pdp-description__inner h2,
.pdp-description__inner h3,
.pdp-description__inner h4 {
	font-family: var(--font-display);
	color: var(--ink);
	font-weight: 500;
	letter-spacing: -0.01em;
	margin: 1.4em 0 0.5em;
}
.pdp-description__inner ul,
.pdp-description__inner ol { margin: 0.4em 0 1.1em; padding-left: 1.2em; }
.pdp-description__inner li { margin-bottom: 0.4em; }
.pdp-description__inner img { border-radius: var(--radius-lg); margin: 1em 0; }
.pdp-description__inner a { color: var(--terracotta); text-decoration: underline; text-underline-offset: 3px; }

/* Striscia "Made in Italy" minimal */
.pdp-madein {
	padding: clamp(34px, 5vw, 60px) var(--gutter);
	border-top: 1px solid var(--line);
	border-bottom: 1px solid var(--line);
	text-align: center;
}
.pdp-madein__inner { max-width: 620px; margin: 0 auto; }
.pdp-madein__flag {
	display: inline-block;
	font-size: 1.7rem;
	line-height: 1;
	margin-bottom: 14px;
}
.pdp-madein__title {
	margin: 0 0 12px;
	font-family: var(--font-display);
	font-weight: 500;
	font-size: clamp(1.2rem, 2.4vw, 1.7rem);
	letter-spacing: 0.02em;
	color: var(--ink);
}
.pdp-madein__title::after {
	content: "";
	display: block;
	width: 40px;
	height: 1px;
	margin: 14px auto 0;
	background: var(--line-strong);
}
.pdp-madein__text {
	margin: 0;
	color: var(--ink-soft);
	font-size: 1rem;
	line-height: 1.75;
}

/* FAQ scheda prodotto (accordion minimal) */
.pdp-faq {
	max-width: 760px;
	margin: 0 auto clamp(40px, 6vw, 72px);
	background: #efe7e2;
	padding: clamp(28px, 5vw, 56px) clamp(20px, 4vw, 48px);
	border-radius: 16px;
}
.pdp-faq__title {
	font-size: clamp(1.5rem, 3vw, 2.1rem);
	text-align: center;
	margin: 0 0 clamp(20px, 3vw, 32px);
}
.faq-item {
	border-bottom: 1px solid var(--line);
}
.faq-item:first-child { border-top: 1px solid var(--line); }
.faq-item__q {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 18px;
	padding: 20px 4px;
	cursor: pointer;
	list-style: none;
	font-family: var(--font-display);
	font-size: clamp(1.02rem, 1.6vw, 1.18rem);
	color: var(--ink);
	transition: color 0.2s var(--ease);
}
.faq-item__q::-webkit-details-marker { display: none; }
.faq-item__q:hover { color: var(--terracotta); }
/* Icona + / − */
.faq-item__icon {
	position: relative;
	flex: 0 0 auto;
	width: 16px;
	height: 16px;
}
.faq-item__icon::before,
.faq-item__icon::after {
	content: "";
	position: absolute;
	top: 50%;
	left: 50%;
	width: 14px;
	height: 1.5px;
	background: currentColor;
	transform: translate(-50%, -50%);
	transition: transform 0.28s var(--ease), opacity 0.28s var(--ease);
}
.faq-item__icon::after { transform: translate(-50%, -50%) rotate(90deg); }
.faq-item[open] .faq-item__icon::after { opacity: 0; transform: translate(-50%, -50%) rotate(0deg); }
.faq-item__a {
	padding: 0 4px 22px;
	color: var(--ink-soft);
	line-height: 1.7;
	max-width: 64ch;
}
.faq-item__a > :first-child { margin-top: 0; }
.faq-item__a > :last-child { margin-bottom: 0; }
.faq-item__a p { margin: 0 0 0.9em; }

/* Tab / correlati */
.pdp-extra { margin-top: clamp(40px, 6vw, 72px); }

/* Must Have (correlati a carosello) */
.pdp-musthave { margin-top: clamp(40px, 6vw, 72px); }
.woocommerce .pdp-musthave .pdp-musthave__title,
.pdp-musthave__title {
	font-size: clamp(1.5rem, 3vw, 2.1rem);
	text-align: center;
	text-transform: none;
	margin: 0 0 clamp(24px, 3vw, 36px);
}
.pdp-extra .related > h2,
.pdp-extra .upsells > h2 { font-size: clamp(1.4rem, 3vw, 2rem); margin-bottom: 20px; }
.woocommerce div.product.pdp .woocommerce-tabs { margin-top: 0; }

/* =========================================================================
   PDP DESKTOP: layout classico a due colonne (foto a sinistra, riepilogo a
   destra sticky). Niente header immersivo.
   ========================================================================= */
@media (min-width: 769px) {

	/* Header solido (annulla l'effetto trasparente/immersivo mobile) */
	.pdp-immersive .site-header,
	.pdp-immersive .site-header.is-scrolled {
		position: sticky;
		background: var(--cream);
		border-bottom-color: var(--line);
		color: var(--ink);
	}
	.pdp-immersive .site-header .site-title,
	.pdp-immersive .site-header .main-navigation a,
	.pdp-immersive .site-header .header-action { color: var(--ink); }
	.pdp-immersive .site-header .nav-toggle__bar { background: var(--ink); }
	.pdp-immersive .site-header .site-logo--light { display: none !important; }
	.pdp-immersive .site-header .site-logo--dark { display: block !important; }

	/* Griglia a due colonne (solo galleria + riepilogo).
	   Lo sticky del riepilogo resta confinato a .pdp-top, così non
	   sconfina su descrizione / FAQ / Must Have. */
	.pdp-wrap { padding: 0; }
	.woocommerce div.product.pdp { display: block; }
	.woocommerce div.product.pdp .pdp-top {
		display: grid;
		grid-template-columns: 1.1fr 0.9fr;
		gap: clamp(28px, 4vw, 64px);
		align-items: start;
		max-width: 1280px;
		margin: 0 auto;
		padding: clamp(20px, 3vw, 44px) var(--gutter) 0;
	}

	/* Colonna sinistra: foto impilate che scorrono con la pagina */
	.pdp-hero {
		height: auto;
		background: transparent;
		overflow: visible;
		border-radius: 0;
	}
	.pdp-hero__track {
		flex-direction: column;
		height: auto;
		overflow: visible;
		scroll-snap-type: none;
		gap: 16px;
	}
	.pdp-hero__slide { flex: 0 0 auto; width: 100%; height: auto; }
	.woocommerce .pdp-hero__img,
	.pdp-hero__img {
		height: auto !important;
		aspect-ratio: 4 / 5;
		border-radius: var(--radius-lg) !important;
	}
	.pdp-hero__caption,
	.pdp-hero__dots { display: none; }
	.pdp-hero__badge { top: 16px; left: 16px; }

	/* Colonna destra: riepilogo sticky */
	.pdp-body,
	.pdp-body.container {
		position: sticky;
		top: calc(var(--header-h) + 24px);
		max-width: none;
		width: auto;
		margin: 0;
		padding: 0;
	}
	.pdp-summary { max-width: none; margin: 0; text-align: left; }
	.pdp-summary__title {
		display: block;
		font-family: var(--font-display);
		font-size: clamp(1.9rem, 2.6vw, 2.7rem);
		font-weight: 500;
		line-height: 1.08;
		letter-spacing: -0.01em;
		margin: 0 0 14px;
	}
	.woocommerce div.product.pdp .woocommerce-product-rating { text-align: left; }
	.woocommerce div.product.pdp p.price,
	.woocommerce div.product.pdp span.price { justify-content: flex-start; }
	.woocommerce div.product.pdp .woocommerce-product-details__short-description {
		margin-left: 0;
		margin-right: 0;
		text-align: left;
		max-width: none;
	}
	.woocommerce div.product.pdp form.cart {
		align-items: stretch;
		margin: 0;
		max-width: none;
	}
	.woocommerce div.product.pdp form.cart .button { max-width: none; }
	.pdp-reassure { margin-left: 0; margin-right: 0; max-width: none; }
	.pdp-swatch-group { text-align: left; }
	.pdp-swatches { justify-content: flex-start; }
	.woocommerce div.product.pdp .product_meta { text-align: left; }

	/* Descrizione e correlati a tutta larghezza sotto le due colonne */
	.pdp-description,
	.pdp-extra { grid-column: 1 / -1; }
	.pdp-description { padding-left: 0; padding-right: 0; }
}

/* Notices */
.woocommerce-message,
.woocommerce-info,
.woocommerce-error {
	border-top-color: var(--terracotta) !important;
	border-radius: var(--radius-lg);
	background: var(--cream);
}
.woocommerce-message::before,
.woocommerce-info::before { color: var(--terracotta); }

/* Cart & checkout tables */
.woocommerce table.shop_table { border-radius: var(--radius-lg); border-color: var(--line); }
.woocommerce-cart table.cart img { width: 80px; border-radius: var(--radius); }
.woocommerce .cart-collaterals .cart_totals,
.woocommerce-checkout #order_review { background: var(--cream); padding: 24px; border-radius: var(--radius-lg); }
.woocommerce form .form-row input.input-text,
.woocommerce form .form-row textarea,
.woocommerce form .form-row select {
	border: 1px solid var(--line-strong);
	border-radius: var(--radius);
	padding: 12px 14px;
}

/* Related products heading */
.woocommerce .related > h2,
.woocommerce .upsells > h2 { font-size: clamp(1.6rem, 3vw, 2.4rem); margin-bottom: 24px; }

/* -------------------------------------------------------------------------
   18. Responsive — tablet
   ---------------------------------------------------------------------- */
@media (max-width: 1024px) {
	.product-grid,
	ul.products { grid-template-columns: repeat(3, 1fr); }
	.editorial { grid-template-columns: 1fr; }
	.editorial__media { max-width: 480px; }
	.woocommerce div.product { grid-template-columns: 1fr; }
	.woocommerce .woo-wrap:has(.woo-wrap__sidebar) { grid-template-columns: 1fr; }
}

/* -------------------------------------------------------------------------
   19. Responsive — mobile
   ---------------------------------------------------------------------- */
@media (max-width: 768px) {
	:root { --header-h: 64px; }

	.nav-toggle { display: flex; }

	.site-header__inner {
		grid-template-columns: auto auto auto;
		justify-content: space-between;
	}
	.site-branding { justify-self: center; }
	.site-header__inner .main-navigation { justify-self: stretch; }

	/* Menu mobile a tutto schermo */
	.main-navigation {
		position: fixed;
		inset: 0;
		width: 100%;
		display: flex;
		flex-direction: column;
		background: linear-gradient(165deg, #ffffff 0%, #f7f0ea 60%, #f0e6dd 100%);
		padding: calc(var(--header-h) + 26px) clamp(26px, 7vw, 56px) clamp(30px, 6vh, 48px);
		opacity: 0;
		visibility: hidden;
		transform: scale(1.03);
		transition: opacity 0.4s var(--ease), transform 0.5s var(--ease), visibility 0s linear 0.45s;
		z-index: 120;
		overflow-y: auto;
	}
	.nav-open .main-navigation {
		opacity: 1;
		visibility: visible;
		transform: none;
		transition: opacity 0.4s var(--ease), transform 0.5s var(--ease), visibility 0s;
	}

	/* X di chiusura in alto a destra */
	.main-navigation .mobile-menu__close {
		position: absolute;
		top: calc(var(--header-h) / 2 - 22px + 12px);
		right: clamp(18px, 5vw, 40px);
		display: inline-flex;
		align-items: center;
		justify-content: center;
		width: 46px;
		height: 46px;
		padding: 0;
		border: 1px solid var(--line-strong);
		border-radius: 50%;
		background: transparent;
		color: var(--ink);
		cursor: pointer;
		transition: background 0.3s var(--ease), color 0.3s var(--ease), border-color 0.3s var(--ease), transform 0.3s var(--ease);
	}
	.mobile-menu__close:hover {
		background: var(--ink);
		border-color: var(--ink);
		color: var(--cream);
		transform: rotate(90deg);
	}

	/* Etichetta "Menu" in alto */
	.main-navigation .mobile-menu__label {
		display: block;
		margin-bottom: 16px;
		font-size: 0.7rem;
		letter-spacing: 0.34em;
		text-transform: uppercase;
		color: var(--ink-soft);
		opacity: 0;
		transform: translateY(-6px);
		transition: opacity 0.4s var(--ease) 0.1s, transform 0.4s var(--ease) 0.1s;
	}
	.nav-open .mobile-menu__label { opacity: 1; transform: none; }

	.main-navigation .nav-menu {
		flex-direction: column;
		align-items: stretch;
		gap: 0;
		counter-reset: navnum;
	}
	.has-transparent-header .site-header .main-navigation a { color: var(--ink); }

	.main-navigation .nav-menu > li {
		counter-increment: navnum;
		border-bottom: 1px solid rgba(14, 15, 17, 0.08);
		opacity: 0;
		transform: translateX(-18px);
		transition: opacity 0.5s var(--ease), transform 0.5s var(--ease);
	}
	.nav-open .main-navigation .nav-menu > li { opacity: 1; transform: none; }
	.nav-open .main-navigation .nav-menu > li:nth-child(1) { transition-delay: 0.12s; }
	.nav-open .main-navigation .nav-menu > li:nth-child(2) { transition-delay: 0.18s; }
	.nav-open .main-navigation .nav-menu > li:nth-child(3) { transition-delay: 0.24s; }
	.nav-open .main-navigation .nav-menu > li:nth-child(4) { transition-delay: 0.30s; }
	.nav-open .main-navigation .nav-menu > li:nth-child(5) { transition-delay: 0.36s; }
	.nav-open .main-navigation .nav-menu > li:nth-child(6) { transition-delay: 0.42s; }
	.nav-open .main-navigation .nav-menu > li:nth-child(7) { transition-delay: 0.48s; }
	.nav-open .main-navigation .nav-menu > li:nth-child(n+8) { transition-delay: 0.52s; }

	.main-navigation .nav-menu > li > a {
		display: flex;
		align-items: baseline;
		gap: 16px;
		padding: 17px 0;
		font-family: var(--font-display);
		font-size: clamp(1.7rem, 7.4vw, 2.3rem);
		font-weight: 500;
		line-height: 1.04;
		color: var(--ink);
		transition: color 0.3s var(--ease), transform 0.3s var(--ease);
	}
	.main-navigation .nav-menu > li > a::before {
		content: counter(navnum, decimal-leading-zero);
		font-family: "Helvetica Neue", Arial, sans-serif;
		font-size: 0.7rem;
		font-weight: 600;
		letter-spacing: 0.06em;
		color: var(--terracotta);
		transform: translateY(-0.55em);
		min-width: 1.4em;
	}
	.main-navigation .nav-menu > li > a::after { display: none; }
	.main-navigation .nav-menu > li > a:hover,
	.main-navigation .nav-menu > li.current-menu-item > a {
		color: var(--terracotta);
		transform: translateX(6px);
	}

	.main-navigation .sub-menu {
		position: static;
		opacity: 1;
		visibility: visible;
		transform: none;
		box-shadow: none;
		border: 0;
		padding: 0 0 10px 30px;
		background: transparent;
	}
	.main-navigation .sub-menu a { padding: 7px 0; font-size: 0.98rem; color: var(--ink-soft); }

	/* Footer del menu: account + social */
	.main-navigation .mobile-menu__foot {
		display: flex;
		flex-direction: column;
		gap: 14px;
		margin-top: auto;
		padding-top: 28px;
		opacity: 0;
		transform: translateY(12px);
		transition: opacity 0.5s var(--ease) 0.42s, transform 0.5s var(--ease) 0.42s;
	}
	.nav-open .main-navigation .mobile-menu__foot { opacity: 1; transform: none; }
	.mobile-menu__account {
		display: inline-flex;
		align-items: center;
		gap: 10px;
		font-size: 0.95rem;
		letter-spacing: 0.01em;
		color: var(--ink);
		transition: color 0.3s var(--ease);
	}
	.mobile-menu__account:hover { color: var(--terracotta); }
	.mobile-menu__follow {
		font-size: 0.66rem;
		letter-spacing: 0.3em;
		text-transform: uppercase;
		color: var(--ink-soft);
		margin-top: 6px;
	}
	.main-navigation .social-links--mobile { display: flex; margin-top: 0; }
	.main-navigation .social-links__item { width: 40px; height: 40px; }

	.product-grid { grid-template-columns: repeat(2, 1fr); gap: 16px; }
	/* Shop su mobile: una sola immagine grande per riga, si scorre col dito */
	ul.products { grid-template-columns: 1fr; gap: clamp(22px, 6vw, 34px); }
	/* Niente "Scegli" su mobile: si tocca la card e si apre il prodotto */
	.shop-card__cta { display: none !important; }
	/* Card promo "New Collection" solo desktop */
	ul.products li.product.shop-card--promo { display: none !important; }
	/* Immagine card più alta/immersiva su mobile */
	.shop-card__media { aspect-ratio: 4 / 5; border-radius: var(--radius-lg); }
	.shop-card__info { padding-top: 12px; }
	.shop-card__title { font-size: 1.18rem; }

	/* Carosello: prima card piena + peek della seconda, si scorre col dito */
	.carousel-nav { display: none; }
	.products.featured-carousel { gap: 14px; }
	.products.featured-carousel > li.product,
	.products.featured-carousel > .product-card { width: 72vw !important; max-width: 340px; }
	.section__foot { justify-content: flex-end; }

	.cat-grid { grid-template-columns: 1fr; }
	.post-grid { grid-template-columns: 1fr; }

	.hero { min-height: 100svh; }
	.hero__content { padding-bottom: 64px; }

	.section__head { align-items: flex-start; }

	.footer-newsletter,
	.footer-grid { grid-template-columns: 1fr; }
	.footer-newsletter__form { flex-direction: column; }
	.footer-newsletter__form .btn { width: 100%; }
	.footer-grid__widgets { grid-template-columns: 1fr 1fr; }
	.footer-bottom { flex-direction: column; gap: 6px; }

	.search-form { flex-direction: column; }
	.search-form .btn { width: 100%; }

	.woocommerce div.product form.cart { width: 100%; }
	.woocommerce div.product form.cart .button { flex: 1; }
}

@media (max-width: 460px) {
	.product-grid,
	ul.products { gap: 12px; }
	.product-card__title,
	ul.products li.product .woocommerce-loop-product__title { font-size: 0.98rem !important; }
}

/* -------------------------------------------------------------------------
   20. Reduced motion
   ---------------------------------------------------------------------- */
@media (prefers-reduced-motion: reduce) {
	*,
	*::before,
	*::after {
		animation-duration: 0.001ms !important;
		animation-iteration-count: 1 !important;
		transition-duration: 0.001ms !important;
		scroll-behavior: auto !important;
	}
	[data-reveal] { opacity: 1; transform: none; }
}

/* =========================================================================
   MINI-CART (drawer off-canvas)
   ========================================================================= */
.mini-cart {
	position: fixed;
	inset: 0;
	z-index: 1200;
	visibility: hidden;
	pointer-events: none;
}
.mini-cart.is-open {
	visibility: visible;
	pointer-events: auto;
}
.mini-cart__backdrop {
	position: absolute;
	inset: 0;
	background: rgba(14, 15, 17, 0.45);
	opacity: 0;
	transition: opacity 0.4s var(--ease);
}
.mini-cart.is-open .mini-cart__backdrop { opacity: 1; }

.mini-cart__panel {
	position: absolute;
	top: 0;
	right: 0;
	bottom: 0;
	width: min(92vw, 420px);
	background: var(--white);
	display: flex;
	flex-direction: column;
	transform: translateX(100%);
	transition: transform 0.45s var(--ease);
	box-shadow: -18px 0 60px -30px rgba(14, 15, 17, 0.6);
}
.mini-cart.is-open .mini-cart__panel { transform: none; }

.mini-cart__head {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: 22px 26px;
	border-bottom: 1px solid var(--line);
	flex: 0 0 auto;
}
.mini-cart__title {
	font-family: var(--font-display);
	font-size: 1.25rem;
	letter-spacing: 0.01em;
}
.mini-cart__close {
	display: inline-flex;
	background: none;
	border: 0;
	padding: 6px;
	margin: -6px;
	cursor: pointer;
	color: var(--ink);
	transition: opacity 0.25s var(--ease);
}
.mini-cart__close:hover { opacity: 0.6; }

.mini-cart .widget_shopping_cart_content {
	flex: 1 1 auto;
	display: flex;
	flex-direction: column;
	overflow-y: auto;
	padding: 6px 26px 26px;
}

/* Lista articoli (template mini-cart di WooCommerce) */
.mini-cart ul.cart_list,
.mini-cart ul.product_list_widget {
	list-style: none;
	margin: 0;
	padding: 0;
	flex: 1 1 auto;
}
.mini-cart ul.cart_list li {
	position: relative;
	padding: 18px 30px 18px 0;
	border-bottom: 1px solid var(--line);
}
/* Il link contiene immagine + nome: lo trasformo in griglia allineata */
.mini-cart ul.cart_list li a:not(.remove) {
	display: grid;
	grid-template-columns: 64px 1fr;
	column-gap: 14px;
	align-items: center;
	font-family: var(--font-display);
	font-size: 1rem;
	line-height: 1.3;
	color: var(--ink);
	text-decoration: none;
}
.mini-cart ul.cart_list li img {
	width: 64px !important;
	height: 80px;
	object-fit: cover;
	border-radius: 8px;
	margin: 0 !important;
	float: none !important;
}
.mini-cart ul.cart_list li .quantity {
	display: block;
	margin-top: 8px;
	padding-left: 78px;
	font-size: 0.9rem;
	color: var(--ink-soft);
}
.mini-cart ul.cart_list li dl.variation {
	margin: 6px 0 0;
	padding-left: 78px;
	font-size: 0.8rem;
	color: var(--ink-soft);
}
.mini-cart ul.cart_list li dl.variation dt,
.mini-cart ul.cart_list li dl.variation dd { display: inline; margin: 0; }
.mini-cart ul.cart_list li dl.variation p { margin: 0; }
.mini-cart a.remove,
.mini-cart .remove_from_cart_button {
	position: absolute;
	top: 18px;
	right: 0;
	width: 22px;
	height: 22px;
	line-height: 20px;
	text-align: center;
	border-radius: 50%;
	font-size: 18px;
	color: var(--ink-soft) !important;
	text-decoration: none;
	transition: color 0.2s var(--ease);
}
.mini-cart a.remove:hover { color: var(--terracotta) !important; background: none !important; }

.mini-cart .woocommerce-mini-cart__empty-message {
	margin: 32px 0;
	text-align: center;
	color: var(--ink-soft);
}

.mini-cart .woocommerce-mini-cart__total {
	display: flex;
	align-items: baseline;
	justify-content: space-between;
	margin: 0;
	padding: 18px 0;
	border-top: 1px solid var(--line);
	font-size: 1.05rem;
}
.mini-cart .woocommerce-mini-cart__total strong { font-family: var(--font-display); }
.mini-cart .woocommerce-mini-cart__total .amount { font-weight: 600; }

.mini-cart .woocommerce-mini-cart__buttons {
	display: flex;
	flex-direction: column;
	gap: 10px;
	margin: 0;
	padding-top: 4px;
}
.mini-cart .woocommerce-mini-cart__buttons .button {
	display: block;
	width: 100%;
	margin: 0;
	text-align: center;
	padding: 14px 20px;
	border-radius: 999px;
	font-size: 0.78rem;
	letter-spacing: 0.16em;
	text-transform: uppercase;
	background: transparent;
	color: var(--ink);
	border: 1px solid var(--line-strong);
	transition: background 0.3s var(--ease), color 0.3s var(--ease), border-color 0.3s var(--ease);
}
.mini-cart .woocommerce-mini-cart__buttons .button:hover {
	border-color: var(--ink);
}
.mini-cart .woocommerce-mini-cart__buttons .checkout,
.mini-cart .woocommerce-mini-cart__buttons .button.wc-forward.checkout {
	background: var(--ink);
	color: var(--cream);
	border-color: var(--ink);
}
.mini-cart .woocommerce-mini-cart__buttons .checkout:hover {
	background: var(--terracotta);
	border-color: var(--terracotta);
}

/* =========================================================================
   PAGINA "CHI SIAMO"
   ========================================================================= */
.about { overflow: hidden; }

.about-hero {
	position: relative;
	display: flex;
	align-items: flex-end;
	min-height: 46vh;
	padding: clamp(80px, 16vh, 180px) 0 clamp(40px, 7vh, 80px);
	background: var(--ink);
	color: var(--cream);
}
.about-hero--photo {
	background-size: cover;
	background-position: center;
}
.about-hero__overlay {
	position: absolute;
	inset: 0;
	background: linear-gradient(180deg, rgba(14, 15, 17, 0.25) 0%, rgba(14, 15, 17, 0.65) 100%);
}
.about-hero__inner {
	position: relative;
	z-index: 1;
}
.about-hero__overline {
	margin: 0 0 14px;
	font-size: 0.78rem;
	letter-spacing: 0.26em;
	text-transform: uppercase;
	color: rgba(255, 255, 255, 0.82);
}
.about-hero__title {
	margin: 0;
	font-size: clamp(2.6rem, 7vw, 5rem);
	line-height: 1.02;
	font-weight: 500;
}

.about-intro {
	padding-block: clamp(56px, 9vw, 110px) clamp(24px, 4vw, 48px);
	text-align: center;
}
.about-intro__lead {
	margin: 0 auto;
	max-width: 760px;
	font-family: var(--font-display);
	font-size: clamp(1.4rem, 3.2vw, 2.1rem);
	line-height: 1.4;
	font-weight: 400;
	color: var(--ink);
}

.about-story {
	display: grid;
	grid-template-columns: 0.9fr 1.1fr;
	gap: clamp(36px, 6vw, 84px);
	align-items: start;
	padding-block: clamp(32px, 6vw, 72px) clamp(48px, 8vw, 110px);
}
.about-story__media {
	position: sticky;
	top: 110px;
	aspect-ratio: 4 / 5;
	border-radius: 14px;
	background-size: cover;
	background-position: center;
	background-color: #efe7e2;
	overflow: hidden;
}
.about-story__caption {
	position: absolute;
	left: 0;
	right: 0;
	bottom: 0;
	display: flex;
	flex-direction: column;
	gap: 2px;
	padding: 40px 22px 20px;
	color: var(--cream);
	background: linear-gradient(180deg, rgba(14, 15, 17, 0) 0%, rgba(14, 15, 17, 0.6) 100%);
}
.about-story__sig-name {
	font-family: var(--font-display);
	font-size: 1.15rem;
}
.about-story__sig-role {
	font-size: 0.74rem;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: rgba(255, 255, 255, 0.82);
}

.about-story__text {
	max-width: 620px;
}
.about-story__text--full {
	grid-column: 1 / -1;
	margin: 0 auto;
	text-align: center;
}
.about-story__text p {
	margin: 0 0 1.4em;
	font-size: clamp(1rem, 1.4vw, 1.12rem);
	line-height: 1.85;
	color: var(--ink-soft);
}
.about-story__text p:last-child { margin-bottom: 0; }

.about-highlight {
	padding: clamp(56px, 10vw, 120px) 24px;
	text-align: center;
	background: #efe7e2;
}
.about-highlight__text {
	margin: 0 auto;
	max-width: 900px;
	font-family: var(--font-display);
	font-size: clamp(2rem, 5.5vw, 3.6rem);
	line-height: 1.15;
	font-weight: 500;
	color: var(--ink);
}

.about-closing {
	padding-block: clamp(56px, 9vw, 110px) clamp(64px, 11vw, 140px);
	text-align: center;
}
.about-closing p {
	margin: 0 auto 1.4em;
	max-width: 680px;
	font-size: clamp(1.05rem, 1.6vw, 1.25rem);
	line-height: 1.7;
	color: var(--ink);
}
.about-closing__cta {
	margin-top: 18px;
}

@media (max-width: 860px) {
	.about-story {
		grid-template-columns: 1fr;
		gap: 30px;
	}
	.about-story__media {
		position: relative;
		top: auto;
		max-width: 460px;
		margin: 0 auto;
		width: 100%;
	}
	.about-story__text { max-width: none; }
}

/* Più aria ai lati sulla pagina "Chi siamo" da mobile */
@media (max-width: 600px) {
	.about-intro,
	.about-story,
	.about-closing { padding-inline: 22px; }
	.about-highlight { padding-inline: 26px; }
	.about-hero { padding-block: clamp(96px, 22vh, 150px) clamp(36px, 7vh, 64px); }
}

/* =========================================================================
   SOCIAL (menu mobile + footer)
   ========================================================================= */
.social-links {
	display: flex;
	align-items: center;
	gap: 12px;
}
.social-links__item {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 42px;
	height: 42px;
	border-radius: 50%;
	border: 1px solid var(--line-strong);
	color: var(--ink);
	transition: background var(--transition), color var(--transition), border-color var(--transition), transform 0.25s var(--ease);
}
.social-links__item:hover {
	background: var(--ink);
	border-color: var(--ink);
	color: var(--cream);
	transform: translateY(-2px);
}

/* Elementi esclusivi del menu off-canvas: nascosti su desktop */
.mobile-menu__close,
.mobile-menu__label,
.mobile-menu__foot { display: none; }

/* Nel menu mobile: visibile solo nell'off-canvas */
.social-links--mobile { display: none; margin-top: 26px; }

/* Nel footer: tono chiaro su fondo scuro */
.social-links--footer { margin-top: 22px; }
.site-footer .social-links__item {
	border-color: rgba(255, 255, 255, 0.28);
	color: var(--cream);
}
.site-footer .social-links__item:hover {
	background: var(--cream);
	border-color: var(--cream);
	color: var(--ink);
}

/* =========================================================================
   RECENSIONI stile Trustpilot (scheda prodotto)
   ========================================================================= */
.tp-reviews {
	padding: clamp(44px, 7vw, 80px) 0;
	background: #f8f8f8;
}
.tp-reviews__inner { max-width: 1100px; }

.tp-reviews__head {
	display: flex;
	align-items: center;
	justify-content: space-between;
	flex-wrap: wrap;
	gap: 16px;
	margin-bottom: clamp(22px, 3vw, 34px);
}
.tp-reviews__rating { display: flex; align-items: center; gap: 14px; }
.tp-reviews__summary { display: flex; flex-direction: column; line-height: 1.3; }
.tp-reviews__summary strong { font-size: 1.05rem; display: inline-flex; align-items: baseline; gap: 8px; }
.tp-reviews__summary span { font-size: 0.86rem; color: var(--ink-soft); }
.tp-reviews__score {
	font-family: var(--font-display);
	font-size: 1.25rem;
	font-weight: 600;
	color: var(--ink);
}

/* Stelle Trustpilot: quadrati verdi con stella bianca */
.tp-stars { display: inline-flex; gap: 3px; }
.tp-star {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 22px;
	height: 22px;
	border-radius: 3px;
	background: #00b67a;
}
.tp-star--off { background: #cfd2d6; }
.tp-stars--lg .tp-star { width: 28px; height: 28px; }
.tp-stars--lg .tp-star svg { width: 16px; height: 16px; }
.tp-star--brand { width: 24px; height: 24px; }

.tp-reviews__track {
	display: flex;
	gap: 18px;
	overflow-x: auto;
	scroll-snap-type: x mandatory;
	-webkit-overflow-scrolling: touch;
	scrollbar-width: none;
	padding-bottom: 6px;
	cursor: grab;
}
.tp-reviews__track::-webkit-scrollbar { display: none; }
.tp-reviews__track.is-dragging { cursor: grabbing; }
.tp-reviews__track.is-dragging .tp-card { pointer-events: none; }
.tp-card {
	display: flex;
	flex-direction: column;
	flex: 0 0 auto;
	width: clamp(260px, 30%, 320px);
	scroll-snap-align: start;
	background: var(--white);
	border: 1px solid var(--line);
	border-radius: 12px;
	padding: 20px;
	box-shadow: 0 10px 30px -24px rgba(14, 15, 17, 0.4);
}
.tp-card__top {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 10px;
	margin-bottom: 14px;
}
.tp-card__verified {
	display: inline-flex;
	align-items: center;
	gap: 4px;
	font-size: 0.72rem;
	font-weight: 600;
	color: #00875a;
}
.tp-card__title {
	margin: 0 0 8px;
	font-family: var(--font-display);
	font-size: 1.05rem;
	font-weight: 600;
	color: var(--ink);
}
.tp-card__text {
	margin: 0 0 18px;
	font-size: 0.9rem;
	line-height: 1.6;
	color: var(--ink-soft);
	flex: 1 1 auto;
}
.tp-card__foot {
	display: flex;
	align-items: center;
	gap: 8px;
	font-size: 0.82rem;
}
.tp-card__avatar {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 28px;
	height: 28px;
	border-radius: 50%;
	background: var(--ink);
	color: var(--cream);
	font-size: 0.78rem;
	font-weight: 600;
	flex: 0 0 auto;
}
.tp-card__name { font-weight: 600; color: var(--ink); }
.tp-card__date { color: var(--ink-soft); margin-left: auto; }

@media (max-width: 560px) {
	.tp-card { width: 80vw; max-width: 340px; }
}

/* =========================================================================
   CARRELLO — layout pulito a due colonne
   ========================================================================= */
/* Carrello e checkout: contenuto più largo del normale container stretto */
.woocommerce-cart .entry-content.container--narrow,
.woocommerce-checkout .entry-content.container--narrow { max-width: 1120px; }

.woocommerce-cart .page-head { text-align: center; }
.woocommerce-cart .woocommerce { max-width: 1080px; margin-inline: auto; }

/* Tabella articoli */
.woocommerce-cart table.cart,
.woocommerce-cart table.shop_table {
	border: 0;
	border-collapse: collapse;
	background: transparent;
}
.woocommerce-cart table.cart thead th {
	border: 0;
	border-bottom: 1px solid var(--line);
	padding: 0 0 12px;
	font-size: 0.7rem;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: var(--ink-soft);
	text-align: left;
}
.woocommerce-cart table.cart tbody td {
	border: 0;
	border-bottom: 1px solid var(--line);
	padding: 18px 10px 18px 0;
	vertical-align: middle;
	background: transparent;
}
.woocommerce-cart table.cart td.product-thumbnail img {
	width: 84px;
	height: 104px;
	object-fit: cover;
	border-radius: 10px;
}
.woocommerce-cart table.cart td.product-name a {
	font-family: var(--font-display);
	font-size: 1.05rem;
	color: var(--ink);
	text-decoration: none;
}
.woocommerce-cart table.cart td.product-name a:hover { color: var(--terracotta); }
.woocommerce-cart table.cart .product-price,
.woocommerce-cart table.cart .product-subtotal { color: var(--ink); }
.woocommerce-cart table.cart td.product-remove a.remove {
	width: 26px;
	height: 26px;
	line-height: 24px;
	font-size: 20px;
	color: var(--ink-soft) !important;
	border-radius: 50%;
}
.woocommerce-cart table.cart td.product-remove a.remove:hover {
	background: none !important;
	color: var(--terracotta) !important;
}

/* Quantità */
.woocommerce-cart .quantity input.qty {
	width: 64px;
	padding: 10px 8px;
	border: 1px solid var(--line-strong);
	border-radius: 8px;
	text-align: center;
	background: var(--white);
}

/* Riga azioni: coupon + aggiorna */
.woocommerce-cart table.cart td.actions {
	border-bottom: 0;
	padding: 22px 0 0;
}
.woocommerce-cart table.cart td.actions .coupon {
	display: flex;
	gap: 10px;
	align-items: center;
}
.woocommerce-cart table.cart td.actions .coupon label { display: none; }
.woocommerce-cart table.cart td.actions .coupon input#coupon_code {
	width: auto;
	min-width: 180px;
	padding: 12px 14px;
	border: 1px solid var(--line-strong);
	border-radius: 999px;
	background: var(--white);
}
.woocommerce-cart table.cart td.actions .button {
	border-radius: 999px;
	padding: 12px 22px;
	background: transparent;
	color: var(--ink);
	border: 1px solid var(--line-strong);
	font-size: 0.76rem;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	white-space: nowrap;
}
.woocommerce-cart table.cart td.actions .button:hover { border-color: var(--ink); background: transparent; }
.woocommerce-cart table.cart td.actions button[name="update_cart"] { float: right; }

/* Totali */
.woocommerce-cart .cart-collaterals { width: 100%; }
.woocommerce-cart .cart-collaterals .cart_totals {
	width: 100%;
	float: none;
	background: #fcf9f6;
	padding: 26px;
	border-radius: 16px;
}
.woocommerce-cart .cart_totals h2 {
	font-family: var(--font-display);
	font-size: 1.3rem;
	font-weight: 500;
	margin: 0 0 16px;
	padding-bottom: 12px;
	border-bottom: 1px solid var(--line);
}
.woocommerce-cart .cart_totals table { border: 0; margin: 0; }
.woocommerce-cart .cart_totals table th,
.woocommerce-cart .cart_totals table td {
	border: 0;
	border-bottom: 1px solid var(--line);
	padding: 12px 0;
	font-size: 0.94rem;
}
.woocommerce-cart .cart_totals tr.order-total th,
.woocommerce-cart .cart_totals tr.order-total td {
	font-family: var(--font-display);
	font-size: 1.2rem;
	border-bottom: 0;
	padding-top: 16px;
}
.woocommerce-cart .cart_totals .wc-proceed-to-checkout { padding: 16px 0 0; }
.woocommerce-cart .cart_totals .wc-proceed-to-checkout .checkout-button {
	display: block;
	width: 100%;
	text-align: center;
	padding: 16px 22px;
	border-radius: 999px;
	background: var(--ink);
	color: var(--cream);
	font-size: 0.8rem;
	letter-spacing: 0.16em;
	text-transform: uppercase;
	transition: background 0.3s var(--ease), transform 0.2s var(--ease);
}
.woocommerce-cart .cart_totals .wc-proceed-to-checkout .checkout-button:hover {
	background: var(--terracotta);
	transform: translateY(-1px);
}

/* Niente cross-sell nella pagina carrello: look più pulito */
.woocommerce-cart .cross-sells { display: none; }

/* Due colonne (desktop) */
@media (min-width: 861px) {
	.woocommerce-cart .woocommerce {
		display: grid;
		grid-template-columns: 1fr 360px;
		gap: 48px;
		align-items: start;
	}
	.woocommerce-cart .woocommerce-notices-wrapper { grid-column: 1 / -1; }
	.woocommerce-cart .woocommerce-cart-form { grid-column: 1; min-width: 0; }
	.woocommerce-cart .cart-collaterals {
		grid-column: 2;
		position: sticky;
		top: calc(var(--header-h) + 20px);
	}
}

/* =========================================================================
   CHECKOUT — stile pulito tipo Shopify
   ========================================================================= */
.woocommerce-checkout .page-head { text-align: center; }
/* Header ridotto in checkout/carrello: meno spazio sopra il titolo */
body.woocommerce-checkout .page-head,
body.woocommerce-cart .page-head {
	padding-block: clamp(28px, 5vw, 56px) clamp(18px, 3vw, 32px);
}

.woocommerce-checkout .woocommerce { max-width: 1080px; margin-inline: auto; }

/* Banda verde "area protetta" in cima al checkout */
.checkout-secure-bar {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 9px;
	padding: 11px 18px;
	background: #1f7a4d;
	color: #ffffff;
	font-size: 0.82rem;
	letter-spacing: 0.04em;
	text-align: center;
}
.checkout-secure-bar svg { flex: 0 0 auto; }

/* Barre login / coupon */
.woocommerce-checkout .woocommerce-form-login-toggle,
.woocommerce-checkout .woocommerce-form-coupon-toggle {
	margin-bottom: 22px;
}
.woocommerce-checkout .woocommerce-form-login-toggle .woocommerce-info,
.woocommerce-checkout .woocommerce-form-coupon-toggle .woocommerce-info {
	background: #f7f1ec;
	border: 0;
	border-top: 0;
	border-radius: 12px;
	padding: 15px 18px;
	margin: 0;
	font-size: 0.92rem;
	line-height: 1.5;
	color: var(--ink);
	list-style: none;
}
/* Niente icona "tofu" del font WooCommerce nelle note del checkout */
.woocommerce-checkout .woocommerce-form-login-toggle .woocommerce-info::before,
.woocommerce-checkout .woocommerce-form-coupon-toggle .woocommerce-info::before {
	display: none;
}
.woocommerce-checkout .woocommerce-form-coupon-toggle .woocommerce-info a,
.woocommerce-checkout .woocommerce-form-login-toggle .woocommerce-info a {
	color: var(--terracotta);
	font-size: inherit;
	font-weight: 500;
	text-decoration: underline;
	text-underline-offset: 2px;
}
.woocommerce-checkout .woocommerce-form-coupon,
.woocommerce-checkout .woocommerce-form-login {
	border: 1px solid var(--line);
	border-radius: 12px;
	padding: 22px;
	margin-bottom: 24px;
}

/* Titoli di sezione */
.woocommerce-checkout .woocommerce-billing-fields > h3,
.woocommerce-checkout .woocommerce-shipping-fields > h3,
.woocommerce-checkout .woocommerce-additional-fields h3,
.woocommerce-checkout #order_review_heading {
	font-family: var(--font-display);
	font-size: 1.3rem;
	font-weight: 500;
	margin: 0 0 18px;
	padding-bottom: 12px;
	border-bottom: 1px solid var(--line);
}
.woocommerce-checkout .woocommerce-additional-fields h3 { margin-top: 8px; }

/* Campi del form */
.woocommerce-checkout .form-row {
	margin: 0 0 16px;
	padding: 0;
}
.woocommerce-checkout .form-row label {
	display: block;
	margin-bottom: 6px;
	font-size: 0.8rem;
	letter-spacing: 0.02em;
	color: var(--ink-soft);
}
.woocommerce-checkout .form-row .required { color: var(--terracotta); border: 0; text-decoration: none; }
.woocommerce-checkout #customer_details .col2-set,
.woocommerce-checkout #customer_details .col-1,
.woocommerce-checkout #customer_details .col-2 { width: 100%; float: none; }

.woocommerce-checkout form .form-row input.input-text,
.woocommerce-checkout form .form-row textarea,
.woocommerce-checkout form .form-row select,
.woocommerce-checkout .select2-container .select2-selection {
	width: 100%;
	border: 1px solid var(--line-strong);
	border-radius: 10px;
	padding: 13px 14px;
	font-size: 0.95rem;
	background: var(--white);
	color: var(--ink);
	transition: border-color 0.25s var(--ease), box-shadow 0.25s var(--ease);
}
.woocommerce-checkout form .form-row input.input-text:focus,
.woocommerce-checkout form .form-row textarea:focus,
.woocommerce-checkout form .form-row select:focus {
	outline: none;
	border-color: var(--terracotta);
	box-shadow: 0 0 0 3px rgba(var(--accent-rgb), 0.14);
}
/* Select2 (nazione/provincia) coerente con gli altri campi */
.woocommerce-checkout .select2-container--default .select2-selection--single {
	height: 48px;
	display: flex;
	align-items: center;
	border: 1px solid var(--line-strong);
	border-radius: 10px;
}
.woocommerce-checkout .select2-container--default .select2-selection--single .select2-selection__arrow { height: 46px; }

/* Pannello riepilogo (colonna destra) */
.relais-co__aside {
	background: #f7f1ec;
	padding: 26px;
	border-radius: 16px;
}
.relais-co__aside #order_review_heading {
	margin-top: 0;
}
.woocommerce-checkout #order_review {
	background: transparent;
	padding: 0;
}

/* Blocco pagamento (colonna sinistra) */
.relais-co__payment { margin-top: 30px; }
.relais-co__title {
	font-family: var(--font-display);
	font-size: 1.3rem;
	font-weight: 500;
	margin: 0 0 18px;
	padding-bottom: 12px;
	border-bottom: 1px solid var(--line);
}
.woocommerce-checkout #order_review table.shop_table {
	border: 0;
	background: transparent;
	border-radius: 0;
	margin: 0 0 8px;
}
.woocommerce-checkout #order_review table.shop_table th,
.woocommerce-checkout #order_review table.shop_table td {
	border: 0;
	border-bottom: 1px solid var(--line);
	padding: 12px 0;
	font-size: 0.94rem;
}
.woocommerce-checkout #order_review table.shop_table thead th { font-size: 0.7rem; letter-spacing: 0.14em; text-transform: uppercase; color: var(--ink-soft); }
.woocommerce-checkout #order_review .cart_item .product-name { color: var(--ink); }
.woocommerce-checkout #order_review .product-quantity { color: var(--ink-soft); }
.woocommerce-checkout #order_review tfoot th,
.woocommerce-checkout #order_review tfoot td { font-size: 0.98rem; }
.woocommerce-checkout #order_review tfoot tr.order-total th,
.woocommerce-checkout #order_review tfoot tr.order-total td {
	font-family: var(--font-display);
	font-size: 1.2rem;
	border-bottom: 0;
	padding-top: 16px;
}

/* Pagamento */
.woocommerce-checkout #payment {
	background: transparent;
	border-radius: 0;
	margin-top: 18px;
}
.woocommerce-checkout #payment ul.payment_methods {
	border: 0;
	padding: 0;
	margin: 0 0 16px;
	background: transparent;
}
.woocommerce-checkout #payment ul.payment_methods li {
	border: 1px solid var(--line-strong);
	border-radius: 12px;
	padding: 14px 16px;
	margin-bottom: 10px;
	list-style: none;
}
.woocommerce-checkout #payment ul.payment_methods li input { margin-right: 8px; }
.woocommerce-checkout #payment div.payment_box {
	background: transparent;
	margin: 10px 0 0;
	padding: 0;
	font-size: 0.88rem;
	color: var(--ink-soft);
}
.woocommerce-checkout #payment div.payment_box::before { display: none; }
.woocommerce-checkout #payment .woocommerce-privacy-policy-text { font-size: 0.82rem; color: var(--ink-soft); }

.woocommerce-checkout #payment .place-order { padding: 0; }
.woocommerce-checkout #place_order {
	width: 100%;
	margin-top: 6px;
	padding: 16px 22px;
	border-radius: 999px;
	background: var(--ink);
	color: var(--cream);
	font-size: 0.8rem;
	letter-spacing: 0.16em;
	text-transform: uppercase;
	border: 0;
	transition: background 0.3s var(--ease), transform 0.2s var(--ease);
}
.woocommerce-checkout #place_order:hover { background: var(--terracotta); transform: translateY(-1px); }

/* Checkout minimale: niente menu né footer, solo logo centrato */
body.woocommerce-checkout .main-navigation,
body.woocommerce-checkout .nav-toggle,
body.woocommerce-checkout .nav-backdrop,
body.woocommerce-checkout .site-header__actions { display: none !important; }
body.woocommerce-checkout .site-header { position: relative; }
body.woocommerce-checkout .site-header__inner {
	grid-template-columns: 1fr;
	justify-items: center;
}
body.woocommerce-checkout .site-branding { justify-self: center; }
body.woocommerce-checkout #colophon { display: none !important; }

/* =========================================================================
   THANK YOU PAGE
   ========================================================================= */
/* Sulla conferma ordine niente titolo "Checkout": il template ha il suo */
body.woocommerce-order-received .page-head { display: none; }

.relais-confetti-canvas {
	position: fixed;
	inset: 0;
	pointer-events: none;
	z-index: 1300;
}

.relais-ty {
	max-width: 640px;
	margin: 0 auto;
	padding: clamp(24px, 5vw, 56px) 0 clamp(40px, 7vw, 80px);
}
.relais-ty__hero {
	position: relative;
	text-align: center;
	margin-bottom: clamp(28px, 4vw, 44px);
}
.relais-ty__check {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 76px;
	height: 76px;
	margin-bottom: 22px;
	border-radius: 50%;
	background: #1f7a4d;
	color: #ffffff;
	box-shadow: 0 16px 40px -16px rgba(31, 122, 77, 0.6);
	animation: relais-ty-pop 0.5s var(--ease) both;
}
@keyframes relais-ty-pop {
	0% { transform: scale(0); opacity: 0; }
	60% { transform: scale(1.12); }
	100% { transform: scale(1); opacity: 1; }
}
.relais-ty__eyebrow {
	margin: 0 0 8px;
	font-size: 0.74rem;
	letter-spacing: 0.26em;
	text-transform: uppercase;
	color: var(--ink-soft);
}
.relais-ty__title {
	margin: 0 0 14px;
	font-family: var(--font-display);
	font-size: clamp(2.2rem, 6vw, 3.4rem);
	line-height: 1.05;
	color: var(--ink);
}
.relais-ty__lead {
	margin: 0 auto;
	max-width: 460px;
	font-size: 1.02rem;
	line-height: 1.6;
	color: var(--ink-soft);
}

/* Riepilogo ordine (numero, data, email, totale, pagamento) */
.relais-ty__overview {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 1px;
	margin: 0 0 clamp(28px, 4vw, 44px);
	padding: 0;
	list-style: none;
	background: var(--line);
	border: 1px solid var(--line);
	border-radius: 14px;
	overflow: hidden;
}
.relais-ty__overview li {
	display: flex;
	flex-direction: column;
	gap: 4px;
	margin: 0;
	padding: 18px 20px;
	background: #fcf9f6;
	border: 0;
}
.relais-ty__overview li span {
	font-size: 0.72rem;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color: var(--ink-soft);
}
.relais-ty__overview li strong {
	font-family: var(--font-display);
	font-size: 1.05rem;
	font-weight: 500;
	color: var(--ink);
}

/* Tabella dettagli ordine + indirizzi (output standard di WooCommerce) */
.relais-ty .woocommerce-order-details,
.relais-ty .woocommerce-customer-details { margin-top: clamp(28px, 4vw, 40px); }
.relais-ty .woocommerce-order-details__title,
.relais-ty .woocommerce-column__title {
	font-family: var(--font-display);
	font-size: 1.2rem;
	font-weight: 500;
	margin: 0 0 14px;
	padding-bottom: 10px;
	border-bottom: 1px solid var(--line);
}
.relais-ty table.woocommerce-table {
	border: 0;
	width: 100%;
}
.relais-ty table.woocommerce-table th,
.relais-ty table.woocommerce-table td {
	border: 0;
	border-bottom: 1px solid var(--line);
	padding: 12px 0;
	font-size: 0.94rem;
}
.relais-ty .woocommerce-customer-details address {
	border: 1px solid var(--line);
	border-radius: 12px;
	padding: 16px 18px;
	font-style: normal;
	line-height: 1.6;
}

.relais-ty__actions {
	margin-top: clamp(30px, 5vw, 48px);
	text-align: center;
}
.relais-ty__actions .btn { min-width: 220px; }

@media (max-width: 480px) {
	.relais-ty__overview { grid-template-columns: 1fr; }
}

/* =========================================================================
   MY ACCOUNT
   ========================================================================= */
.woocommerce-account .entry-content.container--narrow { max-width: 1080px; }

/* Wrapper: sidebar + contenuto (solo quando l'utente è loggato) */
.woocommerce-account .woocommerce:has(.woocommerce-MyAccount-navigation) {
	display: grid;
	grid-template-columns: 256px 1fr;
	gap: clamp(26px, 4vw, 56px);
	align-items: start;
}
.woocommerce-account .woocommerce::before,
.woocommerce-account .woocommerce::after { content: none; display: none; }
/* Avvisi: occupano tutta la riga, non sfasano le due colonne */
.woocommerce-account .woocommerce:has(.woocommerce-MyAccount-navigation) > .woocommerce-notices-wrapper,
.woocommerce-account .woocommerce:has(.woocommerce-MyAccount-navigation) > .woocommerce-message,
.woocommerce-account .woocommerce:has(.woocommerce-MyAccount-navigation) > .woocommerce-info,
.woocommerce-account .woocommerce:has(.woocommerce-MyAccount-navigation) > .woocommerce-error { grid-column: 1 / -1; }

/* Annulla i float/width di default di WooCommerce che rompono la griglia */
.woocommerce-account .woocommerce-MyAccount-navigation,
.woocommerce-account .woocommerce-MyAccount-content {
	float: none !important;
	width: auto !important;
	margin: 0 !important;
}

/* ----- Navigazione laterale ----- */
.woocommerce-account .account-nav { position: sticky; top: calc(var(--header-h) + 18px); padding: 0; border: 0; }
.woocommerce-account .account-nav ul {
	list-style: none;
	margin: 0;
	padding: 6px;
	display: flex;
	flex-direction: column;
	gap: 2px;
	background: var(--cream);
	border: 1px solid var(--line);
	border-radius: 16px;
}
.woocommerce-account .account-nav ul li { margin: 0; padding: 0; border: 0; }
.woocommerce-account .account-nav ul li a {
	display: flex;
	align-items: center;
	gap: 12px;
	padding: 12px 14px;
	border: 0;
	border-radius: 11px;
	font-size: 0.96rem;
	font-weight: 400;
	color: var(--ink-soft);
	text-decoration: none;
	transition: background var(--transition), color var(--transition);
}
.woocommerce-account .account-nav .account-nav__icon { flex: 0 0 auto; opacity: 0.85; }
.woocommerce-account .account-nav ul li a:hover { background: var(--sand); color: var(--ink); }
.woocommerce-account .account-nav ul li.is-active a { background: var(--ink); color: var(--cream); font-weight: 400; }
.woocommerce-account .account-nav ul li.woocommerce-MyAccount-navigation-link--customer-logout a { color: var(--sale); }
.woocommerce-account .account-nav ul li.woocommerce-MyAccount-navigation-link--customer-logout a:hover { background: rgba(216, 54, 42, 0.08); color: var(--sale); }

/* ----- Contenuto ----- */
.woocommerce-MyAccount-content { min-width: 0; }
.woocommerce-MyAccount-content > p:first-child { margin-top: 0; }

/* Dashboard */
.account-dashboard__welcome {
	padding: clamp(24px, 3vw, 34px);
	margin-bottom: 26px;
	background: linear-gradient(150deg, var(--sand) 0%, #fff 100%);
	border: 1px solid var(--line);
	border-radius: 18px;
}
.account-dashboard__eyebrow {
	margin: 0 0 8px;
	font-size: 0.72rem;
	letter-spacing: 0.24em;
	text-transform: uppercase;
	color: var(--ink-soft);
}
.account-dashboard__hello {
	margin: 0 0 10px;
	font-family: var(--font-display);
	font-size: clamp(1.8rem, 4vw, 2.6rem);
	line-height: 1.05;
	color: var(--ink);
}
.account-dashboard__sub { margin: 0; max-width: 52ch; color: var(--ink-soft); line-height: 1.6; }

.account-dashboard__grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 14px;
	margin-bottom: 22px;
}
.account-card {
	display: flex;
	align-items: center;
	gap: 14px;
	padding: 18px;
	background: var(--cream);
	border: 1px solid var(--line);
	border-radius: 16px;
	text-decoration: none;
	color: var(--ink);
	transition: border-color var(--transition), transform 0.3s var(--ease), box-shadow var(--transition);
}
.account-card:hover {
	border-color: var(--line-strong);
	transform: translateY(-3px);
	box-shadow: 0 18px 40px -28px rgba(14, 15, 17, 0.45);
}
.account-card__icon {
	flex: 0 0 auto;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 46px;
	height: 46px;
	border-radius: 12px;
	background: var(--sand);
	color: var(--ink);
}
.account-card:hover .account-card__icon { background: var(--ink); color: var(--cream); }
.account-card__body { display: flex; flex-direction: column; gap: 2px; flex: 1 1 auto; }
.account-card__label { font-family: var(--font-display); font-size: 1.06rem; }
.account-card__desc { font-size: 0.84rem; color: var(--ink-soft); }
.account-card__arrow { flex: 0 0 auto; color: var(--ink-soft); transition: transform 0.3s var(--ease); }
.account-card:hover .account-card__arrow { transform: translateX(4px); color: var(--ink); }
.account-dashboard__logout { font-size: 0.92rem; color: var(--ink-soft); }
.account-dashboard__logout a { color: var(--ink); text-decoration: underline; text-underline-offset: 3px; }

/* Ordini, indirizzi, ecc. */
.woocommerce-MyAccount-content .woocommerce-Message,
.woocommerce-MyAccount-content .woocommerce-info {
	border-radius: var(--radius-lg);
	border-left: 3px solid var(--terracotta);
}
.woocommerce-account table.shop_table,
.woocommerce-account .woocommerce-orders-table {
	border-radius: var(--radius-lg);
	border-color: var(--line);
}
.woocommerce-account .woocommerce-orders-table th { font-family: var(--font-display); font-weight: 500; }
.woocommerce-account .woocommerce-MyAccount-content h2,
.woocommerce-account .woocommerce-MyAccount-content h3 { font-family: var(--font-display); font-weight: 500; }
.woocommerce-account .addresses .woocommerce-Address {
	padding: 22px 24px;
	border: 1px solid var(--line);
	border-radius: 16px;
	margin-bottom: 0;
}
.woocommerce-account .woocommerce-Addresses { gap: 18px; }
.woocommerce-account .woocommerce-Address address { font-style: normal; line-height: 1.7; color: var(--ink-soft); }
.woocommerce-account .woocommerce-MyAccount-content form .form-row label { font-size: 0.86rem; color: var(--ink); }

/* ----- Login / registrazione ----- */
.relais-auth {
	display: grid;
	gap: clamp(22px, 3vw, 36px);
	max-width: 560px;
	margin: clamp(8px, 2vw, 20px) auto 0;
}
.relais-auth--split { max-width: 920px; grid-template-columns: 1fr 1fr; }
.relais-auth__card {
	padding: clamp(26px, 3vw, 40px);
	background: var(--cream);
	border: 1px solid var(--line);
	border-radius: 20px;
}
.relais-auth__card--register { background: var(--sand); border-color: transparent; }
.relais-auth__head { margin-bottom: 22px; }
.relais-auth__eyebrow {
	margin: 0 0 6px;
	font-size: 0.72rem;
	letter-spacing: 0.22em;
	text-transform: uppercase;
	color: var(--ink-soft);
}
.relais-auth__title { margin: 0 0 8px; font-family: var(--font-display); font-size: clamp(1.6rem, 3vw, 2.1rem); line-height: 1.1; }
.relais-auth__lead { margin: 0; font-size: 0.95rem; color: var(--ink-soft); line-height: 1.55; }
.relais-auth .woocommerce-form-row { margin-bottom: 16px; }
.relais-auth label { display: block; margin-bottom: 6px; font-size: 0.86rem; color: var(--ink); }
.woocommerce-account .relais-auth input.input-text,
.woocommerce-account .relais-auth input[type="email"],
.woocommerce-account .relais-auth input[type="password"],
.woocommerce-account .relais-auth input[type="text"] {
	width: 100%;
	border: 1px solid var(--line-strong);
	border-radius: 10px;
	padding: 13px 15px;
	background: #fff;
	font-size: 1rem;
}
.woocommerce-account .relais-auth input.input-text:focus { outline: none; border-color: var(--ink); box-shadow: 0 0 0 3px rgba(var(--accent-rgb), 0.12); }
.relais-auth__row {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 12px;
	flex-wrap: wrap;
	margin: 4px 0 18px;
}
.relais-auth__row label { display: inline-flex; align-items: center; gap: 8px; margin: 0; color: var(--ink-soft); }
.relais-auth__row input[type="checkbox"] { width: auto; accent-color: var(--ink); }
.relais-auth__lost { font-size: 0.88rem; color: var(--ink-soft); text-decoration: underline; text-underline-offset: 3px; }
.relais-auth__lost:hover { color: var(--ink); }
.relais-auth__hint { font-size: 0.88rem; color: var(--ink-soft); line-height: 1.5; }
.relais-auth .button { width: 100%; margin-top: 4px; }

@media (max-width: 760px) {
	.woocommerce-account .woocommerce:has(.woocommerce-MyAccount-navigation) { grid-template-columns: 1fr; }
	.woocommerce-account .account-nav { position: static; }
	.woocommerce-account .account-nav ul {
		flex-direction: row;
		flex-wrap: nowrap;
		overflow-x: auto;
		gap: 8px;
		padding: 8px;
		-webkit-overflow-scrolling: touch;
		scrollbar-width: none;
	}
	.woocommerce-account .account-nav ul::-webkit-scrollbar { display: none; }
	.woocommerce-account .account-nav ul li a { white-space: nowrap; padding: 10px 14px; }
	.account-dashboard__grid { grid-template-columns: 1fr; }
	.relais-auth--split { grid-template-columns: 1fr; }
}

/* Layout a due colonne tipo Shopify (desktop) */
@media (min-width: 861px) {
	.relais-co {
		display: grid;
		grid-template-columns: 1.05fr 0.92fr;
		gap: 56px;
		align-items: start;
	}
	.relais-co__main { grid-column: 1; min-width: 0; }
	.relais-co__aside {
		grid-column: 2;
		position: sticky;
		top: calc(var(--header-h) + 20px);
	}
}
