/* ============================================================================
   LUMALUX — Doposole V2 (landing page)
   Light luxury con accenti sun-gold per atmosfera estiva premium
   ============================================================================ */

:root {
	--ds-bg:        #fdfaf3;   /* warm cream chiaro */
	--ds-bg-2:      #f7efd9;   /* sand light */
	--ds-surface:   #ffffff;
	--ds-surface-2: #faf3e2;   /* sand cream */
	--ds-border:    #e8dec4;
	--ds-gold:      #BA993F;
	--ds-gold-2:    #d4b65a;
	--ds-gold-deep: #8a6e22;
	--ds-sun:       #e89a3a;   /* sun warm */
	--ds-sun-soft:  rgba(232, 154, 58, 0.10);
	--ds-text:      #1a1a1a;
	--ds-muted:     #6c6c6c;
	--ds-muted-2:   #9a9a9a;
	--ds-font:      'Roboto', -apple-system, BlinkMacSystemFont, 'Segoe UI', Arial, sans-serif;
	--ds-serif:     'Cormorant Garamond', 'Playfair Display', Georgia, serif;
}

.lumalux-doposole-v2 {
	background: var(--ds-bg);
	color: var(--ds-text);
	font-family: var(--ds-font);
	-webkit-font-smoothing: antialiased;
	overflow-x: hidden;
}
.lumalux-doposole-v2 *{box-sizing:border-box;}

/* Common */
.ds-section-inner {
	max-width: 1280px;
	margin: 0 auto;
	padding: 110px 32px;
}
.ds-eyebrow {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	color: var(--ds-gold);
	font-size: 11px;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.3em;
	margin-bottom: 22px;
}
.ds-eyebrow svg { color: var(--ds-sun); }
.ds-eyebrow-center {
	display: inline-flex;
	justify-content: center;
}
.ds-section-title {
	font-family: var(--ds-serif);
	font-size: 56px;
	font-weight: 400;
	line-height: 1.05;
	letter-spacing: -0.01em;
	color: var(--ds-text);
	margin: 0 0 28px;
}
.ds-section-title em {
	font-style: italic;
	color: var(--ds-gold);
}
.ds-section-title-sm { font-size: 42px; }
.ds-section-title-center { text-align: center; }
.ds-section-lead {
	font-size: 17px;
	color: var(--ds-muted);
	line-height: 1.7;
	max-width: 640px;
	margin: 0 auto 48px;
}

/* Buttons */
.ds-btn {
	display: inline-flex;
	align-items: center;
	gap: 12px;
	padding: 16px 30px;
	font-size: 13px;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.15em;
	text-decoration: none;
	cursor: pointer;
	border: 1px solid;
	transition: all 0.3s cubic-bezier(0.2, 0.8, 0.2, 1);
	white-space: nowrap;
}
.ds-btn-primary {
	background: var(--ds-gold);
	color: #fff;
	border-color: var(--ds-gold);
	box-shadow: 0 12px 32px rgba(186, 153, 63, 0.30);
}
.ds-btn-primary:hover {
	background: var(--ds-gold-deep);
	border-color: var(--ds-gold-deep);
	color: #fff;
	transform: translateY(-2px);
	box-shadow: 0 16px 40px rgba(186, 153, 63, 0.40);
}
.ds-btn-primary strong {
	background: rgba(255,255,255,0.18);
	padding: 4px 10px;
	border-radius: 0;
	font-weight: 700;
}
.ds-btn-ghost {
	background: transparent;
	color: var(--ds-text);
	border-color: var(--ds-border);
}
.ds-btn-ghost:hover {
	background: var(--ds-surface);
	border-color: var(--ds-gold);
	color: var(--ds-gold);
}
.ds-btn-large { padding: 18px 36px; font-size: 14px; }
.ds-btn-xl { padding: 22px 48px; font-size: 15px; }

/* ═══════════════════════════════════════════════════════
   HERO
   ═══════════════════════════════════════════════════════ */
