/* ────────────────────────────────────────────────────────────
   SkinKo — main.css v3
   Pattern replicati da VeraLab.it (bianco dominante, whitespace,
   typography sobria, lavender solo su accenti/CTA/link).
   ──────────────────────────────────────────────────────────── */

/* ── Reset ────────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; text-size-adjust: 100%; scroll-behavior: smooth; }
body { margin: 0; padding: 0; min-height: 100vh; }
img, picture, video, canvas, svg { display: block; max-width: 100%; height: auto; }
button, input, select, textarea { font: inherit; color: inherit; }
a { color: inherit; text-decoration: none; }
ul, ol { margin: 0; padding: 0; list-style: none; }
h1, h2, h3, h4, h5, h6, p { margin: 0; }
:focus-visible { outline: 2px solid var(--sk-accent); outline-offset: 3px; border-radius: 2px; }

/* ── Design tokens v3 — bianco dominante ──────────────────── */
:root {
	/* Palette Lune Chiara rivalutata */
	--sk-bg:        #FFFFFF;                 /* background bianco base */
	--sk-surface:   #F4F2FC;                 /* lavender chiaro Lune — protagonista sezioni alternate */
	--sk-surface-2: #E6E0F8;                 /* lavender più saturo per card / CTA ghost */
	--sk-surface-3: #D8D0F0;                 /* lavender medio per decorazioni */
	--sk-border:    #E0D8F0;
	--sk-border-2:  #C8BFEA;

	--sk-primary:   #9B8DC8;                 /* lavender brand */
	--sk-accent:    #6B5A9E;                 /* lavender scuro CTA/link/accent */
	--sk-accent-2:  #4A3D6E;
	--sk-secondary: #C8BFEA;

	--sk-text:      #1A1530;                 /* text Lune Chiara (non nero puro) */
	--sk-text-2:    #2B2540;
	--sk-muted:     #6F6289;
	--sk-white:     #FFFFFF;
	--sk-cream:     #FAF8F3;

	/* Ombre LAVENDER-TINTED — tornano protagoniste */
	--sk-glow-sm: 0 4px 14px -3px rgba(107, 90, 158, 0.18);
	--sk-glow-md: 0 12px 30px -6px rgba(107, 90, 158, 0.22);
	--sk-glow-lg: 0 24px 56px -10px rgba(107, 90, 158, 0.28);
	--sk-glow-xl: 0 36px 80px -16px rgba(107, 90, 158, 0.35);

	/* Typography v7 — Sora (geometric rounded sans, no graziati) + Manrope.
	   La var --sk-font-serif resta come nome legacy ma punta a Sora (display rounded). */
	--sk-font-serif: 'Sora', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
	--sk-font-sans:  'Manrope', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;

	--sk-size-xs:     0.78rem;
	--sk-size-sm:     0.88rem;
	--sk-size-body:   1rem;
	--sk-size-lead:   clamp(1.05rem, 1rem + 0.25vw, 1.2rem);
	--sk-size-h4:     clamp(1.1rem, 1rem + 0.35vw, 1.35rem);
	--sk-size-h3:     clamp(1.375rem, 1.2rem + 0.6vw, 1.75rem);
	--sk-size-h2:     clamp(1.75rem, 1.5rem + 1vw, 2.5rem);
	--sk-size-h1:     clamp(2.25rem, 1.8rem + 2vw, 3.5rem);
	--sk-size-display:clamp(2.5rem, 2rem + 2.5vw, 4.5rem);

	/* Spacing — 8px base, scale più ampia per whitespace generoso */
	--sk-s-1: 0.5rem;
	--sk-s-2: 1rem;
	--sk-s-3: 1.5rem;
	--sk-s-4: 2rem;
	--sk-s-5: 3rem;
	--sk-s-6: 4rem;
	--sk-s-7: 6rem;
	--sk-s-8: 8rem;

	/* Section padding — MOLTO più generoso (VeraLab style) */
	--sk-section-y: clamp(4rem, 3rem + 4vw, 7.5rem);

	/* Radius minimal (VeraLab usa 2-4px) */
	--sk-r-xs: 2px;
	--sk-r-sm: 6px;
	--sk-r-md: 10px;
	--sk-r-lg: 16px;
	--sk-r-full: 9999px;

	/* Shadow — lavender-tinted, visibili */
	--sk-sh-xs: 0 1px 2px rgba(107, 90, 158, 0.08);
	--sk-sh-sm: 0 4px 12px -2px rgba(107, 90, 158, 0.12);
	--sk-sh-md: 0 12px 28px -6px rgba(107, 90, 158, 0.18);
	--sk-sh-lg: 0 24px 48px -10px rgba(107, 90, 158, 0.25);

	/* Motion */
	--sk-e-out:  cubic-bezier(0.16, 1, 0.3, 1);
	--sk-t-fast: 200ms var(--sk-e-out);
	--sk-t-med:  350ms var(--sk-e-out);

	/* Container */
	--sk-container: 1360px;
	--sk-narrow:    760px;
	--sk-wide:      1600px;
	--sk-gutter:    clamp(1.25rem, 2vw, 2.5rem);
}

/* ── Base typography ──────────────────────────────────────── */
body {
	font-family: var(--sk-font-sans);
	font-size: var(--sk-size-body);
	line-height: 1.6;
	color: var(--sk-text);
	background: var(--sk-bg);
	font-feature-settings: "kern", "liga";
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}

h1, h2, h3, h4, h5, h6 {
	font-family: var(--sk-font-serif);
	font-weight: 400;             /* VeraLab usa pesi leggeri per serif */
	line-height: 1.15;
	letter-spacing: -0.02em;
	color: var(--sk-text);
}
h1 { font-size: var(--sk-size-h1); letter-spacing: -0.025em; }
h2 { font-size: var(--sk-size-h2); letter-spacing: -0.02em; }
h3 { font-size: var(--sk-size-h3); }
h4 { font-size: var(--sk-size-h4); font-weight: 500; }

em { font-style: italic; }
strong { font-weight: 600; }

/* ── Layout ───────────────────────────────────────────────── */
.sk-container {
	width: min(var(--sk-container), 100% - calc(var(--sk-gutter) * 2));
	margin-inline: auto;
}
.sk-container--narrow { max-width: var(--sk-narrow); }
.sk-container--wide   { max-width: var(--sk-wide); }

.sk-skip-link { position: absolute; left: -9999px; }
.sk-skip-link:focus { left: 1rem; top: 1rem; position: fixed; padding: 0.75rem 1.25rem; background: var(--sk-accent); color: var(--sk-white); z-index: 9999; border-radius: var(--sk-r-sm); }
.sr-only { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0; }

/* ── Announcement bar rotante ─────────────────────────────── */
.sk-announce {
	background: var(--sk-text);
	color: var(--sk-white);
	font-size: var(--sk-size-xs);
	letter-spacing: 0.08em;
	font-weight: 500;
}
.sk-announce__inner { padding: 0.6rem 0; text-align: center; }
.sk-announce__rotator { position: relative; height: 1.25em; overflow: hidden; }
.sk-announce__slot {
	position: absolute; inset: 0;
	display: flex; align-items: center; justify-content: center; gap: 0.55rem;
	opacity: 0; transform: translateY(8px);
	animation: sk-announce-rotate 12s infinite;
}
.sk-announce__slot--1 { animation-delay: 0s; }
.sk-announce__slot--2 { animation-delay: 4s; }
.sk-announce__slot--3 { animation-delay: 8s; }
@keyframes sk-announce-rotate {
	0%, 2%    { opacity: 0; transform: translateY(8px); }
	8%, 30%   { opacity: 1; transform: translateY(0); }
	36%, 100% { opacity: 0; transform: translateY(-8px); }
}
@media (prefers-reduced-motion: reduce) {
	.sk-announce__slot { animation: none; opacity: 1; position: static; }
	.sk-announce__slot:not(:first-child) { display: none; }
}

/* ── Header ───────────────────────────────────────────────── */
.sk-header {
	position: sticky; top: 0; z-index: 100;
	background: rgba(255, 255, 255, 0.92);
	backdrop-filter: saturate(1.6) blur(18px);
	-webkit-backdrop-filter: saturate(1.6) blur(18px);
	border-bottom: 1px solid transparent;
	transition: border-color var(--sk-t-fast);
}
.sk-header.is-scrolled { border-bottom-color: var(--sk-border); }
.sk-header__inner {
	display: flex; align-items: center; justify-content: space-between;
	gap: 1.5rem; padding: 1.1rem 0;
}
.sk-header__brand { display: inline-flex; font-family: var(--sk-font-serif); font-size: 1.6rem; font-weight: 400; }
.sk-header__brand-text { display: inline-flex; align-items: baseline; letter-spacing: 0.01em; }
.sk-header__brand-skin { color: var(--sk-text); }
.sk-header__brand-ko   { color: var(--sk-accent); font-style: italic; margin-left: 0.05em; }

.sk-header__nav { flex: 1; justify-content: center; display: flex; }
.sk-menu {
	display: flex; align-items: center;
	gap: clamp(1.25rem, 0.5rem + 1.5vw, 2.25rem);
	font-size: 0.92rem; font-weight: 500;
}
.sk-menu a {
	color: var(--sk-text); position: relative; padding: 0.35rem 0;
	transition: color var(--sk-t-fast);
}
.sk-menu a:hover { color: var(--sk-accent); }
.sk-menu a::after {
	content: ""; position: absolute; inset: auto 0 -2px 0; height: 1px;
	background: var(--sk-accent); transform: scaleX(0); transform-origin: left;
	transition: transform var(--sk-t-med);
}
.sk-menu a:hover::after { transform: scaleX(1); }

.sk-header__actions { display: flex; align-items: center; gap: 0.3rem; }
.sk-header__action {
	display: inline-flex; align-items: center; justify-content: center;
	width: 40px; height: 40px; border-radius: var(--sk-r-full);
	color: var(--sk-text); cursor: pointer;
	transition: background var(--sk-t-fast);
	position: relative;
}
.sk-header__action:hover { background: var(--sk-surface); }
.sk-header__cart-count {
	position: absolute; top: 4px; right: 4px;
	min-width: 17px; height: 17px; padding: 0 4px;
	background: var(--sk-accent); color: var(--sk-white);
	font-size: 0.68rem; font-weight: 600;
	border-radius: var(--sk-r-full);
	display: inline-flex; align-items: center; justify-content: center;
	line-height: 1;
}
.sk-header__toggle {
	display: none; flex-direction: column; gap: 4px;
	padding: 8px; background: none; border: 0; cursor: pointer;
}
.sk-header__toggle span { width: 22px; height: 1.5px; background: var(--sk-text); }
.sk-mobile-nav { display: none; padding: 1rem 1.25rem 2rem; border-top: 1px solid var(--sk-border); }
.sk-mobile-nav .sk-menu { flex-direction: column; align-items: flex-start; gap: 0.9rem; font-size: 1.05rem; }

@media (max-width: 900px) {
	.sk-header__nav { display: none; }
	.sk-header__toggle { display: inline-flex; }
	.sk-mobile-nav[hidden] { display: none !important; }
	.sk-mobile-nav { display: block; }
}

/* ── Main wrapper ─────────────────────────────────────────── */
.sk-main { display: block; }
.sk-main--home    { padding-bottom: 0; }
.sk-main--page    { padding: var(--sk-s-6) 0 var(--sk-s-7); }
.sk-main--archive { padding: var(--sk-s-6) 0 var(--sk-s-7); }
.sk-main--shop    { padding: var(--sk-s-5) 0 var(--sk-s-7); }

/* ── Section head v3 — con divider ornamentale accent ─────── */
.sk-section-head {
	position: relative;
	display: flex; align-items: baseline; justify-content: space-between;
	gap: 1.5rem;
	margin-bottom: clamp(2.25rem, 1.5rem + 1vw, 3.25rem);
	padding-bottom: 1.5rem;
}
.sk-section-head::before {
	/* Dot + line accent sopra la border */
	content: "";
	position: absolute;
	top: -1.25rem; left: 0;
	width: 40px; height: 2px;
	background: var(--sk-accent);
	border-radius: 2px;
}
.sk-section-head::after {
	content: "";
	position: absolute;
	bottom: 0; left: 0; right: 0;
	height: 1px;
	background: linear-gradient(90deg, var(--sk-accent) 0 56px, var(--sk-border-2) 56px 100%);
}
.sk-section-head__title {
	font-family: var(--sk-font-serif);
	font-size: var(--sk-size-h2);
	font-weight: 400;
	letter-spacing: -0.015em;
	color: var(--sk-text);
	margin: 0;
}
.sk-section-head__title em {
	font-style: italic;
	color: var(--sk-accent);
}
.sk-section-head__link {
	display: inline-flex; align-items: center; gap: 0.3rem;
	font-size: 0.85rem; font-weight: 600;
	color: var(--sk-accent);
	letter-spacing: 0.04em;
	padding: 0.5rem 0.95rem;
	border: 1px solid var(--sk-accent);
	border-radius: var(--sk-r-full);
	transition: all var(--sk-t-fast);
	white-space: nowrap;
}
.sk-section-head__link:hover {
	background: var(--sk-accent);
	color: var(--sk-white);
}

@media (max-width: 600px) {
	.sk-section-head { flex-direction: column; align-items: flex-start; gap: 0.75rem; }
}

/* ═══════════════════════════════════════════════════════════
   HERO V3 — full-bleed image + claim minimal
   ═══════════════════════════════════════════════════════════ */
.sk-hero-v3 {
	position: relative;
	height: clamp(520px, 80vh, 780px);
	overflow: hidden;
	margin-bottom: 0;
}
.sk-hero-v3__media {
	position: absolute; inset: 0;
	margin: 0;
}
.sk-hero-v3__image {
	width: 100%; height: 100%;
	object-fit: cover;
	animation: sk-hero-zoom 12s var(--sk-e-out) forwards;
}
@keyframes sk-hero-zoom {
	from { transform: scale(1.05); }
	to { transform: scale(1); }
}
.sk-hero-v3__overlay {
	position: absolute; inset: 0;
	background:
		linear-gradient( 90deg,
			rgba(15, 11, 32, 0.78) 0%,
			rgba(26, 21, 48, 0.6) 45%,
			rgba(26, 21, 48, 0.4) 100%
		),
		radial-gradient(900px 700px at 8% 60%, rgba(74, 61, 110, 0.4), transparent 65%);
}
/* Blob lavender decorativo per depth */
.sk-hero-v3::after {
	content: "";
	position: absolute;
	width: 520px; height: 520px;
	top: -120px; right: -120px;
	background: radial-gradient(circle, rgba(200, 191, 234, 0.55), transparent 70%);
	filter: blur(60px);
	pointer-events: none;
	z-index: 3;
}
.sk-hero-v3__content {
	position: relative;
	z-index: 2;
	height: 100%;
	display: flex;
	align-items: center;
	padding: clamp(2rem, 2vw + 1rem, 4rem) 0;
}
.sk-hero-v3__inner {
	max-width: 620px;
	color: var(--sk-white);
}
.sk-hero-v3__eyebrow {
	display: inline-block;
	font-size: 0.78rem;
	font-weight: 600;
	letter-spacing: 0.16em;
	text-transform: uppercase;
	color: var(--sk-white);
	margin-bottom: 1.5rem;
	padding-bottom: 0.5rem;
	border-bottom: 1px solid rgba(255, 255, 255, 0.35);
}
.sk-hero-v3__title {
	font-family: var(--sk-font-serif);
	font-size: var(--sk-size-display);
	font-weight: 400;
	line-height: 1.02;
	letter-spacing: -0.03em;
	color: var(--sk-white);
	margin: 0 0 1.5rem;
	text-shadow: 0 2px 24px rgba(0, 0, 0, 0.35);
}
.sk-hero-v3__title span { display: block; }
.sk-hero-v3__title-em {
	font-style: italic;
	color: rgba(255, 255, 255, 0.92);
}
.sk-hero-v3__lead {
	font-size: var(--sk-size-lead);
	line-height: 1.55;
	color: rgba(255, 255, 255, 0.88);
	max-width: 480px;
	margin-bottom: 2rem;
}

@media (max-width: 720px) {
	.sk-hero-v3 { height: 70vh; min-height: 440px; }
	.sk-hero-v3__overlay { background: linear-gradient(180deg, rgba(15,11,32,0.1) 0%, rgba(15,11,32,0.6) 100%); }
}

