/* ===================================================================
   Love Coach AI — main.css
   Design system: Bold Sensual / Editorial Dark — Black & Red
   =================================================================== */

/* ====== 1. TOKENS ================================================== */
:root {
	/* Colors */
	--ink: #0A0A0B;
	--ink-soft: #141416;
	--ink-mid: #1C1C20;
	--ink-card: #16161A;
	--bone: #F5F1EC;
	--bone-dim: rgba(245, 241, 236, 0.72);
	--bone-faint: rgba(245, 241, 236, 0.42);
	--blood: #E10B2C;
	--blood-deep: #8B0A1F;
	--blood-bright: #FF1E3D;
	--blush: #FF4D6D;
	--blush-soft: rgba(255, 77, 109, 0.16);
	--ash: #6B6B70;
	--ash-line: rgba(245, 241, 236, 0.22);
	--ash-line-strong: rgba(245, 241, 236, 0.32);

	/* Effects */
	--glow-blood: 0 0 0 1px rgba(225, 11, 44, .4), 0 8px 32px -4px rgba(225, 11, 44, .35), 0 0 60px -10px rgba(225, 11, 44, .3);
	--glow-soft: 0 0 24px -2px rgba(255, 77, 109, .35);
	--shadow-card: 0 1px 0 rgba(245, 241, 236, .04) inset, 0 24px 60px -20px rgba(0,0,0,.6);

	/* Type */
	--font-display: "Fraunces", "Times New Roman", serif;
	--font-body: "Inter", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
	--font-mono: "JetBrains Mono", ui-monospace, "SF Mono", Menlo, monospace;

	/* Spacing scale (4-based) */
	--s-1: 0.25rem;
	--s-2: 0.5rem;
	--s-3: 0.75rem;
	--s-4: 1rem;
	--s-5: 1.25rem;
	--s-6: 1.5rem;
	--s-8: 2rem;
	--s-10: 2.5rem;
	--s-12: 3rem;
	--s-16: 4rem;
	--s-20: 5rem;
	--s-24: 6rem;
	--s-32: 8rem;

	/* Radius */
	--r-sm: 6px;
	--r-md: 12px;
	--r-lg: 20px;
	--r-xl: 28px;
	--r-pill: 999px;

	/* Layout */
	--container: 1280px;
	--gutter: clamp(1rem, 4vw, 3rem);
	--header-h: 96px;

	/* Motion */
	--ease: cubic-bezier(.22, 1, .36, 1);
	--ease-out: cubic-bezier(.16, 1, .3, 1);
	--dur: 280ms;
	--dur-slow: 600ms;
}

/* ============================================================
   WooCommerce Subscriptions
   ============================================================ */
.recurring-totals,
.cart-subtotal.recurring-total,
.order-total.recurring-total,
.shop_table.woocommerce-checkout-review-order-table tbody,
.woocommerce-checkout.woocommerce-order-received .woocommerce-order-details .shop_table.order_details + header,
.woocommerce-checkout.woocommerce-order-received .woocommerce-order-details .shop_table.order_details + header + .woocommerce-orders-table--subscriptions {
	display: none!important;
}

/* ====== 2. RESET ================================================== */
*, *::before, *::after { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; tab-size: 4; scroll-behavior: smooth; }
body {
	margin: 0;
	min-height: 100vh;
	background: var(--ink);
	color: var(--bone);
	font-family: var(--font-body);
	font-size: 1rem;
	line-height: 1.6;
	font-weight: 400;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	text-rendering: optimizeLegibility;
	overflow-x: hidden;
}
img, svg, video { display: block; max-width: 100%; height: auto; }
button, input, select, textarea { font: inherit; color: inherit; }
button { background: none; border: 0; cursor: pointer; padding: 0; }
a { color: var(--blush); text-decoration: none; transition: color var(--dur) var(--ease); }
a:hover { color: var(--blood-bright); }
hr { border: 0; height: 1px; background: var(--ash-line); margin: var(--s-8) 0; }
::selection { background: var(--blood); color: var(--bone); }
:focus-visible { outline: 2px solid var(--blood-bright); outline-offset: 3px; border-radius: 4px; }

/* ====== 3. TYPOGRAPHY ============================================= */
h1, h2, h3, h4, h5 { font-family: var(--font-display); font-weight: 600; line-height: 1.08; letter-spacing: -0.02em; margin: 0 0 var(--s-4); color: var(--bone); }
h1 { font-size: clamp(2.75rem, 7vw, 6rem); letter-spacing: -0.03em; }
h2 { font-size: clamp(2rem, 4.5vw, 3.75rem); }
h3 { font-size: clamp(1.5rem, 2.5vw, 2.25rem); }
h4 { font-size: clamp(1.15rem, 1.6vw, 1.5rem); }
p { margin: 0 0 var(--s-4); }
small { font-size: 0.8125rem; color: var(--bone-dim); }
strong, b { font-weight: 600; color: var(--bone); }
em, i { font-style: italic; }
blockquote {
	font-family: var(--font-display);
	font-size: clamp(1.5rem, 2.5vw, 2.25rem);
	line-height: 1.25;
	font-style: italic;
	margin: var(--s-8) 0;
	padding-left: var(--s-6);
	border-left: 2px solid var(--blood);
	color: var(--bone);
}
code, kbd, pre, .lca-mono { font-family: var(--font-mono); font-size: 0.875em; }
pre { background: var(--ink-soft); border: 1px solid var(--ash-line); padding: var(--s-4); border-radius: var(--r-md); overflow-x: auto; }

.lca-eyebrow {
	display: inline-flex;
	align-items: center;
	gap: var(--s-2);
	font-family: var(--font-mono);
	font-size: 0.75rem;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: var(--blush);
	font-weight: 500;
}
.lca-eyebrow__dot {
	width: 6px; height: 6px;
	background: var(--blood);
	border-radius: 50%;
	box-shadow: 0 0 12px 2px var(--blood);
	animation: lca-pulse 2.4s var(--ease) infinite;
}
@keyframes lca-pulse {
	0%, 100% { opacity: 1; transform: scale(1); }
	50% { opacity: .55; transform: scale(.85); }
}

.lca-display { font-family: var(--font-display); }
.lca-italic { font-style: italic; }
.lca-text-blood { color: var(--blood); }
.lca-text-blush { color: var(--blush); }
.lca-text-bone { color: var(--bone); }
.lca-text-dim { color: var(--bone-dim); }

/* ====== 4. LAYOUT ================================================= */
.lca-container {
	width: 100%;
	max-width: var(--container);
	margin-inline: auto;
	padding-inline: var(--gutter);
}
.lca-container--wide { max-width: 1440px; }
.lca-container--narrow { max-width: 880px; }

.lca-section {
	padding-block: clamp(4rem, 10vw, 8rem);
	position: relative;
}
.lca-section--tight { padding-block: clamp(3rem, 6vw, 5rem); }
.lca-section--bleed { padding-inline: 0; }

.lca-grid { display: grid; gap: var(--s-6); }
.lca-grid--2 { grid-template-columns: repeat(2, 1fr); }
.lca-grid--3 { grid-template-columns: repeat(3, 1fr); }
.lca-grid--4 { grid-template-columns: repeat(4, 1fr); }
@media (max-width: 900px) {
	.lca-grid--3, .lca-grid--4 { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 640px) {
	.lca-grid--2, .lca-grid--3, .lca-grid--4 { grid-template-columns: 1fr; }
}

/* ====== 5. HEADER / NAV =========================================== */
.lca-header {
	position: sticky;
	top: 0;
	z-index: 80;
	background: rgba(10, 10, 11, 0.72);
	backdrop-filter: blur(18px) saturate(150%);
	-webkit-backdrop-filter: blur(18px) saturate(150%);
	border-bottom: 1px solid var(--ash-line);
}
.lca-header__inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: var(--s-6);
	height: var(--header-h);
}
.lca-brand {
	display: inline-flex;
	align-items: center;
	gap: var(--s-2);
	color: var(--bone);
	font-family: var(--font-display);
	font-size: 1.375rem;
	font-weight: 600;
	letter-spacing: -0.02em;
	text-decoration: none;
	line-height: 1;
}
.lca-brand:hover { color: var(--bone); }
.lca-brand__img,
.lca-header .lca-brand img,
.lca-header__inner img {
	display: block;
	height: clamp(52px, 7vw, 72px) !important;
	width: auto !important;
	max-height: 72px;
	max-width: 280px;
	object-fit: contain;
}
.lca-brand { flex-shrink: 0; max-height: var(--header-h); overflow: hidden; }
@media (max-width: 600px) {
	.lca-brand__img,
	.lca-header .lca-brand img { height: 46px !important; max-height: 46px; max-width: 180px; }
}
@media (max-width: 420px) {
	.lca-brand__img,
	.lca-header .lca-brand img { height: 40px !important; max-height: 40px; max-width: 150px; }
}
.lca-brand__mark {
	color: var(--blood);
	display: inline-flex;
	transform: translateY(2px);
}
.lca-brand__word { font-style: italic; }
.lca-brand__tag {
	display: block;
	font-family: var(--font-mono);
	font-size: 0.65rem;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: var(--bone-faint);
	font-style: normal;
	margin-top: 2px;
}

.lca-nav { display: flex; align-items: center; gap: var(--s-2); }
.lca-nav__list { display: flex; align-items: center; gap: var(--s-1); list-style: none; margin: 0; padding: 0; }
.lca-nav__item { position: relative; }
.lca-nav__link {
	display: inline-flex;
	align-items: center;
	padding: var(--s-2) var(--s-4);
	color: var(--bone-dim);
	text-decoration: none;
	font-size: 0.9375rem;
	font-weight: 500;
	border-radius: var(--r-pill);
	transition: color var(--dur) var(--ease), background var(--dur) var(--ease);
}
.lca-nav__link:hover, .lca-nav__item.is-current > .lca-nav__link { color: var(--bone); background: var(--ink-soft); }
.lca-nav__sub {
	position: absolute;
	top: 100%;
	left: 0;
	min-width: 220px;
	background: var(--ink-soft);
	border: 1px solid var(--ash-line);
	border-radius: var(--r-md);
	padding: var(--s-2);
	display: none;
	flex-direction: column;
	box-shadow: var(--shadow-card);
}
.lca-nav__item.has-sub:hover > .lca-nav__sub,
.lca-nav__item.has-sub:focus-within > .lca-nav__sub { display: flex; }

.lca-header__actions { display: flex; align-items: center; gap: var(--s-3); }
.lca-icon-link {
	display: inline-flex;
	align-items: center;
	gap: var(--s-2);
	color: var(--bone-dim);
	text-decoration: none;
	font-size: 0.875rem;
	font-weight: 500;
	padding: var(--s-2) var(--s-3);
	border-radius: var(--r-pill);
	transition: all var(--dur) var(--ease);
	position: relative;
}
.lca-icon-link:hover { color: var(--bone); background: var(--ink-soft); }
.lca-icon-link--cart .lca-cart-count {
	display: inline-grid;
	place-items: center;
	min-width: 22px;
	height: 22px;
	font-family: var(--font-mono);
	font-size: 0.6875rem;
	background: var(--blood);
	color: var(--bone);
	border-radius: var(--r-pill);
	padding: 0 6px;
	font-weight: 600;
}

.lca-nav-toggle {
	display: none;
	width: 44px; height: 44px;
	color: var(--bone);
	border: 1px solid var(--ash-line);
	border-radius: var(--r-pill);
	align-items: center;
	justify-content: center;
}
@media (max-width: 980px) {
	.lca-nav { display: none; }
	.lca-nav-toggle { display: inline-flex; }
	.lca-icon-link span:not(.lca-cart-count) { display: none; }
}
@media (max-width: 600px) {
	.lca-header__inner { gap: var(--s-3); }
	.lca-header__actions { gap: var(--s-2); }
	.lca-header__actions .lca-btn--sm { padding: var(--s-2) var(--s-3); font-size: 0.8125rem; }
	.lca-header__actions .lca-btn--sm svg { display: none; }
	.lca-icon-link { padding: var(--s-2); }
}
@media (max-width: 420px) {
	.lca-header__inner { gap: var(--s-2); }
	.lca-header__actions .lca-btn--primary span,
	.lca-header__actions .lca-btn--primary { font-size: 0.8125rem; }
	:root { --header-h: 64px; }
}

/* Mobile drawer */
.lca-drawer {
	position: fixed;
	inset: 0;
	z-index: 90;
	background: var(--ink);
	display: flex;
	flex-direction: column;
	padding: var(--s-6);
	transform: translateY(-100%);
	transition: transform 400ms var(--ease);
	overflow-y: auto;
}
.lca-drawer.is-open { transform: translateY(0); }
.lca-drawer__top { display: flex; justify-content: space-between; align-items: center; margin-bottom: var(--s-8); }
.lca-drawer__nav { display: flex; flex-direction: column; gap: var(--s-2); }
.lca-drawer__nav .lca-nav__list { flex-direction: column; align-items: stretch; gap: 0; width: 100%; }
.lca-drawer__nav .lca-nav__item { width: 100%; }
.lca-drawer__nav .lca-nav__link {
	font-family: var(--font-display);
	font-size: clamp(1.75rem, 5vw, 2.5rem);
	padding: var(--s-3) 0;
	width: 100%;
	border-radius: 0;
	border-bottom: 1px solid var(--ash-line);
	color: var(--bone);
}
.lca-drawer__nav .lca-nav__link:hover { color: var(--blood); background: transparent; }
.lca-drawer__cta {
	margin-top: auto;
	padding-top: var(--s-8);
	display: flex;
	flex-direction: column;
	gap: var(--s-3);
}

/* ====== 6. BUTTONS ================================================ */
.lca-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: var(--s-2);
	padding: var(--s-3) var(--s-6);
	font-family: var(--font-body);
	font-size: 0.9375rem;
	font-weight: 600;
	line-height: 1;
	letter-spacing: 0.005em;
	border: 1px solid transparent;
	border-radius: var(--r-pill);
	cursor: pointer;
	text-decoration: none;
	transition: all var(--dur) var(--ease);
	position: relative;
	white-space: nowrap;
}
.lca-btn--primary {
	background: var(--blood);
	color: var(--bone);
	border-color: var(--blood);
}
.lca-btn--primary:hover {
	background: var(--blood-bright);
	border-color: var(--blood-bright);
	color: var(--bone);
	transform: translateY(-1px);
	box-shadow: var(--glow-blood);
}
.lca-btn--ghost {
	background: transparent;
	color: var(--bone);
	border-color: var(--ash-line-strong);
}
.lca-btn--ghost:hover {
	background: var(--ink-soft);
	border-color: var(--bone-faint);
	color: var(--bone);
}
.lca-btn--bone {
	background: var(--bone);
	color: var(--ink);
	border-color: var(--bone);
}
.lca-btn--bone:hover {
	background: var(--bone-dim);
	color: var(--ink);
}
.lca-btn--lg { padding: var(--s-4) var(--s-8); font-size: 1rem; }
.lca-btn--sm { padding: var(--s-2) var(--s-4); font-size: 0.8125rem; }
.lca-btn--full { width: 100%; }
.lca-btn .lca-icon { transition: transform var(--dur) var(--ease); }
.lca-btn:hover .lca-icon--arrow-right { transform: translateX(3px); }

.lca-pill {
	display: inline-flex;
	align-items: center;
	gap: var(--s-2);
	padding: var(--s-2) var(--s-4);
	font-family: var(--font-mono);
	font-size: 0.75rem;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	color: var(--bone-dim);
	background: var(--ink-soft);
	border: 1px solid var(--ash-line);
	border-radius: var(--r-pill);
	text-decoration: none;
	transition: all var(--dur) var(--ease);
	cursor: pointer;
}
.lca-pill:hover, .lca-pill.is-active {
	color: var(--bone);
	border-color: var(--blood);
	background: var(--ink-mid);
}
.lca-pill.is-active::before {
	content: "";
	width: 6px; height: 6px;
	background: var(--blood);
	border-radius: 50%;
	box-shadow: 0 0 8px var(--blood);
}

/* ====== 7. HERO =================================================== */
.lca-hero {
	position: relative;
	padding-block: clamp(5rem, 12vw, 10rem) clamp(4rem, 8vw, 7rem);
	overflow: hidden;
	isolation: isolate;
}
.lca-hero::before {
	content: "";
	position: absolute;
	top: -10%;
	right: -20%;
	width: 80%;
	height: 100%;
	background: radial-gradient(ellipse at center, rgba(225, 11, 44, 0.45) 0%, rgba(139, 10, 31, 0.2) 35%, transparent 65%);
	filter: blur(40px);
	z-index: -1;
	animation: lca-float 14s var(--ease) infinite;
}
.lca-hero::after {
	content: "";
	position: absolute;
	bottom: -30%;
	left: -10%;
	width: 60%;
	height: 80%;
	background: radial-gradient(ellipse at center, rgba(255, 77, 109, 0.18) 0%, transparent 60%);
	filter: blur(60px);
	z-index: -1;
	animation: lca-float 18s var(--ease) infinite reverse;
}
@keyframes lca-float {
	0%, 100% { transform: translate(0, 0) scale(1); }
	50% { transform: translate(-30px, 40px) scale(1.08); }
}

.lca-hero__inner {
	display: grid;
	grid-template-columns: 1.4fr 1fr;
	gap: clamp(2rem, 6vw, 5rem);
	align-items: center;
}
@media (max-width: 980px) {
	.lca-hero__inner { grid-template-columns: 1fr; }
	.lca-hero__visual { order: -1; max-width: 460px; margin: 0 auto; width: 100%; }
}
@media (max-width: 480px) {
	.lca-hero__visual { aspect-ratio: 4/3; }
	.lca-hero__title { font-size: clamp(2.25rem, 11vw, 3.5rem); }
}

.lca-hero__title {
	font-size: clamp(2.5rem, 7vw, 6.25rem);
	font-weight: 600;
	letter-spacing: -0.035em;
	line-height: 0.98;
	margin-bottom: var(--s-6);
}
.lca-hero__title em {
	font-style: italic;
	color: var(--blood);
	background: linear-gradient(180deg, var(--blood) 0%, var(--blush) 100%);
	-webkit-background-clip: text;
	background-clip: text;
	-webkit-text-fill-color: transparent;
}
.lca-hero__lead {
	font-size: clamp(1.0625rem, 1.5vw, 1.25rem);
	color: var(--bone-dim);
	max-width: 56ch;
	line-height: 1.55;
	margin-bottom: var(--s-8);
}
.lca-hero__ctas { display: flex; flex-wrap: wrap; gap: var(--s-3); margin-bottom: var(--s-8); }
.lca-hero__quick {
	display: flex;
	flex-wrap: wrap;
	gap: var(--s-2);
	margin-top: var(--s-6);
}