.ds-hero {
	position: relative;
	min-height: 100vh;
	display: flex;
	align-items: center;
	padding: 100px 32px 60px;
	overflow: hidden;
	background: var(--ds-bg);
}
.ds-hero-bg {
	position: absolute;
	inset: 0;
	z-index: 0;
	background:
		radial-gradient(circle at 50% 30%, rgba(232, 154, 58, 0.20), transparent 60%),
		linear-gradient(180deg, #fefaef 0%, var(--ds-bg) 60%);
}
.ds-hero-sun {
	position: absolute;
	top: -200px;
	right: -200px;
	width: 700px;
	height: 700px;
	border-radius: 50%;
	background: radial-gradient(circle, rgba(232, 154, 58, 0.35) 0%, rgba(186, 153, 63, 0.10) 40%, transparent 70%);
	filter: blur(20px);
	animation: dsSunPulse 8s ease-in-out infinite;
}
@keyframes dsSunPulse {
	0%, 100% { transform: scale(1); opacity: 0.85; }
	50%      { transform: scale(1.08); opacity: 1; }
}
.ds-hero-grain {
	position: absolute;
	inset: 0;
	background-image:
		radial-gradient(circle at 20% 30%, rgba(186, 153, 63, 0.05) 1px, transparent 1px),
		radial-gradient(circle at 75% 70%, rgba(232, 154, 58, 0.07) 1.5px, transparent 1.5px);
	background-size: 80px 80px, 110px 110px;
}
.ds-hero-grid {
	position: relative;
	z-index: 1;
	max-width: 1280px;
	margin: 0 auto;
	display: grid;
	grid-template-columns: 1.1fr 1fr;
	gap: 64px;
	align-items: center;
	width: 100%;
}
.ds-hero-content {
	animation: dsFadeUp 1.2s ease-out;
}
@keyframes dsFadeUp {
	from { opacity: 0; transform: translateY(20px); }
	to   { opacity: 1; transform: translateY(0); }
}
.ds-hero-title {
	font-family: var(--ds-serif);
	font-size: clamp(48px, 8vw, 92px);
	font-weight: 400;
	line-height: 0.95;
	letter-spacing: -0.02em;
	color: var(--ds-text);
	margin: 0 0 28px;
}
.ds-hero-title .ds-line-1 {
	display: block;
	color: var(--ds-text);
}
.ds-hero-title .ds-line-2 {
	display: block;
	font-style: italic;
	background: linear-gradient(135deg, var(--ds-gold) 0%, var(--ds-sun) 50%, var(--ds-gold) 100%);
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent;
	background-clip: text;
}
.ds-hero-tagline {
	font-size: 18px;
	line-height: 1.7;
	color: var(--ds-muted);
	margin: 0 0 28px;
	max-width: 540px;
}
.ds-hero-tagline em {
	font-style: italic;
}
.ds-hero-tagline strong {
	display: inline;
	color: var(--ds-text);
	font-weight: 700;
	background: linear-gradient(180deg, transparent 65%, rgba(232, 154, 58, 0.3) 65%);
	padding: 0 4px;
}
.ds-limited {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	padding: 12px 18px;
	background: var(--ds-sun-soft);
	border: 1px solid rgba(232, 154, 58, 0.3);
	color: var(--ds-gold-deep);
	font-size: 13px;
	margin: 0 0 32px;
	letter-spacing: 0.04em;
}
.ds-limited svg { color: var(--ds-sun); }
.ds-limited strong { color: var(--ds-gold-deep); font-weight: 700; }
.ds-hero-cta {
	display: flex;
	gap: 14px;
	margin-bottom: 36px;
	flex-wrap: wrap;
}
.ds-hero-trust {
	display: flex;
	flex-wrap: wrap;
	color: var(--ds-muted);
	font-size: 12px;
	letter-spacing: 0.12em;
	text-transform: uppercase;
}
.ds-hero-trust > span {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	padding: 0 14px 0 0;
}
.ds-hero-trust .sep { color: var(--ds-gold); padding: 0 14px 0 0; }
.ds-hero-trust svg { color: var(--ds-gold); }

/* Visual side */
.ds-hero-visual {
	position: relative;
	display: flex;
	align-items: center;
	justify-content: center;
	animation: dsFadeUp 1.4s ease-out 0.2s both;
}
.ds-hero-product {
	position: relative;
	width: 100%;
	max-width: 460px;
}
.ds-hero-product-img {
	width: 100%;
	height: auto;
	display: block;
	position: relative;
	z-index: 2;
	animation: dsFloat 6s ease-in-out infinite;
}
@keyframes dsFloat {
	0%, 100% { transform: translateY(0) rotate(-2deg); }
	50%      { transform: translateY(-14px) rotate(2deg); }
}
.ds-hero-product-glow {
	position: absolute;
	inset: -8% -8%;
	background: radial-gradient(circle, rgba(232, 154, 58, 0.40) 0%, transparent 65%);
	filter: blur(36px);
	z-index: 1;
	animation: dsGlow 4s ease-in-out infinite;
}
@keyframes dsGlow {
	0%, 100% { opacity: 0.7; transform: scale(1); }
	50%      { opacity: 1; transform: scale(1.1); }
}
.ds-hero-product-shadow {
	position: absolute;
	bottom: -16%;
	left: 12%;
	right: 12%;
	height: 40px;
	background: radial-gradient(ellipse, rgba(0,0,0,0.20) 0%, transparent 70%);
	filter: blur(14px);
	z-index: 0;
}

/* Stamp circolare "Limited 1000 pezzi" */
.ds-hero-stamp {
	position: absolute;
	top: 24px;
	right: 8px;
	width: 130px;
	height: 130px;
	border-radius: 50%;
	background: var(--ds-gold);
	color: #fff;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	box-shadow: 0 16px 40px rgba(186, 153, 63, 0.40);
	z-index: 3;
	transform: rotate(-12deg);
	animation: dsStampIn 1.2s cubic-bezier(0.2, 0.8, 0.2, 1) 0.8s both;
}
@keyframes dsStampIn {
	from { opacity: 0; transform: scale(0.5) rotate(-30deg); }
	to   { opacity: 1; transform: scale(1) rotate(-12deg); }
}
.ds-hero-stamp::before {
	content: '';
	position: absolute;
	inset: 6px;
	border: 1px dashed rgba(255,255,255,0.5);
	border-radius: 50%;
}
.ds-stamp-top, .ds-stamp-bot {
	font-size: 9px;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.2em;
	color: #fff;
}
.ds-hero-stamp strong {
	font-family: var(--ds-serif);
	font-size: 38px;
	font-weight: 600;
	line-height: 1;
	margin: 2px 0;
	color: #fff;
}

/* ═══════════════════════════════════════════════════════
   FEATURES (3 colonne)
   ═══════════════════════════════════════════════════════ */
.ds-features {
	background: var(--ds-surface);
	border-top: 1px solid var(--ds-border);
}
.ds-features .ds-section-inner { text-align: center; }
.ds-features-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 32px;
	margin-top: 56px;
}
.ds-feature {
	padding: 48px 32px;
	background: var(--ds-bg);
	border: 1px solid var(--ds-border);
	text-align: center;
	transition: transform 0.4s ease, border-color 0.4s ease, box-shadow 0.4s ease;
	position: relative;
}
.ds-feature:hover {
	transform: translateY(-6px);
	border-color: var(--ds-gold);
	box-shadow: 0 16px 40px rgba(186, 153, 63, 0.15);
}
.ds-feature-num {
	font-family: var(--ds-serif);
	font-size: 80px;
	font-weight: 500;
	line-height: 1;
	color: var(--ds-gold);
	margin-bottom: 16px;
	background: linear-gradient(135deg, var(--ds-gold), var(--ds-sun));
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent;
	background-clip: text;
}
.ds-feature h3 {
	font-family: var(--ds-serif);
	font-size: 24px;
	font-weight: 500;
	color: var(--ds-text);
	margin: 0 0 12px;
}
.ds-feature p {
	margin: 0;
	color: var(--ds-muted);
	font-size: 14px;
	line-height: 1.7;
}