/* ═══════════════════════════════════════════════════════════
   BESTSELLERS V3 — grid 4 col, card che galleggiano
   ═══════════════════════════════════════════════════════════ */
.sk-bestsellers-v3 {
	padding: var(--sk-section-y) 0;
	background: var(--sk-bg);                /* BIANCO per fix mobile (era surface lavender) */
	position: relative;
}
.sk-bestsellers-v3 > .sk-container { position: relative; z-index: 1; }

.sk-pgrid {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: clamp(1rem, 1vw + 0.5rem, 2rem) clamp(0.75rem, 1vw + 0.25rem, 1.5rem);
}
@media (max-width: 980px) { .sk-pgrid { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 720px) { .sk-pgrid { grid-template-columns: repeat(2, 1fr); } }

.sk-pcard {
	position: relative;
	background: var(--sk-white);
	border: 1px solid var(--sk-border);
	border-radius: var(--sk-r-md);
	padding: 0.75rem 0.75rem 1rem;
	transition: transform var(--sk-t-med), box-shadow var(--sk-t-med), border-color var(--sk-t-med);
	/* v5.4 — match height tra card della stessa griglia */
	display: flex;
	flex-direction: column;
	height: 100%;
}
.sk-pcard:hover {
	transform: translateY(-4px);
	box-shadow: var(--sk-glow-md);
	border-color: var(--sk-border-2);
}
.sk-pcard__link {
	display: flex;
	flex-direction: column;
	flex: 1 1 auto;
	color: inherit;
}
.sk-pcard__media {
	position: relative;
	aspect-ratio: 1/1;
	background: linear-gradient(135deg, var(--sk-surface) 0%, var(--sk-surface-2) 100%);
	overflow: hidden;
	margin: 0 0 0.9rem;
	border-radius: var(--sk-r-md);
	flex-shrink: 0;                /* v5.4 — non comprimere foto in flex column */
}
.sk-pcard__img {
	width: 100%; height: 100%;
	object-fit: cover;
	transition: transform 700ms var(--sk-e-out);
}
.sk-pcard:hover .sk-pcard__img { transform: scale(1.05); }

.sk-pcard__badge {
	position: absolute; top: 12px; left: 12px;
	padding: 0.42rem 0.85rem;
	font-size: 0.64rem; font-weight: 700;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	border-radius: 999px;          /* v5.4 — pill full */
	line-height: 1;
	z-index: 2;
	backdrop-filter: blur(6px);
	-webkit-backdrop-filter: blur(6px);
	box-shadow: 0 2px 8px rgba(26, 21, 48, 0.06);
}
/* v5.4 — palette badge K-Beauty soft pastel (premium, gentle, in-palette) */
.sk-pcard__badge--bs {
	background: rgba(26, 21, 48, 0.92);
	color: #F4F2FC;
}
.sk-pcard__badge--new {
	background: #DCEAE0;           /* sage soft */
	color: #2F5C42;                /* contrast 7:1 — accessible */
}
.sk-pcard__badge--sale {
	background: #F7DDE3;            /* peony soft */
	color: #8C2F47;                /* contrast 6:1 */
}
.sk-pcard__badge--pick {
	background: #E8DCEB;           /* lavender soft */
	color: #4A3D6E;                /* contrast 8:1 */
}

.sk-pcard__body {
	display: flex; flex-direction: column; gap: 0.25rem;
	flex: 1 1 auto;                /* v5.4 — body si espande per match-height */
}
.sk-pcard__brand {
	font-size: 0.7rem;
	font-weight: 700;
	letter-spacing: 0.13em;
	color: var(--sk-muted);
	margin: 0;
}
.sk-pcard__title {
	font-family: var(--sk-font-sans);
	font-size: 0.88rem;
	font-weight: 500;
	line-height: 1.4;
	color: var(--sk-text);
	margin: 0.1rem 0;
	letter-spacing: 0;
	/* Clamp 2 righe + min-height per uniformare card con titolo 1 riga */
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
	min-height: calc(0.88rem * 1.4 * 2);  /* v5.4 — match height titolo */
}
.sk-pcard__price {
	font-family: var(--sk-font-sans);
	font-size: 0.98rem;
	font-weight: 600;
	color: var(--sk-text);
	margin: auto 0 0;              /* v5.4 — push price al fondo del body */
	padding-top: 0.5rem;
}
.sk-pcard__price del { color: var(--sk-muted); font-size: 0.85rem; font-weight: 400; margin-right: 0.4rem; }
.sk-pcard__price ins { text-decoration: none; color: #C85A7A; }

.sk-pcard__add {
	display: block;
	margin-top: 0.9rem;
	padding: 0.75rem 1rem;
	background: var(--sk-surface-2);
	color: var(--sk-accent);
	font-family: var(--sk-font-sans);
	font-size: 0.78rem;
	font-weight: 600;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	text-align: center;
	text-decoration: none;
	border: 0;
	border-radius: var(--sk-r-full);
	line-height: 1;
	transition: all var(--sk-t-fast);
}
.sk-pcard__add:hover {
	background: var(--sk-accent);
	color: var(--sk-white);
	box-shadow: var(--sk-glow-sm);
	transform: translateY(-1px);
}

/* ═══════════════════════════════════════════════════════════
   CATEGORY CARDS V3 — 3×2 simmetrico, foto dominante
   ═══════════════════════════════════════════════════════════ */
.sk-cats-v3 {
	padding: var(--sk-section-y) 0;
	background: var(--sk-white);
}

.sk-cats-v3__grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: clamp(1rem, 1.5vw, 2rem);
}
@media (max-width: 900px) { .sk-cats-v3__grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 520px) { .sk-cats-v3__grid { grid-template-columns: 1fr; } }

.sk-cat-card {
	display: flex;
	flex-direction: column;
	gap: 1rem;
	color: inherit;
	transition: transform var(--sk-t-med);
}
.sk-cat-card:hover { transform: translateY(-6px); }
.sk-cat-card__media {
	position: relative;
	aspect-ratio: 4/3;
	background: var(--sk-surface);
	overflow: hidden;
	border-radius: var(--sk-r-lg);
	box-shadow: var(--sk-sh-sm);
	transition: box-shadow var(--sk-t-med);
}
.sk-cat-card:hover .sk-cat-card__media { box-shadow: var(--sk-glow-md); }
.sk-cat-card__media::after {
	content: "";
	position: absolute; inset: 0;
	background: linear-gradient(180deg, rgba(107, 90, 158, 0) 50%, rgba(107, 90, 158, 0.15) 100%);
	pointer-events: none;
}
.sk-cat-card__media img {
	width: 100%; height: 100%;
	object-fit: cover;
	transition: transform 800ms var(--sk-e-out);
}
.sk-cat-card:hover .sk-cat-card__media img { transform: scale(1.04); }
.sk-cat-card__name {
	font-family: var(--sk-font-serif);
	font-size: clamp(1.25rem, 1.1rem + 0.5vw, 1.625rem);
	font-weight: 400;
	line-height: 1.15;
	color: var(--sk-text);
	margin: 0;
}
.sk-cat-card__cta {
	display: inline-flex; align-items: center; gap: 0.35rem;
	font-size: 0.82rem; font-weight: 600;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color: var(--sk-accent);
}
.sk-cat-card__cta svg { transition: transform var(--sk-t-fast); }
.sk-cat-card:hover .sk-cat-card__cta svg { transform: translateX(4px); }

/* ═══════════════════════════════════════════════════════════
   LOOKBOOK — 4 card verticali editoriali (VeraLab style)
   ═══════════════════════════════════════════════════════════ */
.sk-lookbook {
	padding: var(--sk-section-y) 0;
	background: linear-gradient(180deg, var(--sk-bg) 0%, var(--sk-surface) 100%);
	position: relative;
}
.sk-lookbook::before {
	content: "";
	position: absolute;
	width: 500px; height: 500px;
	top: 40%; left: -200px;
	background: radial-gradient(circle, rgba(200, 191, 234, 0.35), transparent 65%);
	filter: blur(80px);
	pointer-events: none;
}
.sk-lookbook > .sk-container { position: relative; z-index: 1; }
.sk-lookbook__grid {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: clamp(1rem, 1.5vw, 1.75rem);
}
@media (max-width: 980px) { .sk-lookbook__grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 520px) { .sk-lookbook__grid { grid-template-columns: 1fr; } }

.sk-look-card {
	display: flex; flex-direction: column; gap: 1rem;
	color: inherit;
	transition: transform var(--sk-t-med);
}
.sk-look-card:hover { transform: translateY(-4px); }
.sk-look-card__media {
	position: relative;
	aspect-ratio: 3/4;
	background: var(--sk-surface);
	overflow: hidden;
	border-radius: var(--sk-r-lg);
	margin: 0;
	box-shadow: var(--sk-sh-sm);
	transition: box-shadow var(--sk-t-med);
}
.sk-look-card:hover .sk-look-card__media { box-shadow: var(--sk-glow-lg); }
.sk-look-card__media img {
	width: 100%; height: 100%;
	object-fit: cover;
	transition: transform 900ms var(--sk-e-out);
}
.sk-look-card:hover .sk-look-card__media img { transform: scale(1.05); }
.sk-look-card__body { display: flex; flex-direction: column; gap: 0.35rem; }
.sk-look-card__eyebrow {
	font-size: 0.72rem;
	font-weight: 700;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: var(--sk-accent);
}
.sk-look-card__title {
	font-family: var(--sk-font-serif);
	font-size: clamp(1.05rem, 1rem + 0.3vw, 1.25rem);
	font-weight: 400;
	line-height: 1.25;
	color: var(--sk-text);
	margin: 0;
}
.sk-look-card__cta {
	display: inline-flex; align-items: center; gap: 0.3rem;
	font-size: 0.82rem; font-weight: 500;
	color: var(--sk-text);
	margin-top: 0.25rem;
	padding-bottom: 1px;
	border-bottom: 1px solid currentColor;
	align-self: flex-start;
}

/* ═══════════════════════════════════════════════════════════
   SERVICES — 6 card con icone SVG
   ═══════════════════════════════════════════════════════════ */
.sk-services {
	padding: var(--sk-section-y) 0;
	background: var(--sk-bg);
}
.sk-services__grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 1.25rem;
}
@media (max-width: 900px) { .sk-services__grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 520px) { .sk-services__grid { grid-template-columns: 1fr; } }

.sk-service-card {
	display: flex; flex-direction: column; gap: 0.75rem;
	padding: clamp(1.75rem, 1rem + 1vw, 2.25rem);
	background: var(--sk-surface);
	color: inherit;
	border-radius: var(--sk-r-lg);
	border: 1px solid transparent;
	transition: all var(--sk-t-med);
	position: relative;
	min-height: 240px;
	overflow: hidden;
}
.sk-service-card::before {
	content: "";
	position: absolute;
	top: -40px; right: -40px;
	width: 120px; height: 120px;
	background: radial-gradient(circle, var(--sk-secondary), transparent 70%);
	opacity: 0.3;
	border-radius: 50%;
	transition: opacity var(--sk-t-med), transform var(--sk-t-med);
}
.sk-service-card:hover {
	background: var(--sk-white);
	border-color: var(--sk-border-2);
	transform: translateY(-4px);
	box-shadow: var(--sk-glow-md);
}
.sk-service-card:hover::before {
	opacity: 0.5;
	transform: scale(1.15);
}
.sk-service-card > * { position: relative; z-index: 1; }
.sk-service-card__icon {
	width: 52px; height: 52px;
	padding: 10px;
	color: var(--sk-accent);
	background: var(--sk-white);
	border-radius: var(--sk-r-full);
	box-shadow: var(--sk-sh-xs);
	margin-bottom: 0.4rem;
}
.sk-service-card__icon svg { width: 100%; height: 100%; }
.sk-service-card__title {
	font-family: var(--sk-font-serif);
	font-size: 1.2rem;
	font-weight: 500;
	line-height: 1.2;
	color: var(--sk-text);
	margin: 0;
}
.sk-service-card__desc {
	font-size: 0.92rem;
	line-height: 1.5;
	color: var(--sk-muted);
	margin: 0;
	flex: 1;
}
.sk-service-card__cta {
	display: inline-flex; align-items: center; gap: 0.3rem;
	font-size: 0.78rem; font-weight: 600;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: var(--sk-accent);
	margin-top: 0.5rem;
}
.sk-service-card__cta svg { transition: transform var(--sk-t-fast); }
.sk-service-card:hover .sk-service-card__cta svg { transform: translateX(3px); }

/* ═══════════════════════════════════════════════════════════
   IL RITUALE — page-il-rituale.php (educativa)
   ═══════════════════════════════════════════════════════════ */
.sk-rit-hero {
	padding: clamp(3rem, 2rem + 2vw, 5.5rem) 0 clamp(2rem, 1.5rem + 1vw, 3rem);
	background: linear-gradient(180deg, var(--sk-surface) 0%, var(--sk-bg) 100%);
	text-align: center;
}
.sk-rit-hero__inner { max-width: 880px; margin: 0 auto; }
.sk-rit-hero__eyebrow {
	display: inline-block;
	font-size: 0.78rem; font-weight: 600;
	letter-spacing: 0.16em; text-transform: uppercase;
	color: var(--sk-accent);
	margin-bottom: 1rem;
	padding: 0.45rem 0.9rem;
	background: var(--sk-white);
	border-radius: var(--sk-r-full);
	box-shadow: var(--sk-sh-xs);
}
.sk-rit-hero__title {
	font-family: var(--sk-font-serif);
	font-size: clamp(2.5rem, 1.8rem + 3.5vw, 5rem);
	font-weight: 400;
	line-height: 1.02;
	letter-spacing: -0.035em;
	color: var(--sk-text);
	margin: 1rem 0 1.5rem;
}
.sk-rit-hero__title em { color: var(--sk-accent); font-style: italic; }
.sk-rit-hero__lead {
	font-size: var(--sk-size-lead);
	color: var(--sk-text-2);
	line-height: 1.6;
	max-width: 720px;
	margin: 0 auto 2.5rem;
}
.sk-rit-hero__nav {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 0.5rem;
	max-width: 880px;
	margin: 0 auto;
}
.sk-rit-hero__nav-item {
	display: flex; flex-direction: column; align-items: center; gap: 0.1rem;
	padding: 0.6rem 0.85rem;
	background: var(--sk-white);
	border: 1px solid var(--sk-border);
	border-radius: var(--sk-r-md);
	color: var(--sk-text-2);
	transition: all var(--sk-t-fast);
	min-width: 80px;
}
.sk-rit-hero__nav-item:hover {
	background: var(--sk-accent);
	color: var(--sk-white);
	border-color: var(--sk-accent);
	transform: translateY(-2px);
}
.sk-rit-hero__nav-item span {
	font-family: var(--sk-font-serif);
	font-style: italic;
	font-size: 1.1rem;
	color: var(--sk-accent);
	transition: color var(--sk-t-fast);
}
.sk-rit-hero__nav-item:hover span { color: var(--sk-white); }
.sk-rit-hero__nav-item small { font-size: 0.66rem; letter-spacing: 0.06em; line-height: 1.1; }

.sk-rit-intro {
	padding: clamp(3rem, 2rem + 2vw, 5rem) 0;
	background: var(--sk-bg);
}
.sk-rit-intro__grid {
	display: grid;
	grid-template-columns: 1fr 2fr;
	gap: clamp(2rem, 1rem + 2vw, 4rem);
	align-items: start;
}
@media (max-width: 880px) { .sk-rit-intro__grid { grid-template-columns: 1fr; } }
.sk-rit-intro__title {
	font-family: var(--sk-font-serif);
	font-size: clamp(1.75rem, 1.4rem + 1.5vw, 2.75rem);
	font-weight: 400;
	letter-spacing: -0.02em;
	color: var(--sk-text);
	margin: 0.75rem 0;
	line-height: 1.05;
}
.sk-rit-intro__title em { color: var(--sk-accent); font-style: italic; }
.sk-rit-intro__text p {
	font-size: 1.05rem;
	line-height: 1.7;
	color: var(--sk-text-2);
	margin-bottom: 1rem;
}