.lca-hero__visual {
	position: relative;
	aspect-ratio: 4 / 5;
	border-radius: var(--r-xl);
	overflow: hidden;
	background: var(--ink-soft);
	border: 1px solid var(--ash-line);
}
.lca-hero__photo {
	position: absolute;
	inset: 0;
	z-index: 0;
}
.lca-hero__photo img,
.lca-hero__photo-img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	filter: grayscale(0.25) brightness(0.55) saturate(1.15) contrast(1.05);
}
.lca-hero__visual::before {
	content: "";
	position: absolute;
	inset: 0;
	background: linear-gradient(135deg, rgba(225, 11, 44, 0.45) 0%, rgba(10, 10, 11, 0.55) 50%, rgba(20, 20, 22, 0.85) 100%);
	z-index: 1;
}
.lca-hero__visual::after {
	content: "";
	position: absolute;
	inset: 0;
	background: radial-gradient(ellipse at 30% 20%, rgba(225, 11, 44, 0.4) 0%, transparent 60%);
	z-index: 1;
	mix-blend-mode: screen;
}

/* Hero pages with full background image */
.lca-hero--bg { padding-block: clamp(6rem, 12vw, 10rem) clamp(4rem, 8vw, 7rem); }
.lca-hero__bg {
	position: absolute;
	inset: 0;
	z-index: -2;
	overflow: hidden;
}
.lca-hero__bg img,
.lca-hero__bg-img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	filter: grayscale(0.4) brightness(0.4) saturate(1.2) contrast(1.05);
}
.lca-hero--bg::before {
	content: "";
	position: absolute;
	inset: 0;
	z-index: -1;
	background:
		radial-gradient(ellipse at 30% 30%, rgba(225, 11, 44, 0.35) 0%, transparent 55%),
		linear-gradient(180deg, rgba(10, 10, 11, 0.4) 0%, var(--ink) 90%);
	pointer-events: none;
}
.lca-hero__chat {
	position: absolute;
	z-index: 2;
	inset: 0;
}

/* Ogni conversazione è un layer assoluto. Solo .is-active è visibile. */
.lca-hero__conversation {
	position: absolute;
	inset: 0;
	display: flex;
	flex-direction: column;
	gap: var(--s-3);
	padding: clamp(1.5rem, 3vw, 2.5rem);
	justify-content: flex-end;
	pointer-events: none;
}

.lca-hero__bubble {
	max-width: 80%;
	padding: var(--s-3) var(--s-4);
	border-radius: var(--r-lg);
	font-size: 0.9375rem;
	line-height: 1.45;
	opacity: 0;
	transform: translateY(24px) scale(.96);
	transition:
		opacity 500ms var(--ease),
		transform 600ms var(--ease);
}
.lca-hero__bubble--user {
	align-self: flex-end;
	background: var(--blood);
	color: var(--bone);
	border-bottom-right-radius: 6px;
	transition-delay: 0ms;
}
.lca-hero__bubble--ai {
	align-self: flex-start;
	background: rgba(20, 20, 22, 0.92);
	border: 1px solid var(--ash-line);
	color: var(--bone);
	backdrop-filter: blur(8px);
	border-bottom-left-radius: 6px;
	transition-delay: 0ms;
	box-shadow: 0 0 32px -8px rgba(255, 77, 109, 0.4);
}
.lca-hero__bubble--ai strong { color: var(--blush); }

/* Active state: bubbles entrano stagger */
.lca-hero__conversation.is-active .lca-hero__bubble {
	opacity: 1;
	transform: translateY(0) scale(1);
}
.lca-hero__conversation.is-active .lca-hero__bubble--user {
	transition-delay: 200ms;
}
.lca-hero__conversation.is-active .lca-hero__bubble--ai {
	transition-delay: 900ms;
}

/* Leaving state: fade out tutto insieme, veloce */
.lca-hero__conversation.is-leaving .lca-hero__bubble {
	opacity: 0;
	transform: translateY(-12px) scale(.98);
	transition:
		opacity 380ms var(--ease),
		transform 420ms var(--ease);
	transition-delay: 0ms;
}

/* Cursor blob (hero only) */
.lca-cursor-blob {
	position: fixed;
	pointer-events: none;
	z-index: 70;
	width: 280px;
	height: 280px;
	border-radius: 50%;
	background: radial-gradient(circle, rgba(225, 11, 44, 0.35) 0%, transparent 70%);
	mix-blend-mode: screen;
	transform: translate(-50%, -50%);
	opacity: 0;
	transition: opacity 400ms var(--ease);
	filter: blur(40px);
}
body.lca-cursor-active .lca-cursor-blob { opacity: 1; }
@media (max-width: 980px), (hover: none) { .lca-cursor-blob { display: none; } }

/* ====== 8. SECTIONS — generic ===================================== */
.lca-section__head {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--s-4);
	margin-bottom: clamp(2rem, 5vw, 4rem);
	max-width: 880px;
}
.lca-section__head--center { margin-inline: auto; text-align: center; }
.lca-section__head--center > * { justify-self: center; }
.lca-section__head--split {
	grid-template-columns: 1fr auto;
	max-width: none;
	align-items: end;
}
.lca-section__title {
	font-size: clamp(2rem, 4.5vw, 3.75rem);
	letter-spacing: -0.025em;
	line-height: 1.05;
}
.lca-section__title em { font-style: italic; color: var(--blood); }
.lca-section__lead {
	font-size: clamp(1rem, 1.4vw, 1.125rem);
	color: var(--bone-dim);
	max-width: 60ch;
	line-height: 1.55;
}

/* ====== 9. MODE CARDS ============================================= */
.lca-mode-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--s-5); }
@media (max-width: 980px) { .lca-mode-grid { grid-template-columns: 1fr; } }

.lca-mode-card {
	position: relative;
	background: var(--ink-soft);
	border: 1px solid var(--ash-line);
	border-radius: var(--r-xl);
	overflow: hidden;
	transition: all var(--dur-slow) var(--ease);
	display: flex;
	flex-direction: column;
	min-height: 580px;
	isolation: isolate;
	color: var(--bone);
	text-decoration: none;
}
.lca-mode-card:hover {
	border-color: var(--blood);
	transform: translateY(-4px);
	box-shadow: var(--glow-blood);
}
.lca-mode-card__media {
	position: relative;
	aspect-ratio: 1/1;
	overflow: hidden;
	border-bottom: 1px solid var(--ash-line);
	background: var(--ink);
}
.lca-mode-card__media img,
.lca-mode-card__media-img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform var(--dur-slow) var(--ease);
}
.lca-mode-card:hover .lca-mode-card__media-img,
.lca-mode-card:hover .lca-mode-card__media img {
	transform: scale(1.04);
}
.lca-mode-card__media-overlay {
	position: absolute;
	inset: auto 0 0 0;
	height: 35%;
	background: linear-gradient(180deg, rgba(20,20,22,0) 0%, var(--ink-soft) 100%);
	pointer-events: none;
	transition: opacity var(--dur-slow) var(--ease);
	opacity: 0.9;
}
.lca-mode-card:hover .lca-mode-card__media-overlay {
	opacity: 1;
}
.lca-mode-card__body {
	padding: var(--s-6) var(--s-8) var(--s-8);
	display: flex;
	flex-direction: column;
	flex: 1;
}
.lca-mode-card__num {
	font-family: var(--font-display);
	font-size: 1rem;
	font-style: italic;
	color: var(--blush);
	margin-bottom: var(--s-4);
	font-feature-settings: "ss01" on, "salt" on;
}
.lca-mode-card__icon {
	width: 48px; height: 48px;
	border: 1px solid var(--ash-line-strong);
	border-radius: var(--r-md);
	display: grid;
	place-items: center;
	color: var(--blood);
	margin-bottom: var(--s-4);
	transition: all var(--dur) var(--ease);
	background: var(--ink);
}
.lca-mode-card:hover .lca-mode-card__icon {
	border-color: var(--blood);
	background: rgba(225, 11, 44, 0.15);
	transform: scale(1.05) rotate(-2deg);
}
.lca-mode-card__title {
	font-size: clamp(1.5rem, 2.2vw, 2rem);
	margin-bottom: var(--s-3);
}
.lca-mode-card__desc {
	color: var(--bone-dim);
	margin-bottom: var(--s-6);
	font-size: 0.9375rem;
	line-height: 1.55;
}
.lca-mode-card__example {
	margin-top: auto;
	padding: var(--s-4);
	background: var(--ink);
	border-radius: var(--r-md);
	border-left: 2px solid var(--blood);
	font-family: var(--font-display);
	font-style: italic;
	font-size: 0.9375rem;
	color: var(--bone-dim);
	line-height: 1.4;
}
.lca-mode-card__cta {
	margin-top: var(--s-6);
	display: inline-flex;
	align-items: center;
	gap: var(--s-2);
	color: var(--bone);
	font-weight: 500;
	font-size: 0.875rem;
}
.lca-mode-card:hover .lca-mode-card__cta { color: var(--blush); }

/* ====== 10. CASES (chips/marquee) ================================ */
.lca-cases {
	background: var(--ink-soft);
	border-radius: var(--r-xl);
	padding: clamp(2rem, 5vw, 4rem) 0;
	overflow: hidden;
	position: relative;
}
.lca-cases__head {
	padding-inline: clamp(2rem, 5vw, 4rem);
	margin-bottom: var(--s-8);
}
.lca-cases__row {
	display: flex;
	gap: var(--s-4);
	width: max-content;
	animation: lca-marquee 50s linear infinite;
}
.lca-cases__row:nth-child(2) {
	animation-direction: reverse;
	animation-duration: 60s;
	margin-top: var(--s-4);
	padding-left: 80px;
}
@keyframes lca-marquee {
	from { transform: translateX(0); }
	to { transform: translateX(-50%); }
}
.lca-case-chip {
	display: inline-flex;
	align-items: center;
	gap: var(--s-3);
	padding: var(--s-4) var(--s-5);
	background: var(--ink);
	border: 1px solid var(--ash-line);
	border-radius: var(--r-pill);
	font-family: var(--font-display);
	font-style: italic;
	font-size: clamp(0.95rem, 1.4vw, 1.15rem);
	color: var(--bone);
	white-space: nowrap;
	transition: all var(--dur) var(--ease);
}
.lca-case-chip:hover {
	border-color: var(--blood);
	color: var(--blush);
	transform: translateY(-2px);
}
.lca-case-chip__quote {
	color: var(--blood);
	font-family: var(--font-display);
	font-size: 1.5em;
	line-height: 0;
}
.lca-cases:hover .lca-cases__row { animation-play-state: paused; }

/* ====== 11. STEPS ================================================= */
.lca-steps-wrap {
	display: grid;
	grid-template-columns: minmax(280px, 0.9fr) minmax(0, 1.4fr);
	gap: clamp(5rem, 16vw, 16rem);
	align-items: stretch;
}
@media (max-width: 980px) { .lca-steps-wrap { grid-template-columns: 1fr; } }
.lca-steps-wrap__visual {
	position: sticky;
	top: calc(var(--header-h) + 2rem);
	border-radius: var(--r-xl);
	overflow: hidden;
	aspect-ratio: 941/1672;
	max-height: 780px;
	border: 1px solid var(--ash-line);
	background: var(--ink);
}
@media (max-width: 980px) {
	.lca-steps-wrap__visual { position: relative; top: 0; aspect-ratio: 941/1672; max-width: 380px; max-height: none; margin: 0 auto; }
}
.lca-steps-wrap__img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
.lca-steps-wrap__visual-overlay {
	position: absolute;
	inset: 0;
	background: transparent;
	pointer-events: none;
}
.lca-steps-wrap__badge {
	position: absolute;
	top: var(--s-4);
	left: var(--s-4);
	display: inline-flex;
	align-items: center;
	gap: var(--s-2);
	padding: var(--s-2) var(--s-3);
	background: rgba(10, 10, 11, 0.7);
	backdrop-filter: blur(8px);
	border: 1px solid var(--ash-line-strong);
	border-radius: var(--r-pill);
	font-family: var(--font-mono);
	font-size: 0.6875rem;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color: var(--blush);
	z-index: 1;
}
.lca-steps-wrap__content { display: flex; flex-direction: column; gap: var(--s-8); }
.lca-steps {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: var(--s-8);
	counter-reset: step;
}
.lca-steps--vertical {
	grid-template-columns: 1fr;
	gap: var(--s-8);
}
.lca-steps--vertical .lca-step {
	padding-top: var(--s-10);
	padding-bottom: var(--s-8);
	border-bottom: 1px solid var(--ash-line);
}
.lca-steps--vertical .lca-step:last-child {
	border-bottom: 0;
	padding-bottom: 0;
}
.lca-steps--vertical .lca-step::before {
	font-size: clamp(3.5rem, 7vw, 5.5rem);
	top: -8px;
}
.lca-steps--vertical .lca-step__title {
	margin-top: var(--s-4);
}
@media (max-width: 980px) { .lca-steps { grid-template-columns: 1fr; gap: var(--s-6); } }

.lca-step {
	position: relative;
	padding-top: var(--s-12);
}
.lca-step::before {
	counter-increment: step;
	content: counter(step, decimal-leading-zero);
	font-family: var(--font-display);
	font-size: clamp(4rem, 10vw, 8rem);
	font-style: italic;
	color: var(--blood-deep);
	line-height: 0.85;
	letter-spacing: -0.05em;
	position: absolute;
	top: 0;
	left: -8px;
	opacity: 0.92;
}
.lca-step__title {
	font-size: clamp(1.25rem, 1.8vw, 1.5rem);
	margin-bottom: var(--s-3);
	position: relative;
}
.lca-step__desc { color: var(--bone-dim); font-size: 0.9375rem; line-height: 1.55; position: relative; }

/* ====== 12. PRICING ============================================== */
/* Flex anziché grid 3-col fissa: se le variazioni abilitate sono <3
   (es. solo 1 mese + 3 mesi), i piani restano centrati invece di
   ammucchiarsi a sinistra. `max-width` per card preserva la larghezza
   visiva del layout originale (≈ 1100/3 − gap). */
.lca-pricing-grid {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	align-items: stretch;
	gap: var(--s-5);
}
.lca-pricing-grid > .lca-plan {
	flex: 1 1 280px;
	max-width: 360px;
}
@media (max-width: 980px) {
	.lca-pricing-grid > .lca-plan { max-width: none; }
}

.lca-plan {
	display: flex;
	flex-direction: column;
	background: var(--ink-soft);
	border: 1px solid var(--ash-line);
	border-radius: var(--r-xl);
	padding: var(--s-8);
	position: relative;
	transition: all var(--dur-slow) var(--ease);
}
.lca-plan:hover { border-color: var(--ash-line-strong); transform: translateY(-2px); }
.lca-plan--featured {
	background: linear-gradient(180deg, rgba(225, 11, 44, 0.18) 0%, var(--ink-soft) 60%);
	border-color: var(--blood);
	box-shadow: var(--glow-blood);
	transform: translateY(-4px);
}
.lca-plan--featured:hover { transform: translateY(-6px); }
.lca-plan__badge {
	position: absolute;
	top: -14px;
	left: 50%;
	transform: translateX(-50%);
	padding: var(--s-1) var(--s-4);
	background: var(--blood);
	color: var(--bone);
	font-family: var(--font-mono);
	font-size: 0.6875rem;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	border-radius: var(--r-pill);
	font-weight: 600;
	white-space: nowrap;
}

.lca-plan__head {
	display: flex;
	justify-content: space-between;
	align-items: baseline;
	margin-bottom: var(--s-5);
	gap: var(--s-3);
}
.lca-plan__name {
	font-family: var(--font-display);
	font-size: 1.5rem;
	font-style: italic;
	color: var(--bone);
	margin: 0;
	letter-spacing: -0.01em;
}
.lca-plan__head-strike {
	font-family: var(--font-body);
	font-size: 0.9375rem;
	color: var(--bone-faint);
	text-decoration: line-through;
	text-decoration-color: rgba(255, 77, 109, 0.5);
}

/* Variant card per piani con trial attivo: la card mostra SOLO il prezzo
   di ingresso (sign-up fee o 0€). Il prezzo ricorrente non appare sulla
   card per ridurre la dissonanza visiva — viene comunicato dall'admin
   nelle features o nelle note generiche. */
.lca-plan__main--trial {
	grid-template-columns: 1fr;
	justify-items: end;       /* spinge il blocco entry a destra */
}
.lca-plan__perday--entry .lca-plan__perday-label {
	text-transform: none;     /* "per 24 h" è frase, non kicker mono */
	letter-spacing: 0.02em;
	font-family: var(--font-body);
	font-size: 0.75rem;
	color: var(--bone-dim);
	max-width: 160px;
	text-align: right;
	line-height: 1.3;
}

/* Layout principale del prezzo: periodo a sinistra, per-day a destra in evidenza */
.lca-plan__main {
	display: grid;
	grid-template-columns: 1fr auto;
	gap: var(--s-4);
	align-items: end;
	padding-bottom: var(--s-6);
	margin-bottom: var(--s-6);
	border-bottom: 1px solid var(--ash-line);
}

.lca-plan__period {
	display: flex;
	flex-direction: column;
	gap: 2px;
	font-family: var(--font-body);
	min-width: 0;
}
.lca-plan__period-strike {
	font-size: 0.8125rem;
	color: var(--bone-faint);
	text-decoration: line-through;
	text-decoration-color: rgba(255, 77, 109, 0.55);
	line-height: 1.2;
}
.lca-plan__period-current {
	font-family: var(--font-display);
	font-size: clamp(1.5rem, 2.2vw, 1.875rem);
	font-weight: 600;
	color: var(--bone);
	line-height: 1.1;
	letter-spacing: -0.015em;
}
.lca-plan__period-label {
	font-size: 0.8125rem;
	color: var(--bone-dim);
	line-height: 1.3;
}

.lca-plan__perday {
	display: flex;
	flex-direction: column;
	align-items: flex-end;
	min-width: 90px;
	text-align: right;
}
.lca-plan__perday-strike {
	font-family: var(--font-body);
	font-size: 0.8125rem;
	color: var(--bone-faint);
	text-decoration: line-through;
	text-decoration-color: rgba(255, 77, 109, 0.55);
	line-height: 1.2;
	margin-bottom: 2px;
}
.lca-plan__perday-row {
	display: inline-flex;
	align-items: baseline;
	gap: 4px;
	font-family: var(--font-display);
	font-weight: 600;
	color: var(--blood);
	line-height: 1;
	letter-spacing: -0.03em;
}
.lca-plan--featured .lca-plan__perday-row { color: var(--blood-bright); }
.lca-plan__perday-currency {
	font-size: clamp(1rem, 1.5vw, 1.25rem);
	color: var(--blush);
	font-weight: 500;
}
.lca-plan__perday-value {
	font-size: clamp(2.25rem, 4.5vw, 3.5rem);
	font-style: italic;
}
.lca-plan__perday-label {
	font-family: var(--font-mono);
	font-size: 0.6875rem;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color: var(--bone-faint);
	margin-top: 2px;
}