/* ═══════════════════════════════════════════════════════
   INCI (9 ingredienti grid)
   ═══════════════════════════════════════════════════════ */
.ds-inci {
	background: var(--ds-bg);
	position: relative;
}
.ds-inci .ds-section-inner { text-align: center; }
.ds-ingredients {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 20px;
	margin: 48px 0 32px;
	text-align: left;
}
.ds-ingredient {
	padding: 28px 26px;
	background: var(--ds-surface);
	border: 1px solid var(--ds-border);
	position: relative;
	overflow: hidden;
	transition: transform 0.3s ease, border-color 0.3s ease;
}
.ds-ingredient::before {
	content: '';
	position: absolute;
	top: 0; left: 0;
	width: 100%; height: 2px;
	background: linear-gradient(90deg, var(--ds-gold), var(--ds-sun));
	transform: scaleX(0);
	transform-origin: left;
	transition: transform 0.4s ease;
}
.ds-ingredient:hover {
	transform: translateY(-4px);
	border-color: var(--ds-gold);
}
.ds-ingredient:hover::before { transform: scaleX(1); }
.ds-ingredient-highlight {
	background: linear-gradient(135deg, var(--ds-surface-2), var(--ds-surface));
}
.ds-ing-icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 56px;
	height: 56px;
	background: var(--ds-sun-soft);
	color: var(--ds-gold);
	margin-bottom: 16px;
	border-radius: 50%;
	transition: transform 0.3s ease;
}
.ds-ing-icon svg { width: 28px; height: 28px; }
.ds-ingredient:hover .ds-ing-icon {
	transform: rotate(-8deg) scale(1.05);
	background: rgba(232, 154, 58, 0.18);
}
.ds-ingredient h3 {
	font-family: var(--ds-serif);
	font-size: 20px;
	font-weight: 500;
	color: var(--ds-text);
	margin: 0 0 8px;
	letter-spacing: 0.01em;
}
.ds-ingredient p {
	margin: 0;
	color: var(--ds-muted);
	font-size: 13px;
	line-height: 1.65;
}
.ds-inci-note { margin: 24px 0 0; }
.ds-inci-note a {
	color: var(--ds-gold);
	font-size: 13px;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.12em;
	text-decoration: none;
	border-bottom: 1px solid var(--ds-gold);
	padding-bottom: 3px;
	transition: gap 0.2s ease;
}
.ds-inci-note a:hover { color: var(--ds-gold-deep); border-color: var(--ds-gold-deep); }