.sk-rit-step {
	padding: clamp(3rem, 2rem + 2vw, 5rem) 0;
	border-top: 1px solid var(--sk-border);
}
.sk-rit-step:nth-child(odd) { background: var(--sk-bg); }
.sk-rit-step:nth-child(even) { background: var(--sk-surface); }

.sk-rit-step__inner {
	display: grid;
	grid-template-columns: 1fr 1.5fr;
	gap: clamp(2rem, 1rem + 2vw, 4rem);
	align-items: start;
}
.sk-rit-step--reverse .sk-rit-step__inner { grid-template-columns: 1.5fr 1fr; }
.sk-rit-step--reverse .sk-rit-step__visual { order: 2; }
@media (max-width: 880px) {
	.sk-rit-step__inner,
	.sk-rit-step--reverse .sk-rit-step__inner { grid-template-columns: 1fr; }
	.sk-rit-step--reverse .sk-rit-step__visual { order: 0; }
}

.sk-rit-step__visual {
	position: relative;
	min-height: 320px;
}
.sk-rit-step__num-bg {
	position: absolute;
	top: -1rem; left: -0.5rem;
	font-family: var(--sk-font-serif);
	font-style: italic;
	font-size: clamp(8rem, 6rem + 6vw, 16rem);
	font-weight: 400;
	line-height: 1;
	color: rgba(107, 90, 158, 0.12);
	letter-spacing: -0.06em;
	font-variant-numeric: oldstyle-nums;
	pointer-events: none;
	z-index: 0;
}
.sk-rit-step__photo {
	position: relative; z-index: 1;
	aspect-ratio: 4/5;
	margin: 0;
	border-radius: var(--sk-r-md);
	overflow: hidden;
	background: var(--sk-white);
	box-shadow: var(--sk-glow-md);
}
.sk-rit-step__img {
	width: 100%; height: 100%;
	object-fit: cover;
}

.sk-rit-step__num-label {
	position: absolute; bottom: 1rem; left: 1rem; z-index: 2;
	display: flex; flex-direction: column; gap: 0.1rem;
	padding: 0.55rem 0.85rem;
	background: var(--sk-white);
	border-radius: var(--sk-r-sm);
	box-shadow: var(--sk-sh-xs);
}
.sk-rit-step__num-label span { font-size: 0.65rem; font-weight: 700; letter-spacing: 0.16em; color: var(--sk-muted); }
.sk-rit-step__num-label strong { font-family: var(--sk-font-serif); font-style: italic; font-size: 1.6rem; color: var(--sk-accent); line-height: 1; }

.sk-rit-step__step-num {
	display: inline-block;
	font-size: 0.78rem;
	font-weight: 700;
	letter-spacing: 0.16em;
	text-transform: uppercase;
	color: var(--sk-accent);
	margin-bottom: 0.75rem;
}