.lca-plan__features {
	list-style: none;
	margin: 0 0 var(--s-8);
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: var(--s-3);
}
.lca-plan__features li {
	display: flex;
	gap: var(--s-3);
	align-items: flex-start;
	color: var(--bone);
	font-size: 0.9375rem;
	line-height: 1.45;
}
.lca-plan__features svg { color: var(--blood); flex-shrink: 0; margin-top: 4px; }
.lca-plan__cta { margin-top: auto; }

.lca-pricing-note {
	margin-top: var(--s-8);
	text-align: center;
	font-size: 0.875rem;
}
.lca-pricing-note a {
	margin-left: var(--s-2);
	color: var(--blush);
	border-bottom: 1px solid currentColor;
	padding-bottom: 1px;
}

@media (max-width: 600px) {
	.lca-plan { padding: var(--s-6); }
	.lca-plan__main { grid-template-columns: 1fr auto; gap: var(--s-3); }
	.lca-plan__perday-value { font-size: 2.5rem; }
}

/* ====== 13. CHAT UI (editorial · intimate) ========================= */

/* Wrap principale: niente sidebar. Layout intimo, max-width contenuto. */
.lca-chat {
	width: 100%;
	max-width: 760px;
	margin-inline: auto;
	min-height: 70vh;
	display: flex;
	flex-direction: column;
	position: relative;
}

/* ---- ENTRY: scelta modalità ---- */
.lca-chat__entry {
	padding: var(--s-8) 0;
	transition: opacity 400ms var(--ease), transform 400ms var(--ease);
}
.lca-chat__entry.is-hidden,
.lca-chat__setup.is-hidden,
.lca-chat__resume.is-hidden {
	display: none;
}

/* ---- STEP: context-setup (wizard pre-chat) ---- */
.lca-chat__setup {
	padding: var(--s-4) 0;
	animation: lca-step-in 400ms var(--ease) both;
}
/* Step intermedi (setup + resume): titoli più contenuti dell'entry */
.lca-chat__setup .lca-chat__intro,
.lca-chat__resume .lca-chat__intro { margin-bottom: var(--s-5); }
.lca-chat__setup .lca-chat__intro-title,
.lca-chat__resume .lca-chat__intro-title {
	font-size: clamp(1.5rem, 3.5vw, 2.25rem);
	margin: 0 0 var(--s-2);
}
.lca-chat__setup .lca-chat__intro-lead,
.lca-chat__resume .lca-chat__intro-lead {
	font-size: 0.9375rem;
}
.lca-chat__setup-form {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: var(--s-4);
	max-width: 560px;
}
.lca-chat__context-field--full { grid-column: 1 / -1; }
@media (max-width: 600px) { .lca-chat__setup-form { grid-template-columns: 1fr; } }
.lca-chat__setup-actions {
	grid-column: 1 / -1;
	display: flex;
	gap: var(--s-3);
	justify-content: flex-end;
	margin-top: var(--s-3);
	flex-wrap: wrap;
}

/* Error inline nel wizard (sopra al form). aria-live="alert" sul nodo. */
.lca-chat__setup-error {
	grid-column: 1 / -1;
	margin: 0 0 var(--s-2);
	padding: var(--s-2) var(--s-3);
	background: rgba(225, 11, 44, .08);
	border-left: 3px solid var(--blood);
	border-radius: var(--r-sm);
	color: var(--blood-bright);
	font-size: 0.875rem;
	display: none;
}
.lca-chat__setup-error.is-visible { display: block; }

/* Step animation: applied via JS quando lo step diventa visibile */
.lca-chat__setup.is-step-in,
.lca-chat__resume.is-step-in {
	animation: lca-step-in 380ms var(--ease) both;
}

/* Loading state sui bottoni primary del wizard */
.lca-btn.is-loading {
	position: relative;
	color: transparent !important;
	pointer-events: none;
}
.lca-btn.is-loading::after {
	content: "";
	position: absolute;
	top: 50%;
	left: 50%;
	width: 16px;
	height: 16px;
	margin: -8px 0 0 -8px;
	border: 2px solid currentColor;
	border-right-color: transparent;
	border-radius: 50%;
	color: var(--bone);
	animation: lca-spin 0.7s linear infinite;
}
@keyframes lca-spin { to { transform: rotate(360deg); } }

/* ---- STEP: resume picker ---- */
.lca-chat__resume {
	padding: var(--s-4) 0;
	animation: lca-step-in 400ms var(--ease) both;
}
.lca-chat__resume-card {
	display: flex;
	flex-direction: column;
	gap: var(--s-2);
	padding: var(--s-5) var(--s-6);
	background: var(--ink-soft);
	border: 1px solid var(--ash-line);
	border-left: 3px solid var(--blood);
	border-radius: var(--r-md);
	max-width: 560px;
	margin-bottom: var(--s-5);
}
.lca-chat__resume-card-title {
	font-family: var(--font-display);
	font-size: 1.125rem;
	font-weight: 600;
	color: var(--bone);
}
.lca-chat__resume-card-preview {
	font-size: 0.9rem;
	color: var(--bone-dim);
	line-height: 1.5;
}
.lca-chat__resume-card-date {
	font-size: 0.75rem;
	color: var(--bone-faint);
	text-transform: uppercase;
	letter-spacing: .08em;
}
.lca-chat__resume-actions {
	display: flex;
	gap: var(--s-3);
	flex-wrap: wrap;
}

@keyframes lca-step-in {
	from { opacity: 0; transform: translateY(8px); }
	to   { opacity: 1; transform: translateY(0); }
}

/* Generic .is-hidden helper per nuovi elementi (rename UI, ecc.) */
.is-hidden { display: none !important; }

/* ---- Loader fullbleed durante caricamento conversazione ---- */
.lca-chat__loader {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	gap: var(--s-3);
	padding: var(--s-10) var(--s-4);
	min-height: 240px;
	color: var(--bone-dim);
	font-family: var(--font-mono);
	font-size: 0.8125rem;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	animation: lca-step-in 200ms var(--ease) both;
}
.lca-chat__loader[hidden] { display: none; }
.lca-chat__loader-spinner {
	width: 28px;
	height: 28px;
	border: 2px solid var(--ash-line);
	border-top-color: var(--blood);
	border-radius: 50%;
	animation: lca-spin 0.7s linear infinite;
}

/* ---- Context panel: save button row ---- */
.lca-chat__context-actions {
	grid-column: 1 / -1;
	display: flex;
	justify-content: flex-end;
	margin-top: var(--s-2);
}

/* ---- History: rename inline UI ---- */
.lca-history__li {
	position: relative;
	display: flex;
	align-items: stretch;
	gap: var(--s-2);
}
.lca-history__li .lca-history__item { flex: 1; }
.lca-history__rename {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 36px;
	flex-shrink: 0;
	background: transparent;
	color: var(--bone-faint);
	border: 1px solid transparent;
	border-radius: var(--r-sm);
	cursor: pointer;
	transition: all var(--dur) var(--ease);
}
.lca-history__rename:hover {
	color: var(--bone);
	border-color: var(--ash-line);
	background: var(--ink-soft);
}
.lca-history__rename svg { width: 14px; height: 14px; }
.lca-history__edit { flex: 1; display: flex; align-items: center; }
.lca-history__rename-input {
	width: 100%;
	background: var(--ink-soft);
	border: 1.5px solid var(--blood);
	border-radius: var(--r-sm);
	padding: var(--s-2) var(--s-3);
	color: var(--bone);
	font-size: 0.9375rem;
	outline: none;
}

/* Mode-scope: nascondi gruppi non attivi quando dentro a una modalità.
   La regola di scoping è applicata dal JS aggiungendo .is-hidden al group. */
.lca-history__group.is-hidden { display: none; }
.lca-chat__intro { margin-bottom: var(--s-10); text-align: left; }
.lca-chat__intro-title {
	font-family: var(--font-display);
	font-size: clamp(2.25rem, 5.5vw, 3.75rem);
	font-weight: 600;
	letter-spacing: -0.025em;
	line-height: 1.05;
	margin: var(--s-3) 0 var(--s-4);
}
.lca-chat__intro-title em {
	font-style: italic;
	color: var(--blood);
}
.lca-chat__intro-lead {
	color: var(--bone-dim);
	font-size: clamp(1rem, 1.4vw, 1.125rem);
	line-height: 1.55;
	max-width: 52ch;
	margin: 0;
}

.lca-chat__choices {
	display: flex;
	flex-direction: column;
	gap: var(--s-3);
}

.lca-chat__choice {
	display: grid;
	grid-template-columns: auto 1fr auto;
	gap: var(--s-5);
	align-items: center;
	width: 100%;
	padding: var(--s-5) var(--s-6);
	background: var(--ink-soft);
	border: 1px solid var(--ash-line);
	border-radius: var(--r-xl);
	text-align: left;
	cursor: pointer;
	transition: all var(--dur) var(--ease);
	color: var(--bone);
	min-height: 96px;
}
.lca-chat__choice:hover {
	border-color: var(--blood);
	background: var(--ink-mid);
	transform: translateY(-2px);
	box-shadow: var(--glow-blood);
}
.lca-chat__choice-icon {
	width: 52px; height: 52px;
	border-radius: var(--r-md);
	background: var(--ink);
	border: 1px solid var(--ash-line-strong);
	display: grid;
	place-items: center;
	color: var(--blood);
	flex-shrink: 0;
	transition: all var(--dur) var(--ease);
}
.lca-chat__choice:hover .lca-chat__choice-icon {
	background: rgba(225, 11, 44, 0.12);
	border-color: var(--blood);
	transform: scale(1.05) rotate(-2deg);
}
.lca-chat__choice-body { display: flex; flex-direction: column; gap: 4px; min-width: 0; }
.lca-chat__choice-title {
	font-family: var(--font-display);
	font-size: clamp(1.125rem, 1.8vw, 1.375rem);
	font-weight: 600;
	font-style: italic;
	color: var(--bone);
	line-height: 1.2;
}
.lca-chat__choice-desc {
	color: var(--bone-dim);
	font-size: 0.9375rem;
	line-height: 1.45;
}
.lca-chat__choice-arrow {
	color: var(--bone-faint);
	transition: all var(--dur) var(--ease);
	flex-shrink: 0;
}
.lca-chat__choice:hover .lca-chat__choice-arrow {
	color: var(--blood);
	transform: translateX(4px);
}

@media (max-width: 600px) {
	.lca-chat__choice {
		padding: var(--s-4) var(--s-5);
		min-height: 80px;
		gap: var(--s-4);
	}
	.lca-chat__choice-icon { width: 44px; height: 44px; }
	.lca-chat__choice-arrow { display: none; }
}

/* ---- ROOM: conversazione ---- */
.lca-chat__room {
	display: none;
	flex-direction: column;
	flex: 1;
	min-height: 0;
}
.lca-chat__room.is-active { display: flex; }

.lca-chat__topbar {
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: var(--s-3);
	padding: var(--s-4) 0;
	margin-bottom: var(--s-4);
	border-bottom: 1px solid var(--ash-line);
	position: sticky;
	top: var(--header-h);
	z-index: 4;
	background: var(--ink);
}
.lca-chat__back {
	display: inline-flex;
	align-items: center;
	gap: var(--s-2);
	padding: var(--s-2) var(--s-3) var(--s-2) var(--s-2);
	border-radius: var(--r-pill);
	color: var(--bone-dim);
	font-size: 0.9375rem;
	background: transparent;
	transition: all var(--dur) var(--ease);
	font-family: var(--font-display);
	font-style: italic;
	font-weight: 500;
}
.lca-chat__back svg { transform: rotate(-90deg); }
.lca-chat__back:hover { color: var(--bone); background: var(--ink-soft); }
.lca-chat__back span { font-size: 1rem; }

.lca-chat__topbar-actions {
	display: flex;
	gap: var(--s-2);
}
.lca-chat__topbar-btn {
	display: inline-flex;
	align-items: center;
	gap: var(--s-2);
	padding: var(--s-2) var(--s-3);
	border: 1px solid var(--ash-line);
	border-radius: var(--r-pill);
	color: var(--bone-dim);
	font-size: 0.8125rem;
	background: transparent;
	transition: all var(--dur) var(--ease);
	cursor: pointer;
}
.lca-chat__topbar-btn:hover {
	color: var(--bone);
	border-color: var(--bone-faint);
	background: var(--ink-soft);
}
.lca-chat__topbar-btn[aria-expanded="true"] {
	background: var(--ink-soft);
	color: var(--bone);
	border-color: var(--blood);
}
@media (max-width: 480px) {
	.lca-chat__topbar-btn span { display: none; }
	.lca-chat__topbar-btn { padding: var(--s-2); width: 36px; height: 36px; justify-content: center; }
}

/* ---- History drawer ---- */
.lca-history {
	position: fixed;
	top: 0;
	left: 0;
	bottom: 0;
	width: min(420px, 100vw);
	background: var(--ink-soft);
	border-right: 1px solid var(--ash-line);
	z-index: 95;
	display: flex;
	flex-direction: column;
	transform: translateX(-100%);
	transition: transform 360ms var(--ease);
	overflow: hidden;
	box-shadow: 24px 0 60px -20px rgba(0, 0, 0, 0.7);
}
.lca-history.is-open { transform: translateX(0); }
.lca-history__backdrop {
	position: fixed;
	inset: 0;
	background: rgba(0, 0, 0, 0.6);
	backdrop-filter: blur(4px);
	z-index: 94;
	border: 0;
	cursor: pointer;
	opacity: 0;
	pointer-events: none;
	transition: opacity 320ms var(--ease);
}
.lca-history.is-open ~ .lca-history__backdrop {
	opacity: 1;
	pointer-events: auto;
}

.lca-history__head {
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding: var(--s-5) var(--s-6);
	border-bottom: 1px solid var(--ash-line);
	flex-shrink: 0;
}
.lca-history__title {
	font-family: var(--font-display);
	font-size: 1.25rem;
	font-weight: 600;
	font-style: italic;
	margin: 0;
	color: var(--bone);
}
.lca-history__close {
	width: 36px; height: 36px;
	border-radius: 50%;
	border: 1px solid var(--ash-line);
	display: grid;
	place-items: center;
	color: var(--bone);
	background: transparent;
	transition: all var(--dur) var(--ease);
}
.lca-history__close:hover {
	background: var(--ink);
	border-color: var(--bone-faint);
}

.lca-history__login {
	margin: var(--s-4) var(--s-6);
	padding: var(--s-4);
	background: var(--ink);
	border: 1px solid var(--ash-line);
	border-radius: var(--r-md);
	display: flex;
	flex-direction: column;
	gap: var(--s-3);
}
.lca-history__login p {
	margin: 0;
	font-size: 0.875rem;
	color: var(--bone-dim);
	line-height: 1.5;
}

.lca-history__groups {
	flex: 1;
	overflow-y: auto;
	padding: var(--s-2) var(--s-4) var(--s-4);
}

.lca-history__group {
	border-bottom: 1px solid var(--ash-line);
}
.lca-history__group:last-child { border-bottom: 0; }
.lca-history__group-head {
	display: flex;
	align-items: center;
	gap: var(--s-3);
	padding: var(--s-4) var(--s-2);
	cursor: pointer;
	list-style: none;
	color: var(--bone);
	transition: color var(--dur) var(--ease);
}
.lca-history__group-head::-webkit-details-marker { display: none; }
.lca-history__group-head:hover { color: var(--blush); }
.lca-history__group-icon {
	width: 32px; height: 32px;
	border-radius: var(--r-sm);
	background: var(--ink);
	border: 1px solid var(--ash-line-strong);
	display: grid;
	place-items: center;
	color: var(--blood);
	flex-shrink: 0;
}
.lca-history__group-label {
	flex: 1;
	font-family: var(--font-display);
	font-style: italic;
	font-size: 1rem;
	font-weight: 500;
}
.lca-history__group-count {
	font-family: var(--font-mono);
	font-size: 0.75rem;
	color: var(--bone-faint);
	background: var(--ink);
	padding: 2px 8px;
	border-radius: var(--r-pill);
	min-width: 24px;
	text-align: center;
}
.lca-history__group-chev {
	color: var(--bone-faint);
	transition: transform var(--dur) var(--ease);
	display: inline-flex;
}
.lca-history__group[open] .lca-history__group-chev { transform: rotate(180deg); }

.lca-history__list {
	list-style: none;
	margin: 0;
	padding: 0 0 var(--s-4);
	display: flex;
	flex-direction: column;
	gap: var(--s-1);
}
.lca-history__item {
	display: grid;
	grid-template-columns: 1fr auto;
	grid-template-areas:
		"title date"
		"preview preview";
	gap: 4px var(--s-3);
	width: 100%;
	padding: var(--s-3);
	border-radius: var(--r-md);
	background: transparent;
	border: 1px solid transparent;
	color: var(--bone);
	text-align: left;
	cursor: pointer;
	transition: all var(--dur) var(--ease);
}
.lca-history__item:hover, .lca-history__item.is-active {
	background: var(--ink);
	border-color: var(--ash-line);
}
.lca-history__item-title {
	grid-area: title;
	font-size: 0.9375rem;
	font-weight: 500;
	color: var(--bone);
	line-height: 1.3;
}
.lca-history__item-preview {
	grid-area: preview;
	font-size: 0.8125rem;
	color: var(--bone-dim);
	line-height: 1.4;
	overflow: hidden;
	text-overflow: ellipsis;
	display: -webkit-box;
	-webkit-line-clamp: 1;
	line-clamp: 1;
	-webkit-box-orient: vertical;
}
.lca-history__item-date {
	grid-area: date;
	font-family: var(--font-mono);
	font-size: 0.6875rem;
	color: var(--bone-faint);
	letter-spacing: 0.04em;
	white-space: nowrap;
	flex-shrink: 0;
	margin-top: 2px;
}

.lca-history__empty {
	margin: 0;
	padding: var(--s-2) var(--s-3) var(--s-4);
	font-size: 0.8125rem;
	color: var(--bone-faint);
	font-style: italic;
}

.lca-history__foot {
	padding: var(--s-4) var(--s-6);
	border-top: 1px solid var(--ash-line);
	flex-shrink: 0;
}

@media (max-width: 600px) {
	.lca-history {
		top: auto;
		bottom: 0;
		left: 0;
		right: 0;
		width: 100%;
		height: 90vh;
		max-height: 720px;
		border-right: 0;
		border-top: 1px solid var(--ash-line);
		border-radius: var(--r-xl) var(--r-xl) 0 0;
		transform: translateY(100%);
		box-shadow: 0 -24px 60px -20px rgba(0, 0, 0, 0.7);
	}
	.lca-history.is-open { transform: translateY(0); }
	.lca-history__head { padding: var(--s-4) var(--s-5); }
	.lca-history__head::before {
		content: "";
		position: absolute;
		top: 8px;
		left: 50%;
		transform: translateX(-50%);
		width: 40px; height: 4px;
		background: var(--ash-line-strong);
		border-radius: 999px;
	}
}