/* ═══════════════════════════════════════════════════════
   SHOWCASE (prodotto + prezzo)
   ═══════════════════════════════════════════════════════ */
.ds-showcase {
	background: linear-gradient(180deg, var(--ds-bg) 0%, var(--ds-bg-2) 100%);
	position: relative;
}
.ds-showcase-grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 80px;
	align-items: center;
}
.ds-showcase-img {
	position: relative;
	text-align: center;
}
.ds-showcase-img img {
	width: 100%;
	max-width: 420px;
	height: auto;
	display: block;
	margin: 0 auto;
	filter: drop-shadow(0 30px 60px rgba(186, 153, 63, 0.25));
}
.ds-showcase-badge {
	position: absolute;
	top: 24px;
	left: 24px;
	padding: 10px 18px;
	background: var(--ds-gold);
	color: #fff;
	font-size: 11px;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.18em;
	box-shadow: 0 10px 24px rgba(186, 153, 63, 0.30);
}
.ds-showcase-price {
	display: flex;
	flex-direction: column;
	gap: 4px;
	margin: 28px 0;
	padding: 22px 0;
	border-top: 1px solid var(--ds-border);
	border-bottom: 1px solid var(--ds-border);
}
.ds-price-old {
	font-size: 12px;
	color: var(--ds-muted);
	letter-spacing: 0.06em;
	font-style: italic;
}
.ds-price-now {
	font-family: var(--ds-serif);
	font-size: 56px;
	font-weight: 500;
	color: var(--ds-gold);
	line-height: 1;
	letter-spacing: -0.01em;
}
.ds-price-note {
	font-size: 12px;
	color: var(--ds-muted);
	text-transform: uppercase;
	letter-spacing: 0.14em;
}
.ds-showcase-feats {
	list-style: none;
	padding: 0;
	margin: 0 0 32px;
	display: flex;
	flex-direction: column;
	gap: 12px;
}
.ds-showcase-feats li {
	display: flex;
	align-items: flex-start;
	gap: 12px;
	color: var(--ds-text);
	font-size: 15px;
	line-height: 1.55;
}
.ds-showcase-feats li > svg {
	color: var(--ds-gold);
	flex-shrink: 0;
	margin-top: 4px;
	width: 18px;
	height: 18px;
}
.ds-showcase-feats li > span {
	flex: 1 1 auto;
	min-width: 0;
}
.ds-showcase-feats strong { color: var(--ds-text); font-weight: 700; margin-right: 2px; }
.ds-showcase-cta {
	display: flex;
	gap: 12px;
	flex-wrap: wrap;
}

/* ═══════════════════════════════════════════════════════
   UPSELL
   ═══════════════════════════════════════════════════════ */