.sk-rit-block { margin-bottom: 2.25rem; }
.sk-rit-block:last-child { margin-bottom: 0; }
.sk-rit-block__h {
	font-family: var(--sk-font-sans);
	font-size: 0.78rem;
	font-weight: 700;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: var(--sk-accent);
	margin: 0 0 0.85rem;
	padding-bottom: 0.5rem;
	border-bottom: 1px solid var(--sk-border-2);
	display: inline-block;
	min-width: 240px;
	max-width: 100%;
}
.sk-rit-block__h--warn { color: #C85A7A; border-color: rgba(200, 90, 122, 0.4); }
.sk-rit-block__caption {
	font-size: 0.85rem;
	font-style: italic;
	color: var(--sk-muted);
	margin: 0 0 1rem;
}
.sk-rit-block__p {
	font-size: 1.02rem;
	line-height: 1.7;
	color: var(--sk-text-2);
	margin: 0;
	max-width: 60ch;
}
.sk-rit-block__list { padding-left: 1.25rem; margin: 0; }
.sk-rit-block__list li {
	font-size: 0.98rem;
	line-height: 1.65;
	color: var(--sk-text-2);
	margin-bottom: 0.55rem;
}
.sk-rit-block__list li::marker { color: var(--sk-accent); }
.sk-rit-block__list--num { padding-left: 1.5rem; counter-reset: rit-num; list-style: none; }
.sk-rit-block__list--num li { counter-increment: rit-num; position: relative; padding-left: 0.4rem; }
.sk-rit-block__list--num li::before {
	content: counter(rit-num) ".";
	position: absolute; left: -1.5rem;
	font-family: var(--sk-font-serif);
	font-style: italic;
	font-weight: 500;
	color: var(--sk-accent);
}
.sk-rit-block__list--err li::marker { color: #C85A7A; }
.sk-rit-block__list--tip li::marker { color: #5A9E7A; content: "✦ "; }

.sk-rit-block--two {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 2rem;
}
@media (max-width: 720px) { .sk-rit-block--two { grid-template-columns: 1fr; } }

.sk-rit-skin-list {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
	gap: 1rem;
	margin: 0;
}
.sk-rit-skin-list__item {
	padding: 1rem 1.1rem;
	background: var(--sk-surface);
	border-left: 3px solid var(--sk-accent);
	border-radius: 0 var(--sk-r-sm) var(--sk-r-sm) 0;
}
.sk-rit-skin-list__item dt {
	font-family: var(--sk-font-serif);
	font-style: italic;
	font-size: 1.1rem;
	color: var(--sk-accent);
	margin-bottom: 0.35rem;
}
.sk-rit-skin-list__item dd {
	font-size: 0.92rem;
	line-height: 1.5;
	color: var(--sk-text-2);
	margin: 0;
}

.sk-rit-block--products {
	margin-top: 2.5rem;
	padding-top: 2rem;
	border-top: 1px solid var(--sk-border);
}
.sk-rit-step__title {
	font-family: var(--sk-font-serif);
	font-size: clamp(2rem, 1.5rem + 2vw, 3.25rem);
	font-weight: 400;
	letter-spacing: -0.025em;
	line-height: 1.05;
	margin: 0 0 1.5rem;
}
.sk-rit-step__title small {
	display: block;
	font-style: italic;
	font-weight: 400;
	font-size: 0.45em;
	color: var(--sk-muted);
	margin-top: 0.2rem;
}
.sk-rit-step__cosa {
	font-family: var(--sk-font-serif);
	font-style: italic;
	font-size: 1.2rem;
	line-height: 1.55;
	color: var(--sk-text);
	margin: 0 0 2rem;
	max-width: 60ch;
}
.sk-rit-step__meta {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 1.5rem;
	margin-bottom: 2rem;
}
@media (max-width: 600px) { .sk-rit-step__meta { grid-template-columns: 1fr; } }
.sk-rit-step__meta-item {}
.sk-rit-step__meta-item dt {
	font-size: 0.72rem;
	font-weight: 700;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: var(--sk-muted);
	margin-bottom: 0.4rem;
}
.sk-rit-step__meta-item dd {
	margin: 0;
	font-size: 0.95rem;
	line-height: 1.5;
	color: var(--sk-text-2);
}

.sk-rit-step__columns {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 1.5rem;
	margin-bottom: 2rem;
}
@media (max-width: 600px) { .sk-rit-step__columns { grid-template-columns: 1fr; } }
.sk-rit-step__col h3 {
	font-family: var(--sk-font-sans);
	font-size: 0.78rem;
	font-weight: 700;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: var(--sk-accent);
	margin: 0 0 0.75rem;
	padding-bottom: 0.5rem;
	border-bottom: 1px solid var(--sk-border-2);
}
.sk-rit-step__col ul { padding-left: 1rem; margin: 0; }
.sk-rit-step__col li {
	font-size: 0.92rem;
	line-height: 1.55;
	color: var(--sk-text-2);
	margin-bottom: 0.5rem;
}
.sk-rit-step__col--err li::marker { color: #C85A7A; }

.sk-rit-step__products h3 {
	font-family: var(--sk-font-sans);
	font-size: 0.78rem; font-weight: 700;
	letter-spacing: 0.14em; text-transform: uppercase;
	color: var(--sk-accent);
	margin: 1.5rem 0 1rem;
	padding-top: 1.5rem;
	border-top: 1px solid var(--sk-border);
}
.sk-rit-step__product-list {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
	gap: 0.75rem;
	list-style: none; padding: 0; margin: 0;
}
.sk-rit-step__product-list a {
	display: flex; gap: 0.75rem; align-items: center;
	padding: 0.6rem;
	background: var(--sk-white);
	border: 1px solid var(--sk-border);
	border-radius: var(--sk-r-sm);
	transition: all var(--sk-t-fast);
}
.sk-rit-step__product-list a:hover {
	border-color: var(--sk-accent);
	box-shadow: var(--sk-sh-sm);
	transform: translateY(-1px);
}
.sk-rit-step__product-list img {
	width: 56px; height: 56px;
	object-fit: cover;
	border-radius: var(--sk-r-xs);
	flex-shrink: 0;
}
.sk-rit-step__product-list div { display: flex; flex-direction: column; gap: 0.1rem; min-width: 0; }
.sk-rit-step__product-list span {
	font-size: 0.66rem; font-weight: 700;
	letter-spacing: 0.13em;
	color: var(--sk-muted);
}
.sk-rit-step__product-list strong {
	font-family: var(--sk-font-sans);
	font-size: 0.85rem; font-weight: 500;
	color: var(--sk-text);
	line-height: 1.3;
	display: -webkit-box;
	-webkit-line-clamp: 1;
	-webkit-box-orient: vertical;
	overflow: hidden;
}
.sk-rit-step__product-list em {
	font-style: normal;
	font-family: var(--sk-font-serif);
	font-size: 0.9rem;
	font-weight: 500;
	color: var(--sk-accent);
	margin-top: 0.1rem;
}

.sk-rit-quiz-cta {
	padding: clamp(4rem, 3rem + 2vw, 6rem) 0;
	background: linear-gradient(135deg, var(--sk-accent) 0%, var(--sk-accent-2) 100%);
	color: var(--sk-white);
	text-align: center;
}
.sk-rit-quiz-cta__inner { max-width: 720px; margin: 0 auto; }
.sk-rit-quiz-cta__title {
	font-family: var(--sk-font-serif);
	font-size: clamp(1.75rem, 1.4rem + 2vw, 2.75rem);
	font-weight: 400;
	color: var(--sk-white);
	margin: 1rem 0 1rem;
	line-height: 1.15;
}
.sk-rit-quiz-cta__title em { color: var(--sk-secondary); font-style: italic; }
.sk-rit-quiz-cta__lead { font-size: 1.05rem; color: rgba(255,255,255,0.85); margin-bottom: 2rem; }
.sk-rit-quiz-cta .sk-section-head__eyebrow { color: var(--sk-secondary) !important; }

/* ═══════════════════════════════════════════════════════════
   QUIZ — page-quiz.php
   ═══════════════════════════════════════════════════════════ */
.sk-quiz-hero {
	padding: clamp(3rem, 2rem + 2vw, 5rem) 0 clamp(1.5rem, 1rem + 1vw, 2.5rem);
	background: var(--sk-surface);
	text-align: center;
}
.sk-quiz-hero__eyebrow {
	display: inline-block;
	font-size: 0.78rem; font-weight: 600;
	letter-spacing: 0.16em; text-transform: uppercase;
	color: var(--sk-accent);
	margin-bottom: 1rem;
}
.sk-quiz-hero__title {
	font-family: var(--sk-font-serif);
	font-size: clamp(2.5rem, 1.8rem + 3vw, 4.5rem);
	font-weight: 400;
	letter-spacing: -0.03em;
	color: var(--sk-text);
	margin: 0 0 1rem;
	line-height: 1.05;
}
.sk-quiz-hero__title em { color: var(--sk-accent); font-style: italic; }
.sk-quiz-hero__lead { color: var(--sk-text-2); max-width: 600px; margin: 0 auto; font-size: var(--sk-size-lead); line-height: 1.5; }

.sk-quiz {
	padding: clamp(2rem, 1.5rem + 1vw, 3.5rem) 0 var(--sk-section-y);
	background: var(--sk-bg);
}

.sk-quiz__progress {
	display: flex; align-items: center; gap: 1rem;
	max-width: 720px; margin: 0 auto 2.5rem;
}
.sk-quiz__progress::before {
	content: ""; flex: 1; height: 3px;
	background: var(--sk-border);
	border-radius: 3px;
	position: relative;
}
.sk-quiz__progress-bar {
	height: 3px;
	background: var(--sk-accent);
	border-radius: 3px;
	transition: width 400ms var(--sk-e-out);
	position: absolute;
	left: 0;
}
.sk-quiz__progress { position: relative; }
.sk-quiz__progress-bar { position: absolute; left: 0; top: 0; height: 100%; }
.sk-quiz__progress {
	height: 3px;
	background: var(--sk-border);
	border-radius: 3px;
	max-width: 720px;
	margin: 0 auto 1rem;
	overflow: visible;
}
.sk-quiz__progress::before { display: none; }
.sk-quiz__progress-text {
	display: block;
	margin-top: 1rem;
	text-align: center;
	font-size: 0.78rem;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: var(--sk-muted);
	font-weight: 600;
}

.sk-quiz__form { max-width: 720px; margin: 0 auto; }
.sk-quiz-step {
	display: none;
	border: 0; padding: 0; margin: 0;
	animation: sk-quiz-fade 400ms var(--sk-e-out);
}
.sk-quiz-step.is-active { display: block; }
.sk-quiz-step.is-error { animation: sk-quiz-shake 400ms ease-in-out; }
@keyframes sk-quiz-fade { from { opacity: 0; transform: translateX(20px); } to { opacity: 1; transform: none; } }
@keyframes sk-quiz-shake { 0%, 100% { transform: translateX(0); } 25% { transform: translateX(-8px); } 75% { transform: translateX(8px); } }

.sk-quiz-step__num {
	font-family: var(--sk-font-serif); font-style: italic;
	font-size: 1rem;
	color: var(--sk-accent);
	letter-spacing: 0.04em;
	margin-bottom: 0.5rem;
	display: block;
	float: none;
}
.sk-quiz-step__question {
	font-family: var(--sk-font-serif);
	font-size: clamp(1.5rem, 1.3rem + 1vw, 2.25rem);
	font-weight: 400;
	letter-spacing: -0.02em;
	line-height: 1.15;
	color: var(--sk-text);
	margin: 0 0 0.5rem;
}
.sk-quiz-step__hint { color: var(--sk-muted); font-size: 0.95rem; margin-bottom: 1.75rem; }

.sk-quiz-options {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 0.75rem;
}
@media (max-width: 600px) { .sk-quiz-options { grid-template-columns: 1fr; } }
.sk-quiz-options label {
	cursor: pointer;
	margin: 0;
	display: block;
}
.sk-quiz-options input { position: absolute; opacity: 0; pointer-events: none; }
.sk-quiz-options span {
	display: block;
	padding: 1.1rem 1.25rem;
	background: var(--sk-white);
	border: 2px solid var(--sk-border);
	border-radius: var(--sk-r-md);
	transition: all var(--sk-t-fast);
}
.sk-quiz-options span strong {
	display: block;
	font-family: var(--sk-font-serif);
	font-size: 1.15rem; font-weight: 500;
	color: var(--sk-text);
	margin-bottom: 0.2rem;
	letter-spacing: -0.01em;
}
.sk-quiz-options span em {
	display: block;
	font-style: normal;
	font-size: 0.85rem;
	color: var(--sk-muted);
	line-height: 1.4;
}
.sk-quiz-options label:hover span {
	border-color: var(--sk-border-2);
	background: var(--sk-surface);
}
.sk-quiz-options input:checked + span {
	border-color: var(--sk-accent);
	background: var(--sk-surface);
	box-shadow: var(--sk-sh-sm);
}
.sk-quiz-options input:focus-visible + span { outline: 2px solid var(--sk-accent); outline-offset: 3px; }

.sk-quiz-email input {
	max-width: 480px;
	margin: 0 auto;
	display: block;
}
.sk-quiz-email small { display: block; text-align: center; margin-top: 0.6rem; color: var(--sk-muted); font-size: 0.82rem; }

.sk-quiz__nav {
	display: flex; justify-content: space-between; align-items: center;
	gap: 1rem;
	margin-top: 2.5rem;
}
.sk-quiz__nav .sk-btn[hidden] + .sk-btn,
.sk-quiz__nav > .sk-btn:first-child[hidden] ~ .sk-btn { margin-left: auto; }

.sk-quiz-loading {
	text-align: center;
	padding: 4rem 1rem;
}
.sk-quiz-loading__spinner {
	width: 48px; height: 48px;
	margin: 0 auto 1.5rem;
	border: 3px solid var(--sk-border-2);
	border-top-color: var(--sk-accent);
	border-radius: 50%;
	animation: sk-spin 800ms linear infinite;
}
.sk-quiz-loading p {
	font-family: var(--sk-font-serif);
	font-style: italic;
	font-size: 1.2rem;
	color: var(--sk-muted);
}

.sk-quiz-result { padding-top: 1rem; }
.sk-result__head { text-align: center; margin-bottom: 3rem; max-width: 720px; margin-inline: auto; }
.sk-result__eyebrow {
	display: inline-block;
	font-size: 0.78rem; font-weight: 600;
	letter-spacing: 0.16em; text-transform: uppercase;
	color: var(--sk-accent); margin-bottom: 1rem;
	padding: 0.45rem 0.9rem;
	background: var(--sk-surface);
	border-radius: var(--sk-r-full);
}
.sk-result__title {
	font-family: var(--sk-font-serif);
	font-size: clamp(2rem, 1.5rem + 2vw, 3rem);
	font-weight: 400;
	color: var(--sk-text);
	margin: 0 0 1rem;
}
.sk-result__summary { color: var(--sk-text-2); line-height: 1.6; font-size: var(--sk-size-lead); }
.sk-result__list { list-style: none; padding: 0; max-width: 880px; margin: 0 auto; display: flex; flex-direction: column; gap: 1rem; }
.sk-result__item {
	display: grid;
	grid-template-columns: 60px 100px 1fr auto;
	gap: 1.25rem;
	align-items: center;
	padding: 1rem;
	background: var(--sk-white);
	border: 1px solid var(--sk-border);
	border-radius: var(--sk-r-md);
	transition: all var(--sk-t-fast);
}
.sk-result__item:hover {
	border-color: var(--sk-border-2);
	box-shadow: var(--sk-sh-sm);
}
@media (max-width: 600px) {
	.sk-result__item { grid-template-columns: 50px 80px 1fr; grid-template-rows: auto auto; }
	.sk-result__actions { grid-column: 1 / -1; flex-direction: row; justify-content: space-between; }
}
.sk-result__num {
	font-family: var(--sk-font-serif); font-style: italic;
	font-size: 2rem;
	color: var(--sk-accent);
	font-variant-numeric: oldstyle-nums;
	line-height: 1;
}
.sk-result__media {
	display: block;
	width: 100px; height: 100px;
	border-radius: var(--sk-r-sm);
	overflow: hidden;
	background: var(--sk-surface);
}
.sk-result__media img { width: 100%; height: 100%; object-fit: cover; }
.sk-result__body { display: flex; flex-direction: column; gap: 0.2rem; min-width: 0; }
.sk-result__cat {
	font-family: var(--sk-font-sans);
	font-size: 0.7rem; font-weight: 700;
	letter-spacing: 0.14em; text-transform: uppercase;
	color: var(--sk-muted);
}
.sk-result__brand {
	font-size: 0.7rem; font-weight: 700;
	letter-spacing: 0.13em;
	color: var(--sk-accent);
}
.sk-result__name {
	font-family: var(--sk-font-sans);
	font-size: 0.95rem; font-weight: 500;
	color: var(--sk-text);
	line-height: 1.35;
}
.sk-result__name:hover { color: var(--sk-accent); }
.sk-result__actions { display: flex; flex-direction: column; align-items: flex-end; gap: 0.5rem; }
.sk-result__price {
	font-family: var(--sk-font-serif);
	font-size: 1.1rem; font-weight: 500;
	color: var(--sk-text);
}
.sk-result__cta { text-align: center; margin-top: 2.5rem; }

/* ═══════════════════════════════════════════════════════════
   ROUTINE V3 — horizontal scroll, foto prodotti REALI, dark theme
   ═══════════════════════════════════════════════════════════ */
.sk-routine-v3 {
	padding: clamp(4rem, 3rem + 2vw, 6.5rem) 0 clamp(3rem, 2rem + 2vw, 5rem);
	background: linear-gradient(135deg, #1A1530 0%, #2B2540 50%, #4A3D6E 100%);
	color: var(--sk-white);
	position: relative;
	overflow: hidden;
}
.sk-routine-v3::before {
	content: "";
	position: absolute;
	width: 700px; height: 700px;
	top: -200px; right: -100px;
	background: radial-gradient(circle, rgba(155, 141, 200, 0.18), transparent 65%);
	filter: blur(60px);
	pointer-events: none;
}
.sk-routine-v3::after {
	content: "";
	position: absolute;
	width: 500px; height: 500px;
	bottom: -100px; left: -100px;
	background: radial-gradient(circle, rgba(200, 191, 234, 0.15), transparent 65%);
	filter: blur(80px);
	pointer-events: none;
}

.sk-routine-v3__head { position: relative; z-index: 2; margin-bottom: clamp(2rem, 1.5rem + 1vw, 3rem); }
.sk-routine-v3__head-row {
	display: grid;
	grid-template-columns: 1.2fr 1fr;
	gap: 2rem;
	align-items: end;
}
@media (max-width: 720px) { .sk-routine-v3__head-row { grid-template-columns: 1fr; gap: 1rem; } }

.sk-routine-v3__eyebrow {
	display: inline-block;
	font-family: var(--sk-font-sans);
	font-size: 0.78rem;
	font-weight: 600;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: var(--sk-secondary);
	margin-bottom: 1rem;
}
.sk-routine-v3__title {
	font-family: var(--sk-font-serif);
	font-size: clamp(2.25rem, 1.8rem + 2.5vw, 4rem);
	font-weight: 400;
	line-height: 1.02;
	letter-spacing: -0.03em;
	color: var(--sk-white);
	margin: 0;
}
.sk-routine-v3__title em {
	color: var(--sk-secondary);
	font-style: italic;
	display: inline-block;
}
.sk-routine-v3__lead {
	font-family: var(--sk-font-serif);
	font-style: italic;
	font-size: 1.1rem;
	line-height: 1.5;
	color: rgba(255, 255, 255, 0.72);
	margin: 0;
	max-width: 380px;
	justify-self: end;
}
@media (max-width: 720px) { .sk-routine-v3__lead { justify-self: start; max-width: none; } }

.sk-routine-v3__rail {
	position: relative;
	z-index: 2;
	margin-bottom: 2rem;
}
.sk-routine-v3__track {
	list-style: none;
	display: flex;
	gap: clamp(1rem, 0.5rem + 1vw, 1.75rem);
	overflow-x: auto;
	overflow-y: visible;
	scroll-snap-type: x mandatory;
	scroll-padding: clamp(1.5rem, 2vw, 2.5rem);
	padding: 1rem clamp(1.5rem, 2vw, 2.5rem) 2rem;
	margin: 0;
	-webkit-overflow-scrolling: touch;
	scrollbar-width: none;
}
.sk-routine-v3__track::-webkit-scrollbar { display: none; }

.sk-rstep {
	flex: 0 0 320px;
	scroll-snap-align: start;
	margin: 0;
	padding: 0;
	animation: sk-rstep-rise 600ms var(--sk-e-out) backwards;
	animation-delay: calc(var(--idx, 0) * 60ms);
}
@keyframes sk-rstep-rise {
	from { opacity: 0; transform: translateY(20px); }
	to { opacity: 1; transform: translateY(0); }
}
@media (max-width: 600px) { .sk-rstep { flex: 0 0 280px; } }

.sk-rstep__card {
	position: relative;
	display: flex;
	flex-direction: column;
	height: 100%;
	min-height: 480px;
	padding: 1.75rem 1.5rem 1.5rem;
	background: rgba(255, 255, 255, 0.04);
	border: 1px solid rgba(255, 255, 255, 0.1);
	border-radius: var(--sk-r-lg);
	color: var(--sk-white);
	overflow: hidden;
	backdrop-filter: blur(8px);
	-webkit-backdrop-filter: blur(8px);
	transition: all 400ms var(--sk-e-out);
	isolation: isolate;
}
.sk-rstep__card:hover {
	background: rgba(255, 255, 255, 0.08);
	border-color: rgba(200, 191, 234, 0.4);
	transform: translateY(-6px) rotate(-0.5deg);
	box-shadow: 0 30px 60px -15px rgba(0, 0, 0, 0.4), 0 0 0 1px rgba(200, 191, 234, 0.25);
}

.sk-rstep__num {
	position: absolute;
	top: -1.5rem; right: -0.5rem;
	font-family: var(--sk-font-serif);
	font-style: italic;
	font-size: clamp(7rem, 6rem + 2vw, 10rem);
	font-weight: 400;
	line-height: 1;
	color: rgba(200, 191, 234, 0.18);
	letter-spacing: -0.06em;
	font-variant-numeric: oldstyle-nums;
	pointer-events: none;
	z-index: 0;
	transition: color 400ms var(--sk-e-out), transform 600ms var(--sk-e-out);
}
.sk-rstep__card:hover .sk-rstep__num {
	color: rgba(200, 191, 234, 0.35);
	transform: translateY(-4px) scale(1.04);
}

.sk-rstep__media {
	position: relative;
	z-index: 1;
	margin: 0 0 1.25rem;
	aspect-ratio: 1/1;
	border-radius: var(--sk-r-md);
	overflow: hidden;
	background: rgba(255, 255, 255, 0.06);
}
.sk-rstep__img,
.sk-rstep__placeholder {
	width: 100%; height: 100%;
	object-fit: cover;
	transition: transform 700ms var(--sk-e-out);
}
.sk-rstep__placeholder {
	background: linear-gradient(135deg, rgba(155, 141, 200, 0.15), rgba(74, 61, 110, 0.3));
}
.sk-rstep__card:hover .sk-rstep__img { transform: scale(1.06); }

.sk-rstep__body {
	position: relative; z-index: 1;
	display: flex; flex-direction: column; gap: 0.4rem;
	flex: 1;
}
.sk-rstep__step-label {
	font-family: var(--sk-font-sans);
	font-size: 0.7rem;
	font-weight: 700;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: var(--sk-secondary);
}
.sk-rstep__name {
	font-family: var(--sk-font-serif);
	font-size: 1.5rem;
	font-weight: 500;
	line-height: 1.1;
	letter-spacing: -0.015em;
	color: var(--sk-white);
	margin: 0.15rem 0 0.4rem;
}
.sk-rstep__desc {
	font-size: 0.88rem;
	line-height: 1.5;
	color: rgba(255, 255, 255, 0.7);
	margin: 0 0 0.85rem;
}
.sk-rstep__product {
	display: flex; flex-direction: column; gap: 0.1rem;
	padding: 0.65rem 0.8rem;
	background: rgba(255, 255, 255, 0.06);
	border-radius: var(--sk-r-sm);
	border-left: 2px solid var(--sk-secondary);
	margin-top: auto;
}
.sk-rstep__product-brand {
	font-size: 0.66rem;
	font-weight: 700;
	letter-spacing: 0.13em;
	color: var(--sk-secondary);
}
.sk-rstep__product-name {
	font-size: 0.78rem;
	color: rgba(255, 255, 255, 0.85);
	line-height: 1.3;
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
}

.sk-rstep__cta {
	position: relative; z-index: 1;
	display: inline-flex; align-items: center; gap: 0.4rem;
	margin-top: 0.85rem;
	font-size: 0.78rem;
	font-weight: 600;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: var(--sk-secondary);
	transition: gap var(--sk-t-fast);
}
.sk-rstep__card:hover .sk-rstep__cta { gap: 0.7rem; }
.sk-rstep__cta svg { transition: transform var(--sk-t-fast); }
.sk-rstep__card:hover .sk-rstep__cta svg { transform: translateX(3px); }

.sk-routine-v3__progress {
	position: relative;
	height: 2px;
	margin: 0 clamp(1.5rem, 2vw, 2.5rem);
	background: rgba(255, 255, 255, 0.1);
	border-radius: 2px;
	overflow: hidden;
}
.sk-routine-v3__progress-bar {
	position: absolute;
	left: 0; top: 0;
	height: 100%;
	width: 10%;
	background: var(--sk-secondary);
	border-radius: 2px;
	transition: width 200ms ease;
}

.sk-routine-v3__controls {
	display: flex; justify-content: center;
	margin-top: clamp(2rem, 1.5rem + 1vw, 3rem);
	position: relative; z-index: 2;
}

/* ═══════════════════════════════════════════════════════════
   ROUTINE V2 (legacy — backward compat)
   ═══════════════════════════════════════════════════════════ */
.sk-routine-v2 {
	padding: var(--sk-section-y) 0;
	background: var(--sk-bg);
	position: relative;
}
.sk-routine-v2__intro {
	font-family: var(--sk-font-serif);
	font-style: italic;
	font-size: clamp(1rem, 0.95rem + 0.3vw, 1.2rem);
	color: var(--sk-text-2);
	max-width: 64ch;
	margin: -1rem 0 clamp(2rem, 1.5rem + 1vw, 3rem);
	line-height: 1.5;
}
.sk-routine-v2__grid {
	display: grid;
	grid-template-columns: repeat(5, 1fr);
	gap: clamp(0.75rem, 0.5rem + 0.8vw, 1.5rem);
	list-style: none;
	padding: 0;
	counter-reset: step;
}
@media (max-width: 1080px) { .sk-routine-v2__grid { grid-template-columns: repeat(4, 1fr); } }
@media (max-width: 880px)  { .sk-routine-v2__grid { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 600px)  { .sk-routine-v2__grid { grid-template-columns: repeat(2, 1fr); } }

.sk-step { margin: 0; padding: 0; }
.sk-step__link {
	display: flex;
	flex-direction: column;
	gap: 0.85rem;
	color: inherit;
	transition: transform var(--sk-t-med);
}
.sk-step__link:hover { transform: translateY(-4px); }
.sk-step__media {
	position: relative;
	aspect-ratio: 4/5;
	margin: 0;
	border-radius: var(--sk-r-md);
	overflow: hidden;
	box-shadow: var(--sk-sh-xs);
	transition: box-shadow var(--sk-t-med);
}
.sk-step__link:hover .sk-step__media { box-shadow: var(--sk-glow-md); }
.sk-step__media img {
	width: 100%; height: 100%;
	object-fit: cover;
	transition: transform 800ms var(--sk-e-out);
}
.sk-step__link:hover .sk-step__media img { transform: scale(1.05); }
.sk-step__num {
	position: absolute;
	top: 0.85rem; left: 0.85rem;
	font-family: var(--sk-font-serif);
	font-style: italic;
	font-size: 1.6rem;
	font-weight: 500;
	color: var(--sk-white);
	line-height: 1;
	text-shadow: 0 2px 12px rgba(0,0,0,0.3);
	letter-spacing: -0.02em;
	font-variant-numeric: oldstyle-nums;
}
.sk-step__body {
	display: flex;
	flex-direction: column;
	gap: 0.25rem;
}
.sk-step__name {
	font-family: var(--sk-font-serif);
	font-size: clamp(0.95rem, 0.9rem + 0.3vw, 1.15rem);
	font-weight: 500;
	line-height: 1.2;
	color: var(--sk-text);
	margin: 0;
	letter-spacing: -0.01em;
}
.sk-step__desc {
	font-size: 0.85rem;
	line-height: 1.45;
	color: var(--sk-muted);
	margin: 0;
}

/* Vecchia routine bento — manteniamo per backward compat su altri template */
.sk-routine {
	padding: var(--sk-section-y) 0;
	background: var(--sk-bg);
}

.sk-bento {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	grid-auto-rows: minmax(200px, auto);
	gap: clamp(0.75rem, 1vw, 1rem);
}
@media (max-width: 980px) { .sk-bento { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 520px) { .sk-bento { grid-template-columns: 1fr; } }

.sk-bento-card {
	position: relative;
	display: flex; flex-direction: column; justify-content: space-between;
	padding: clamp(1.25rem, 1rem + 0.5vw, 1.75rem);
	background: var(--sk-white);
	border: 1px solid var(--sk-border);
	border-radius: var(--sk-r-lg);
	overflow: hidden;
	transition: transform var(--sk-t-med), box-shadow var(--sk-t-med), border-color var(--sk-t-med);
	box-shadow: var(--sk-sh-xs);
}
.sk-bento-card::before {
	content: "";
	position: absolute;
	top: 0; right: 0;
	width: 140px; height: 140px;
	background: radial-gradient(circle at top right, var(--sk-secondary), transparent 70%);
	opacity: 0;
	transition: opacity var(--sk-t-med);
	pointer-events: none;
}
.sk-bento-card:hover {
	transform: translateY(-6px);
	box-shadow: var(--sk-glow-lg);
	border-color: var(--sk-border-2);
}
.sk-bento-card:hover::before { opacity: 0.45; }
.sk-bento-card > * { position: relative; z-index: 1; }
.sk-bento-card--lg { grid-column: span 2; }
@media (max-width: 520px) { .sk-bento-card--lg { grid-column: span 1; } }

.sk-bento-card__top {
	display: flex; align-items: center; justify-content: space-between;
	gap: 1rem; margin-bottom: 1rem;
}
.sk-bento-card__num {
	font-family: var(--sk-font-serif);
	font-size: clamp(2.25rem, 1.8rem + 1.2vw, 3rem);
	font-weight: 400;
	line-height: 0.9;
	color: var(--sk-accent);
	font-variant-numeric: oldstyle-nums;
}
.sk-bento-card__hint {
	font-size: 0.66rem; font-weight: 600;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color: var(--sk-accent);
	padding: 0.35rem 0.65rem;
	background: var(--sk-surface);
	border-radius: var(--sk-r-full);
}
.sk-bento-card__icon {
	color: var(--sk-accent);
	width: clamp(48px, 5vw, 64px);
	height: clamp(48px, 5vw, 64px);
	padding: 10px;
	background: var(--sk-surface);
	border-radius: var(--sk-r-md);
	margin-bottom: 1rem;
	transition: background var(--sk-t-med), transform var(--sk-t-med);
}
.sk-bento-card:hover .sk-bento-card__icon {
	background: var(--sk-surface-2);
	transform: scale(1.06) rotate(-3deg);
}
.sk-bento-card__icon svg { width: 100%; height: 100%; }
.sk-bento-card__name {
	font-family: var(--sk-font-serif);
	font-size: clamp(1.1rem, 1rem + 0.3vw, 1.25rem);
	font-weight: 500;
	line-height: 1.15;
	color: var(--sk-text);
	margin-bottom: 0.4rem;
}
.sk-bento-card__desc {
	font-size: 0.88rem;
	line-height: 1.5;
	color: var(--sk-muted);
}

/* ═══════════════════════════════════════════════════════════
   NEWSLETTER — compact, cream style
   ═══════════════════════════════════════════════════════════ */
.sk-newsletter {
	padding: var(--sk-section-y) 0;
	background: var(--sk-text);
	color: var(--sk-white);
	text-align: center;
}
.sk-newsletter__inner { position: relative; }
.sk-newsletter__content { max-width: 640px; margin: 0 auto; }
.sk-newsletter__eyebrow {
	display: inline-block;
	font-size: 0.78rem;
	font-weight: 600;
	letter-spacing: 0.16em;
	text-transform: uppercase;
	color: var(--sk-secondary);
	margin-bottom: 1.25rem;
}
.sk-newsletter__title {
	font-family: var(--sk-font-serif);
	font-size: clamp(1.75rem, 1.5rem + 1.5vw, 2.75rem);
	line-height: 1.1;
	letter-spacing: -0.02em;
	font-weight: 400;
	color: var(--sk-white);
	margin: 0 0 1rem;
}
.sk-newsletter__title em {
	color: var(--sk-secondary);
	font-style: italic;
	font-size: 1.15em;
	display: inline-block;
	margin-right: 0.15em;
}
.sk-newsletter__title-sub {
	display: block;
	font-style: italic;
	color: rgba(255, 255, 255, 0.85);
	font-size: 0.82em;
	margin-top: 0.25rem;
}
.sk-newsletter__lead {
	font-size: 0.98rem;
	line-height: 1.55;
	color: rgba(255, 255, 255, 0.78);
	max-width: 500px;
	margin: 0 auto 1.75rem;
}
.sk-newsletter__form {
	display: flex; gap: 0.5rem;
	max-width: 460px;
	margin: 0 auto 0.8rem;
	padding: 0.3rem;
	background: rgba(255, 255, 255, 0.1);
	border: 1px solid rgba(255, 255, 255, 0.2);
	border-radius: var(--sk-r-full);
}
.sk-newsletter__input {
	flex: 1;
	padding: 0.7rem 1rem !important;
	font-size: 0.95rem !important;
	color: var(--sk-white) !important;
	background: transparent !important;
	border: 0 !important;
	border-radius: var(--sk-r-full) !important;
}
.sk-newsletter__input::placeholder { color: rgba(255, 255, 255, 0.55); }
.sk-newsletter__input:focus { outline: none !important; box-shadow: none !important; }
.sk-newsletter__submit {
	padding: 0.7rem 1.4rem !important;
	font-size: 0.82rem !important;
	background: var(--sk-white) !important;
	color: var(--sk-text) !important;
	border: 0 !important;
}
.sk-newsletter__submit:hover { background: var(--sk-secondary) !important; }
.sk-newsletter__note {
	font-size: 0.75rem;
	color: rgba(255, 255, 255, 0.5);
	margin-top: 0.5rem;
}
@media (max-width: 520px) {
	.sk-newsletter__form { flex-direction: column; background: transparent; border: 0; padding: 0; }
	.sk-newsletter__input { background: rgba(255, 255, 255, 0.1) !important; border: 1px solid rgba(255, 255, 255, 0.2) !important; }
}

/* ═══════════════════════════════════════════════════════════
   TRUST BAR + payment icons
   ═══════════════════════════════════════════════════════════ */
.sk-trust-bar {
	padding: clamp(2.5rem, 1.5rem + 1.5vw, 4rem) 0;
	background: var(--sk-surface);
}
.sk-trust-bar__inner { display: flex; flex-direction: column; gap: 2rem; align-items: center; }
.sk-trust-bar__cols {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
	gap: 1.25rem 2rem;
	width: 100%;
}
.sk-trust-bar__item { display: flex; align-items: center; gap: 0.9rem; }
.sk-trust-bar__item svg {
	color: var(--sk-accent);
	padding: 0.55rem;
	width: 50px; height: 50px;
	background: var(--sk-white);
	border-radius: var(--sk-r-full);
	box-shadow: var(--sk-sh-xs);
	flex-shrink: 0;
}
.sk-trust-bar__title { font-weight: 600; font-size: 0.95rem; margin: 0 0 0.1rem; color: var(--sk-text); }
.sk-trust-bar__desc { font-size: 0.82rem; color: var(--sk-muted); margin: 0; }

.sk-trust-bar__pay {
	display: flex; flex-direction: column; align-items: center; gap: 0.6rem;
	padding-top: 1.25rem;
	border-top: 1px dashed var(--sk-border-2);
	width: 100%;
}
.sk-trust-bar__pay-label {
	font-size: 0.7rem; font-weight: 600;
	letter-spacing: 0.15em; text-transform: uppercase;
	color: var(--sk-muted);
}
.sk-trust-bar__pay-icons { display: flex; flex-wrap: wrap; gap: 0.55rem; justify-content: center; }

/* ═══════════════════════════════════════════════════════════
   BRANDS typographic (minimal)
   ═══════════════════════════════════════════════════════════ */
.sk-brands { padding: var(--sk-section-y) 0; background: var(--sk-white); text-align: center; }
.sk-brand-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
	border-top: 1px solid var(--sk-border);
	border-left: 1px solid var(--sk-border);
}
.sk-brand-item {
	border-right: 1px solid var(--sk-border);
	border-bottom: 1px solid var(--sk-border);
	padding: clamp(1.5rem, 1rem + 1vw, 2.25rem) 1rem;
	display: flex; align-items: center; justify-content: center;
	transition: background var(--sk-t-fast);
}
.sk-brand-item:hover { background: var(--sk-surface); }
.sk-brand-item__name {
	font-family: var(--sk-font-serif);
	font-size: 1.3rem;
	font-style: italic;
	color: var(--sk-muted);
	font-weight: 400;
	transition: color var(--sk-t-fast);
}
.sk-brand-item:hover .sk-brand-item__name { color: var(--sk-accent); }

/* ═══════════════════════════════════════════════════════════
   FOOTER dark
   ═══════════════════════════════════════════════════════════ */
.sk-footer {
	background: #0F0B20;
	color: #A9A0C9;
	font-size: 0.92rem;
	margin-top: 0;
}
.sk-footer__top { padding: clamp(3rem, 2rem + 2vw, 5rem) 0 clamp(2rem, 1rem + 1.5vw, 3rem); }
.sk-footer__top-inner {
	display: grid;
	grid-template-columns: 1.4fr 1fr 1fr 1fr 1fr;
	gap: clamp(1.5rem, 1rem + 1vw, 3rem);
	align-items: start;
}
.sk-footer__brand-title {
	font-family: var(--sk-font-serif);
	font-size: 1.9rem; font-weight: 400;
	color: var(--sk-white);
	margin-bottom: 0.5rem;
}
.sk-footer__brand-skin { color: var(--sk-white); }
.sk-footer__brand-ko { color: var(--sk-secondary); font-style: italic; }
.sk-footer__tagline { color: #857AA8; font-size: 0.9rem; line-height: 1.55; max-width: 260px; }
.sk-footer__col-title {
	font-family: var(--sk-font-sans);
	font-size: 0.76rem; font-weight: 600;
	letter-spacing: 0.15em;
	text-transform: uppercase;
	color: var(--sk-white);
	margin-bottom: 1rem;
}
.sk-footer__list { display: flex; flex-direction: column; gap: 0.55rem; }
.sk-footer__list a { color: #857AA8; transition: color var(--sk-t-fast); }
.sk-footer__list a:hover { color: var(--sk-white); }
.sk-footer__trust-list { display: flex; flex-direction: column; gap: 0.55rem; color: #857AA8; font-size: 0.88rem; }
.sk-footer__bottom { padding: 1.25rem 0; border-top: 1px solid rgba(200, 191, 234, 0.1); }
.sk-footer__bottom-inner { display: flex; align-items: center; justify-content: center; }
.sk-footer__copy { color: #B8ADDE; font-size: 0.82rem; text-align: center; }
.sk-footer__copy a { color: var(--sk-secondary); }
.sk-footer__divider { margin: 0 0.5rem; opacity: 0.5; }
@media (max-width: 980px) {
	.sk-footer__top-inner { grid-template-columns: 1fr 1fr; gap: 2rem; }
	.sk-footer__brand { grid-column: 1 / -1; }
	.sk-footer__trust { grid-column: 1 / -1; }
}
@media (max-width: 520px) { .sk-footer__top-inner { grid-template-columns: 1fr; } }

/* ═══════════════════════════════════════════════════════════
   WhatsApp floating
   ═══════════════════════════════════════════════════════════ */
.sk-wa-float {
	position: fixed;
	bottom: 24px; right: 24px;
	z-index: 1000;
	display: inline-flex; align-items: center; gap: 0.55rem;
	padding: 0.8rem 1.2rem 0.8rem 0.95rem;
	background: #25D366;
	color: var(--sk-white);
	text-decoration: none;
	border-radius: var(--sk-r-full);
	box-shadow: 0 10px 28px -6px rgba(37, 211, 102, 0.45);
	font-size: 0.85rem; font-weight: 500;
	letter-spacing: 0.01em;
	transition: transform var(--sk-t-med), box-shadow var(--sk-t-med);
}
.sk-wa-float:hover { transform: translateY(-2px); box-shadow: 0 14px 34px -4px rgba(37, 211, 102, 0.55); }
.sk-wa-float__label { max-width: 0; overflow: hidden; white-space: nowrap; transition: max-width 350ms var(--sk-e-out), padding 350ms var(--sk-e-out); padding: 0; }
.sk-wa-float:hover .sk-wa-float__label { max-width: 220px; padding-left: 0.3rem; }
@media (max-width: 720px) {
	.sk-wa-float { bottom: 16px; right: 16px; padding: 0.75rem; }
	.sk-wa-float__label { display: none; }
}

/* ═══════════════════════════════════════════════════════════
   PAGE / 404 / POSTS / FORMS basic
   ═══════════════════════════════════════════════════════════ */
.sk-page__header { margin-bottom: 2.5rem; text-align: center; }
.sk-page__title { font-size: var(--sk-size-h1); margin-bottom: 0.5rem; }
.sk-page__excerpt { color: var(--sk-muted); font-size: var(--sk-size-lead); max-width: 620px; margin-inline: auto; }
.sk-page__featured { margin-block: 2.5rem; border-radius: var(--sk-r-md); overflow: hidden; }
.sk-page__content { font-size: 1.02rem; line-height: 1.75; color: var(--sk-text-2); max-width: 68ch; margin-inline: auto; }
.sk-page__content > * + * { margin-top: 1.1rem; }
.sk-page__content h2 { font-size: var(--sk-size-h3); margin-top: 2.25rem; margin-bottom: 0.75rem; color: var(--sk-text); }
.sk-page__content h3 { font-size: var(--sk-size-h4); margin-top: 1.75rem; margin-bottom: 0.5rem; }
.sk-page__content ul, .sk-page__content ol { padding-left: 1.5rem; }
.sk-page__content ul { list-style: disc; }
.sk-page__content ol { list-style: decimal; }
.sk-page__content a { color: var(--sk-accent); text-decoration: underline; text-underline-offset: 3px; }
.sk-page__content .sk-lead { font-family: var(--sk-font-serif); font-size: 1.3rem; font-style: italic; color: var(--sk-text); line-height: 1.45; }

.sk-404 { text-align: center; padding: clamp(3rem, 2rem + 2vw, 6rem) 0; }
.sk-404__code { font-family: var(--sk-font-serif); font-size: clamp(5rem, 4rem + 3vw, 9rem); color: var(--sk-accent); font-style: italic; line-height: 1; margin-bottom: 1rem; }
.sk-404__title { font-size: var(--sk-size-h2); margin-bottom: 0.75rem; }
.sk-404__text { color: var(--sk-muted); font-size: var(--sk-size-lead); max-width: 500px; margin: 0 auto 2rem; }
.sk-404__actions { display: flex; gap: 0.75rem; justify-content: center; flex-wrap: wrap; }

.sk-page-header { text-align: center; margin-bottom: 3rem; }
.sk-page-title { font-size: var(--sk-size-h1); margin-bottom: 0.5rem; }
.sk-posts-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(300px, 1fr)); gap: 2rem; }

/* ═══════════════════════════════════════════════════════════
   CART DRAWER slide-in
   ═══════════════════════════════════════════════════════════ */
.sk-cart-drawer {
	position: fixed; inset: 0;
	z-index: 1100;
	pointer-events: none;
}
.sk-cart-drawer.is-open { pointer-events: auto; }
.sk-cart-drawer__backdrop {
	position: absolute; inset: 0;
	background: rgba(15, 11, 32, 0.5);
	opacity: 0;
	transition: opacity 350ms var(--sk-e-out);
	cursor: pointer;
}
.sk-cart-drawer.is-open .sk-cart-drawer__backdrop { opacity: 1; }

.sk-cart-drawer__panel {
	position: absolute; top: 0; right: 0; bottom: 0;
	width: min(440px, 100vw);
	background: var(--sk-bg);
	display: flex; flex-direction: column;
	transform: translateX(100%);
	transition: transform 400ms var(--sk-e-out);
	box-shadow: -24px 0 48px -12px rgba(15, 11, 32, 0.25);
}
.sk-cart-drawer.is-open .sk-cart-drawer__panel { transform: translateX(0); }

.sk-cart-drawer__head {
	display: flex; align-items: center; justify-content: space-between;
	padding: 1.25rem 1.5rem;
	border-bottom: 1px solid var(--sk-border);
	background: var(--sk-bg);
	flex-shrink: 0;
}
.sk-cart-drawer__title {
	font-family: var(--sk-font-serif);
	font-size: 1.4rem; font-weight: 400;
	color: var(--sk-text);
	margin: 0;
	display: flex; align-items: center; gap: 0.6rem;
}
.sk-cart-drawer__count {
	display: inline-flex; align-items: center; justify-content: center;
	min-width: 26px; height: 26px;
	padding: 0 0.5rem;
	font-family: var(--sk-font-sans);
	font-size: 0.78rem; font-weight: 600;
	background: var(--sk-accent); color: var(--sk-white);
	border-radius: var(--sk-r-full);
	line-height: 1;
}
.sk-cart-drawer__close {
	background: var(--sk-surface);
	border: 0;
	width: 38px; height: 38px;
	border-radius: var(--sk-r-full);
	color: var(--sk-text);
	cursor: pointer;
	display: inline-flex; align-items: center; justify-content: center;
	transition: background var(--sk-t-fast);
}
.sk-cart-drawer__close:hover { background: var(--sk-surface-2); }

.sk-cart-drawer__body { flex: 1; overflow-y: auto; padding: 1.25rem 1.5rem; }
.sk-cart-drawer__empty { text-align: center; padding: 3rem 1rem; color: var(--sk-muted); }
.sk-cart-drawer__empty svg { color: var(--sk-secondary); margin: 0 auto 1rem; }
.sk-cart-drawer__empty h3 { font-family: var(--sk-font-serif); font-size: 1.25rem; margin-bottom: 0.5rem; color: var(--sk-text); }
.sk-cart-drawer__empty p { margin-bottom: 1.5rem; }

.sk-cart-drawer__items { display: flex; flex-direction: column; gap: 1rem; }
.sk-cart-drawer__item {
	display: grid;
	grid-template-columns: 80px 1fr auto;
	gap: 1rem;
	padding-bottom: 1rem;
	border-bottom: 1px solid var(--sk-border);
	transition: opacity 200ms ease;
}
.sk-cart-drawer__item-link { display: block; }
.sk-cart-drawer__item-img {
	width: 80px; height: 80px;
	object-fit: cover;
	border-radius: var(--sk-r-sm);
	background: var(--sk-surface);
}
.sk-cart-drawer__item-body { display: flex; flex-direction: column; gap: 0.25rem; min-width: 0; }
.sk-cart-drawer__item-brand {
	font-size: 0.66rem; font-weight: 700;
	letter-spacing: 0.13em;
	color: var(--sk-muted);
	margin: 0;
}
.sk-cart-drawer__item-title {
	font-size: 0.88rem; font-weight: 500;
	color: var(--sk-text);
	line-height: 1.35;
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
}
.sk-cart-drawer__item-row {
	display: flex; align-items: center; justify-content: space-between;
	gap: 0.5rem; margin-top: 0.4rem;
}
.sk-cart-drawer__qty {
	display: inline-flex; align-items: center; gap: 0.4rem;
	border: 1px solid var(--sk-border-2);
	border-radius: var(--sk-r-full);
	padding: 0.15rem;
}
.sk-cart-drawer__qty-btn {
	width: 24px; height: 24px;
	background: transparent; border: 0; cursor: pointer;
	color: var(--sk-text);
	border-radius: var(--sk-r-full);
	font-size: 1rem; line-height: 1;
	transition: background var(--sk-t-fast);
}
.sk-cart-drawer__qty-btn:hover { background: var(--sk-surface); }
.sk-cart-drawer__qty-num {
	min-width: 18px;
	font-size: 0.85rem; font-weight: 600;
	text-align: center;
}
.sk-cart-drawer__item-price {
	font-family: var(--sk-font-serif);
	font-size: 1rem; font-weight: 500;
	color: var(--sk-text);
}
.sk-cart-drawer__remove {
	background: transparent; border: 0; cursor: pointer;
	color: var(--sk-muted);
	padding: 0.25rem;
	transition: color var(--sk-t-fast);
}
.sk-cart-drawer__remove:hover { color: #C85A7A; }

.sk-cart-drawer__footer {
	border-top: 1px solid var(--sk-border);
	padding: 1.25rem 1.5rem;
	background: var(--sk-surface);
	flex-shrink: 0;
}
.sk-cart-drawer__totals {
	display: flex; align-items: center; justify-content: space-between;
	margin-bottom: 0.75rem;
	font-size: 0.95rem;
}
.sk-cart-drawer__totals strong {
	font-family: var(--sk-font-serif);
	font-size: 1.25rem;
	color: var(--sk-text);
}
.sk-cart-drawer__progress {
	margin-bottom: 1rem;
}
.sk-cart-drawer__progress-bar {
	height: 4px;
	background: var(--sk-accent);
	border-radius: 2px;
	transition: width 300ms var(--sk-e-out);
}
.sk-cart-drawer__progress-text {
	font-size: 0.78rem;
	color: var(--sk-muted);
	margin: 0.4rem 0 0;
}
.sk-cart-drawer__progress-text--ok { color: #3a7353; font-weight: 500; }
.sk-cart-drawer__actions {
	display: flex; flex-direction: column; gap: 0.5rem;
}
.sk-cart-drawer__actions .sk-btn { width: 100%; }

/* Body scroll lock when drawer open */
body.sk-cart-open { overflow: hidden; }

/* Cart count bump animation */
.sk-bump { animation: sk-bump 500ms var(--sk-e-out); }
@keyframes sk-bump {
	0%, 100% { transform: scale(1); }
	50% { transform: scale(1.4); }
}

/* ═══════════════════════════════════════════════════════════
   TOAST notification
   ═══════════════════════════════════════════════════════════ */
.sk-toast {
	position: fixed; top: 88px; left: 50%;
	z-index: 1200;
	transform: translateX(-50%) translateY(-100px);
	padding: 0.85rem 1.5rem;
	background: var(--sk-text);
	color: var(--sk-white);
	font-size: 0.92rem; font-weight: 500;
	border-radius: var(--sk-r-full);
	box-shadow: var(--sk-glow-md);
	opacity: 0;
	transition: opacity 300ms var(--sk-e-out), transform 350ms var(--sk-e-out);
	max-width: 90vw;
}
.sk-toast.is-visible {
	opacity: 1;
	transform: translateX(-50%) translateY(0);
}
.sk-toast--error { background: #C85A7A; }
.sk-toast--success { background: var(--sk-accent); }

/* ═══════════════════════════════════════════════════════════
   SHOP — sidebar filters + grid (la struttura via WC default,
   noi stiliamo classi WC)
   ═══════════════════════════════════════════════════════════ */
.sk-shop-layout {
	display: grid;
	grid-template-columns: 280px 1fr;
	gap: clamp(1.5rem, 1rem + 1.5vw, 3rem);
	margin-top: 2rem;
}
@media (max-width: 980px) {
	.sk-shop-layout { grid-template-columns: 1fr; }
}

.sk-shop-filters {
	position: sticky; top: 90px;
	max-height: calc(100vh - 110px);
	overflow-y: auto;
	padding: 0;
	background: transparent;
	border-radius: 0;
	font-size: 0.92rem;
}
.sk-shop-filters__search {
	margin-bottom: 1.5rem;
	position: relative;
}
.sk-shop-filters__search-label {
	display: block;
	font-size: 0.7rem;
	font-weight: 700;
	letter-spacing: 0.16em;
	text-transform: uppercase;
	color: var(--sk-muted);
	margin-bottom: 0.55rem;
}
.sk-shop-filters__search-box {
	display: flex; align-items: center; gap: 0.5rem;
	padding: 0.6rem 0.85rem;
	background: var(--sk-white);
	border: 1px solid var(--sk-border-2);
	border-radius: var(--sk-r-full);
	transition: border-color var(--sk-t-fast), box-shadow var(--sk-t-fast);
}
.sk-shop-filters__search-box:focus-within {
	border-color: var(--sk-accent);
	box-shadow: 0 0 0 3px rgba(107, 90, 158, 0.12);
}
.sk-shop-filters__search-box svg { color: var(--sk-muted); flex-shrink: 0; }
.sk-shop-filters__search-box input {
	flex: 1;
	border: 0 !important;
	background: transparent !important;
	padding: 0 !important;
	font-size: 0.92rem !important;
	border-radius: 0 !important;
	min-width: 0;
}
.sk-shop-filters__search-box input:focus { box-shadow: none !important; }
.sk-shop-filters__search-clear {
	background: transparent; border: 0; cursor: pointer;
	color: var(--sk-muted); padding: 4px;
	display: inline-flex; align-items: center; justify-content: center;
	border-radius: 50%;
}
.sk-shop-filters__search-clear:hover { background: var(--sk-surface); color: var(--sk-text); }

.sk-shop-filters__search-results {
	position: absolute; top: calc(100% + 6px); left: 0; right: 0;
	z-index: 20;
	background: var(--sk-white);
	border: 1px solid var(--sk-border);
	border-radius: var(--sk-r-md);
	box-shadow: var(--sk-glow-lg);
	max-height: 380px;
	overflow-y: auto;
	padding: 0.5rem;
}
.sk-shop-filters__search-item {
	display: flex; gap: 0.75rem; align-items: center;
	padding: 0.6rem;
	border-radius: var(--sk-r-sm);
	color: var(--sk-text);
	transition: background var(--sk-t-fast);
}
.sk-shop-filters__search-item:hover { background: var(--sk-surface); }
.sk-shop-filters__search-item img { width: 44px; height: 44px; object-fit: cover; border-radius: var(--sk-r-xs); flex-shrink: 0; }
.sk-shop-filters__search-item div { display: flex; flex-direction: column; min-width: 0; flex: 1; }
.sk-shop-filters__search-brand { font-size: 0.62rem; font-weight: 700; letter-spacing: 0.13em; color: var(--sk-muted); }
.sk-shop-filters__search-item strong { font-size: 0.82rem; font-weight: 500; color: var(--sk-text); line-height: 1.3;
	display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.sk-shop-filters__search-item em { font-style: normal; font-size: 0.78rem; font-weight: 600; color: var(--sk-accent); margin-top: 0.15rem; }
.sk-shop-filters__search-more {
	display: block;
	padding: 0.65rem 0.85rem;
	margin-top: 0.35rem;
	border-top: 1px solid var(--sk-border);
	font-size: 0.82rem; font-weight: 600;
	color: var(--sk-accent);
	text-align: center;
}
.sk-shop-filters__search-empty {
	padding: 1rem;
	text-align: center;
	color: var(--sk-muted);
	font-size: 0.9rem;
	margin: 0;
}

.sk-shop-filters__form { padding: 1.25rem; background: var(--sk-surface); border-radius: var(--sk-r-md); }
.sk-shop-filters__header {
	display: flex; align-items: center; justify-content: space-between;
	margin-bottom: 1rem;
	padding-bottom: 0.75rem;
	border-bottom: 1px solid var(--sk-border-2);
}
.sk-shop-filters__title {
	font-family: var(--sk-font-serif);
	font-size: 1.15rem; font-weight: 500;
	margin: 0;
	letter-spacing: -0.015em;
}
.sk-shop-filters__count {
	font-size: 0.7rem; font-weight: 700;
	letter-spacing: 0.1em; text-transform: uppercase;
	color: var(--sk-white);
	background: var(--sk-accent);
	padding: 0.25rem 0.55rem;
	border-radius: var(--sk-r-full);
}
.sk-shop-filters__actions {
	margin-top: 1rem;
	padding-top: 1rem;
	border-top: 1px solid var(--sk-border-2);
}
.sk-shop-filters__clear {
	display: inline-block;
	font-size: 0.82rem; font-weight: 500;
	color: var(--sk-accent);
	text-decoration: underline;
	transition: color var(--sk-t-fast);
}
.sk-shop-filters__clear:hover { color: var(--sk-accent-2); }
.sk-shop-filters__title {
	font-family: var(--sk-font-serif);
	font-size: 1.1rem; font-weight: 500;
	margin-bottom: 1rem;
	padding-bottom: 0.75rem;
	border-bottom: 1px solid var(--sk-border-2);
}
.sk-filter-group { margin-bottom: 1.25rem; }
.sk-filter-group:last-child { margin-bottom: 0; }
.sk-filter-group__label {
	display: block;
	font-size: 0.72rem; font-weight: 700;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: var(--sk-muted);
	margin-bottom: 0.7rem;
}
.sk-filter-group__label small { font-weight: 400; opacity: 0.7; }
.sk-filter-group--collapsible details summary {
	cursor: pointer;
	list-style: none;
	display: flex; align-items: center; justify-content: space-between;
	padding: 0.5rem 0;
}
.sk-filter-group--collapsible details summary::-webkit-details-marker { display: none; }
.sk-filter-group--collapsible details summary::after {
	content: "+";
	color: var(--sk-accent);
	font-size: 1.1rem;
	font-weight: 400;
	margin-left: auto;
}
.sk-filter-group--collapsible details[open] summary::after { content: "−"; }
.sk-filter-group--collapsible details > .sk-pill-list { margin-top: 0.65rem; }

/* ── PILL LIST (sostituisce checkbox) ───────────────────── */
.sk-pill-list {
	display: flex;
	flex-wrap: wrap;
	gap: 0.4rem;
}
.sk-pill {
	display: inline-flex; align-items: center; gap: 0.35rem;
	padding: 0.45rem 0.8rem;
	font-family: var(--sk-font-sans);
	font-size: 0.82rem; font-weight: 500;
	letter-spacing: 0.01em;
	color: var(--sk-text);
	background: var(--sk-white);
	border: 1px solid var(--sk-border);
	border-radius: var(--sk-r-full);
	cursor: pointer;
	transition: all 200ms var(--sk-e-out);
	line-height: 1.2;
}
.sk-pill:hover {
	border-color: var(--sk-accent);
	color: var(--sk-accent);
	transform: translateY(-1px);
}
.sk-pill.is-active {
	background: var(--sk-text);
	color: var(--sk-white);
	border-color: var(--sk-text);
	padding-right: 1.6rem;
	position: relative;
}
.sk-pill.is-active::after {
	content: "×";
	position: absolute;
	right: 0.55rem; top: 50%;
	transform: translateY(-50%);
	font-size: 1rem; font-weight: 400;
	line-height: 1;
}
.sk-pill__count {
	font-size: 0.7rem;
	font-weight: 600;
	color: var(--sk-muted);
	background: var(--sk-surface);
	padding: 0.1rem 0.4rem;
	border-radius: var(--sk-r-full);
	transition: all var(--sk-t-fast);
}
.sk-pill:hover .sk-pill__count { background: var(--sk-secondary); color: var(--sk-accent); }
.sk-pill.is-active .sk-pill__count { display: none; }

/* ── SEARCH OVERLAY full-screen ────────────────────────── */
.sk-search-overlay {
	position: fixed; inset: 0; z-index: 1100;
	pointer-events: none;
}
.sk-search-overlay.is-open { pointer-events: auto; }
.sk-search-overlay__backdrop {
	position: absolute; inset: 0;
	background: rgba(15, 11, 32, 0.65);
	backdrop-filter: blur(8px);
	-webkit-backdrop-filter: blur(8px);
	opacity: 0;
	transition: opacity 350ms var(--sk-e-out);
}
.sk-search-overlay.is-open .sk-search-overlay__backdrop { opacity: 1; }
.sk-search-overlay__panel {
	position: absolute; top: 0; left: 0; right: 0;
	background: var(--sk-bg);
	transform: translateY(-100%);
	transition: transform 400ms var(--sk-e-out);
	max-height: 90vh;
	overflow-y: auto;
}
.sk-search-overlay.is-open .sk-search-overlay__panel { transform: translateY(0); }

.sk-search-overlay__head {
	padding: 1.5rem 0;
	border-bottom: 1px solid var(--sk-border);
}
.sk-search-overlay__inputbox {
	display: flex; align-items: center; gap: 0.85rem;
	padding: 0.5rem 0;
}
.sk-search-overlay__inputbox svg { color: var(--sk-muted); flex-shrink: 0; }
.sk-search-overlay__inputbox input {
	flex: 1;
	font-family: var(--sk-font-serif);
	font-size: clamp(1.5rem, 1.2rem + 1vw, 2.25rem) !important;
	font-weight: 400 !important;
	color: var(--sk-text) !important;
	background: transparent !important;
	border: 0 !important;
	padding: 0 !important;
	letter-spacing: -0.015em;
	border-radius: 0 !important;
}
.sk-search-overlay__inputbox input:focus { outline: none !important; box-shadow: none !important; }
.sk-search-overlay__close {
	background: var(--sk-surface);
	border: 0;
	width: 44px; height: 44px;
	border-radius: var(--sk-r-full);
	color: var(--sk-text);
	cursor: pointer;
	display: inline-flex; align-items: center; justify-content: center;
}
.sk-search-overlay__close:hover { background: var(--sk-surface-2); }

.sk-search-overlay__results {
	padding: 2rem 0 4rem;
}
.sk-search-overlay__hint {
	color: var(--sk-muted);
	text-align: center;
	font-style: italic;
	font-family: var(--sk-font-serif);
	font-size: 1.1rem;
	padding: 2rem 0;
}
.sk-search-overlay__empty {
	color: var(--sk-muted);
	text-align: center;
	padding: 2rem 0;
}

.sk-search-overlay__suggestions {
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem;
	margin-bottom: 2rem;
	padding-bottom: 1.5rem;
	border-bottom: 1px solid var(--sk-border);
}
.sk-search-overlay__suggestion {
	display: inline-flex; align-items: center;
	padding: 0.5rem 0.9rem;
	font-size: 0.85rem; font-weight: 500;
	color: var(--sk-accent);
	background: var(--sk-surface);
	border-radius: var(--sk-r-full);
	transition: all var(--sk-t-fast);
}
.sk-search-overlay__suggestion:hover { background: var(--sk-accent); color: var(--sk-white); }

.sk-search-overlay__products {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
	gap: 1rem;
}
.sk-search-overlay__product {
	display: flex; gap: 1rem; align-items: center;
	padding: 0.75rem;
	background: var(--sk-white);
	border: 1px solid var(--sk-border);
	border-radius: var(--sk-r-md);
	color: var(--sk-text);
	transition: all var(--sk-t-fast);
}
.sk-search-overlay__product:hover { border-color: var(--sk-accent); transform: translateY(-2px); box-shadow: var(--sk-sh-sm); }
.sk-search-overlay__product img { width: 60px; height: 60px; object-fit: cover; border-radius: var(--sk-r-sm); flex-shrink: 0; }
.sk-search-overlay__product div { display: flex; flex-direction: column; gap: 0.15rem; min-width: 0; flex: 1; }
.sk-search-overlay__product-brand { font-size: 0.66rem; font-weight: 700; letter-spacing: 0.13em; color: var(--sk-muted); }
.sk-search-overlay__product strong { font-size: 0.92rem; font-weight: 500; line-height: 1.3;
	display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.sk-search-overlay__product em { font-style: normal; font-family: var(--sk-font-serif); font-size: 1rem; font-weight: 500; color: var(--sk-accent); }
.sk-search-overlay__more {
	display: block;
	margin-top: 1.5rem;
	padding: 1rem;
	text-align: center;
	font-size: 0.92rem; font-weight: 600;
	color: var(--sk-accent);
	background: var(--sk-surface);
	border-radius: var(--sk-r-md);
}
.sk-search-overlay__more:hover { background: var(--sk-surface-2); }

body.sk-search-open { overflow: hidden; }
.sk-filter-clear {
	display: inline-block;
	font-size: 0.85rem;
	color: var(--sk-accent);
	text-decoration: underline;
	background: transparent; border: 0;
	cursor: pointer;
	padding: 0.5rem 0.75rem;
}
.sk-shop-filters__actions {
	display: flex; gap: 0.5rem; align-items: center;
	margin-top: 1rem;
	padding-top: 1rem;
	border-top: 1px solid var(--sk-border-2);
}
.sk-shop-filters__actions .sk-btn { flex: 1; }

/* Shop loading state */
.sk-shop-products.is-loading {
	opacity: 0.5;
	pointer-events: none;
	transition: opacity 200ms;
}

/* ═══════════════════════════════════════════════════════════
   CHI SIAMO — page-chi-siamo.php
   ═══════════════════════════════════════════════════════════ */
.sk-main--about, .sk-main--contact { padding: 0; }

.sk-about-hero {
	padding: clamp(3rem, 2rem + 2vw, 5rem) 0;
	background: var(--sk-surface);
}
.sk-about-hero__inner {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: clamp(2rem, 1rem + 2vw, 4rem);
	align-items: center;
}
@media (max-width: 880px) { .sk-about-hero__inner { grid-template-columns: 1fr; } }

.sk-about-hero__title {
	font-family: var(--sk-font-serif);
	font-size: clamp(2.5rem, 1.8rem + 3vw, 4.5rem);
	font-weight: 400;
	line-height: 1.02;
	letter-spacing: -0.03em;
	color: var(--sk-text);
	margin: 1rem 0 1.5rem;
}
.sk-about-hero__title em { color: var(--sk-accent); font-style: italic; }
.sk-about-hero__lead {
	font-size: var(--sk-size-lead);
	color: var(--sk-text-2);
	line-height: 1.6;
	max-width: 520px;
}
.sk-about-hero__media {
	margin: 0;
	aspect-ratio: 4/5;
	border-radius: var(--sk-r-lg);
	overflow: hidden;
	box-shadow: var(--sk-glow-lg);
}
.sk-about-hero__media img { width: 100%; height: 100%; object-fit: cover; }

.sk-about-story {
	padding: var(--sk-section-y) 0;
	background: var(--sk-bg);
}
.sk-about-story__inner {
	display: grid;
	grid-template-columns: 1fr 1.2fr;
	gap: clamp(2rem, 1rem + 3vw, 5rem);
	align-items: center;
}
@media (max-width: 880px) { .sk-about-story__inner { grid-template-columns: 1fr; } }

.sk-about-story__media {
	margin: 0;
	aspect-ratio: 4/5;
	border-radius: var(--sk-r-lg);
	overflow: hidden;
	box-shadow: var(--sk-glow-md);
}
.sk-about-story__media img { width: 100%; height: 100%; object-fit: cover; }
.sk-about-story__title {
	font-family: var(--sk-font-serif);
	font-size: clamp(2rem, 1.5rem + 2vw, 3.25rem);
	font-weight: 400;
	line-height: 1.05;
	color: var(--sk-text);
	margin: 1rem 0 1.5rem;
}
.sk-about-story__title em { color: var(--sk-accent); font-style: italic; }
.sk-about-story__para {
	font-size: 1.05rem;
	line-height: 1.75;
	color: var(--sk-text-2);
	margin-bottom: 1.25rem;
	max-width: 56ch;
}
.sk-about-story__para--dropcap::first-letter {
	font-family: var(--sk-font-serif);
	font-size: 4rem;
	font-weight: 400;
	float: left;
	line-height: 0.9;
	padding: 0.3rem 0.6rem 0 0;
	color: var(--sk-accent);
	font-style: italic;
}
.sk-about-story__quote {
	border-left: 3px solid var(--sk-accent);
	padding: 0.5rem 0 0.5rem 1.5rem;
	font-family: var(--sk-font-serif);
	font-style: italic;
	font-size: clamp(1.2rem, 1rem + 0.5vw, 1.45rem);
	line-height: 1.4;
	color: var(--sk-text);
	margin: 1.5rem 0;
	max-width: 50ch;
}
.sk-about-story__sign { display: flex; flex-direction: column; gap: 0.15rem; padding-top: 1rem; border-top: 1px solid var(--sk-border); margin-top: 0.5rem; }
.sk-about-story__sign span { font-family: var(--sk-font-serif); font-style: italic; font-size: 1.15rem; color: var(--sk-text); }
.sk-about-story__sign small { font-size: 0.78rem; letter-spacing: 0.12em; text-transform: uppercase; color: var(--sk-muted); font-weight: 500; }

.sk-about-values {
	padding: var(--sk-section-y) 0;
	background: var(--sk-surface);
}
.sk-values__grid {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: clamp(1rem, 1vw + 0.5rem, 2rem);
}
@media (max-width: 720px) { .sk-values__grid { grid-template-columns: 1fr; } }

.sk-value-card {
	padding: clamp(1.75rem, 1rem + 1vw, 2.5rem);
	background: var(--sk-white);
	border-radius: var(--sk-r-lg);
	box-shadow: var(--sk-sh-xs);
	transition: transform var(--sk-t-med), box-shadow var(--sk-t-med);
}
.sk-value-card:hover { transform: translateY(-4px); box-shadow: var(--sk-glow-md); }
.sk-value-card__num {
	font-family: var(--sk-font-serif);
	font-size: 2.5rem;
	font-weight: 400;
	color: var(--sk-accent);
	font-style: italic;
	margin-bottom: 0.5rem;
	line-height: 1;
}
.sk-value-card__title {
	font-family: var(--sk-font-serif);
	font-size: 1.5rem;
	font-weight: 500;
	color: var(--sk-text);
	margin-bottom: 0.75rem;
	letter-spacing: -0.015em;
}
.sk-value-card__desc { color: var(--sk-text-2); line-height: 1.6; margin: 0; }

.sk-about-stats {
	padding: clamp(3rem, 2rem + 2vw, 5rem) 0;
	background: var(--sk-text);
	color: var(--sk-white);
}
.sk-stats__grid {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 2rem;
	text-align: center;
}
@media (max-width: 720px) { .sk-stats__grid { grid-template-columns: repeat(2, 1fr); } }

.sk-stat strong {
	display: block;
	font-family: var(--sk-font-serif);
	font-size: clamp(2.5rem, 2rem + 2vw, 4rem);
	font-weight: 400;
	color: var(--sk-secondary);
	line-height: 1;
	margin-bottom: 0.4rem;
}
.sk-stat span {
	font-size: 0.78rem;
	font-weight: 500;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: rgba(255, 255, 255, 0.75);
}

.sk-about-cta { padding: var(--sk-section-y) 0; background: var(--sk-bg); text-align: center; }
.sk-about-cta__inner { max-width: 640px; margin: 0 auto; }
.sk-about-cta__title {
	font-family: var(--sk-font-serif);
	font-size: clamp(1.75rem, 1.4rem + 1.5vw, 2.5rem);
	font-weight: 400;
	color: var(--sk-text);
	margin-bottom: 1rem;
	letter-spacing: -0.02em;
}
.sk-about-cta__desc { color: var(--sk-muted); font-size: var(--sk-size-lead); margin-bottom: 2rem; }
.sk-about-cta__actions { display: flex; gap: 0.75rem; justify-content: center; flex-wrap: wrap; }

/* ═══════════════════════════════════════════════════════════
   CONTATTI — page-contatti.php
   ═══════════════════════════════════════════════════════════ */
.sk-contact-hero {
	padding: clamp(3rem, 2rem + 2vw, 5rem) 0 clamp(2rem, 1rem + 1vw, 3rem);
	background: var(--sk-surface);
	text-align: center;
}
.sk-contact-hero__title {
	font-family: var(--sk-font-serif);
	font-size: clamp(2rem, 1.5rem + 2vw, 3.5rem);
	font-weight: 400;
	letter-spacing: -0.025em;
	color: var(--sk-text);
	margin: 1rem 0 1rem;
}
.sk-contact-hero__title em { color: var(--sk-accent); font-style: italic; }
.sk-contact-hero__lead {
	font-size: var(--sk-size-lead);
	color: var(--sk-text-2);
	max-width: 580px;
	margin: 0 auto;
	line-height: 1.55;
}

.sk-contact-channels { padding: clamp(3rem, 2rem + 2vw, 5rem) 0; background: var(--sk-bg); }
.sk-channels__grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: clamp(1rem, 1vw + 0.5rem, 1.75rem);
}
@media (max-width: 880px) { .sk-channels__grid { grid-template-columns: 1fr; } }

.sk-channel-card {
	display: flex;
	flex-direction: column;
	gap: 1rem;
	padding: clamp(1.75rem, 1rem + 1vw, 2.5rem);
	background: var(--sk-white);
	border: 1px solid var(--sk-border);
	border-radius: var(--sk-r-lg);
	color: inherit;
	transition: all var(--sk-t-med);
}
.sk-channel-card:hover {
	transform: translateY(-4px);
	box-shadow: var(--sk-glow-md);
	border-color: var(--sk-border-2);
}
.sk-channel-card__icon {
	width: 56px; height: 56px;
	padding: 12px;
	color: var(--sk-accent);
	background: var(--sk-surface);
	border-radius: var(--sk-r-full);
}
.sk-channel-card--wa .sk-channel-card__icon { color: #25D366; background: rgba(37, 211, 102, 0.1); }
.sk-channel-card__icon svg { width: 100%; height: 100%; }
.sk-channel-card__title {
	font-family: var(--sk-font-serif);
	font-size: 1.5rem;
	font-weight: 500;
	color: var(--sk-text);
	margin: 0;
}
.sk-channel-card__desc { color: var(--sk-text-2); margin: 0; line-height: 1.5; flex: 1; }
.sk-channel-card__cta {
	display: inline-block;
	margin-top: auto;
	font-size: 0.85rem; font-weight: 600;
	letter-spacing: 0.08em;
	color: var(--sk-accent);
	text-transform: uppercase;
}

.sk-contact-form-section { padding: var(--sk-section-y) 0; background: var(--sk-surface); }
.sk-contact-form-section__inner {
	display: grid;
	grid-template-columns: 1fr 1.3fr;
	gap: clamp(2rem, 1rem + 2vw, 4rem);
	align-items: start;
}
@media (max-width: 880px) { .sk-contact-form-section__inner { grid-template-columns: 1fr; } }

.sk-contact-form-info__title {
	font-family: var(--sk-font-serif);
	font-size: clamp(1.75rem, 1.5rem + 1.5vw, 2.5rem);
	font-weight: 400;
	letter-spacing: -0.02em;
	margin: 0.75rem 0 1rem;
}
.sk-contact-form-info__title em { color: var(--sk-accent); font-style: italic; }
.sk-contact-info-list { display: flex; flex-direction: column; gap: 1rem; margin-top: 2rem; padding: 1.5rem; background: var(--sk-white); border-radius: var(--sk-r-md); }
.sk-contact-info-list li { display: flex; flex-direction: column; gap: 0.1rem; }
.sk-contact-info-list strong { font-size: 0.78rem; font-weight: 600; letter-spacing: 0.1em; text-transform: uppercase; color: var(--sk-muted); }
.sk-contact-info-list span { color: var(--sk-text); font-weight: 500; }

.sk-contact-form {
	display: flex;
	flex-direction: column;
	gap: 1rem;
	padding: clamp(1.5rem, 1rem + 1vw, 2.25rem);
	background: var(--sk-white);
	border-radius: var(--sk-r-lg);
	box-shadow: var(--sk-sh-sm);
}
.sk-contact-form label { display: flex; flex-direction: column; gap: 0.4rem; margin: 0; font-size: 0.9rem; font-weight: 500; color: var(--sk-text); }
.sk-form-row--two { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; }
@media (max-width: 520px) { .sk-form-row--two { grid-template-columns: 1fr; } }
.sk-form-check { flex-direction: row !important; align-items: flex-start; gap: 0.5rem !important; font-size: 0.85rem; color: var(--sk-text-2); cursor: pointer; }
.sk-form-check input { margin-top: 0.2rem; accent-color: var(--sk-accent); width: 16px; height: 16px; }

.sk-contact-faq { padding: var(--sk-section-y) 0; background: var(--sk-bg); }
.sk-faq-list { display: flex; flex-direction: column; gap: 0.75rem; max-width: 760px; margin: 0 auto; }
.sk-faq-item {
	background: var(--sk-surface);
	border-radius: var(--sk-r-md);
	padding: 1.25rem 1.5rem;
	transition: background var(--sk-t-fast);
}
.sk-faq-item[open] { background: var(--sk-white); box-shadow: var(--sk-sh-sm); }
.sk-faq-item summary {
	font-family: var(--sk-font-serif);
	font-size: 1.15rem;
	font-weight: 500;
	cursor: pointer;
	list-style: none;
	display: flex;
	justify-content: space-between;
	align-items: center;
	color: var(--sk-text);
}
.sk-faq-item summary::-webkit-details-marker { display: none; }
.sk-faq-item summary::after {
	content: "+";
	font-family: var(--sk-font-sans);
	font-size: 1.5rem;
	color: var(--sk-accent);
	margin-left: 1rem;
	transition: transform var(--sk-t-fast);
}
.sk-faq-item[open] summary::after { content: "−"; }
.sk-faq-item p { margin: 0.75rem 0 0; color: var(--sk-text-2); line-height: 1.6; }

/* ═══════════════════════════════════════════════════════════
   PAGINA HUB RITUALI
   ═══════════════════════════════════════════════════════════ */
.sk-rituali-hero {
	padding: clamp(3rem, 2rem + 2vw, 5rem) 0 clamp(2rem, 1rem + 1vw, 3rem);
	background: var(--sk-surface);
	text-align: center;
}
.sk-rituali-hero__title {
	font-family: var(--sk-font-serif);
	font-size: clamp(2rem, 1.5rem + 2vw, 3.5rem);
	font-weight: 400;
	line-height: 1.05;
	letter-spacing: -0.025em;
	color: var(--sk-text);
	margin: 0.75rem 0 1rem;
}
.sk-rituali-hero__title em {
	color: var(--sk-accent);
	font-style: italic;
}
.sk-rituali-hero__lead {
	font-size: var(--sk-size-lead);
	line-height: 1.55;
	color: var(--sk-muted);
	max-width: 580px;
	margin: 0 auto;
}

.sk-rituali-grid { padding: var(--sk-section-y) 0; background: var(--sk-bg); }

.sk-rituale-block {
	display: grid;
	gap: 2rem;
	margin-bottom: clamp(3rem, 2rem + 2vw, 5rem);
	padding-bottom: clamp(3rem, 2rem + 2vw, 5rem);
	border-bottom: 1px solid var(--sk-border);
}
.sk-rituale-block:last-child { border-bottom: 0; padding-bottom: 0; margin-bottom: 0; }

.sk-rituale-block__head {
	display: grid;
	grid-template-columns: 1fr 1.4fr;
	gap: clamp(1.5rem, 1rem + 2vw, 3rem);
	align-items: center;
}
@media (max-width: 760px) { .sk-rituale-block__head { grid-template-columns: 1fr; } }

.sk-rituale-block__media {
	position: relative;
	aspect-ratio: 4/3;
	margin: 0;
	border-radius: var(--sk-r-lg);
	overflow: hidden;
	box-shadow: var(--sk-glow-md);
}
.sk-rituale-block__media img {
	width: 100%; height: 100%;
	object-fit: cover;
	transition: transform 800ms var(--sk-e-out);
}
.sk-rituale-block:hover .sk-rituale-block__media img { transform: scale(1.04); }

.sk-rituale-block__intro { display: flex; flex-direction: column; gap: 0.9rem; }
.sk-rituale-block__icon {
	width: 56px; height: 56px;
	padding: 12px;
	color: var(--sk-accent);
	background: var(--sk-surface);
	border-radius: var(--sk-r-full);
}
.sk-rituale-block__icon svg { width: 100%; height: 100%; }
.sk-rituale-block__name {
	font-family: var(--sk-font-serif);
	font-size: clamp(1.75rem, 1.4rem + 1.5vw, 2.75rem);
	font-weight: 400;
	letter-spacing: -0.02em;
	color: var(--sk-text);
	margin: 0;
	line-height: 1.05;
}
.sk-rituale-block__desc {
	font-size: var(--sk-size-lead);
	color: var(--sk-text-2);
	margin: 0;
}
.sk-rituale-block__more {
	font-size: 0.95rem;
	color: var(--sk-muted);
	line-height: 1.5;
	margin: 0;
}
.sk-rituale-block .sk-btn--sm { padding: 0.6rem 1.25rem; font-size: 0.78rem; align-self: flex-start; }

.sk-pgrid--4 {
	grid-template-columns: repeat(4, 1fr);
}
@media (max-width: 980px) { .sk-pgrid--4 { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 720px) { .sk-pgrid--4 { grid-template-columns: repeat(2, 1fr); } }

/* ═══════════════════════════════════════════════════════════
   v7 — Sora rounded sans, no più italic display.
   Override globale: dove c'era italic per accent uso peso+colore.
   ═══════════════════════════════════════════════════════════ */
em { font-style: italic; } /* body inline emphasis: fallback system serif italic */

/* Accent em dentro titoli display: niente italic, peso + colore */
.sk-hero-v3__title em,
.sk-rit-hero__title em,
.sk-rit-intro__title em,
.sk-rit-quiz-cta__title em,
.sk-quiz-hero__title em,
.sk-rituali-hero__title em,
.sk-routine-v3__title em,
.sk-section-head__title em,
.sk-result__title em,
.sk-newsletter__title em,
.sk-newsletter__title-sub,
.sk-about-hero__title em,
.sk-about-story__title em,
.sk-about-cta__title em,
.sk-contact-hero__title em,
.sk-contact-form-info__title em,
.sk-cat-card__cta em,
.sk-editorial__title em,
.sk-editorial__title-accent {
	font-style: normal !important;
	font-weight: 700;
	color: var(--sk-accent);
}

/* Numeri grandi: no italic, peso light */
.sk-rstep__num,
.sk-rit-step__num-bg,
.sk-bento-card__num,
.sk-step__num,
.sk-result__num,
.sk-rit-step__num-label strong,
.sk-value-card__num,
.sk-routine__num,
.sk-quiz-step__num,
.sk-404__code,
.sk-stat strong {
	font-style: normal !important;
	font-weight: 300;
	letter-spacing: -0.02em;
}

/* Brand "KO" senza italic ma peso medio + accent */
.sk-header__brand-ko,
.sk-footer__brand-ko {
	font-style: normal;
	font-weight: 600;
}

/* Lead/intro/quote: weight light invece di italic */
.sk-routine-v2__intro,
.sk-page__content .sk-lead,
.sk-rit-step__cosa,
.sk-about-story__quote,
.sk-rit-intro__text em,
.sk-rit-step__title small,
.sk-rit-skin-list__item dt,
.sk-quiz-loading p,
.sk-routine-v3__lead,
.sk-bestsellers blockquote,
.sk-prose blockquote {
	font-style: normal;
	font-weight: 400;
}

/* Heading globale: weight medium, letter-spacing tighter */
h1, h2, h3, h4, h5, h6 {
	font-weight: 600;
	letter-spacing: -0.02em;
}
h1 { font-weight: 600; letter-spacing: -0.035em; }
h2 { font-weight: 600; letter-spacing: -0.025em; }

/* ═══════════════════════════════════════════════════════════
   MOBILE MENU OVERLAY full-screen (sostituisce sk-mobile-nav)
   ═══════════════════════════════════════════════════════════ */
.sk-mobile-overlay {
	position: fixed; inset: 0; z-index: 1100;
	background: var(--sk-bg);
	transform: translateX(-100%);
	transition: transform 350ms var(--sk-e-out);
	overflow-y: auto;
}
.sk-mobile-overlay.is-open { transform: translateX(0); }
.sk-mobile-overlay__head {
	display: flex; align-items: center; justify-content: space-between;
	padding: 1.25rem 0;
	border-bottom: 1px solid var(--sk-border);
}
.sk-mobile-overlay__brand {
	font-family: var(--sk-font-serif);
	font-size: 1.6rem;
	font-weight: 600;
	letter-spacing: -0.01em;
	color: var(--sk-text);
}
.sk-mobile-overlay__close {
	width: 44px; height: 44px;
	background: var(--sk-surface);
	border: 0; border-radius: var(--sk-r-full);
	cursor: pointer;
	display: inline-flex; align-items: center; justify-content: center;
	color: var(--sk-text);
}

.sk-mobile-overlay__body { padding: 2rem 0 4rem; }

.sk-mobile-overlay__primary { margin-bottom: 2.5rem; }
.sk-mobile-overlay__list {
	list-style: none;
	padding: 0;
	margin: 0;
	display: flex;
	flex-direction: column;
	gap: 0.5rem;
}
.sk-mobile-overlay__list li { margin: 0; }
.sk-mobile-overlay__list a {
	display: block;
	padding: 1rem 0;
	font-family: var(--sk-font-sans);
	font-size: 1rem;
	font-weight: 600;
	letter-spacing: 0.18em;
	text-transform: uppercase;        /* MOBILE UPPERCASE come richiesto */
	color: var(--sk-text);
	border-bottom: 1px solid var(--sk-border);
	transition: color var(--sk-t-fast), padding-left var(--sk-t-fast);
}
.sk-mobile-overlay__list a:hover,
.sk-mobile-overlay__list .current-menu-item a {
	color: var(--sk-accent);
	padding-left: 0.5rem;
}

.sk-mobile-overlay__quick {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 0.5rem;
	margin-bottom: 2rem;
}
.sk-mobile-overlay__quick-item {
	display: flex; align-items: center; gap: 0.6rem;
	padding: 0.85rem 1rem;
	background: var(--sk-surface);
	border-radius: var(--sk-r-md);
	color: var(--sk-text);
	font-size: 0.9rem;
	font-weight: 500;
}
.sk-mobile-overlay__quick-item svg { color: var(--sk-accent); flex-shrink: 0; }
.sk-mobile-overlay__quick-item:hover { background: var(--sk-surface-2); }

.sk-mobile-overlay__promo {
	padding: 1rem;
	text-align: center;
	background: var(--sk-text);
	color: var(--sk-secondary);
	border-radius: var(--sk-r-md);
}
.sk-mobile-overlay__promo small {
	font-size: 0.78rem;
	letter-spacing: 0.04em;
}

body.sk-mobile-menu-open { overflow: hidden; }

/* ═══════════════════════════════════════════════════════════
   BOTTOM NAVIGATION mobile (sticky)
   ═══════════════════════════════════════════════════════════ */
.sk-bottom-nav {
	display: none;
	position: fixed; bottom: 0; left: 0; right: 0;
	z-index: 90;
	background: rgba(255, 255, 255, 0.96);
	backdrop-filter: saturate(1.6) blur(16px);
	-webkit-backdrop-filter: saturate(1.6) blur(16px);
	border-top: 1px solid var(--sk-border);
	padding: 0.4rem 0.5rem env(safe-area-inset-bottom);
	display: none;
}
@media (max-width: 720px) {
	.sk-bottom-nav { display: flex; }
	body { padding-bottom: 70px; }
}
.sk-bottom-nav { display: none; }
@media (max-width: 720px) { .sk-bottom-nav { display: flex; } }

.sk-bottom-nav {
	gap: 0.25rem;
}
.sk-bottom-nav__item {
	flex: 1;
	display: flex; flex-direction: column; align-items: center; justify-content: center;
	gap: 0.2rem;
	padding: 0.55rem 0.25rem;
	font-size: 0.65rem;
	font-weight: 600;
	letter-spacing: 0.04em;
	text-transform: uppercase;
	color: var(--sk-muted);
	transition: color 200ms var(--sk-e-out);
	min-height: 56px;
	position: relative;
}
.sk-bottom-nav__item.is-active {
	color: var(--sk-accent);
}
.sk-bottom-nav__item.is-active::before {
	content: ""; position: absolute; top: 0;
	left: 50%; transform: translateX(-50%);
	width: 24px; height: 2px;
	background: var(--sk-accent);
	border-radius: 2px;
}
.sk-bottom-nav__icon {
	position: relative;
	display: flex; align-items: center; justify-content: center;
	width: 24px; height: 24px;
}
.sk-bottom-nav__icon svg { width: 22px; height: 22px; }
.sk-bottom-nav__badge {
	position: absolute; top: -4px; right: -8px;
	min-width: 16px; height: 16px;
	padding: 0 4px;
	font-size: 0.62rem; font-weight: 700;
	color: var(--sk-white); background: var(--sk-accent);
	border-radius: var(--sk-r-full);
	display: inline-flex; align-items: center; justify-content: center;
	line-height: 1;
}
.sk-bottom-nav__label { line-height: 1; }

/* ═══════════════════════════════════════════════════════════
   SHOP FILTERS — Mobile drawer + Desktop refinements
   ═══════════════════════════════════════════════════════════ */
.sk-shop-filters__mobile-trigger {
	display: none;
	align-items: center; gap: 0.5rem;
	padding: 0.7rem 1.25rem;
	background: var(--sk-text);
	color: var(--sk-white);
	border: 0;
	border-radius: var(--sk-r-full);
	font-family: var(--sk-font-sans);
	font-size: 0.85rem; font-weight: 600;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	cursor: pointer;
	margin-bottom: 1rem;
	min-height: 44px;
	box-shadow: var(--sk-sh-sm);
}
.sk-shop-filters__mobile-trigger svg { flex-shrink: 0; }
.sk-shop-filters__mobile-badge {
	display: inline-flex; align-items: center; justify-content: center;
	min-width: 22px; height: 22px; padding: 0 0.4rem;
	background: var(--sk-accent); color: var(--sk-white);
	font-size: 0.72rem; font-weight: 700;
	border-radius: var(--sk-r-full);
	margin-left: 0.25rem;
}

.sk-shop-filters__close-mobile {
	display: none;
	position: absolute; top: 1rem; right: 1rem; z-index: 2;
	width: 40px; height: 40px;
	background: var(--sk-surface);
	border: 0;
	border-radius: var(--sk-r-full);
	color: var(--sk-text);
	cursor: pointer;
	align-items: center; justify-content: center;
}

@media (max-width: 980px) {
	.sk-shop-filters__mobile-trigger { display: inline-flex; }

	.sk-shop-filters {
		position: fixed; inset: 0; z-index: 1100;
		max-height: 100vh; height: 100vh;
		padding: 4rem 1.25rem 2rem;
		background: var(--sk-bg);
		border-radius: 0;
		transform: translateX(100%);
		transition: transform 350ms var(--sk-e-out);
		overflow-y: auto;
	}
	.sk-shop-filters.is-mobile-open {
		transform: translateX(0);
	}
	.sk-shop-filters__close-mobile { display: inline-flex; }

	body.sk-filters-open { overflow: hidden; }
}

/* ═══════════════════════════════════════════════════════════
   FIX MOBILE + ACCESSIBILITY (post-audit)
   ═══════════════════════════════════════════════════════════ */

/* Click target ≥ 44px su nav header (WCAG 2.5.5) */
@media (min-width: 901px) {
	.sk-menu a {
		min-height: 44px;
		display: inline-flex;
		align-items: center;
		padding: 0.5rem 0;
	}
}

/* Section padding-top hero — evita H1 attaccato a sticky header */
.sk-rituali-hero,
.sk-contact-hero,
.sk-about-hero,
.sk-cart-page-hero {
	padding-top: clamp(2.5rem, 1.5rem + 2vw, 4rem) !important;
}

/* Mobile-first overrides cruciali */
@media (max-width: 720px) {
	/* Sezioni: meno padding verticale, piu' fluidità */
	.sk-bestsellers-v3,
	.sk-cats-v3,
	.sk-lookbook,
	.sk-services,
	.sk-routine,
	.sk-brands,
	.sk-trust-bar {
		padding: clamp(2rem, 2rem + 2vw, 3rem) 0;
	}
	/* Card prodotto: padding ridotto, testi visibili */
	.sk-pcard {
		padding: 0.5rem 0.5rem 0.75rem;
	}
	.sk-pcard__title {
		font-size: 0.82rem;
		line-height: 1.3;
	}
	.sk-pcard__price {
		font-size: 0.92rem;
	}
	/* Routine bento mobile: aspect ratio fissato */
	.sk-bento-card {
		min-height: 180px;
	}
	/* Section head divider: ricalibrato */
	.sk-section-head__title {
		font-size: clamp(1.5rem, 1.3rem + 1vw, 2rem);
	}
	/* Hero proof items: spacing su mobile */
	.sk-hero-v3__title { font-size: clamp(2rem, 1.5rem + 4vw, 3rem); }
	.sk-hero-v3__lead { font-size: 1rem; }
	/* Brand grid mobile */
	.sk-brand-grid { grid-template-columns: repeat(2, 1fr); }
}

/* Disabilita zoom WC trigger overflow */
.woocommerce-product-gallery__trigger {
	display: none !important;
}

/* WhatsApp float: sposta più in alto su mobile per non coprire CTA */
@media (max-width: 720px) {
	.sk-wa-float {
		bottom: 80px !important;
	}
}

/* ── Reduce motion ────────────────────────────────────────── */
@media (prefers-reduced-motion: reduce) {
	*, *::before, *::after {
		animation-duration: 0.01ms !important;
		animation-iteration-count: 1 !important;
		transition-duration: 0.01ms !important;
	}
}