/* ---- Context panel (collapsibile) ---- */
.lca-chat__context {
	max-height: 0;
	overflow: hidden;
	transition: max-height 360ms var(--ease);
}
.lca-chat__context.is-open { max-height: 600px; }
.lca-chat__context-grid {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: var(--s-3);
	padding: var(--s-4) 0 var(--s-2);
	margin-bottom: var(--s-4);
	border-bottom: 1px solid var(--ash-line);
}
@media (max-width: 600px) { .lca-chat__context-grid { grid-template-columns: 1fr; } }
.lca-chat__context-field {
	display: flex;
	flex-direction: column;
	gap: 6px;
}
.lca-chat__context-label {
	font-size: 0.75rem;
	color: var(--bone-faint);
	font-weight: 500;
	letter-spacing: 0.02em;
}
.lca-chat__context-field input,
.lca-chat__context-field select {
	background: var(--ink-soft);
	border: 1.5px solid var(--ash-line);
	border-radius: var(--r-md);
	padding: var(--s-3);
	color: var(--bone);
	font-size: 0.9375rem;
	font-family: var(--font-body);
	transition: border-color var(--dur) var(--ease);
}
.lca-chat__context-field input:focus,
.lca-chat__context-field select:focus {
	outline: 0;
	border-color: var(--blood);
}
.lca-chat__context-field input::placeholder { color: var(--bone-faint); }

/* ---- Stream ---- */
.lca-chat__stream {
	flex: 1;
	overflow-y: auto;
	display: flex;
	flex-direction: column;
	gap: var(--s-8);
	padding: var(--s-6) 0 var(--s-12);
	scroll-padding-bottom: 200px;
}

/* Welcome message (editorial, no bubble) */
.lca-chat__welcome {
	padding: var(--s-4) 0;
	max-width: 56ch;
	animation: lca-welcome-in 700ms var(--ease) both;
}
.lca-chat__welcome-text {
	font-family: var(--font-display);
	font-style: italic;
	font-size: clamp(1.25rem, 2vw, 1.5rem);
	line-height: 1.45;
	color: var(--bone-dim);
	margin: 0;
}
.lca-chat__welcome-text::before {
	content: "";
	display: block;
	width: 32px;
	height: 2px;
	background: var(--blood);
	margin-bottom: var(--s-4);
}
@keyframes lca-welcome-in { from { opacity: 0; transform: translateY(8px); } to { opacity: 1; transform: translateY(0); } }

/* Message base */
.lca-msg {
	opacity: 0;
	transform: translateY(8px);
	transition: opacity 400ms var(--ease), transform 500ms var(--ease);
	max-width: 100%;
}
.lca-msg.is-in { opacity: 1; transform: translateY(0); }

/* User: piccolo, allineato dx, sans, soft */
.lca-msg--user { align-self: flex-end; max-width: 80%; }
.lca-msg--user .lca-msg__body {
	background: var(--blood);
	color: var(--bone);
	padding: var(--s-3) var(--s-4);
	border-radius: var(--r-lg);
	border-bottom-right-radius: 6px;
	font-size: 0.9375rem;
	line-height: 1.5;
	white-space: pre-wrap;
	word-wrap: break-word;
}

/* AI: card grigio scuro su sfondo ink. Lo stile della card vive
   sull'<article> stesso così tutto ciò che è dentro (testo + barra
   azioni col bottone "Copia") è visivamente parte del riquadro. */
.lca-msg--ai {
	align-self: stretch;
	max-width: 60ch;
	background: var(--ink-mid);
	border: 1px solid var(--ash-line);
	border-radius: var(--r-lg);
	border-bottom-left-radius: 6px;
	padding: var(--s-4) var(--s-5);
}
.lca-msg--ai .lca-msg__body {
	font-family: var(--font-display);
	font-size: clamp(1.0625rem, 1.6vw, 1.25rem);
	line-height: 1.6;
	color: var(--bone);
	background: transparent;
	border: 0;
	padding: 0;
}
.lca-msg--ai .lca-msg__body p { margin: 0 0 var(--s-4); }
.lca-msg--ai .lca-msg__body p:last-child { margin-bottom: 0; }
.lca-msg--ai .lca-msg__body strong {
	color: var(--bone);
	font-weight: 600;
	font-style: normal;
	background: rgb(247 23 57 / 50%);
	padding: 0 4px;
	border-radius: 3px;
}
/* Structured AI block: dl/dt/dd come definizione editoriale */
.lca-ai-block {
	margin: var(--s-4) 0 0;
	display: flex;
	flex-direction: column;
	gap: var(--s-3);
}
.lca-ai-block dt {
	font-family: var(--font-body);
	font-size: 0.6875rem;
	font-weight: 600;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: var(--blush);
	margin-bottom: 2px;
}
.lca-ai-block dd {
	font-family: var(--font-display);
	font-size: 1rem;
	line-height: 1.55;
	color: var(--bone);
	margin: 0 0 var(--s-3);
	font-style: normal;
}
.lca-ai-block dd:last-child { margin-bottom: 0; }
.lca-ai-quote {
	font-style: italic !important;
	color: var(--blush) !important;
	background: var(--ink-soft);
	border-left: 2px solid var(--blush);
	padding: var(--s-2) var(--s-4) !important;
	border-radius: 0 var(--r-md) var(--r-md) 0;
	font-size: 1.05em !important;
}

/* Risk indicator */
.lca-ai-risk {
	display: inline-flex;
	align-items: center;
	gap: var(--s-3);
	padding: var(--s-3) var(--s-4);
	background: var(--ink-soft);
	border: 1px solid var(--ash-line);
	border-radius: var(--r-md);
	margin: var(--s-3) 0;
	font-family: var(--font-body);
}
.lca-ai-risk__label {
	font-size: 0.6875rem;
	font-weight: 600;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color: var(--bone-faint);
}
.lca-ai-risk__value {
	font-family: var(--font-display);
	font-style: italic;
	font-size: 1.25rem;
	font-weight: 600;
}
.lca-ai-risk--low { border-color: rgba(34, 197, 94, .4); }
.lca-ai-risk--low .lca-ai-risk__value { color: #22c55e; }
.lca-ai-risk--mid { border-color: rgba(255, 77, 109, .5); }
.lca-ai-risk--mid .lca-ai-risk__value { color: var(--blush); }
.lca-ai-risk--high { border-color: var(--blood); background: rgba(225, 11, 44, .1); }
.lca-ai-risk--high .lca-ai-risk__value { color: var(--blood); }

/* Thinking — stesso look del messaggio AI ma con dots animati */
.lca-msg--thinking .lca-msg__body {
	display: inline-flex;
	gap: 6px;
	padding: var(--s-3) var(--s-4);
	background: var(--ink-mid);
	border: 1px solid var(--ash-line);
	border-radius: var(--r-md);
	border-top-left-radius: 6px;
}
.lca-thinking__dot {
	width: 8px; height: 8px;
	background: var(--blush);
	border-radius: 50%;
	animation: lca-dot 1.2s var(--ease) infinite;
}
.lca-thinking__dot:nth-child(2) { animation-delay: .2s; }
.lca-thinking__dot:nth-child(3) { animation-delay: .4s; }
@keyframes lca-dot { 0%, 80%, 100% { opacity: .25; transform: scale(.85); } 40% { opacity: 1; transform: scale(1.1); } }

/* ---- Tones (solo modalità reply) ---- */
.lca-chat__tones {
	display: none;
	flex-direction: column;
	gap: var(--s-3);
	padding: var(--s-4) 0;
	border-top: 1px solid var(--ash-line);
	margin-top: var(--s-4);
}
.lca-chat__tones.is-visible { display: flex; }
.lca-chat__tones-label {
	font-family: var(--font-display);
	font-style: italic;
	font-size: 1rem;
	color: var(--bone-dim);
}
.lca-chat__tones-pills {
	display: flex;
	flex-wrap: wrap;
	gap: var(--s-2);
}
.lca-chat__tone {
	padding: var(--s-2) var(--s-4);
	background: transparent;
	border: 1px solid var(--ash-line);
	border-radius: var(--r-pill);
	color: var(--bone-dim);
	font-size: 0.875rem;
	cursor: pointer;
	transition: all var(--dur) var(--ease);
	font-family: var(--font-body);
}
.lca-chat__tone:hover { border-color: var(--bone-faint); color: var(--bone); }
.lca-chat__tone.is-active {
	background: var(--blood);
	color: var(--bone);
	border-color: var(--blood);
}

/* ---- Input bar (sticky bottom) ---- */
.lca-chat__inputbar {
	position: sticky;
	bottom: 0;
	padding: var(--s-4) 0 var(--s-5);
	background: linear-gradient(180deg, transparent 0%, var(--ink) 18%);
	z-index: 5;
}
/* WhatsApp-style: una sola "pillola" full-width con icone integrate
   senza bordi propri. Attach a sx, textarea al centro, send a dx.
   Tutto il blocco è il campo, non tre elementi separati.
   NOTA: gli `!important` sulla textarea servono per battere
   `.lca-wc textarea { ... !important }` che si applica quando la
   chat vive dentro a `.woocommerce-MyAccount-content`. */
.lca-chat__inputwrap {
	display: flex;
	gap: 4px;
	align-items: center;
	background: var(--ink-soft);
	border: 1px solid var(--ash-line);
	border-radius: var(--r-lg);
	padding: 4px 4px 4px var(--s-2);
	width: 100%;
	transition: all var(--dur) var(--ease);
	box-shadow: 0 8px 32px -12px rgba(0, 0, 0, 0.6);
}
.lca-chat__inputwrap:focus-within {
	border-color: var(--blood);
	box-shadow: 0 0 0 3px rgba(225, 11, 44, .12), 0 8px 32px -8px rgba(225, 11, 44, .25);
}
textarea.lca-chat__input,
.lca-wc textarea.lca-chat__input {
	flex: 1 1 auto;
	min-width: 0;
	background: transparent !important;
	border: 0 !important;
	border-radius: 0 !important;
	outline: 0 !important;
	box-shadow: none !important;
	color: var(--bone) !important;
	font-size: 1rem !important;
	line-height: 1.5 !important;
	resize: none !important;
	height: auto !important;
	max-height: 240px !important;
	min-height: 36px !important;
	padding: 8px var(--s-2) !important;
	font-family: var(--font-body) !important;
	overflow-y: auto;
	/* Autogrow CSS-only (Chrome 123+, Edge 123+, Safari 18.4+).
	   Fallback al JS handler che usa scrollHeight per i browser più vecchi. */
	field-sizing: content;
}
.lca-chat__input::placeholder { color: var(--bone-faint); }
.lca-chat__input:focus { border: 0 !important; box-shadow: none !important; }

/* Attach: icon-only, niente bordo, si confonde col wrap (stile WA). */
.lca-chat__attach {
	width: 36px; height: 36px;
	flex-shrink: 0;
	background: transparent;
	color: var(--bone-faint);
	border: 0;
	border-radius: 50%;
	display: grid;
	place-items: center;
	transition: color var(--dur) var(--ease), background var(--dur) var(--ease);
}
.lca-chat__attach svg { width: 20px; height: 20px; }
.lca-chat__attach:hover {
	color: var(--bone);
	background: var(--ink-mid);
}

/* Send: pillola rossa piena, integrata dentro al wrap. */
.lca-chat__send {
	width: 36px; height: 36px;
	flex-shrink: 0;
	border-radius: 50%;
	background: var(--blood);
	color: var(--bone);
	display: grid;
	place-items: center;
	transition: all var(--dur) var(--ease);
}
.lca-chat__send svg { width: 16px; height: 16px; }
.lca-chat__send:hover {
	background: var(--blood-bright);
	box-shadow: 0 0 16px -2px var(--blood);
}
.lca-chat__send:disabled {
	opacity: 0.4;
	cursor: not-allowed;
	box-shadow: none;
}

.lca-chat__uploads {
	display: none;
	flex-wrap: wrap;
	gap: var(--s-2);
	margin: 0 0 var(--s-3);
	padding: var(--s-2);
	background: var(--ink-soft);
	border: 1px solid var(--ash-line);
	border-radius: var(--r-md);
}
.lca-chat__uploads.is-visible { display: flex; }
.lca-chat__upload-item {
	position: relative;
	width: 72px;
	aspect-ratio: 1 / 1;
	border-radius: var(--r-sm);
	overflow: hidden;
	background: var(--ink);
}
.lca-chat__upload-link {
	display: block;
	width: 100%; height: 100%;
	cursor: zoom-in;
}
.lca-chat__upload-thumb {
	width: 100%; height: 100%;
	object-fit: cover;
	display: block;
}
.lca-chat__upload-remove {
	position: absolute;
	top: 2px; right: 2px;
	width: 22px; height: 22px;
	border-radius: 50%;
	background: rgba(0,0,0,.7);
	color: var(--bone);
	display: grid;
	place-items: center;
	font-size: 16px;
	line-height: 1;
	border: 0;
	z-index: 2;
}
.lca-chat__upload-remove:hover { background: var(--blood); }
.lca-chat__upload-item--loading {
	display: grid;
	place-items: center;
	background: var(--ink-soft);
	border: 1px dashed var(--ash-line);
}
.lca-chat__upload-spinner {
	width: 18px; height: 18px;
	border: 2px solid var(--ash-line);
	border-top-color: var(--blood);
	border-radius: 50%;
	animation: lca-spin 0.7s linear infinite;
}
@keyframes lca-spin { to { transform: rotate(360deg); } }
.lca-chat__uploads-loading {
	padding: var(--s-2) var(--s-3);
	color: var(--bone-faint);
	font-size: 0.85rem;
}

.lca-msg__gallery {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(80px, 1fr));
	gap: var(--s-2);
	margin-top: var(--s-3);
}
.lca-msg__img-link {
	display: block;
	aspect-ratio: 1 / 1;
	border-radius: var(--r-sm);
	overflow: hidden;
	cursor: zoom-in;
	background: var(--ink);
}
.lca-msg__img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
	transition: transform var(--dur) var(--ease);
}
.lca-msg__img-link:hover .lca-msg__img {
	transform: scale(1.04);
}
.lca-msg__raw {
	white-space: pre-wrap;
	word-break: break-word;
	font-family: var(--font-body);
	margin: 0;
}
/* --- Messaggio: scroll spacing + barra azioni --- */
.lca-msg {
	position: relative;
	/* Lo scroll-margin evita che il messaggio finisca dietro all'input bar sticky. */
	scroll-margin-bottom: 140px;
	scroll-margin-top: 80px;
}

/* Barra azioni del messaggio AI (Copia, ecc).
   Renderizzata PRIMA del body nel DOM → sta in alto-destra del card.
   No bordi/separatori: il card stesso fa contenitore. */
.lca-msg__actions {
	display: flex;
	justify-content: flex-end;
	gap: var(--s-2);
	margin-bottom: var(--s-2);
}
.lca-msg__copy {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	padding: 8px 12px;
	min-height: 36px;           /* touch-target friendly su mobile */
	background: transparent;
	color: var(--bone-faint);
	border: 1px solid var(--ash-line);
	border-radius: var(--r-sm);
	font-size: 0.85rem;
	font-weight: 500;
	letter-spacing: .02em;
	cursor: pointer;
	transition: all var(--dur) var(--ease);
}
.lca-msg__copy:hover {
	color: var(--bone);
	border-color: var(--blood);
	background: rgba(225, 11, 44, .08);
}
.lca-msg__copy:focus-visible {
	outline: 2px solid var(--blood);
	outline-offset: 2px;
}
.lca-msg__copy.is-success {
	color: #4ade80;
	border-color: #4ade80;
	background: rgba(74, 222, 128, .1);
}
.lca-msg__copy svg { width: 15px; height: 15px; flex-shrink: 0; }
.lca-msg__copy-label { line-height: 1; }

/* --- Thinking indicator --- */
.lca-msg--thinking .lca-msg__body {
	display: flex;
	align-items: center;
	gap: var(--s-3);
}
.lca-thinking__dots {
	display: inline-flex;
	gap: 4px;
}
.lca-thinking__label {
	color: var(--bone-faint);
	font-size: 0.9rem;
	font-style: italic;
}

.lca-msg__md p { margin: 0 0 var(--s-3); }
.lca-msg__md p:last-child { margin-bottom: 0; }
.lca-msg__md strong { color: var(--bone); font-weight: 700; }
.lca-msg__md em { font-style: italic; }
.lca-msg__md ul, .lca-msg__md ol { margin: var(--s-2) 0 var(--s-3); padding-left: var(--s-4); }
.lca-msg__md li { margin: var(--s-1) 0; }
.lca-msg__md h3, .lca-msg__md h4 { margin: var(--s-3) 0 var(--s-2); color: var(--blood); }
.lca-msg__md h3 { font-size: 1.05rem; }
.lca-msg__md h4 { font-size: 0.95rem; text-transform: uppercase; letter-spacing: .04em; }
.lca-msg__md blockquote { margin: var(--s-3) 0; padding-left: var(--s-3); border-left: 2px solid var(--blood); color: var(--bone-faint); font-style: italic; }
.lca-msg__md code { background: var(--ink-soft); padding: 2px 6px; border-radius: 4px; font-family: ui-monospace, SFMono-Regular, Menlo, monospace; font-size: 0.9em; }
.lca-msg__md a { color: var(--blood-bright); text-decoration: underline; }
.lca-msg--error .lca-msg__body {
	color: var(--blood-bright);
	background: rgba(225, 11, 44, 0.08);
	border: 1px solid rgba(225, 11, 44, 0.35);
	border-radius: var(--r-md);
	padding: var(--s-3) var(--s-4);
}
.lca-ai-list { margin: var(--s-2) 0 0; padding-left: var(--s-4); }
.lca-ai-list li { margin: var(--s-1) 0; }
.lca-ai-list--quotes { list-style: none; padding-left: 0; }

/* ---- Reply mode: card per tono con copy button individuale ----
   Pulito, niente italic pesante, gerarchia chiara. Ogni card è un
   blocco di testo "pronto da copiare" — il copy button è inline nella
   header così è subito raggiungibile.
*/
.lca-ai-replies {
	display: flex;
	flex-direction: column;
	gap: var(--s-3);
	margin: var(--s-3) 0 0;
}
.lca-ai-reply {
	background: var(--ink-soft);
	border: 1px solid var(--ash-line);
	border-left: 3px solid var(--blush);
	border-radius: var(--r-md);
	padding: var(--s-3) var(--s-4);
	transition: border-color var(--dur) var(--ease);
}
.lca-ai-reply:hover { border-color: var(--bone-faint); border-left-color: var(--blush); }
.lca-ai-reply--soft   { border-left-color: rgba(255, 182, 193, .8); }
.lca-ai-reply--direct { border-left-color: var(--blush); }
.lca-ai-reply--strong { border-left-color: var(--blood); }

.lca-ai-reply__head {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: var(--s-3);
	margin-bottom: var(--s-2);
}
.lca-ai-reply__label {
	font-family: var(--font-body);
	font-size: 0.6875rem;
	font-weight: 700;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: var(--bone-faint);
}
.lca-ai-reply--soft   .lca-ai-reply__label { color: rgba(255, 182, 193, .9); }
.lca-ai-reply--direct .lca-ai-reply__label { color: var(--blush); }
.lca-ai-reply--strong .lca-ai-reply__label { color: var(--blood-bright); }