.ds-upsell {
	background: var(--ds-bg);
}
.ds-upsell-card {
	background: var(--ds-surface);
	border: 1px solid var(--ds-border);
	padding: 40px 48px;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 32px;
	flex-wrap: wrap;
	position: relative;
	overflow: hidden;
}
.ds-upsell-card::before {
	content: '';
	position: absolute;
	top: 0; left: 0; bottom: 0;
	width: 4px;
	background: linear-gradient(180deg, var(--ds-gold), var(--ds-sun));
}
.ds-upsell-text {
	flex: 1;
	min-width: 280px;
}
.ds-upsell-text h3 {
	font-family: var(--ds-serif);
	font-size: 28px;
	font-weight: 500;
	color: var(--ds-text);
	margin: 0 0 10px;
}
.ds-upsell-text p {
	margin: 0;
	color: var(--ds-muted);
	font-size: 15px;
	line-height: 1.6;
	max-width: 520px;
}

/* ═══════════════════════════════════════════════════════
   COME SI USA — passi numerati
   ═══════════════════════════════════════════════════════ */
.ds-howto {
	background: var(--ds-surface);
	border-top: 1px solid var(--ds-border);
}
.ds-howto .ds-section-inner { text-align: center; }
.ds-steps {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 28px;
	list-style: none !important;
	margin: 56px 0 0;
	padding: 0 !important;
	counter-reset: steps;
	position: relative;
}
.ds-steps > li { list-style: none !important; }
.ds-steps > li::marker { content: '' !important; }
.ds-steps::before {
	content: '';
	position: absolute;
	top: 44px;
	left: 12%;
	right: 12%;
	height: 1px;
	background: linear-gradient(90deg, transparent, var(--ds-gold) 15%, var(--ds-gold) 85%, transparent);
	opacity: 0.4;
	z-index: 0;
}
.ds-step {
	text-align: center;
	position: relative;
	z-index: 1;
	padding: 28px 22px 30px;
	background: var(--ds-surface);
	border: 1px solid var(--ds-border);
	transition: transform 0.35s ease, box-shadow 0.35s ease, border-color 0.35s ease;
}
.ds-step:hover {
	transform: translateY(-4px);
	border-color: var(--ds-gold);
	box-shadow: 0 18px 40px rgba(186, 153, 63, 0.14);
}
.ds-step-num {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 72px;
	height: 72px;
	margin: -56px auto 22px;
	background: linear-gradient(135deg, var(--ds-gold) 0%, var(--ds-gold-2) 100%);
	border: 4px solid var(--ds-bg);
	border-radius: 50%;
	font-family: var(--ds-serif);
	font-size: 34px;
	font-weight: 600;
	color: #ffffff;
	line-height: 1;
	box-shadow: 0 10px 26px rgba(186, 153, 63, 0.28);
	position: relative;
}
.ds-step-num::after {
	content: '';
	position: absolute;
	inset: -10px;
	border: 1px solid var(--ds-gold);
	border-radius: 50%;
	opacity: 0.18;
	pointer-events: none;
}
.ds-step h3 {
	font-family: var(--ds-serif);
	font-size: 22px;
	font-weight: 500;
	color: var(--ds-text);
	margin: 0 0 12px;
	letter-spacing: 0.01em;
}
.ds-step p {
	margin: 0;
	color: var(--ds-muted);
	font-size: 14px;
	line-height: 1.7;
}

/* ═══════════════════════════════════════════════════════
   PER CHI — 4 card target audience
   ═══════════════════════════════════════════════════════ */
.ds-perchi {
	background: var(--ds-bg);
}
.ds-perchi .ds-section-inner { text-align: center; }
.ds-perchi-grid {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 24px;
	margin-top: 48px;
	text-align: left;
}
.ds-perchi-card {
	padding: 40px 32px 36px;
	background: var(--ds-surface);
	border: 1px solid var(--ds-border);
	transition: transform 0.3s ease, border-color 0.3s ease, box-shadow 0.3s ease;
	position: relative;
	overflow: hidden;
}
.ds-perchi-card::before {
	content: '';
	position: absolute;
	top: 0; left: 0; right: 0;
	height: 3px;
	background: linear-gradient(90deg, var(--ds-gold), var(--ds-sun));
	transform: scaleX(0);
	transform-origin: left;
	transition: transform 0.45s ease;
}
.ds-perchi-card:hover {
	transform: translateY(-4px);
	border-color: var(--ds-gold);
	box-shadow: 0 18px 38px rgba(186, 153, 63, 0.14);
}
.ds-perchi-card:hover::before { transform: scaleX(1); }
.ds-perchi-icon {
	width: 64px !important;
	height: 64px !important;
	max-width: 64px;
	max-height: 64px;
	margin: 0 0 22px;
	display: flex !important;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
	background: linear-gradient(135deg, rgba(186, 153, 63, 0.10) 0%, rgba(232, 154, 58, 0.06) 100%);
	border: 1px solid rgba(186, 153, 63, 0.22);
	border-radius: 50%;
	color: var(--ds-gold);
	transition: background 0.3s ease, border-color 0.3s ease, transform 0.4s ease;
}
.ds-perchi-icon svg { width: 30px !important; height: 30px !important; max-width: 30px; max-height: 30px; display: block; }
.ds-perchi-card:hover .ds-perchi-icon {
	background: linear-gradient(135deg, var(--ds-gold) 0%, var(--ds-gold-2) 100%);
	border-color: var(--ds-gold);
	color: #ffffff;
	transform: rotate(-6deg) scale(1.04);
}
.ds-perchi-card h3 {
	font-family: var(--ds-serif);
	font-size: 25px;
	font-weight: 500;
	color: var(--ds-text);
	margin: 0 0 14px;
	letter-spacing: 0.01em;
}
.ds-perchi-card p {
	margin: 0;
	color: var(--ds-muted);
	font-size: 14px;
	line-height: 1.75;
}

/* ═══════════════════════════════════════════════════════
   FAQ — accordion
   ═══════════════════════════════════════════════════════ */
.ds-faq {
	background: var(--ds-surface);
	border-top: 1px solid var(--ds-border);
}
.ds-faq .ds-section-inner { text-align: center; }
.ds-faq-list {
	max-width: 820px;
	margin: 48px auto 0;
	text-align: left;
}
.ds-faq-item {
	background: var(--ds-bg);
	border: 1px solid var(--ds-border);
	margin-bottom: 12px;
	transition: border-color 0.25s ease;
}
.ds-faq-item[open] {
	border-color: var(--ds-gold);
	box-shadow: 0 10px 24px rgba(186, 153, 63, 0.08);
}
.ds-faq-item summary {
	list-style: none;
	cursor: pointer;
	padding: 20px 28px;
	font-family: var(--ds-serif);
	font-size: 19px;
	font-weight: 500;
	color: var(--ds-text);
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 16px;
	position: relative;
}
.ds-faq-item summary::-webkit-details-marker { display: none; }
.ds-faq-item summary::after {
	content: '+';
	color: var(--ds-gold);
	font-size: 28px;
	font-weight: 300;
	line-height: 1;
	transition: transform 0.3s ease;
	flex-shrink: 0;
}
.ds-faq-item[open] summary::after {
	transform: rotate(45deg);
}
.ds-faq-item p {
	margin: 0;
	padding: 0 28px 22px;
	color: var(--ds-muted);
	font-size: 15px;
	line-height: 1.75;
}
.ds-faq-item p strong {
	color: var(--ds-text);
	font-weight: 600;
}

/* ═══════════════════════════════════════════════════════
   CTA FINALE
   ═══════════════════════════════════════════════════════ */
.ds-cta {
	background: radial-gradient(ellipse 800px 500px at 50% 50%, rgba(232, 154, 58, 0.12), transparent 70%), var(--ds-bg);
	text-align: center;
	position: relative;
	overflow: hidden;
}
.ds-cta::before, .ds-cta::after {
	content: '';
	position: absolute;
	left: 50%;
	transform: translateX(-50%);
	width: 280px;
	height: 1px;
	background: linear-gradient(90deg, transparent, var(--ds-gold), transparent);
}
.ds-cta::before { top: 0; }
.ds-cta::after { bottom: 0; }
.ds-cta-lead {
	font-size: 18px;
	color: var(--ds-muted);
	line-height: 1.6;
	margin: 0 auto 40px;
	max-width: 600px;
}
.ds-cta-lead strong { color: var(--ds-text); font-weight: 600; }
.ds-cta-trust {
	display: inline-flex;
	align-items: center;
	gap: 12px;
	margin-top: 32px;
	color: var(--ds-muted);
	font-size: 12px;
	text-transform: uppercase;
	letter-spacing: 0.14em;
}
.ds-cta-trust svg { color: var(--ds-gold); }

/* ═══════════════════════════════════════════════════════
   RESPONSIVE
   ═══════════════════════════════════════════════════════ */