.lca-ai-reply__copy {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	padding: 6px 10px;
	min-height: 32px;
	background: transparent;
	color: var(--bone-faint);
	border: 1px solid var(--ash-line);
	border-radius: var(--r-sm);
	font-size: 0.75rem;
	font-weight: 500;
	letter-spacing: .02em;
	cursor: pointer;
	transition: all var(--dur) var(--ease);
}
.lca-ai-reply__copy:hover {
	color: var(--bone);
	border-color: var(--blood);
	background: rgba(225, 11, 44, .08);
}
.lca-ai-reply__copy:focus-visible {
	outline: 2px solid var(--blood);
	outline-offset: 2px;
}
.lca-ai-reply__copy.is-success {
	color: #4ade80;
	border-color: #4ade80;
	background: rgba(74, 222, 128, .1);
}
.lca-ai-reply__copy svg { width: 13px; height: 13px; flex-shrink: 0; }

.lca-ai-reply__text {
	margin: 0;
	font-family: var(--font-body);
	font-size: 0.975rem;
	line-height: 1.55;
	color: var(--bone);
	font-style: normal;
	white-space: pre-wrap;       /* preserva eventuali a-capo della risposta */
}

.lca-history__loading { color: var(--bone-faint); padding: var(--s-3); }
.lca-history__empty { color: var(--bone-faint); padding: var(--s-3); text-align: center; }

.lca-chat__hint {
	margin: var(--s-3) 0 0;
	font-size: 0.75rem;
	color: var(--bone-faint);
	text-align: center;
	letter-spacing: 0.01em;
}

/* ---- Mobile tweaks ---- */
@media (max-width: 600px) {
	.lca-chat { min-height: calc(100vh - var(--header-h)); }
	.lca-chat__entry { padding: var(--s-6) 0; }
	.lca-chat__topbar { padding: var(--s-3) 0; }
	.lca-chat__back span { font-size: 0.9375rem; }
	.lca-chat__back .lca-icon { display: inline-flex; }

	.lca-msg--user { max-width: 88%; }
	.lca-msg--ai .lca-msg__body { padding-left: var(--s-4); font-size: 1rem; }

	.lca-chat__inputbar { padding-bottom: var(--s-4); }
	.lca-chat__input { font-size: 16px; /* prevent iOS zoom */ }
}
/* ====== 13.5 INSIDER (trust band con foto) ========================= */
.lca-insider__grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: clamp(2rem, 6vw, 5rem);
	align-items: center;
}
@media (max-width: 980px) { .lca-insider__grid { grid-template-columns: 1fr; } }

.lca-insider__visual {
	position: relative;
	min-height: 620px;
}
.lca-insider__photo {
	position: absolute;
	border-radius: var(--r-xl);
	overflow: hidden;
	border: 1px solid var(--ash-line);
	background: var(--ink);
}
.lca-insider__photo--main {
	top: 0;
	left: 0;
	width: 62%;
	aspect-ratio: 941/1672;
	z-index: 1;
}
.lca-insider__photo--accent {
	bottom: 0;
	right: 0;
	width: 48%;
	aspect-ratio: 941/1672;
	z-index: 2;
	box-shadow: -24px -24px 50px -16px rgba(0,0,0,.6);
}
.lca-insider__photo img,
.lca-insider__img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
.lca-insider__photo-overlay {
	position: absolute;
	inset: 0;
	background: transparent;
	pointer-events: none;
}
.lca-insider__badge {
	position: absolute;
	top: 50%;
	right: -16px;
	transform: translateY(-50%);
	z-index: 3;
	display: inline-flex;
	align-items: center;
	gap: var(--s-2);
	padding: var(--s-3) var(--s-4);
	background: var(--ink);
	border: 1px solid var(--blood);
	border-radius: var(--r-pill);
	font-family: var(--font-mono);
	font-size: 0.75rem;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--bone);
	font-weight: 500;
	box-shadow: 0 8px 32px -8px rgba(225, 11, 44, 0.5);
	white-space: nowrap;
}
.lca-insider__badge-dot {
	width: 8px; height: 8px;
	background: var(--blood);
	border-radius: 50%;
	box-shadow: 0 0 12px 2px var(--blood);
	animation: lca-pulse 2.4s var(--ease) infinite;
}

.lca-insider__points {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: var(--s-5);
}
.lca-insider__point {
	display: grid;
	grid-template-columns: 44px 1fr;
	gap: var(--s-4);
	align-items: start;
}
.lca-insider__point-icon {
	width: 44px; height: 44px;
	border: 1px solid var(--ash-line-strong);
	border-radius: var(--r-md);
	display: grid;
	place-items: center;
	color: var(--blood);
	background: var(--ink-soft);
	flex-shrink: 0;
}
.lca-insider__point-title {
	font-family: var(--font-display);
	font-size: 1.125rem;
	font-weight: 600;
	color: var(--bone);
	margin: 0 0 var(--s-1);
}
.lca-insider__point-desc {
	color: var(--bone-dim);
	font-size: 0.9375rem;
	line-height: 1.5;
	margin: 0;
}

@media (max-width: 980px) {
	.lca-insider__visual {
		min-height: 0;
		max-width: 480px;
		margin: 0 auto;
		display: grid;
		grid-template-columns: 1.6fr 1fr;
		gap: var(--s-3);
		position: relative;
	}
	.lca-insider__photo {
		position: relative;
		top: auto; left: auto; right: auto; bottom: auto;
		width: 100%;
		aspect-ratio: 941 / 1672;
		box-shadow: none;
	}
	.lca-insider__photo--main { grid-column: 1; }
	.lca-insider__photo--accent { grid-column: 2; align-self: end; }
	.lca-insider__badge {
		position: absolute;
		left: 50%;
		right: auto;
		top: auto;
		bottom: -14px;
		transform: translateX(-50%);
		white-space: nowrap;
	}
}
@media (max-width: 480px) {
	.lca-insider__visual { gap: var(--s-2); }
	.lca-insider__badge { font-size: 0.6875rem; padding: var(--s-2) var(--s-3); }
}

/* ====== 14. EDITORIAL / TESTIMONIAL =============================== */
.lca-editorial {
	background: var(--ink);
	padding: clamp(5rem, 12vw, 10rem) 0;
	position: relative;
	isolation: isolate;
	overflow: hidden;
	min-height: 60vh;
	display: flex;
	align-items: center;
}
.lca-editorial__bg {
	position: absolute;
	inset: 0;
	z-index: -2;
	overflow: hidden;
}
.lca-editorial__bg img,
.lca-editorial__bg-img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	filter: grayscale(0.6) brightness(0.45) saturate(1.2) contrast(1.05);
}
.lca-editorial::before {
	content: "";
	position: absolute;
	inset: 0;
	background:
		linear-gradient(135deg, rgba(139, 10, 31, 0.45) 0%, rgba(10, 10, 11, 0.7) 60%, rgba(10, 10, 11, 0.95) 100%),
		url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='160' height='160'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='.9' /></filter><rect width='100%' height='100%' filter='url(%23n)' opacity='.18'/></svg>");
	background-blend-mode: normal, overlay;
	z-index: -1;
	pointer-events: none;
}
.lca-editorial::after {
	content: "";
	position: absolute;
	top: -20%;
	right: -10%;
	width: 60%;
	height: 80%;
	background: radial-gradient(ellipse at center, rgba(225, 11, 44, 0.4) 0%, transparent 60%);
	filter: blur(40px);
	z-index: -1;
	pointer-events: none;
}
.lca-editorial__quote {
	font-family: var(--font-display);
	font-style: italic;
	font-size: clamp(2rem, 5vw, 4.5rem);
	line-height: 1.05;
	letter-spacing: -0.02em;
	color: var(--bone);
	max-width: 22ch;
}
.lca-editorial__quote::before {
	content: "“";
	font-family: var(--font-display);
	font-size: 4em;
	line-height: 0.7;
	color: var(--blush);
	display: block;
	margin-bottom: var(--s-3);
}
.lca-editorial__attr {
	margin-top: var(--s-8);
	font-family: var(--font-mono);
	font-size: 0.8125rem;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color: var(--blush);
}

/* ====== 15. FAQ ================================================== */
.lca-faq { display: flex; flex-direction: column; gap: var(--s-1); max-width: 880px; margin-inline: auto; }
.lca-faq__item {
	border-bottom: 1px solid var(--ash-line);
	padding: var(--s-2) 0;
}
.lca-faq__q {
	display: flex;
	width: 100%;
	justify-content: space-between;
	align-items: center;
	gap: var(--s-4);
	padding: var(--s-5) 0;
	text-align: left;
	font-family: var(--font-display);
	font-size: clamp(1.15rem, 1.8vw, 1.5rem);
	font-weight: 500;
	color: var(--bone);
	transition: color var(--dur) var(--ease);
}
.lca-faq__q:hover { color: var(--blush); }
.lca-faq__q-icon {
	width: 36px; height: 36px;
	border: 1px solid var(--ash-line-strong);
	border-radius: 50%;
	display: grid;
	place-items: center;
	flex-shrink: 0;
	transition: all var(--dur) var(--ease);
	color: var(--bone);
}
.lca-faq__item[open] .lca-faq__q-icon {
	background: var(--blood);
	border-color: var(--blood);
	transform: rotate(45deg);
}
.lca-faq__a {
	color: var(--bone-dim);
	padding: 0 0 var(--s-5);
	max-width: 75ch;
	font-size: 1rem;
	line-height: 1.6;
}

/* ====== 16. DISCLAIMER BAND ====================================== */
.lca-disclaimer-band {
	background: var(--ink-soft);
	border-block: 1px solid var(--ash-line);
	padding: var(--s-5) 0;
}
.lca-disclaimer-band__inner {
	display: flex;
	gap: var(--s-4);
	align-items: flex-start;
}
.lca-disclaimer-band__icon {
	color: var(--blush);
	flex-shrink: 0;
	margin-top: 2px;
}
.lca-disclaimer-band__text {
	font-family: var(--font-mono);
	font-size: 0.8125rem;
	letter-spacing: 0.02em;
	color: var(--bone-dim);
	line-height: 1.6;
	margin: 0;
}

/* ====== 17. CTA BAND ============================================= */
.lca-cta-band {
	position: relative;
	padding: clamp(4rem, 10vw, 8rem) 0;
	background: var(--ink);
	border-top: 1px solid var(--ash-line);
	overflow: hidden;
	isolation: isolate;
	text-align: center;
}
.lca-cta-band::before {
	content: "";
	position: absolute;
	inset: -50% 0 -50% 0;
	background: radial-gradient(ellipse at center, rgba(225, 11, 44, 0.35) 0%, transparent 60%);
	filter: blur(60px);
	z-index: -1;
}
.lca-cta-band__title {
	font-size: clamp(2.5rem, 6vw, 5rem);
	letter-spacing: -0.03em;
	line-height: 0.98;
	margin-bottom: var(--s-6);
}
.lca-cta-band__title em { font-style: italic; color: var(--blood); }
.lca-cta-band__lead {
	font-size: clamp(1rem, 1.4vw, 1.125rem);
	color: var(--bone-dim);
	max-width: 50ch;
	margin: 0 auto var(--s-8);
}

/* ====== 18. AUTH SPLIT ============================================ */
.lca-auth {
	display: grid;
	grid-template-columns: 1fr 1fr;
	min-height: calc(100vh - var(--header-h));
}
@media (max-width: 980px) { .lca-auth { grid-template-columns: 1fr; } }
.lca-auth__form {
	display: flex;
	flex-direction: column;
	justify-content: center;
	padding: clamp(2rem, 6vw, 5rem);
	max-width: 600px;
	width: 100%;
	margin-inline: auto;
}
.lca-auth__title { font-size: clamp(2.25rem, 4vw, 3rem); margin-bottom: var(--s-3); }
.lca-auth__lead { color: var(--bone-dim); margin-bottom: var(--s-8); font-size: 1.0625rem; }
.lca-auth__visual {
	position: relative;
	overflow: hidden;
	min-height: 400px;
}
.lca-auth__visual img {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	filter: brightness(0.6) saturate(1.1);
}
.lca-auth__visual::before {
	content: "";
	position: absolute;
	inset: 0;
	background: linear-gradient(135deg, rgba(225, 11, 44, 0.25) 0%, transparent 50%, rgba(0, 0, 0, 0.4) 100%);
	z-index: 1;
}
.lca-auth__quote {
	position: absolute;
	left: var(--s-8); right: var(--s-8); bottom: var(--s-8);
	z-index: 2;
	font-family: var(--font-display);
	font-style: italic;
	font-size: clamp(1.5rem, 2.5vw, 2.25rem);
	line-height: 1.15;
	color: var(--bone);
	max-width: 24ch;
}
.lca-auth__quote::before {
	content: "“";
	color: var(--blush);
	font-size: 2em;
	display: block;
	line-height: 0.6;
	margin-bottom: var(--s-2);
}
@media (max-width: 980px) { .lca-auth__visual { display: none; } }

/* ====== 19. FORM CONTROLS ======================================== */
.lca-form { display: flex; flex-direction: column; gap: var(--s-4); }
.lca-field { display: flex; flex-direction: column; gap: var(--s-2); }
.lca-label {
	font-family: var(--font-mono);
	font-size: 0.6875rem;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: var(--bone-faint);
}
.lca-input, .lca-textarea, .lca-select {
	background: var(--ink-soft);
	border: 1.5px solid var(--ash-line);
	border-radius: var(--r-md);
	padding: var(--s-3) var(--s-4);
	color: var(--bone);
	font-size: 1rem;
	width: 100%;
	transition: all var(--dur) var(--ease);
	font-family: var(--font-body);
}
.lca-input:focus, .lca-textarea:focus, .lca-select:focus {
	outline: 0;
	border-color: var(--blood);
	box-shadow: 0 0 0 3px rgba(225, 11, 44, 0.12);
}
.lca-textarea { resize: vertical; min-height: 120px; line-height: 1.55; }
.lca-checkbox-row { display: flex; gap: var(--s-2); align-items: flex-start; }
.lca-checkbox-row input { margin-top: 4px; accent-color: var(--blood); }
.lca-checkbox-row label { font-size: 0.875rem; color: var(--bone-dim); line-height: 1.5; }

/* ====== 20. POSTS GRID =========================================== */
.lca-posts-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: var(--s-6);
	margin-block: var(--s-8);
}
@media (max-width: 980px) { .lca-posts-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 640px) { .lca-posts-grid { grid-template-columns: 1fr; } }

.lca-post-card {
	display: flex;
	flex-direction: column;
	gap: var(--s-4);
	padding: var(--s-5);
	background: var(--ink-soft);
	border: 1px solid var(--ash-line);
	border-radius: var(--r-lg);
	overflow: hidden;
	transition: all var(--dur) var(--ease);
}
.lca-post-card:hover { border-color: var(--ash-line-strong); transform: translateY(-2px); }
.lca-post-card__media {
	aspect-ratio: 16/10;
	overflow: hidden;
	border-radius: var(--r-md);
	margin: calc(var(--s-5) * -1) calc(var(--s-5) * -1) 0;
}
.lca-post-card__media img { width: 100%; height: 100%; object-fit: cover; transition: transform var(--dur-slow) var(--ease); }
.lca-post-card:hover .lca-post-card__media img { transform: scale(1.05); }
.lca-post-card__title { font-size: 1.25rem; margin: 0; }
.lca-post-card__title a { color: var(--bone); }
.lca-post-card__title a:hover { color: var(--blush); }
.lca-post-card__meta { font-family: var(--font-mono); font-size: 0.75rem; letter-spacing: 0.06em; color: var(--bone-faint); }
.lca-post-card__excerpt { color: var(--bone-dim); font-size: 0.9375rem; margin: 0; }

/* ====== 21. ARCHIVE / SINGLE ===================================== */
.lca-archive-header {
	padding: var(--s-12) 0 var(--s-8);
	border-bottom: 1px solid var(--ash-line);
	margin-bottom: var(--s-8);
}
.lca-archive-header__title { font-size: clamp(2.5rem, 5vw, 4rem); margin: 0; }

.lca-single { padding-block: var(--s-12) var(--s-16); }
.lca-single__head { max-width: 880px; margin: 0 auto var(--s-8); text-align: center; }
.lca-single__title { font-size: clamp(2.25rem, 5vw, 4rem); margin-bottom: var(--s-4); }
/* Quando il filtro `the_title` restituisce '' (es. dashboard My Account / cart /
   checkout) l'<h1> resta nel DOM ma vuoto. Lo nascondiamo + collassiamo l'head. */
.lca-single__title:empty { display: none; }
.lca-single__head:has(.lca-single__title:empty) { margin: 0; }
.lca-single__meta { font-family: var(--font-mono); font-size: 0.8125rem; letter-spacing: 0.08em; text-transform: uppercase; color: var(--bone-faint); }
.lca-single__media {
	max-width: 1280px;
	margin: 0 auto var(--s-12);
	border-radius: var(--r-xl);
	overflow: hidden;
}
.lca-single__media img { width: 100%; height: auto; }
.lca-single__content {
	max-width: 720px;
	margin: 0 auto;
	font-size: 1.125rem;
	line-height: 1.75;
	color: var(--bone-dim);
}
.lca-single__content > * { margin-bottom: var(--s-5); }
.lca-single__content h2, .lca-single__content h3 { color: var(--bone); margin-top: var(--s-10); margin-bottom: var(--s-4); }
.lca-single__content a { color: var(--blush); border-bottom: 1px solid currentColor; }
.lca-single__content a:hover { color: var(--blood-bright); }

/* ====== 22. EMPTY / 404 ========================================== */
.lca-empty {
	min-height: 60vh;
	display: grid;
	place-content: center;
	text-align: center;
	padding-block: var(--s-16);
}
.lca-empty__title {
	font-size: clamp(3rem, 8vw, 6rem);
	margin-bottom: var(--s-4);
}
.lca-empty__text { color: var(--bone-dim); font-size: 1.0625rem; margin-bottom: var(--s-8); }
.lca-404__code {
	font-family: var(--font-display);
	font-size: clamp(8rem, 20vw, 16rem);
	font-style: italic;
	color: var(--blood);
	line-height: 0.85;
	letter-spacing: -0.05em;
	background: linear-gradient(180deg, var(--blood) 0%, var(--blood-deep) 100%);
	-webkit-background-clip: text;
	background-clip: text;
	-webkit-text-fill-color: transparent;
}