@media (max-width: 1024px) {
	.ds-section-inner { padding: 80px 28px; }
	.ds-section-title { font-size: 42px; }
	.ds-section-title-sm { font-size: 34px; }
	.ds-steps { grid-template-columns: repeat(2, 1fr); gap: 32px; }
	.ds-steps::before { display: none; }
	.ds-perchi-grid { grid-template-columns: 1fr; }
	.ds-faq-item summary { font-size: 17px; padding: 18px 22px; }
	.ds-faq-item p { padding: 0 22px 20px; font-size: 14px; }
	.ds-hero-grid { grid-template-columns: 1fr; gap: 40px; text-align: center; }
	.ds-hero-tagline { margin-left: auto; margin-right: auto; }
	.ds-hero-cta, .ds-hero-trust { justify-content: center; }
	.ds-hero-product { max-width: 320px; }
	.ds-hero-stamp { width: 100px; height: 100px; right: -10px; top: 0; }
	.ds-hero-stamp strong { font-size: 28px; }
	.ds-features-grid { grid-template-columns: 1fr; gap: 16px; }
	.ds-feature { padding: 36px 28px; }
	.ds-feature-num { font-size: 64px; }
	.ds-ingredients { grid-template-columns: repeat(2, 1fr); gap: 14px; }
	.ds-showcase-grid { grid-template-columns: 1fr; gap: 48px; }
	.ds-upsell-card { padding: 32px 28px; }
}
@media (max-width: 720px) {
	.ds-section-inner { padding: 60px 20px; }
	.ds-section-title { font-size: 34px; }
	.ds-section-title-sm { font-size: 28px; }
	.ds-steps { grid-template-columns: 1fr; gap: 50px; margin-top: 70px; }
	.ds-step { padding: 24px 20px 26px; }
	.ds-step-num { width: 64px; height: 64px; font-size: 28px; margin-top: -48px; }
	.ds-perchi-card { padding: 32px 24px 28px; }
	.ds-perchi-icon { width: 56px; height: 56px; }
	.ds-perchi-icon svg { width: 26px; height: 26px; }
	.ds-faq-item summary { font-size: 16px; padding: 16px 18px; }
	.ds-faq-item p { padding: 0 18px 18px; }
	.ds-section-lead { font-size: 15px; }
	.ds-hero { padding: 80px 20px 50px; min-height: 90vh; }
	.ds-hero-tagline { font-size: 16px; }
	.ds-hero-trust { gap: 4px; font-size: 11px; }
	.ds-hero-trust > span { padding: 0 8px 0 0; }
	.ds-hero-trust .sep { padding: 0 8px 0 0; }
	.ds-hero-product { max-width: 240px; }
	.ds-hero-stamp { width: 84px; height: 84px; }
	.ds-hero-stamp strong { font-size: 22px; }
	.ds-stamp-top, .ds-stamp-bot { font-size: 8px; }
	.ds-ingredients { grid-template-columns: 1fr; gap: 12px; }
	.ds-ingredient { padding: 22px 20px; }
	.ds-feature-num { font-size: 56px; }
	.ds-price-now { font-size: 42px; }
	.ds-showcase-cta { flex-direction: column; }
	.ds-showcase-cta .ds-btn { justify-content: center; }
	.ds-upsell-card { padding: 28px 22px; flex-direction: column; align-items: stretch; text-align: center; }
	.ds-btn-xl { padding: 18px 30px; font-size: 13px; }
}

/* ═══════════════════════════════════════════════════════
   INCI trigger button (apre modal)
   ═══════════════════════════════════════════════════════ */
.ds-inci-note { text-align: center; margin-top: 32px; }
.lumalux-doposole-v2 button.ds-inci-trigger,
button.ds-inci-trigger {
	display: inline-flex !important;
	align-items: center;
	gap: 8px;
	background: transparent !important;
	background-color: transparent !important;
	background-image: none !important;
	border: 1px solid var(--ds-gold) !important;
	color: var(--ds-gold) !important;
	font-family: var(--ds-font) !important;
	font-size: 12px !important;
	font-weight: 700 !important;
	letter-spacing: 0.16em !important;
	text-transform: uppercase !important;
	padding: 13px 28px !important;
	cursor: pointer !important;
	line-height: 1.2 !important;
	text-shadow: none !important;
	box-shadow: none !important;
	border-radius: 0 !important;
	transition: background 0.3s ease, color 0.3s ease, transform 0.2s ease !important;
}
.lumalux-doposole-v2 button.ds-inci-trigger:hover,
button.ds-inci-trigger:hover {
	background: var(--ds-gold) !important;
	background-color: var(--ds-gold) !important;
	color: #ffffff !important;
	transform: translateY(-1px);
}