/* ====== 23. FOOTER =============================================== */
.lca-footer {
	background: var(--ink-soft);
	border-top: 1px solid var(--ash-line);
	padding: clamp(3rem, 6vw, 5rem) 0 var(--s-6);
}
.lca-footer__top {
	display: grid;
	grid-template-columns: 2fr 1fr 1fr 1fr;
	gap: var(--s-8);
	padding-bottom: var(--s-12);
	border-bottom: 1px solid var(--ash-line);
}
@media (max-width: 980px) { .lca-footer__top { grid-template-columns: 1fr 1fr; } }
@media (max-width: 640px) { .lca-footer__top { grid-template-columns: 1fr; } }
.lca-footer__brand { display: flex; flex-direction: column; gap: var(--s-4); max-width: 320px; }
.lca-footer__payoff { font-family: var(--font-display); font-style: italic; font-size: 1.125rem; color: var(--bone-dim); margin: 0; line-height: 1.4; }
.lca-footer__col-title { font-family: var(--font-mono); font-size: 0.6875rem; letter-spacing: 0.12em; text-transform: uppercase; color: var(--bone-faint); margin-bottom: var(--s-4); }
.lca-footer-widget ul, .lca-footer__col ul { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: var(--s-2); }
.lca-footer-widget a, .lca-footer__col a { color: var(--bone-dim); font-size: 0.9375rem; }
.lca-footer-widget a:hover, .lca-footer__col a:hover { color: var(--bone); }

.lca-footer__bottom {
	display: flex;
	justify-content: space-between;
	align-items: center;
	flex-wrap: wrap;
	gap: var(--s-3);
	padding-top: var(--s-6);
	font-family: var(--font-mono);
	font-size: 0.75rem;
	letter-spacing: 0.05em;
	color: var(--bone-faint);
}
.lca-footer__legal { display: flex; gap: var(--s-4); }

.lca-footer__big-mark {
	font-family: var(--font-display);
	font-style: italic;
	font-size: clamp(8rem, 22vw, 18rem);
	line-height: 0.85;
	letter-spacing: -0.05em;
	background: linear-gradient(180deg, rgba(225, 11, 44, 0.3) 0%, transparent 80%);
	-webkit-background-clip: text;
	background-clip: text;
	-webkit-text-fill-color: transparent;
	margin-top: var(--s-12);
	text-align: center;
	user-select: none;
	pointer-events: none;
}

/* Social */
.lca-socials { display: flex; gap: var(--s-2); }
.lca-socials a {
	width: 36px; height: 36px;
	border: 1px solid var(--ash-line);
	border-radius: 50%;
	display: grid;
	place-items: center;
	color: var(--bone-dim);
	transition: all var(--dur) var(--ease);
}
.lca-socials a:hover { background: var(--blood); border-color: var(--blood); color: var(--bone); }

/* ====== 24. WOOCOMMERCE STYLING ================================== */
.lca-main--woocommerce { padding-block: clamp(2rem, 5vw, 4rem); min-height: 60vh; }
.lca-wc { color: var(--bone); }

/* product loop */
.lca-wc .products {
	list-style: none;
	margin: 0;
	padding: 0;
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: var(--s-5);
}
@media (max-width: 980px) { .lca-wc .products { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 640px) { .lca-wc .products { grid-template-columns: 1fr; } }

.lca-wc .product {
	background: var(--ink-soft);
	border: 1px solid var(--ash-line);
	border-radius: var(--r-xl);
	padding: var(--s-6);
	transition: all var(--dur) var(--ease);
	display: flex !important;
	flex-direction: column;
	gap: var(--s-3);
}
.lca-wc .product:hover { border-color: var(--blood); box-shadow: var(--glow-blood); transform: translateY(-2px); }
.lca-wc .product img { border-radius: var(--r-md); margin-bottom: var(--s-3); }
.lca-wc .product .woocommerce-loop-product__title {
	font-family: var(--font-display);
	font-size: 1.5rem;
	color: var(--bone);
	margin: 0;
	padding: 0;
}
.lca-wc .product .price {
	font-family: var(--font-display);
	font-size: 1.75rem;
	color: var(--bone);
	font-weight: 600;
}
.lca-wc .product .price del { color: var(--bone-faint); font-size: 0.7em; }
.lca-wc .product .price ins { background: transparent; color: var(--blood); }

/* WC buttons → tema */
.lca-wc .button,
.lca-wc button.button,
.lca-wc input[type="submit"].button,
.lca-wc a.button,
.woocommerce #respond input#submit,
.woocommerce a.button.alt,
.woocommerce button.button.alt,
.woocommerce-message .button,
.woocommerce-info .button {
	display: inline-flex !important;
	align-items: center;
	justify-content: center;
	gap: var(--s-2);
	padding: var(--s-3) var(--s-6) !important;
	background: var(--blood) !important;
	color: var(--bone) !important;
	font-family: var(--font-body) !important;
	font-size: 0.9375rem !important;
	font-weight: 600 !important;
	letter-spacing: 0.005em;
	border: 1px solid var(--blood) !important;
	border-radius: var(--r-pill) !important;
	cursor: pointer;
	text-decoration: none !important;
	transition: all var(--dur) var(--ease) !important;
	text-shadow: none !important;
	line-height: 1 !important;
}
.lca-wc .button:hover, .lca-wc a.button:hover, .lca-wc button.button:hover {
	background: var(--blood-bright) !important;
	border-color: var(--blood-bright) !important;
	box-shadow: var(--glow-blood);
}

/* notices */
.woocommerce-message,
.woocommerce-info,
.woocommerce-error {
	background: var(--ink-soft) !important;
	border-left: 4px solid var(--blood) !important;
	color: var(--bone) !important;
	border-radius: var(--r-md);
	padding: var(--s-4) var(--s-5) !important;
	margin-bottom: var(--s-6);
}
.woocommerce-message::before,
.woocommerce-info::before { color: var(--blood) !important; }

/* Single product */
.lca-wc div.product {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: clamp(2rem, 5vw, 4rem);
}
@media (max-width: 768px) { .lca-wc div.product { grid-template-columns: 1fr; } }
.lca-wc div.product .woocommerce-product-gallery { float: none !important; width: 100% !important; }
.lca-wc div.product .summary { float: none !important; width: 100% !important; }
.lca-wc div.product .product_title { font-family: var(--font-display); font-size: clamp(2rem, 4vw, 3.5rem); }
.lca-wc div.product p.price { font-family: var(--font-display); font-size: 2.5rem; color: var(--bone); margin: var(--s-4) 0; }

/* Cart / Checkout / My Account */
.lca-wc table.shop_table,
.lca-wc table.cart,
.lca-wc table.woocommerce-table--order-details {
	width: 100%;
	border: 1px solid var(--ash-line);
	border-radius: var(--r-md);
	border-collapse: collapse;
	background: var(--ink-soft);
	overflow: hidden;
}
.lca-wc table.shop_table th,
.lca-wc table.shop_table td {
	padding: var(--s-4);
	border-bottom: 1px solid var(--ash-line);
	text-align: left;
	color: var(--bone);
}
.lca-wc table.shop_table th {
	font-family: var(--font-mono);
	font-size: 0.75rem;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color: var(--bone-faint);
	background: var(--ink);
}
.lca-wc input[type=text],
.lca-wc input[type=email],
.lca-wc input[type=tel],
.lca-wc input[type=password],
.lca-wc input[type=number],
.lca-wc textarea:not(.lca-chat__input),
.lca-wc select,
.lca-wc .select2-container .select2-selection {
	background: var(--ink-soft) !important;
	border: 1.5px solid var(--ash-line) !important;
	border-radius: var(--r-md) !important;
	color: var(--bone) !important;
	padding: var(--s-3) var(--s-4) !important;
	font-family: var(--font-body) !important;
	font-size: 1rem !important;
	height: auto !important;
}
.lca-wc input:focus, .lca-wc textarea:not(.lca-chat__input):focus, .lca-wc select:focus {
	border-color: var(--blood) !important;
	outline: 0;
}
.lca-wc form .form-row label { font-family: var(--font-mono); font-size: 0.75rem; letter-spacing: 0.08em; text-transform: uppercase; color: var(--bone-faint); margin-bottom: var(--s-2); }

/* ============================================================
   Checkout — restyle (v1.22.18)
   Migliora gerarchia del "Il tuo ordine" + payment box.
   ============================================================ */

/* Heading "Il tuo ordine" */
.lca-wc #order_review_heading {
	font-family: var(--font-display);
	font-size: clamp(1.75rem, 3vw, 2.5rem);
	margin: var(--s-8) 0 var(--s-4);
	color: var(--bone);
}

/* Order review table — riga prodotto evidenziata, totali bold, ricorrenti separati */
.lca-wc table.woocommerce-checkout-review-order-table {
	margin-bottom: var(--s-6);
}
/* Riga prodotto principale */
.lca-wc table.woocommerce-checkout-review-order-table tbody td.product-name,
.lca-wc table.woocommerce-checkout-review-order-table tbody td.product-total {
	font-size: 1rem;
	font-weight: 500;
	color: var(--bone);
	background: rgba(225, 11, 44, 0.04);
}
/* Subtotale / Totale: label compact mono, value bold */
.lca-wc table.woocommerce-checkout-review-order-table tfoot th {
	font-family: var(--font-mono);
	font-size: 0.75rem;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color: var(--bone-faint);
	background: var(--ink);
	font-weight: 500;
}
.lca-wc table.woocommerce-checkout-review-order-table tfoot td {
	font-family: var(--font-body);
	font-size: 1rem;
	color: var(--bone);
	font-weight: 500;
}
/* Riga "TOTALE" finale (più enfasi) */
.lca-wc table.woocommerce-checkout-review-order-table tfoot tr.order-total td,
.lca-wc table.woocommerce-checkout-review-order-table tfoot tr.recurring-total td {
	font-size: 1.25rem;
	font-weight: 600;
	font-family: var(--font-display);
	color: var(--bone);
}
.lca-wc table.woocommerce-checkout-review-order-table tfoot tr.order-total td .amount,
.lca-wc table.woocommerce-checkout-review-order-table tfoot tr.recurring-total td .amount {
	color: var(--blood-bright);
}
/* Header "TOTALI RICORRENTI" (WC Subscriptions): row separatore con barra rossa */
.lca-wc table.woocommerce-checkout-review-order-table .recurring-totals th,
.lca-wc table.woocommerce-checkout-review-order-table tr.cart-subscription-total-heading th {
	font-family: var(--font-display);
	font-size: 0.875rem;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	color: var(--blood-bright);
	background: var(--ink);
	border-left: 3px solid var(--blood);
	padding-left: calc(var(--s-4) - 3px);
}
/* Data primo rinnovo (sotto al totale ricorrente) */
.lca-wc table.woocommerce-checkout-review-order-table .first-payment-date,
.lca-wc table.woocommerce-checkout-review-order-table .first-renewal-date {
	display: block;
	font-family: var(--font-mono);
	font-size: 0.6875rem;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	color: var(--bone-faint);
	font-weight: 400;
	margin-top: 4px;
}

/* =================== Payment box =================== */
.lca-wc #payment {
	background: var(--ink-soft);
	border: 1px solid var(--ash-line);
	border-radius: var(--r-lg);
	padding: var(--s-5);
	margin-top: var(--s-5);
}
.lca-wc #payment ul.payment_methods {
	list-style: none;
	margin: 0;
	padding: 0;
}
.lca-wc #payment ul.payment_methods > li.wc_payment_method {
	padding: 0;
	margin: 0;
}
.lca-wc #payment ul.payment_methods > li.wc_payment_method > label {
	display: flex;
	align-items: center;
	gap: var(--s-3);
	font-family: var(--font-display);
	font-size: 1.125rem;
	color: var(--bone);
	cursor: pointer;
	margin: 0;
	padding: 0 0 var(--s-3);
	border-bottom: 1px solid var(--ash-line);
	margin-bottom: var(--s-4);
	letter-spacing: -0.01em;
	text-transform: none;
}
/* Brand icons inline (Visa, MC, Amex, Discover) — allineate a destra */
.lca-wc #payment ul.payment_methods > li.wc_payment_method > label img {
	height: 24px;
	width: auto;
	max-width: 36px;
	object-fit: contain;
	margin: 0 2px;
	border-radius: 3px;
}
.lca-wc #payment ul.payment_methods > li.wc_payment_method > label .wc-stripe-card-icons-container,
.lca-wc #payment ul.payment_methods > li.wc_payment_method > label .payment_method_icons {
	margin-left: auto;
	display: inline-flex;
	gap: 4px;
	align-items: center;
}

/* Payment box inner (campi Stripe / form CC) */
.lca-wc #payment div.payment_box {
	background: transparent;
	color: var(--bone-dim);
	padding: 0;
	margin: 0 0 var(--s-4);
	border-radius: var(--r-md);
	font-size: 0.9375rem;
	line-height: 1.55;
}
.lca-wc #payment div.payment_box::before { display: none; }

/* "Usa pagamento salvato" link */
.lca-wc #payment .wc-saved-payment-methods,
.lca-wc #payment .woocommerce-SavedPaymentMethods {
	margin: 0 0 var(--s-3);
}
.lca-wc #payment a.wc-stripe-saved-payment-method-link,
.lca-wc #payment a.wc-payment-token-toggle,
.lca-wc #payment .woocommerce-SavedPaymentMethods-tokenInput + label,
.lca-wc #payment .wc-saved-payment-methods-toggle {
	color: var(--blood-bright) !important;
	font-size: 0.875rem;
	text-decoration: none;
	border-bottom: 1px dotted var(--ash-line);
	padding-bottom: 2px;
}

/* Wrapper Stripe Element / campi CC: bezel scuro che cinge l'iframe bianco */
.lca-wc #payment .wc-stripe-elements-field,
.lca-wc #payment .wc-credit-card-form-card-number,
.lca-wc #payment .wc-credit-card-form-card-expiry,
.lca-wc #payment .wc-credit-card-form-card-cvc,
.lca-wc #payment .StripeElement,
.lca-wc #payment .wc-stripe-iban-element-field {
	background: #fff !important;
	border: 1px solid var(--ash-line) !important;
	border-radius: var(--r-md) !important;
	padding: var(--s-3) var(--s-4) !important;
	min-height: 48px;
	transition: border-color var(--dur) var(--ease), box-shadow var(--dur) var(--ease);
}
.lca-wc #payment .wc-stripe-elements-field--focused,
.lca-wc #payment .StripeElement--focus {
	border-color: var(--blood) !important;
	box-shadow: 0 0 0 3px rgba(225, 11, 44, 0.12) !important;
}

/* Layout 3-colonne per i campi CC (Numero / Scadenza / CVC) */
.lca-wc #payment .form-row.form-row-wide ~ .form-row-first,
.lca-wc #payment fieldset.wc-credit-card-form {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--s-3);
	margin-top: var(--s-3);
}
@media (min-width: 600px) {
	.lca-wc #payment fieldset.wc-credit-card-form {
		grid-template-columns: 2fr 1fr 1fr;
	}
}
.lca-wc #payment fieldset.wc-credit-card-form .form-row {
	margin: 0;
	padding: 0;
}
.lca-wc #payment fieldset.wc-credit-card-form label {
	display: block;
	margin-bottom: var(--s-2);
}

/* Disclaimer testo sotto */
.lca-wc #payment .terms,
.lca-wc #payment .wc-terms-and-conditions,
.lca-wc #payment .woocommerce-terms-and-conditions-wrapper,
.lca-wc #payment .place-order .terms-text,
.lca-wc #payment .place-order p.terms {
	margin: var(--s-4) 0 0;
	color: var(--bone-faint);
	font-size: 0.8125rem;
	line-height: 1.55;
}

/* Submit "Place order" — assicuriamoci sia full-width nel box */
.lca-wc #payment #place_order,
.lca-wc #payment .button.alt {
	width: 100%;
	margin-top: var(--s-4);
	padding: var(--s-4) var(--s-5);
	font-family: var(--font-display);
	font-size: 1.0625rem;
}

/* ============================================================
   View Subscription / View Order — restyle (v1.22.28)
   Le tabelle k:v (dettaglio sub/ordine) sono key→value: th=label,
   td=value, NIENTE thead. Le trasformiamo in righe inline (etichetta
   sx, valore dx) invece di card stack che spreca verticale.
   ============================================================ */
.lca-wc table.shop_table_responsive.subscription_details,
.lca-wc table.shop_table_responsive.order_details {
	background: var(--ink-soft);
	border: 1px solid var(--ash-line);
	border-radius: var(--r-md);
	overflow: hidden;
	margin-bottom: var(--s-6);
}
.lca-wc table.shop_table_responsive.subscription_details tr,
.lca-wc table.shop_table_responsive.order_details tr {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	gap: var(--s-3);
	padding: var(--s-3) var(--s-4);
	border-bottom: 1px solid var(--ash-line);
	background: transparent !important;
	border-left: 0 !important;
	border-radius: 0 !important;
	margin: 0 !important;
}
.lca-wc table.shop_table_responsive.subscription_details tr:last-child,
.lca-wc table.shop_table_responsive.order_details tr:last-child {
	border-bottom: 0;
}
.lca-wc table.shop_table_responsive.subscription_details th,
.lca-wc table.shop_table_responsive.order_details th {
	font-family: var(--font-mono);
	font-size: 0.6875rem;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color: var(--bone-faint);
	font-weight: 500;
	padding: 0;
	background: transparent;
	border: 0;
	flex: 0 0 auto;
	text-align: left;
}
.lca-wc table.shop_table_responsive.subscription_details td,
.lca-wc table.shop_table_responsive.order_details td {
	padding: 0;
	border: 0;
	color: var(--bone);
	font-size: 0.9375rem;
	text-align: right;
	flex: 1 1 auto;
	display: block;
}
.lca-wc table.shop_table_responsive.subscription_details td::before,
.lca-wc table.shop_table_responsive.order_details td::before {
	display: none !important;
}
/* Azioni (es. Annulla nel dettaglio sub): bottone più piccolo, no full-width */
.lca-wc table.shop_table_responsive.subscription_details .button,
.lca-wc table.shop_table_responsive.order_details .button {
	display: inline-flex !important;
	width: auto !important;
	margin: 0 !important;
	font-size: 0.75rem !important;
	padding: 5px 12px !important;
}

/* Subscription totals: la table con il line-item del prodotto. Il
   product-name è dentro a <a> che eredita `.lca-single__content a`
   (rosso underline) — qui lo neutralizziamo. */
.lca-wc table.subscription_totals .product-name,
.lca-wc table.shop_table.order_details .product-name,
.lca-wc table.woocommerce-table--order-details .product-name {
	color: var(--bone);
	font-weight: 500;
}
.lca-wc table.subscription_totals .product-name a,
.lca-wc table.shop_table.order_details .product-name a,
.lca-wc table.woocommerce-table--order-details .product-name a {
	color: var(--bone) !important;
	border-bottom: 0 !important;
	text-decoration: none;
}
.lca-wc table.subscription_totals .product-name a:hover,
.lca-wc table.shop_table.order_details .product-name a:hover {
	color: var(--blood-bright) !important;
}

/* Bottoni "globali" in MyAccount: bound forte per non far esplodere
   le righe. Vale per tutti i container, anche fuori tabelle. */
.lca-wc .woocommerce-MyAccount-content .button,
.lca-wc .woocommerce-MyAccount-content a.button,
.lca-wc .woocommerce-MyAccount-content button.button {
	font-size: 0.8125rem !important;
	font-weight: 500 !important;
	padding: 6px 14px !important;
}

/* Titoli sezioni dentro al dettaglio sub/ordine ("Totali abbonamenti",
   "Ordini correlati", "Indirizzo di fatturazione"). Su mobile sono troppo
   grandi: bound a un valore compatto + spazio ridotto. */
.lca-wc .woocommerce-MyAccount-content h2,
.lca-wc .woocommerce-MyAccount-content h3 {
	font-family: var(--font-display);
	font-size: clamp(1.25rem, 2.4vw, 1.625rem);
	font-weight: 600;
	letter-spacing: -0.01em;
	line-height: 1.15;
	margin: var(--s-6) 0 var(--s-3);
	color: var(--bone);
}
/* Primo H2/H3 → niente margin-top extra */
.lca-wc .woocommerce-MyAccount-content > h2:first-child,
.lca-wc .woocommerce-MyAccount-content > h3:first-child,
.lca-wc .woocommerce-MyAccount-content > section > h2:first-child {
	margin-top: 0;
}

/* ============================================================
   Orders / Subscriptions table — responsive (v1.22.23)
   Pattern stack-on-mobile: la table standard WC esce dal viewport
   sotto i 760px. WC fornisce già `data-title` su ogni <td>, quindi
   trasformiamo ogni <tr> in card con label inline davanti al value.
   ============================================================ */
/* Selettore unico riusabile: tutte le table di My Account che vanno
   collassate in card su mobile. Aggiungere qui i nomi quando vengono
   trovate altre table di plugin terzi. */
.lca-wc .woocommerce-MyAccount-content table.shop_table,
.lca-wc table.my_account_orders,
.lca-wc table.account-orders-table,
.lca-wc table.woocommerce-orders-table,
.lca-wc table.my_account_subscriptions,
.lca-wc table.shop_table_responsive {
	width: 100%;
}
/* Bottoni azioni nelle table My Account: i WC base button hanno
   padding/font !important molto generosi, qui li slim per non
   far esplodere la riga. !important per battere `.lca-wc .button`. */
.lca-wc .woocommerce-MyAccount-content table.shop_table td .button,
.lca-wc table.my_account_orders td .button,
.lca-wc table.woocommerce-orders-table td .button,
.lca-wc table.my_account_subscriptions td .button {
	font-size: 0.8125rem !important;
	font-weight: 500 !important;
	padding: 6px 14px !important;
	margin: 2px !important;
}

@media (max-width: 760px) {
	/* Block layout: a tutte le table dentro a MyAccount-content (orders,
	   subscriptions, downloads, ecc). Escludiamo l'order-details table del
	   view-order endpoint che ha sua semantica. */
	.lca-wc .woocommerce-MyAccount-content table.shop_table:not(.woocommerce-table--order-details):not(.woocommerce-checkout-review-order-table):not(.cart) {
		display: block;
		border: 0;
		background: transparent;
		overflow: visible;
	}
	.lca-wc .woocommerce-MyAccount-content table.shop_table:not(.woocommerce-table--order-details):not(.woocommerce-checkout-review-order-table):not(.cart) thead {
		display: none;
	}
	.lca-wc .woocommerce-MyAccount-content table.shop_table:not(.woocommerce-table--order-details):not(.woocommerce-checkout-review-order-table):not(.cart) tbody {
		display: block;
	}
	.lca-wc .woocommerce-MyAccount-content table.shop_table:not(.woocommerce-table--order-details):not(.woocommerce-checkout-review-order-table):not(.cart) tbody tr {
		display: block;
		margin: 0 0 var(--s-4);
		padding: var(--s-4);
		background: var(--ink-soft);
		border: 1px solid var(--ash-line);
		border-left: 3px solid var(--blood);
		border-radius: var(--r-md);
	}
	.lca-wc .woocommerce-MyAccount-content table.shop_table:not(.woocommerce-table--order-details):not(.woocommerce-checkout-review-order-table):not(.cart) tbody td {
		display: flex;
		justify-content: space-between;
		align-items: center;
		gap: var(--s-3);
		padding: 6px 0;
		border: 0;
		border-bottom: 1px solid var(--ash-line);
		text-align: right;
		color: var(--bone);
	}
	.lca-wc .woocommerce-MyAccount-content table.shop_table:not(.woocommerce-table--order-details):not(.woocommerce-checkout-review-order-table):not(.cart) tbody td:last-child {
		border-bottom: 0;
		padding-top: var(--s-3);
	}
	/* Label via data-title (WC lo aggiunge automaticamente alle <td>) */
	.lca-wc .woocommerce-MyAccount-content table.shop_table:not(.woocommerce-table--order-details):not(.woocommerce-checkout-review-order-table):not(.cart) tbody td::before {
		content: attr(data-title);
		font-family: var(--font-mono);
		font-size: 0.6875rem;
		letter-spacing: 0.1em;
		text-transform: uppercase;
		color: var(--bone-faint);
		flex-shrink: 0;
	}
	/* Celle "Azioni" stacked full-width */
	.lca-wc .woocommerce-MyAccount-content table.shop_table:not(.woocommerce-table--order-details):not(.woocommerce-checkout-review-order-table):not(.cart) tbody td.order-actions,
	.lca-wc .woocommerce-MyAccount-content table.shop_table:not(.woocommerce-table--order-details):not(.woocommerce-checkout-review-order-table):not(.cart) tbody td.subscription-actions,
	.lca-wc .woocommerce-MyAccount-content table.shop_table:not(.woocommerce-table--order-details):not(.woocommerce-checkout-review-order-table):not(.cart) tbody td.woocommerce-orders-table__cell-order-actions {
		flex-direction: column;
		align-items: stretch;
		text-align: center;
	}
	.lca-wc .woocommerce-MyAccount-content table.shop_table:not(.woocommerce-table--order-details):not(.woocommerce-checkout-review-order-table):not(.cart) tbody td.order-actions::before,
	.lca-wc .woocommerce-MyAccount-content table.shop_table:not(.woocommerce-table--order-details):not(.woocommerce-checkout-review-order-table):not(.cart) tbody td.subscription-actions::before,
	.lca-wc .woocommerce-MyAccount-content table.shop_table:not(.woocommerce-table--order-details):not(.woocommerce-checkout-review-order-table):not(.cart) tbody td.woocommerce-orders-table__cell-order-actions::before {
		display: none;
	}
	.lca-wc .woocommerce-MyAccount-content table.shop_table:not(.woocommerce-table--order-details):not(.woocommerce-checkout-review-order-table):not(.cart) tbody td.order-actions .button,
	.lca-wc .woocommerce-MyAccount-content table.shop_table:not(.woocommerce-table--order-details):not(.woocommerce-checkout-review-order-table):not(.cart) tbody td.subscription-actions .button,
	.lca-wc .woocommerce-MyAccount-content table.shop_table:not(.woocommerce-table--order-details):not(.woocommerce-checkout-review-order-table):not(.cart) tbody td.woocommerce-orders-table__cell-order-actions .button {
		display: block;
		width: 100%;
		margin: 4px 0 0;
	}
}

/* ============================================================
   My Account v1.22+ — layout dropdown
   La sidebar tradizionale è stata sostituita da un dropdown nella
   topbar; il dashboard endpoint ospita la chat AI a tutta larghezza.
   ============================================================ */

/* Forziamo single-column: niente più grid 260px+1fr (override v1.22). */
.woocommerce-account .woocommerce {
	display: block;
	max-width: 100%;
}

/* My Account ha la propria topbar interna che fornisce gerarchia visiva:
   il padding-top massiccio dei vari container WP/WC diventa rumore.
   Page.php avvolge in `.lca-section` (clamp 4-8rem!) che è il vero colpevole
   visivo del "gap" sopra la topbar — gli altri sono minori. Abbattiamo tutti
   i container che possono ospitare la pagina su /my-account. */
.woocommerce-account .lca-single,
.woocommerce-account .lca-main--woocommerce,
.woocommerce-account .lca-main--page .lca-section {
	padding-block: var(--s-3) var(--s-10);
}

/* ---- Focus mode su /my-account (v1.22.17) ----
   La chat è una destination, non un'esplorazione: tagliamo le distrazioni.
   - Footer sparisce (zero scroll noise)
   - Nav primaria del header sparisce (logo + avatar dropdown bastano)
   - Burger mobile sparisce (niente nav = niente drawer)
   - Drawer mobile aperto comunque non si attiva, ma per pulizia lo nascondiamo */
.woocommerce-account .lca-footer,
.woocommerce-account .lca-header .lca-nav,
.woocommerce-account .lca-header .lca-nav-toggle,
.woocommerce-account .lca-drawer {
	display: none !important;
}
/* Header più snello (niente nav centrale = riallineamento) */
.woocommerce-account .lca-header__inner {
	justify-content: space-between;
}

/* CRITICO: page.php mette `.lca-reveal` con `transform: translateY(30px)`
   sul wrapper `.lca-single__content` per la reveal-on-scroll. Ma `transform`
   crea un nuovo containing block che rompe `position: fixed` dei discendenti.
   Risultato: il drawer history `.lca-history` (position:fixed) si posiziona
   relativo al wrapper invece che al viewport → finisce inline a sinistra.
   Su my-account neutralizziamo la reveal (non serve, la chat è già visibile). */
.woocommerce-account .lca-reveal {
	opacity: 1 !important;
	transform: none !important;
	transition: none !important;
}

/* Stesso problema: `.lca-single__content > * { margin-bottom: var(--s-5) }`
   aggiunge spaziature parassite ai children. Reset locale. */
.woocommerce-account .lca-single__content > * {
	margin-bottom: 0;
}

/* `.lca-single__content a { color: var(--blush); border-bottom: ... }` ha
   specificità (0,1,1) e vince sui miei `.lca-myaccount__nav-link` (0,1,0).
   Wrappo i miei selettori in `.lca-myaccount` per portarli a (0,2,0). */

.lca-myaccount {
	display: flex;
	flex-direction: column;
	gap: var(--s-5);
	min-height: calc(100vh - 200px);
}

/* Topbar: brand a sx, dropdown trigger a dx */
.lca-myaccount__topbar {
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: var(--s-4);
	padding: 0 0 var(--s-4);
	border-bottom: 1px solid var(--ash-line);
}
.lca-myaccount__brand { min-width: 0; }
.lca-myaccount__hello {
	font-family: var(--font-display);
	font-size: clamp(1rem, 1.6vw, 1.25rem);
	color: var(--bone-dim);
	font-style: italic;
}

/* Dropdown menu */
.lca-myaccount__menu {
	position: relative;
}
.lca-myaccount__menu-trigger {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	padding: var(--s-2) var(--s-4);
	min-height: 40px;
	background: var(--ink-soft);
	border: 1px solid var(--ash-line);
	border-radius: var(--r-pill);
	color: var(--bone);
	font-family: var(--font-body);
	font-size: 0.9375rem;
	font-weight: 500;
	cursor: pointer;
	transition: all var(--dur) var(--ease);
}
.lca-myaccount__menu-trigger:hover {
	border-color: var(--blood);
	background: var(--ink-mid);
}
.lca-myaccount__menu-trigger:focus-visible {
	outline: 2px solid var(--blood);
	outline-offset: 2px;
}
.lca-myaccount__menu-trigger[aria-expanded="true"] {
	border-color: var(--blood);
	background: var(--ink-mid);
}
.lca-myaccount__menu-trigger-chev {
	width: 16px;
	height: 16px;
	transition: transform var(--dur) var(--ease);
}
.lca-myaccount__menu-trigger[aria-expanded="true"] .lca-myaccount__menu-trigger-chev {
	transform: rotate(180deg);
}

.lca-myaccount__menu-panel {
	position: absolute;
	top: calc(100% + 8px);
	right: 0;
	min-width: 240px;
	background: var(--ink-soft);
	border: 1px solid var(--ash-line);
	border-radius: var(--r-md);
	box-shadow: 0 12px 32px -8px rgba(0, 0, 0, 0.6);
	padding: var(--s-2);
	z-index: 50;
	opacity: 0;
	transform: translateY(-4px);
	transition: opacity 180ms var(--ease), transform 180ms var(--ease);
	pointer-events: none;
}
.lca-myaccount__menu-panel[hidden] { display: none; }
.lca-myaccount__menu-panel.is-open {
	opacity: 1;
	transform: translateY(0);
	pointer-events: auto;
}

.lca-myaccount .lca-myaccount__nav-list {
	list-style: none;
	padding: 0;
	margin: 0;
	display: flex;
	flex-direction: column;
	gap: 2px;
}
.lca-myaccount .lca-myaccount__nav-item {
	margin: 0;
}
/* Specificità (0,2,1) per battere `.lca-single__content a` (0,1,1). */
.lca-myaccount .lca-myaccount__nav-link {
	display: block;
	padding: var(--s-2) var(--s-3);
	border-radius: var(--r-sm);
	color: var(--bone-dim);
	font-size: 0.9375rem;
	text-decoration: none;
	border-bottom: 0;
	transition: all var(--dur) var(--ease);
}
.lca-myaccount .lca-myaccount__nav-link:hover {
	background: var(--ink-mid);
	color: var(--bone);
}
.lca-myaccount .lca-myaccount__nav-item.is-active .lca-myaccount__nav-link {
	background: var(--blood);
	color: var(--bone);
}

/* Content area: full-width, niente padding extra (la chat shell ha il suo) */
.lca-myaccount__content {
	width: 100%;
}
.lca-myaccount__content h2,
.lca-myaccount__content h3 { font-family: var(--font-display); }

/* La chat-shell dentro a my-account: rimuove padding-top extra perché
   la topbar di my-account fornisce già il respiro verticale */
.lca-myaccount__content > .lca-chat {
	padding-top: 0;
}

/* Mobile: topbar comprime hello */
@media (max-width: 600px) {
	.lca-myaccount__hello { font-size: 0.95rem; }
	.lca-myaccount__menu-trigger { padding: 6px var(--s-3); font-size: 0.875rem; }
	.lca-myaccount__menu-panel { min-width: 200px; }
}

/* ============ Header avatar dropdown (logged-in state) ============
   Riusa la stessa logica JS (myaccount-dropdown.js itera tutte le
   istanze `[data-lca-acc-menu]`). Stile distinto dalla topbar
   My Account perché vive in un contesto più denso. */

.lca-header-acc {
	position: relative;
	display: inline-flex;
}
.lca-header-acc__trigger {
	display: inline-flex;
	align-items: center;
	gap: var(--s-2);
	padding: 4px var(--s-2) 4px 4px;
	background: transparent;
	border: 1px solid transparent;
	border-radius: 999px;
	color: var(--bone-dim);
	cursor: pointer;
	font-family: inherit;
	font-size: 0.9375rem;
	transition: all var(--dur) var(--ease);
}
.lca-header-acc__trigger:hover {
	background: var(--ink-soft);
	border-color: var(--ash-line);
	color: var(--bone);
}
.lca-header-acc__trigger[aria-expanded="true"] {
	background: var(--ink-soft);
	border-color: var(--blood);
	color: var(--bone);
}
.lca-header-acc__trigger:focus-visible {
	outline: 2px solid var(--blood);
	outline-offset: 2px;
}
.lca-header-acc__avatar {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 28px;
	height: 28px;
	border-radius: 999px;
	background: linear-gradient(135deg, var(--blood), #8B0A1F);
	color: var(--bone);
	font-weight: 600;
	font-size: 0.8125rem;
	text-transform: uppercase;
	letter-spacing: 0.02em;
	flex-shrink: 0;
}
.lca-header-acc__name {
	max-width: 140px;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}
.lca-header-acc__chev {
	width: 14px;
	height: 14px;
	opacity: 0.7;
	transition: transform var(--dur) var(--ease);
}
.lca-header-acc__trigger[aria-expanded="true"] .lca-header-acc__chev {
	transform: rotate(180deg);
}

.lca-header-acc__panel {
	position: absolute;
	top: calc(100% + 10px);
	right: 0;
	min-width: 220px;
	background: var(--ink-soft);
	border: 1px solid var(--ash-line);
	border-radius: var(--r-md);
	box-shadow: 0 12px 32px -8px rgba(0, 0, 0, 0.6);
	padding: var(--s-2);
	z-index: 60;
	opacity: 0;
	transform: translateY(-4px);
	transition: opacity 180ms var(--ease), transform 180ms var(--ease);
	pointer-events: none;
}
.lca-header-acc__panel[hidden] { display: none; }
.lca-header-acc__panel.is-open {
	opacity: 1;
	transform: translateY(0);
	pointer-events: auto;
}

.lca-header-acc__list {
	list-style: none;
	padding: 0;
	margin: 0;
	display: flex;
	flex-direction: column;
	gap: 2px;
}
.lca-header-acc__list li { margin: 0; }
.lca-header-acc__list a {
	display: block;
	padding: var(--s-2) var(--s-3);
	border-radius: var(--r-sm);
	color: var(--bone-dim);
	font-size: 0.9375rem;
	text-decoration: none;
	border-bottom: 0;
	transition: all var(--dur) var(--ease);
}
.lca-header-acc__list a:hover {
	background: var(--ink-mid);
	color: var(--bone);
}
.lca-header-acc__logout-item {
	margin-top: 6px !important;
	padding-top: 6px;
	border-top: 1px solid var(--ash-line);
}
.lca-header-acc__logout-item a { color: var(--bone-dim); }

/* Mobile: nascondi nome utente, mostra solo avatar (compatta header) */
@media (max-width: 720px) {
	.lca-header-acc__name { display: none; }
	.lca-header-acc__trigger { padding: 4px; }
}

/* ============ Locked dashboard (utente senza sub valida) ============ */

.lca-locked {
	max-width: 720px;
	margin: var(--s-6) auto;
	padding: var(--s-7) var(--s-5);
	text-align: center;
	background: linear-gradient(180deg, rgba(225,11,44,0.06), transparent 60%), var(--ink-soft);
	border: 1px solid var(--ash-line);
	border-radius: var(--r-lg);
}
.lca-locked__icon {
	display: inline-flex;
	width: 56px;
	height: 56px;
	align-items: center;
	justify-content: center;
	border-radius: 999px;
	background: rgba(225,11,44,0.12);
	color: var(--blood);
	margin-bottom: var(--s-4);
}
.lca-locked__icon svg { width: 28px; height: 28px; }
.lca-locked__title {
	font-family: var(--font-display);
	font-size: clamp(1.5rem, 3vw, 2rem);
	margin: 0 0 var(--s-2);
	color: var(--bone);
}
.lca-locked__lede {
	color: var(--bone-dim);
	margin: 0 auto var(--s-5);
	max-width: 52ch;
}
.lca-locked__actions {
	display: flex;
	gap: var(--s-3);
	justify-content: center;
	flex-wrap: wrap;
}

/* ============ Login / Register / Lost password (WC native) ============ */

/* Quando NON è loggato il my-account è single-column (override del grid) */
.woocommerce-account:not(.logged-in) .woocommerce {
	display: block;
	max-width: 1080px;
	margin-inline: auto;
}

/* Wrapper del login: 2 colonne (login + register) o 1 (solo login) */
.lca-wc #customer_login,
.lca-wc .u-columns.col2-set {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(360px, 1fr));
	gap: clamp(1.5rem, 4vw, 3rem);
	margin: 0;
	padding: 0;
	list-style: none;
}
.lca-wc #customer_login::before,
.lca-wc #customer_login::after,
.lca-wc .u-columns::before,
.lca-wc .u-columns::after { display: none !important; }