/* ═══════════════════════════════════════════════════════
   MODAL — popup INCI completo
   ═══════════════════════════════════════════════════════ */
.ds-modal {
	position: fixed !important;
	inset: 0;
	top: 0; left: 0; right: 0; bottom: 0;
	z-index: 99990;
	display: none !important;
	align-items: center;
	justify-content: center;
	padding: 24px;
}
.ds-modal.is-open { display: flex !important; animation: dsFadeIn 0.25s ease; }
@keyframes dsFadeIn { from { opacity: 0; } to { opacity: 1; } }
.ds-modal-overlay {
	position: absolute;
	inset: 0;
	background: rgba(13, 13, 13, 0.62);
	backdrop-filter: blur(4px);
	-webkit-backdrop-filter: blur(4px);
	cursor: pointer;
}
.ds-modal-dialog {
	position: relative;
	max-width: 720px;
	width: 100%;
	max-height: 90vh;
	background: var(--ds-surface);
	border: 1px solid var(--ds-border);
	box-shadow: 0 30px 80px rgba(13, 13, 13, 0.35);
	overflow-y: auto;
	animation: dsSlideUp 0.35s cubic-bezier(0.16, 1, 0.3, 1);
}
@keyframes dsSlideUp {
	from { transform: translateY(20px); opacity: 0; }
	to   { transform: translateY(0);    opacity: 1; }
}
button.ds-modal-close,
.ds-modal .ds-modal-close {
	position: absolute !important;
	top: 16px !important;
	right: 16px !important;
	width: 44px !important;
	height: 44px !important;
	min-width: 44px !important;
	min-height: 44px !important;
	background: var(--ds-bg) !important;
	background-color: var(--ds-bg) !important;
	background-image: none !important;
	border: 1.5px solid var(--ds-gold) !important;
	border-radius: 50% !important;
	color: var(--ds-gold) !important;
	cursor: pointer !important;
	display: inline-flex !important;
	align-items: center !important;
	justify-content: center !important;
	padding: 0 !important;
	line-height: 1 !important;
	box-shadow: 0 4px 14px rgba(13, 13, 13, 0.12) !important;
	transition: color 0.25s ease, border-color 0.25s ease, background 0.25s ease, transform 0.25s ease !important;
	z-index: 5 !important;
}
button.ds-modal-close svg,
.ds-modal-close svg { width: 18px !important; height: 18px !important; display: block !important; pointer-events: none; }
button.ds-modal-close:hover,
.ds-modal .ds-modal-close:hover {
	color: #ffffff !important;
	background: var(--ds-gold) !important;
	background-color: var(--ds-gold) !important;
	border-color: var(--ds-gold) !important;
	transform: rotate(90deg);
}
.ds-modal-body {
	padding: 50px 50px 44px;
}
.ds-modal-body .ds-eyebrow {
	color: var(--ds-gold);
	font-size: 11px;
	letter-spacing: 0.22em;
	text-transform: uppercase;
	font-weight: 700;
}
.ds-modal-body h3 {
	font-family: var(--ds-serif);
	font-size: 32px;
	font-weight: 500;
	color: var(--ds-text);
	margin: 8px 0 14px;
	line-height: 1.2;
}
.ds-modal-lead {
	color: var(--ds-muted);
	font-size: 14px;
	line-height: 1.7;
	margin: 0 0 24px;
	padding-bottom: 20px;
	border-bottom: 1px solid var(--ds-border);
}
.ds-inci-text p {
	color: var(--ds-text);
	font-size: 13px;
	line-height: 1.85;
	letter-spacing: 0.02em;
	word-break: break-word;
	margin: 0 0 16px;
}
.ds-inci-text strong { color: var(--ds-gold); font-weight: 700; letter-spacing: 0.06em; text-transform: uppercase; font-size: 11px; }
.ds-inci-cert {
	margin: 16px 0 0 !important;
	padding: 14px 16px;
	background: rgba(186, 153, 63, 0.06);
	border-left: 3px solid var(--ds-gold);
	color: var(--ds-muted) !important;
	font-size: 13px !important;
	font-style: italic;
}

@media (max-width: 720px) {
	.ds-modal { padding: 12px; }
	.ds-modal-body { padding: 38px 26px 32px; }
	.ds-modal-body h3 { font-size: 24px; }
	.ds-modal-close { top: 12px; right: 12px; width: 36px; height: 36px; }
}