.lca-wc #customer_login .col-1,
.lca-wc #customer_login .col-2,
.lca-wc .u-column1,
.lca-wc .u-column2 {
	width: 100% !important;
	max-width: none !important;
	float: none !important;
	margin: 0 !important;
	padding: clamp(1.75rem, 3vw, 2.5rem);
	background: var(--ink-soft);
	border: 1px solid var(--ash-line);
	border-radius: var(--r-xl);
}

.lca-wc #customer_login h2,
.lca-wc .u-columns h2,
.lca-wc form.lost_reset_password h2 {
	font-family: var(--font-display);
	font-size: clamp(1.75rem, 2.5vw, 2.25rem);
	font-weight: 600;
	letter-spacing: -0.02em;
	line-height: 1.1;
	margin: 0 0 var(--s-2);
	color: var(--bone);
}

/* ============================================================
   My Account → Indirizzi (v1.22.26)
   Card billing/shipping erano enormi: H2 wrappa, link "Modifica"
   in 2 righe rosso underline, indirizzo italic con line-height
   troppo aperto. Restyle compatto. */

.lca-wc .woocommerce-Addresses .u-column1,
.lca-wc .woocommerce-Addresses .u-column2 {
	padding: var(--s-5) var(--s-5) var(--s-6);
}
.lca-wc .woocommerce-Address-title.title {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	align-items: center;
	gap: var(--s-2) var(--s-4);
	margin-bottom: var(--s-3);
	padding-bottom: var(--s-3);
	border-bottom: 1px solid var(--ash-line);
}
.lca-wc .woocommerce-Address-title.title h2,
.lca-wc .woocommerce-Address-title.title h3 {
	font-family: var(--font-display);
	font-size: clamp(1.125rem, 2vw, 1.375rem);
	font-weight: 600;
	letter-spacing: -0.01em;
	line-height: 1.15;
	margin: 0;
	color: var(--bone);
	flex: 1 1 auto;
	min-width: 0;
}
/* Link "Modifica / Aggiungi" → chip discreto */
.lca-wc .woocommerce-Address-title.title a.edit,
.lca-wc .woocommerce-Address a.edit {
	display: inline-flex;
	align-items: center;
	gap: 4px;
	font-family: var(--font-mono);
	font-size: 0.6875rem;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--bone-dim) !important;
	background: transparent;
	border: 1px solid var(--ash-line);
	border-bottom: 1px solid var(--ash-line) !important;
	border-radius: var(--r-pill);
	padding: 4px 10px;
	white-space: nowrap;
	text-decoration: none !important;
	transition: all var(--dur) var(--ease);
}
.lca-wc .woocommerce-Address-title.title a.edit:hover,
.lca-wc .woocommerce-Address a.edit:hover {
	border-color: var(--blood);
	color: var(--blood-bright) !important;
}
/* Indirizzo body */
.lca-wc .woocommerce-Address address {
	font-style: normal;
	font-family: var(--font-body);
	font-size: 0.9375rem;
	line-height: 1.55;
	color: var(--bone-dim);
	margin: 0;
}
/* Empty state "Non hai ancora impostato…" */
.lca-wc .woocommerce-Address > p:not(.woocommerce-Address-title) {
	font-style: normal;
	font-size: 0.9375rem;
	color: var(--bone-faint);
	margin: 0;
}
.lca-wc #customer_login h2 + p,
.lca-wc .u-columns h2 + p {
	color: var(--bone-dim);
	margin-bottom: var(--s-6);
	font-size: 0.9375rem;
}

/* Form generico WC */
.lca-wc form.woocommerce-form,
.lca-wc form.woocommerce-form-login,
.lca-wc form.woocommerce-form-register,
.lca-wc form.woocommerce-ResetPassword,
.lca-wc form.lost_reset_password {
	display: flex;
	flex-direction: column;
	gap: var(--s-4);
	margin: 0;
}

.lca-wc .woocommerce-form-row,
.lca-wc form .form-row {
	display: flex;
	flex-direction: column;
	gap: var(--s-2);
	margin: 0 !important;
	padding: 0 !important;
	width: 100% !important;
	float: none !important;
}
.lca-wc .woocommerce-form-row label,
.lca-wc form .form-row label {
	font-size: 0.75rem;
	font-weight: 500;
	letter-spacing: 0.02em;
	color: var(--bone-faint);
	text-transform: none;
	margin: 0 !important;
	display: block;
	font-family: var(--font-body);
}
.lca-wc .required {
	color: var(--blood);
	border: 0;
	text-decoration: none;
}

.lca-wc .woocommerce-Input,
.lca-wc input.input-text,
.lca-wc form .form-row input.input-text,
.lca-wc form .form-row textarea {
	background: var(--ink) !important;
	border: 1.5px solid var(--ash-line) !important;
	border-radius: var(--r-md) !important;
	padding: var(--s-3) var(--s-4) !important;
	color: var(--bone) !important;
	font-size: 1rem !important;
	font-family: var(--font-body) !important;
	width: 100% !important;
	height: auto !important;
	line-height: 1.4 !important;
	transition: border-color var(--dur) var(--ease), box-shadow var(--dur) var(--ease);
}
.lca-wc .woocommerce-Input:focus,
.lca-wc input.input-text:focus {
	outline: 0 !important;
	border-color: var(--blood) !important;
	box-shadow: 0 0 0 3px rgba(225, 11, 44, 0.15) !important;
}
.lca-wc input::placeholder { color: var(--bone-faint); }

/* Password reveal button (WC injects) */
.lca-wc .show-password-input,
.lca-wc .password-input span.show-password-input {
	color: var(--bone-faint);
	right: var(--s-3);
	top: 50%;
	transform: translateY(-50%);
}
.lca-wc .show-password-input::after { color: var(--blush) !important; }
.lca-wc .password-input { position: relative; }

/* Remember me / consent checkboxes
   NB: usavamo `display: inline-flex` ma rompe le label con figli inline
   (<strong>, <em>) come quella di WC Subscriptions
   "Aggiorna i dati relativi all'<strong>Indirizzo</strong> per <strong>tutti</strong>...
   <em>(facoltativo)</em>": ogni <strong>/<em> diventava un flex item con `gap`
   creando 3-4 colonne separate. Soluzione: `inline-block` + checkbox allineato
   con `vertical-align: middle` + margin-right. Le sub-label restano inline. */
.lca-wc .woocommerce-form-login__rememberme,
.lca-wc .woocommerce-form__label-for-checkbox,
.lca-wc label.checkbox {
	display: inline-block !important;
	cursor: pointer;
	font-size: 0.875rem;
	color: var(--bone-dim);
	font-weight: 400 !important;
	letter-spacing: normal !important;
	text-transform: none !important;
	line-height: 1.5;
}
.lca-wc .woocommerce-form-login__rememberme input[type="checkbox"],
.lca-wc .woocommerce-form__label-for-checkbox input[type="checkbox"],
.lca-wc label.checkbox input[type="checkbox"] {
	margin-right: var(--s-2);
	vertical-align: middle;
}
.lca-wc input[type="checkbox"] {
	accent-color: var(--blood);
	width: 18px;
	height: 18px;
	cursor: pointer;
}

/* WC Subscriptions: "Aggiorna i dati di fatturazione per i rinnovi"
   Stesso pattern: label con <strong> / <em> figli — forziamo inline-block. */
.lca-wc .woocommerce_subscription_update_addresses_label,
.lca-wc p.update_subscription_addresses,
.lca-wc .form-row label[for*="update_subscription"],
.lca-wc .form-row.update_subscription_addresses_field label {
	display: inline-block !important;
	font-family: var(--font-body) !important;
	font-size: 0.875rem !important;
	color: var(--bone-dim) !important;
	letter-spacing: normal !important;
	text-transform: none !important;
	line-height: 1.5 !important;
}
.lca-wc .form-row.update_subscription_addresses_field {
	margin: var(--s-3) 0 !important;
}

/* Fieldset "Modifica password" e altri fieldset in WC forms */
.lca-wc form fieldset {
	margin: var(--s-6) 0 0;
	padding: var(--s-5) var(--s-5);
	border: 1px solid var(--ash-line);
	border-radius: var(--r-md);
	background: var(--ink-soft);
}
.lca-wc form fieldset legend {
	padding: 0 var(--s-3);
	font-family: var(--font-body);
	font-size: 0.6875rem;
	font-weight: 600;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: var(--blush);
}

/* Submit row + lost password link */
.lca-wc .woocommerce-form-login__submit,
.lca-wc .woocommerce-form-register__submit,
.lca-wc .woocommerce-Button,
.lca-wc form.lost_reset_password button[type="submit"] {
	width: 100% !important;
	padding: var(--s-4) var(--s-6) !important;
	font-size: 1rem !important;
	margin: var(--s-2) 0 !important;
	float: none !important;
}

.lca-wc .lost_password {
	margin: 0 !important;
	padding: 0 !important;
	text-align: center;
}
.lca-wc .lost_password a {
	font-size: 0.875rem;
	color: var(--bone-dim);
	text-decoration: none;
	border-bottom: 1px solid var(--ash-line);
	padding-bottom: 2px;
	transition: color var(--dur) var(--ease), border-color var(--dur) var(--ease);
}
.lca-wc .lost_password a:hover {
	color: var(--blush);
	border-color: var(--blush);
}

/* Lost password page (specific) */
.lca-wc .woocommerce-ResetPassword,
.lca-wc form.lost_reset_password {
	max-width: 480px;
	margin: 0 auto !important;
	padding: clamp(1.75rem, 3vw, 2.5rem) !important;
	background: var(--ink-soft);
	border: 1px solid var(--ash-line);
	border-radius: var(--r-xl);
}
.lca-wc .woocommerce-ResetPassword p:first-of-type,
.lca-wc form.lost_reset_password p:first-of-type {
	color: var(--bone-dim);
	font-size: 0.9375rem;
	line-height: 1.55;
	margin-bottom: var(--s-6);
}

/* Privacy / consent text WC adds in register form */
.lca-wc .woocommerce-privacy-policy-text,
.lca-wc .woocommerce-form-register__privacy {
	font-size: 0.8125rem;
	color: var(--bone-faint);
	line-height: 1.5;
	margin: var(--s-2) 0;
}
.lca-wc .woocommerce-privacy-policy-text a,
.lca-wc .woocommerce-form-register__privacy a {
	color: var(--blush);
	border-bottom: 1px solid currentColor;
}

/* Reset password specific fields */
.lca-wc .woocommerce-ResetPassword .woocommerce-form-row {
	margin-bottom: var(--s-4) !important;
}

/* Title del page in WC pages — molti template lo wrappano in entry-title */
.lca-wc .entry-title,
.lca-wc h1.page-title {
	font-family: var(--font-display);
	font-size: clamp(2rem, 4vw, 3rem);
	font-weight: 600;
	letter-spacing: -0.02em;
	line-height: 1.05;
	margin: 0 0 var(--s-8);
	text-align: center;
	color: var(--bone);
}

/* Layout wrapper per la pagina login intera */
.woocommerce-account:not(.logged-in) .lca-main--woocommerce {
	padding-block: clamp(3rem, 6vw, 6rem);
	background:
		radial-gradient(ellipse at 50% 0%, rgba(225, 11, 44, 0.18) 0%, transparent 50%),
		var(--ink);
}

/* Hero/eyebrow injection sopra il login (vedi inc/woocommerce.php) */
.lca-wc__auth-intro {
	text-align: center;
	max-width: 560px;
	margin: 0 auto var(--s-10);
}
.lca-wc__auth-intro h1 {
	font-family: var(--font-display);
	font-size: clamp(2.25rem, 4.5vw, 3.5rem);
	font-weight: 600;
	letter-spacing: -0.025em;
	line-height: 1.05;
	margin: var(--s-3) 0 var(--s-3);
	color: var(--bone);
}
.lca-wc__auth-intro h1 em {
	font-style: italic;
	color: var(--blood);
}
.lca-wc__auth-intro p {
	color: var(--bone-dim);
	font-size: 1.0625rem;
	line-height: 1.55;
	margin: 0;
}

/* Mobile single column (force) */
@media (max-width: 720px) {
	.lca-wc #customer_login,
	.lca-wc .u-columns.col2-set { grid-template-columns: 1fr; }
}

/* ====== 25. UTILITIES ============================================ */
.lca-mt-0 { margin-top: 0 !important; }
.lca-mb-0 { margin-bottom: 0 !important; }
.lca-text-center { text-align: center; }
.lca-flex { display: flex; }
.lca-flex-col { flex-direction: column; }
.lca-gap-2 { gap: var(--s-2); }
.lca-gap-3 { gap: var(--s-3); }
.lca-gap-4 { gap: var(--s-4); }
.lca-hidden { display: none !important; }
.lca-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;
}

/* Reveal-on-scroll */
.lca-reveal {
	opacity: 0;
	transform: translateY(30px);
	transition: opacity 800ms var(--ease-out), transform 800ms var(--ease-out);
}
.lca-reveal.is-visible {
	opacity: 1;
	transform: translateY(0);
}
.lca-reveal--delay-1 { transition-delay: 100ms; }
.lca-reveal--delay-2 { transition-delay: 200ms; }
.lca-reveal--delay-3 { transition-delay: 300ms; }

/* Scrollbars (webkit) */
::-webkit-scrollbar { width: 10px; height: 10px; }
::-webkit-scrollbar-track { background: var(--ink); }
::-webkit-scrollbar-thumb { background: var(--ink-mid); border-radius: var(--r-pill); border: 2px solid var(--ink); }
::-webkit-scrollbar-thumb:hover { background: var(--ash); }

/* Reduce motion */
@media (prefers-reduced-motion: reduce) {
	*, *::before, *::after {
		animation-duration: 0.01ms !important;
		animation-iteration-count: 1 !important;
		transition-duration: 0.01ms !important;
		scroll-behavior: auto !important;
	}
}


/* =========================================================
   Inline-style replacements (refactor 1.3.x — vedi page templates).
   Tutte le seguenti classi sostituiscono attributi style="" inline.
   ========================================================= */

/* Hero — fondo isolato (per @bg + filter senza affettare i siblings) */
.lca-hero--isolated { position: relative; overflow: hidden; isolation: isolate; }

/* Hero title con larghezza vincolata a 18ch (cap leggibilità) */
.lca-hero__title--narrow { max-width: 18ch; }

/* Modes split: 2 colonne 50/50 con gap fluido */
.lca-modes-split {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: clamp(2rem, 5vw, 5rem);
	align-items: start;
}
.lca-modes-split--reverse > :first-child { order: 2; }
.lca-modes-split--reverse > :last-child  { order: 1; }
@media (max-width: 768px) {
	.lca-modes-split { grid-template-columns: 1fr; }
	.lca-modes-split--reverse > :first-child,
	.lca-modes-split--reverse > :last-child { order: initial; }
}

/* Titolo grande per le mode columns (display fluido) */
.lca-modes__title {
	font-size: clamp(2.25rem, 4vw, 3.5rem);
	margin: var(--s-3) 0;
}

/* Lead di paragrafo descrittivo (modes / pricing) */
.lca-lead--editorial {
	font-size: 1.0625rem;
	line-height: 1.6;
	margin-bottom: var(--s-6);
}

/* Chat message bubble dimensioning */
.lca-chat-msg--user { max-width: 85%; margin-bottom: var(--s-4); }
.lca-chat-msg--ai   { max-width: 100%; }

/* Tone pills row (lista chip orizzontali) */
.lca-tone-pills {
	display: flex;
	flex-wrap: wrap;
	gap: var(--s-2);
	margin-bottom: var(--s-6);
}

/* Mono caption / kicker (es. "Tono richiesto: maturo") */
.lca-mono-caption {
	font-size: .75rem;
	letter-spacing: .1em;
	color: var(--blush);
	text-transform: uppercase;
	margin-bottom: var(--s-6);
}

/* Section background variant (ink-soft) */
.lca-section--ink-soft { background: var(--ink-soft); }

/* Chat bubble lead paragraph (primo paragrafo dentro bubble AI) */
.lca-chat-bubble__lead { margin-top: 0; }

/* Empty state actions (404, ecc.) */
.lca-empty__actions {
	display: flex;
	gap: var(--s-3);
	justify-content: center;
	flex-wrap: wrap;
}

/* Archive description (sotto al titolo archive) */
.lca-archive__desc {
	font-size: 1.0625rem;
	max-width: 60ch;
}

/* Search results — form wrap sotto al titolo */
.lca-search__form-wrap { max-width: 600px; }

/* Single post tags row */
.lca-single__tags {
	max-width: 720px;
	margin: var(--s-12) auto 0;
	display: flex;
	flex-wrap: wrap;
	gap: var(--s-2);
}

/* Section heading offsets minori (cases / insider) */
.lca-section__title--tight { margin-top: .5rem; }
.lca-section__title--m3    { margin-top: var(--s-3); }

/* Insider lead paragraph */
.lca-insider__lead {
	font-size: 1.0625rem;
	line-height: 1.6;
	margin: var(--s-4) 0 var(--s-8);
	max-width: 48ch;
}

/* Pricing — section head centrato */
.lca-section__head--centered { margin-inline: auto; }

/* Card CTA push-to-bottom */
.lca-mode-card__cta--push { margin-top: auto; }

/* Comparativa pricing — tabella accessibile */
.lca-compare-table-wrap {
	overflow-x: auto;
	border: 1px solid var(--ash-line);
	border-radius: var(--r-lg);
	background: var(--ink-soft);
}
.lca-compare-table { width: 100%; border-collapse: collapse; font-size: .9375rem; }
.lca-compare-table thead tr { background: var(--ink); }
.lca-compare-table th {
	padding: var(--s-4);
	font-family: var(--font-mono);
	font-size: .6875rem;
	letter-spacing: .1em;
	text-transform: uppercase;
	font-weight: 600;
}
.lca-compare-table th:first-child { text-align: left;   color: var(--bone-faint); }
.lca-compare-table th:not(:first-child) { text-align: center; color: var(--bone-faint); }
.lca-compare-table th.is-featured { color: var(--blood); }
.lca-compare-table tbody tr { border-top: 1px solid var(--ash-line); }
.lca-compare-table td { padding: var(--s-4); }
.lca-compare-table td:first-child { color: var(--bone); }
.lca-compare-table td:not(:first-child) { text-align: center; color: var(--bone-dim); }
.lca-compare-table td.is-featured { background: rgba(225, 11, 44, .05); color: var(--bone); }
