/* --- Reset --- */

*,
*::before,
*::after {
	box-sizing: border-box;
	margin: 0;
	padding: 0;
}

html {
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	text-rendering: optimizeLegibility;
}

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

/* --- Custom Properties --- */

:root {
	/* Palette: derivata dai colori esatti del logo Innova INM */
	--color-bg: #ffffff;
	--color-bg-alt: #f4f6fa;
	--color-bg-dark: #0a1a35;
	--color-text: #142a4f;
	--color-text-light: #546479;
	--color-text-on-dark: #edf0f5;
	--color-primary: #142a4f;
	--color-primary-light: #1e3a6a;
	--color-primary-hover: #1a3560;
	--color-primary-dark: #0a1a35;
	--color-accent: #e4b54b;
	--color-accent-hover: #c99a2e;
	--color-accent-light: #efce7d;
	--color-border: #dadfe7;
	--color-success: #1a8a5c;
	--color-danger: #b52a1c;
	--color-danger-light: #d4503f;
	--font-sans: "DM Sans", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
	--font-heading: "Outfit", var(--font-sans);
	--space-xs: 0.25rem;
	--space-sm: 0.5rem;
	--space-md: 1rem;
	--space-lg: 1.5rem;
	--space-xl: 2rem;
	--space-2xl: 3rem;
	--space-3xl: 4rem;
	--radius-sm: 0.25rem;
	--radius-md: 0.5rem;
	--radius-lg: 0.75rem;
	--container-max: 1200px;
	--container-padding: 1.5rem;

	/* Shadows — blue-tinted for brand cohesion */
	--shadow-sm: 0 1px 3px rgba(20, 42, 79, 0.07), 0 1px 2px rgba(20, 42, 79, 0.04);
	--shadow-md: 0 4px 16px rgba(20, 42, 79, 0.09), 0 2px 4px rgba(20, 42, 79, 0.04);
	--shadow-lg: 0 12px 40px rgba(20, 42, 79, 0.14), 0 4px 12px rgba(20, 42, 79, 0.07);
	--shadow-accent: 0 4px 20px rgba(228, 181, 75, 0.30);

	/* Transitions */
	--ease-out: cubic-bezier(0.2, 0, 0, 1);
	--duration: 0.3s;
}

/* --- Selection --- */

::selection {
	background-color: var(--color-primary);
	color: var(--color-text-on-dark);
}

/* --- Smooth scroll --- */

html {
	scroll-behavior: smooth;
}

/* --- Base Typography --- */

body {
	font-family: var(--font-sans);
	font-size: 1rem;
	line-height: 1.6;
	color: var(--color-text);
	background-color: var(--color-bg);
}

h1,
h2,
h3,
h4,
h5,
h6 {
	font-family: var(--font-heading);
	line-height: 1.15;
	font-weight: 700;
	letter-spacing: -0.02em;
	color: var(--color-primary);
}

h1 {
	font-size: clamp(2rem, 5vw, 3rem);
}

h2 {
	font-size: clamp(1.5rem, 4vw, 2.25rem);
}

h3 {
	font-size: clamp(1.25rem, 3vw, 1.75rem);
}

h4 {
	font-size: clamp(1.1rem, 2.5vw, 1.375rem);
}

h5 {
	font-size: 1.125rem;
}

h6 {
	font-size: 1rem;
}

a {
	color: var(--color-accent);
	text-decoration: none;
	transition: color var(--duration) var(--ease-out);
}

a:hover {
	color: var(--color-accent-hover);
}

:focus-visible {
	outline: 2px solid var(--color-accent);
	outline-offset: 2px;
	border-radius: var(--radius-sm);
}

/* --- Layout Utilities --- */

.container {
	max-width: var(--container-max);
	margin: 0 auto;
	padding: 0 var(--container-padding);
}

.section {
	padding: var(--space-3xl) 0;
}

.section--alt {
	background-color: var(--color-bg-alt);
}

.section--dark {
	background: linear-gradient(135deg, var(--color-primary-dark) 0%, var(--color-primary) 100%);
	color: var(--color-text-on-dark);
	position: relative;
}

.section--dark h2 {
	color: #ffffff;
}

.section--dark .btn--primary {
	box-shadow: var(--shadow-accent);
}

.grid {
	display: grid;
	gap: var(--space-lg);
}

.grid--2 {
	grid-template-columns: 1fr;
}

.grid--3 {
	grid-template-columns: 1fr;
}

.grid--4 {
	grid-template-columns: 1fr;
}

@media (min-width: 768px) {
	.grid--2 {
		grid-template-columns: repeat(2, 1fr);
	}

	.grid--3 {
		grid-template-columns: repeat(3, 1fr);
	}

	.grid--4 {
		grid-template-columns: repeat(2, 1fr);
	}
}

@media (min-width: 1024px) {
	.grid--4 {
		grid-template-columns: repeat(4, 1fr);
	}
}

/* --- Buttons --- */

.btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 0.75rem 1.5rem;
	border: none;
	border-radius: var(--radius-md);
	font-family: var(--font-sans);
	font-size: 1rem;
	font-weight: 600;
	line-height: 1;
	text-decoration: none;
	cursor: pointer;
	transition: all var(--duration) var(--ease-out);
}

.btn--primary {
	background: linear-gradient(135deg, var(--color-accent-light) 0%, var(--color-accent) 50%, var(--color-accent-hover) 100%);
	background-size: 200% 200%;
	background-position: 50% 50%;
	color: #ffffff;
	box-shadow: var(--shadow-sm), 0 2px 8px rgba(228, 181, 75, 0.2);
}

.btn--primary:hover {
	background-position: 100% 100%;
	color: #ffffff;
	transform: translateY(-1px);
	box-shadow: var(--shadow-md), var(--shadow-accent);
}

.btn--primary:active {
	transform: translateY(0);
	box-shadow: var(--shadow-sm);
}

.btn--secondary {
	background-color: transparent;
	border: 1.5px solid var(--color-border);
	color: var(--color-text);
}

.btn--secondary:hover {
	border-color: var(--color-primary);
	color: var(--color-primary);
	background-color: rgba(20, 42, 79, 0.04);
}

.btn--lg {
	padding: 1rem 2rem;
	font-size: 1.1rem;
	border-radius: var(--radius-lg);
}

/* --- Cards --- */

.card {
	background-color: #ffffff;
	border: 1px solid var(--color-border);
	border-left: 4px solid var(--color-accent);
	border-radius: var(--radius-md);
	overflow: hidden;
	box-shadow: var(--shadow-sm);
	transition: all var(--duration) var(--ease-out);
}

.card:hover {
	transform: translateY(-3px);
	box-shadow: var(--shadow-lg);
	border-left-color: var(--color-primary);
}

a.card {
	color: inherit;
	text-decoration: none;
	display: block;
}

a.card:hover {
	color: inherit;
}

.card__image {
	width: 100%;
	aspect-ratio: 16 / 9;
	object-fit: cover;
}

.card__body {
	padding: var(--space-lg);
}

.card__title {
	font-size: 1.125rem;
	font-weight: 600;
}

.card__meta {
	font-size: 0.875rem;
	color: var(--color-text-light);
	margin-top: var(--space-xs);
}

.card__excerpt {
	margin-top: var(--space-sm);
	line-height: 1.6;
	color: var(--color-text-light);
}

.card__price {
	font-size: 1.25rem;
	font-weight: 700;
	margin-top: var(--space-sm);
}

.card__cta {
	margin-top: var(--space-md);
}

/* --- Hero --- */

.hero {
	padding: var(--space-3xl) 0 calc(var(--space-3xl) * 1.5);
	text-align: center;
	background:
		radial-gradient(ellipse 80% 50% at 50% -10%, rgba(20, 42, 79, 0.06) 0%, transparent 70%),
		radial-gradient(ellipse 40% 40% at 80% 60%, rgba(228, 181, 75, 0.04) 0%, transparent 70%),
		var(--color-bg);
	position: relative;
	overflow: hidden;
}

.hero::after {
	content: "";
	position: absolute;
	bottom: 0;
	left: 50%;
	transform: translateX(-50%);
	width: 60px;
	height: 3px;
	background: linear-gradient(90deg, var(--color-accent), var(--color-primary));
	border-radius: 2px;
}

.hero--rich {
	padding-top: calc(var(--space-3xl) * 1.25);
	padding-bottom: calc(var(--space-3xl) * 1.75);
}

.hero__inner {
	position: relative;
	z-index: 2;
}

.hero__pattern {
	position: absolute;
	inset: 0;
	background-image:
		radial-gradient(circle at 10% 20%, rgba(20, 42, 79, 0.05) 0%, transparent 30%),
		radial-gradient(circle at 90% 80%, rgba(228, 181, 75, 0.08) 0%, transparent 35%);
	background-size: 100% 100%;
	pointer-events: none;
	z-index: 1;
}

.hero__pattern::before,
.hero__pattern::after {
	content: "";
	position: absolute;
	border-radius: 50%;
	pointer-events: none;
}

.hero__pattern::before {
	top: 10%;
	left: 4%;
	width: 180px;
	height: 180px;
	background: radial-gradient(circle, rgba(228, 181, 75, 0.08) 0%, transparent 70%);
}

.hero__pattern::after {
	bottom: 15%;
	right: 6%;
	width: 240px;
	height: 240px;
	background: radial-gradient(circle, rgba(20, 42, 79, 0.06) 0%, transparent 70%);
}

.hero__eyebrow-dot {
	display: inline-block;
	width: 8px;
	height: 8px;
	border-radius: 50%;
	background: var(--color-accent);
	margin-right: var(--space-xs);
	vertical-align: middle;
	box-shadow: 0 0 0 3px rgba(228, 181, 75, 0.2);
	animation: pulse-dot 2s var(--ease-out) infinite;
}

@keyframes pulse-dot {
	0%, 100% { box-shadow: 0 0 0 3px rgba(228, 181, 75, 0.2); }
	50% { box-shadow: 0 0 0 6px rgba(228, 181, 75, 0.1); }
}

.hero__trust {
	display: inline-flex;
	align-items: center;
	gap: var(--space-lg);
	margin-top: calc(var(--space-2xl) + var(--space-md));
	padding: var(--space-md) var(--space-xl);
	background: rgba(255, 255, 255, 0.6);
	backdrop-filter: blur(8px);
	border: 1px solid var(--color-border);
	border-radius: 999px;
	box-shadow: var(--shadow-sm);
	flex-wrap: wrap;
	justify-content: center;
}

.hero__trust-item {
	display: flex;
	flex-direction: column;
	align-items: center;
	line-height: 1.2;
}

.hero__trust-item strong {
	font-family: var(--font-heading);
	font-size: 1.25rem;
	font-weight: 800;
	color: var(--color-primary);
	letter-spacing: -0.02em;
}

.hero__trust-item span {
	font-size: 0.75rem;
	color: var(--color-text-light);
	text-transform: uppercase;
	letter-spacing: 0.08em;
	margin-top: 2px;
}

.hero__trust-divider {
	width: 1px;
	height: 32px;
	background: var(--color-border);
}

.hero__eyebrow {
	text-transform: uppercase;
	font-family: var(--font-heading);
	font-size: 0.8rem;
	font-weight: 600;
	letter-spacing: 0.15em;
	color: var(--color-accent);
	margin-bottom: var(--space-lg);
}

.hero__title {
	font-size: clamp(2.25rem, 5.5vw, 3.5rem);
	font-weight: 800;
	letter-spacing: -0.025em;
	line-height: 1.08;
}

.hero__subtitle {
	font-size: clamp(1.05rem, 2vw, 1.2rem);
	color: var(--color-text-light);
	max-width: 640px;
	margin: var(--space-lg) auto 0;
	line-height: 1.7;
}

.hero__actions {
	margin-top: var(--space-2xl);
	display: flex;
	gap: var(--space-md);
	justify-content: center;
	flex-wrap: wrap;
}

/* --- Hero category chips (quick navigation) --- */

.hero__categories {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 0.6rem;
	margin-top: var(--space-xl);
	padding: 0 var(--space-md);
}

.hero__category {
	display: inline-flex;
	align-items: center;
	gap: 0.55rem;
	padding: 0.5rem 1.05rem 0.5rem 0.5rem;
	background: rgba(255, 255, 255, 0.7);
	backdrop-filter: blur(8px);
	border: 1px solid var(--color-border);
	border-radius: 999px;
	color: var(--color-primary);
	font-family: var(--font-heading);
	font-weight: 600;
	font-size: 0.92rem;
	letter-spacing: -0.005em;
	box-shadow: 0 1px 2px rgba(20, 42, 79, 0.04);
	transition: transform var(--duration) var(--ease-out),
		border-color var(--duration) var(--ease-out),
		box-shadow var(--duration) var(--ease-out),
		background var(--duration) var(--ease-out);
	white-space: nowrap;
}

.hero__category:hover {
	transform: translateY(-2px);
	border-color: var(--color-accent);
	background: #ffffff;
	box-shadow: 0 10px 20px -10px rgba(20, 42, 79, 0.22);
}

.hero__category-icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 30px;
	height: 30px;
	border-radius: 50%;
	background: rgba(228, 181, 75, 0.18);
	color: var(--color-accent);
	flex-shrink: 0;
	transition: background var(--duration) var(--ease-out),
		color var(--duration) var(--ease-out);
}

.hero__category-icon svg {
	width: 16px;
	height: 16px;
}

.hero__category:hover .hero__category-icon {
	background: var(--color-accent);
	color: var(--color-primary);
}

@media (max-width: 640px) {
	.hero__categories {
		flex-wrap: nowrap;
		overflow-x: auto;
		justify-content: flex-start;
		scroll-snap-type: x mandatory;
		padding: 0.25rem var(--container-padding) 0.5rem;
		margin: var(--space-lg) calc(-1 * var(--container-padding)) 0;
		scrollbar-width: none;
		-webkit-overflow-scrolling: touch;
	}
	.hero__categories::-webkit-scrollbar { display: none; }
	.hero__category { scroll-snap-align: center; flex-shrink: 0; }
}

/* --- Steps (How It Works) --- */

.steps {
	display: grid;
	gap: var(--space-xl);
}

@media (min-width: 768px) {
	.steps {
		grid-template-columns: repeat(3, 1fr);
	}
}

.steps__item {
	text-align: center;
	padding: var(--space-xl) var(--space-lg);
	position: relative;
}

@media (min-width: 768px) {
	.steps__item:not(:last-child)::after {
		content: "";
		position: absolute;
		top: calc(var(--space-xl) + 28px);
		right: calc(-1 * var(--space-xl) / 2);
		width: var(--space-xl);
		height: 2px;
		background: repeating-linear-gradient(90deg, var(--color-border) 0, var(--color-border) 6px, transparent 6px, transparent 12px);
	}
}

.steps__number {
	display: inline-flex;
	width: 56px;
	height: 56px;
	border-radius: 50%;
	background: linear-gradient(135deg, var(--color-accent-light), var(--color-accent));
	color: #ffffff;
	font-family: var(--font-heading);
	font-weight: 800;
	font-size: 1.35rem;
	align-items: center;
	justify-content: center;
	box-shadow: 0 4px 12px rgba(228, 181, 75, 0.3);
	position: relative;
}

.steps__number::before {
	content: "";
	position: absolute;
	inset: -6px;
	border-radius: 50%;
	border: 2px solid rgba(228, 181, 75, 0.15);
}

.steps__title {
	margin-top: var(--space-lg);
	font-size: 1.15rem;
	font-weight: 700;
}

.steps__desc {
	margin-top: var(--space-sm);
	color: var(--color-text-light);
	font-size: 0.9rem;
	line-height: 1.7;
	max-width: 280px;
	margin-left: auto;
	margin-right: auto;
}

/* --- Site Header --- */

.site-header {
	position: sticky;
	top: 0;
	background-color: #ffffff;
	box-shadow: var(--shadow-sm);
	z-index: 100;
}

.site-header .container {
	display: flex;
	align-items: center;
	justify-content: space-between;
	min-height: 68px;
}

.site-header__logo a {
	display: inline-flex;
	align-items: center;
	text-decoration: none;
	color: var(--color-primary);
	transition: opacity var(--duration) var(--ease-out);
}

.site-header__logo a:hover {
	opacity: 0.85;
}

.site-header__logo-img {
	display: block;
	width: 130px;
	height: auto;
	aspect-ratio: 16627 / 5911;
	flex-shrink: 0;
	max-width: 220px;
}

@media (min-width: 768px) {
	.site-header__logo-img {
		width: 150px;
	}
}

.site-header__nav ul {
	display: flex;
	list-style: none;
	gap: var(--space-lg);
	margin: 0;
	padding: 0;
}

.site-header__nav ul.menu,
.site-header__nav ul#primary-menu {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	gap: var(--space-lg);
}

.site-header__nav a {
	color: var(--color-text);
	text-decoration: none;
	font-size: 0.95rem;
	font-weight: 500;
	transition: color var(--duration) var(--ease-out);
	position: relative;
	padding: 0.5rem 0;
}

.site-header__nav a::after {
	content: "";
	position: absolute;
	bottom: 0;
	left: 0;
	width: 0;
	height: 2px;
	background: var(--color-accent);
	border-radius: 1px;
	transition: width var(--duration) var(--ease-out);
}

.site-header__nav a:hover,
.site-header__nav .current-menu-item > a {
	color: var(--color-primary);
}

.site-header__nav a:hover::after,
.site-header__nav .current-menu-item > a::after {
	width: 100%;
}

/* --- Header actions (cart + account) --- */

.site-header__actions {
	display: flex;
	align-items: center;
	gap: var(--space-xs);
}

.site-header__action {
	position: relative;
}

.site-header__action-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 42px;
	height: 42px;
	border-radius: var(--radius-md);
	color: var(--color-primary);
	background: transparent;
	border: none;
	cursor: pointer;
	text-decoration: none;
	transition: all var(--duration) var(--ease-out);
	position: relative;
}

.site-header__action-btn:hover,
.site-header__action:hover .site-header__action-btn,
.site-header__action:focus-within .site-header__action-btn {
	background: rgba(20, 42, 79, 0.06);
	color: var(--color-primary);
}

.site-header__cart-count {
	position: absolute;
	top: 4px;
	right: 4px;
	min-width: 18px;
	height: 18px;
	padding: 0 5px;
	border-radius: 9px;
	background: var(--color-accent);
	color: var(--color-primary);
	font-size: 0.7rem;
	font-weight: 700;
	line-height: 18px;
	text-align: center;
	box-shadow: 0 0 0 2px var(--color-bg);
	font-family: var(--font-heading);
}

.site-header__dropdown {
	position: absolute;
	top: calc(100% + 8px);
	right: 0;
	min-width: 260px;
	background: var(--color-bg);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-lg);
	box-shadow: var(--shadow-lg);
	padding: var(--space-md);
	opacity: 0;
	visibility: hidden;
	transform: translateY(-8px);
	transition: all var(--duration) var(--ease-out);
	z-index: 110;
	display: flex;
	flex-direction: column;
	gap: 2px;
}

.site-header__dropdown::before {
	content: "";
	position: absolute;
	top: -6px;
	right: 14px;
	width: 12px;
	height: 12px;
	background: var(--color-bg);
	border-left: 1px solid var(--color-border);
	border-top: 1px solid var(--color-border);
	transform: rotate(45deg);
}

.site-header__action:hover .site-header__dropdown,
.site-header__action:focus-within .site-header__dropdown {
	opacity: 1;
	visibility: visible;
	transform: translateY(0);
}

.site-header__dropdown-greet {
	font-family: var(--font-heading);
	font-size: 0.85rem;
	font-weight: 700;
	color: var(--color-text-light);
	padding: 0 var(--space-sm) var(--space-xs);
	margin: 0;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	border-bottom: 1px solid var(--color-border);
	margin-bottom: var(--space-xs);
}

.site-header__dropdown a {
	display: block;
	padding: 0.55rem var(--space-sm);
	color: var(--color-text);
	text-decoration: none;
	border-radius: var(--radius-sm);
	font-size: 0.95rem;
	font-weight: 500;
	transition: background-color var(--duration) var(--ease-out);
}

.site-header__dropdown a:hover {
	background: var(--color-bg-alt);
	color: var(--color-primary);
}

.site-header__dropdown-logout {
	margin-top: var(--space-xs);
	padding-top: var(--space-sm);
	border-top: 1px solid var(--color-border);
	color: var(--color-danger);
}

.site-header__dropdown--cart {
	min-width: 320px;
}

.site-header__cart-empty {
	text-align: center;
	color: var(--color-text-light);
	font-size: 0.9rem;
	margin: var(--space-md) 0;
}

.site-header__dropdown--cart .btn {
	width: 100%;
	margin-top: var(--space-sm);
}

/* Mini cart WC overrides */

.widget_shopping_cart_content .woocommerce-mini-cart {
	list-style: none;
	padding: 0;
	margin: 0 0 var(--space-sm);
	max-height: 320px;
	overflow-y: auto;
}

.widget_shopping_cart_content .woocommerce-mini-cart__empty-message {
	text-align: center;
	color: var(--color-text-light);
	font-size: 0.9rem;
}

.widget_shopping_cart_content .total {
	padding: var(--space-sm) 0;
	border-top: 1px solid var(--color-border);
	font-weight: 700;
	color: var(--color-primary);
}

.widget_shopping_cart_content .buttons {
	display: flex;
	flex-direction: column;
	gap: var(--space-xs);
}

.widget_shopping_cart_content .buttons .button {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 0.65rem 1rem;
	border-radius: var(--radius-md);
	font-weight: 600;
	font-size: 0.9rem;
	text-decoration: none;
	text-align: center;
	transition: all var(--duration) var(--ease-out);
}

.widget_shopping_cart_content .buttons .wc-forward:not(.checkout) {
	background: transparent;
	border: 1.5px solid var(--color-border);
	color: var(--color-text);
}

.widget_shopping_cart_content .buttons .checkout {
	background: linear-gradient(135deg, var(--color-accent-light) 0%, var(--color-accent) 50%, var(--color-accent-hover) 100%);
	color: var(--color-primary);
	border: none;
}

/* --- Site Footer --- */

.site-footer {
	padding: var(--space-2xl) 0;
	background: linear-gradient(180deg, var(--color-primary-dark) 0%, #060e18 100%);
	color: var(--color-text-on-dark);
	position: relative;
}

.site-footer::before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	height: 3px;
	background: linear-gradient(90deg, var(--color-accent), var(--color-primary-light), var(--color-accent));
}

.site-footer a {
	color: var(--color-text-on-dark);
	text-decoration: none;
}

.site-footer__grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--space-xl);
	align-items: start;
}

@media (min-width: 640px) {
	.site-footer__grid {
		grid-template-columns: repeat(2, 1fr);
		gap: var(--space-2xl);
	}
}

@media (min-width: 960px) {
	.site-footer__grid {
		grid-template-columns: 1.4fr 1fr 1.3fr 1fr;
	}
}

.site-footer__col-title {
	font-family: var(--font-heading);
	font-size: 0.95rem;
	font-weight: 700;
	letter-spacing: 0.02em;
	color: #fff;
	margin: 0 0 var(--space-md);
	text-transform: uppercase;
	letter-spacing: 0.08em;
}

.site-footer__brand {
	display: flex;
	flex-direction: column;
	gap: var(--space-md);
}

.site-footer__logo {
	display: inline-flex;
	align-items: center;
	text-decoration: none;
	transition: opacity var(--duration) var(--ease-out);
}

.site-footer__logo:hover { opacity: 0.85; }

/* Specificity boost: su pagine WooCommerce body.woocommerce-page applica
   `.woocommerce img { height: auto; max-width: 100% }` che altrimenti
   vincerebbe su questa regola → logo footer più grande su cart/checkout. */
.site-footer .site-footer__logo-img,
.site-footer__logo .site-footer__logo-img {
	display: block;
	height: 44px;
	width: auto;
	max-width: 180px;
}

.site-footer__tagline {
	font-size: 0.9rem;
	line-height: 1.6;
	color: rgba(255, 255, 255, 0.72);
	margin: 0;
	max-width: 340px;
}

.site-footer__social {
	display: flex;
	gap: 0.5rem;
	margin-top: 1rem;
}

.site-footer__social-link {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 36px;
	height: 36px;
	border-radius: 999px;
	background: rgba(255, 255, 255, 0.08);
	color: rgba(255, 255, 255, 0.82);
	transition: background var(--duration) var(--ease-out), color var(--duration) var(--ease-out), transform var(--duration) var(--ease-out);
}

.site-footer__social-link:hover {
	background: var(--color-accent);
	color: var(--color-primary);
	transform: translateY(-2px);
}

.site-footer__nav ul,
.site-footer__legal ul {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: 0.55rem;
}

.site-footer__nav a,
.site-footer__legal a {
	font-size: 0.92rem;
	color: rgba(255, 255, 255, 0.82);
	transition: color var(--duration) var(--ease-out);
}

.site-footer__nav a:hover,
.site-footer__legal a:hover {
	color: var(--color-accent);
}

.site-footer__contact-list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: 0.85rem;
}

.site-footer__contact-link {
	display: inline-flex;
	align-items: center;
	gap: 0.75rem;
	text-decoration: none;
	color: #fff;
	padding: 0.3rem 0;
	transition: color var(--duration) var(--ease-out);
}

.site-footer__contact-link:hover {
	color: var(--color-accent);
}

.site-footer__contact-icon {
	flex: 0 0 auto;
	width: 36px;
	height: 36px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	border-radius: 50%;
	background: rgba(255, 255, 255, 0.06);
	color: var(--color-accent);
}

.site-footer__contact-link--wa .site-footer__contact-icon {
	background: rgba(37, 211, 102, 0.16);
	color: #25d366;
}

.site-footer__contact-label {
	display: block;
	font-size: 0.72rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	color: rgba(255, 255, 255, 0.55);
	margin-bottom: 2px;
}

.site-footer__contact-value {
	display: block;
	font-size: 0.95rem;
	font-weight: 600;
	line-height: 1.2;
}

.site-footer__bar {
	margin-top: var(--space-2xl);
	padding-top: var(--space-lg);
	border-top: 1px solid rgba(255, 255, 255, 0.1);
}

.site-footer__bar-inner {
	display: flex;
	flex-direction: column;
	gap: 0.4rem;
	align-items: flex-start;
	font-size: 0.8rem;
	color: rgba(255, 255, 255, 0.55);
}

@media (min-width: 640px) {
	.site-footer__bar-inner {
		flex-direction: row;
		justify-content: space-between;
		align-items: center;
	}
}

.site-footer__copy {
	font-size: 0.82rem;
}

.site-footer__made {
	font-size: 0.78rem;
	font-style: italic;
}

.site-footer__credit {
	display: inline-flex;
	align-items: center;
	gap: 0.3rem;
	color: inherit;
	text-decoration: none;
	transition: color var(--duration) var(--ease-out);
	font-style: italic;
}

.site-footer__credit strong {
	font-weight: 700;
	font-style: normal;
	letter-spacing: -0.005em;
	border-bottom: 1px solid transparent;
	transition: border-color var(--duration) var(--ease-out);
}

.site-footer__credit-heart {
	display: inline-block;
	color: rgba(255, 255, 255, 0.55);
	transition: color 200ms var(--ease-out), fill 200ms var(--ease-out), transform 200ms var(--ease-out);
	transform-origin: center;
}

.site-footer__credit:hover {
	color: rgba(255, 255, 255, 0.85);
}

.site-footer__credit:hover strong {
	border-bottom-color: var(--color-accent);
}

.site-footer__credit:hover .site-footer__credit-heart {
	color: #ff3e57;
	fill: #ff3e57;
	animation: footer-heartbeat 0.9s var(--ease-out) infinite;
}

@keyframes footer-heartbeat {
	0%, 100% { transform: scale(1); }
	14% { transform: scale(1.25); }
	28% { transform: scale(1); }
	42% { transform: scale(1.18); }
	70% { transform: scale(1); }
}

@media (prefers-reduced-motion: reduce) {
	.site-footer__credit:hover .site-footer__credit-heart {
		animation: none;
	}
}

/* ===== WhatsApp FAB floating (appare sempre in basso a destra) ===== */

.site-wa-float {
	position: fixed;
	bottom: 18px;
	right: 18px;
	z-index: 940;
	width: 54px;
	height: 54px;
	border-radius: 50%;
	background: #25d366;
	color: #fff;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	box-shadow: 0 14px 28px -8px rgba(37, 211, 102, 0.55), 0 2px 6px rgba(0, 0, 0, 0.12);
	text-decoration: none;
	transition: transform 220ms cubic-bezier(0.16, 1, 0.3, 1), box-shadow 200ms ease, opacity 220ms ease, visibility 0s linear 0s;
}

.site-wa-float:hover,
.site-wa-float:focus-visible {
	transform: translateY(-3px) scale(1.04);
	box-shadow: 0 20px 40px -8px rgba(37, 211, 102, 0.6), 0 3px 10px rgba(0, 0, 0, 0.15);
	outline: none;
}

.site-wa-float::before {
	content: "";
	position: absolute;
	inset: -4px;
	border-radius: 50%;
	background: rgba(37, 211, 102, 0.25);
	animation: siteWaPulse 2.4s ease-out infinite;
	z-index: -1;
}

@keyframes siteWaPulse {
	0%   { transform: scale(1); opacity: 0.5; }
	80%  { transform: scale(1.35); opacity: 0; }
	100% { transform: scale(1.35); opacity: 0; }
}

/* Evita sovrapposizione con la floating buy bar e il toast mobile. */
body.has-floating-buy .site-wa-float {
	bottom: 90px;
}

@media (max-width: 640px) {
	.site-wa-float {
		bottom: 16px;
		right: 16px;
		width: 52px;
		height: 52px;
	}
	/* Quando la sticky buy bar è visibile su mobile due elementi flottanti
	   competono nello stesso angolo. Il FAB WhatsApp si ritira: la CTA
	   primaria ora è "Aggiungi al carrello". Riappare scrollando in alto. */
	body.has-floating-buy .site-wa-float {
		opacity: 0;
		visibility: hidden;
		pointer-events: none;
		transform: translateY(16px) scale(0.9);
		transition: transform 220ms cubic-bezier(0.16, 1, 0.3, 1), opacity 200ms ease, visibility 0s linear 220ms;
	}
}

@media (prefers-reduced-motion: reduce) {
	.site-wa-float::before { animation: none; }
}

/* --- Service Meta --- */

.service-meta {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
	gap: var(--space-lg);
	padding: var(--space-lg);
	background: var(--color-bg-alt);
	border-left: 4px solid var(--color-accent);
	border-radius: var(--radius-md);
	margin: var(--space-xl) 0;
}

.service-meta__label {
	font-size: 0.75rem;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	color: var(--color-text-light);
	margin-bottom: var(--space-xs);
}

.service-meta__value {
	font-weight: 600;
	font-size: 1rem;
}

/* --- Service Documents --- */

.service-documents {
	margin: var(--space-xl) 0;
}

.service-documents__title {
	font-size: 1rem;
	font-weight: 600;
	margin-bottom: var(--space-md);
}

.service-documents__list {
	list-style: none;
	padding: 0;
}

.service-documents__list li {
	padding: var(--space-sm) 0;
	padding-left: 1.5rem;
	position: relative;
	border-bottom: 1px solid var(--color-border);
}

.service-documents__list li::before {
	content: "";
	position: absolute;
	left: 0;
	top: 50%;
	transform: translateY(-50%);
	width: 8px;
	height: 10px;
	border: 2px solid var(--color-accent);
	border-top: none;
	border-radius: 0 0 2px 2px;
}

.service-documents__list li::after {
	content: "";
	position: absolute;
	left: 1px;
	top: 50%;
	transform: translateY(-50%) translateY(-5px);
	width: 6px;
	height: 2px;
	border-top: 2px solid var(--color-accent);
	border-radius: 1px 1px 0 0;
}

/* --- WooCommerce Overrides --- */

.woocommerce ul.products {
	display: grid;
	gap: var(--space-lg);
	grid-template-columns: 1fr;
}

@media (min-width: 768px) {
	.woocommerce ul.products {
		grid-template-columns: repeat(3, 1fr);
	}
}

.woocommerce ul.products li.product {
	border: 1px solid var(--color-border);
	border-top: 3px solid var(--color-accent);
	border-radius: var(--radius-md);
	overflow: hidden;
	box-shadow: var(--shadow-sm);
	transition: all var(--duration) var(--ease-out);
}

.woocommerce ul.products li.product:hover {
	transform: translateY(-3px);
	box-shadow: var(--shadow-lg);
}

.woocommerce ul.products li.product a img {
	width: 100%;
	height: auto;
}

.woocommerce ul.products li.product .woocommerce-loop-product__title {
	font-size: 1.1rem;
	font-weight: 600;
	padding: var(--space-sm) var(--space-lg) 0;
}

.woocommerce ul.products li.product .price {
	padding: 0 var(--space-lg);
	font-size: 1.1rem;
	font-weight: 700;
}

.woocommerce .single_add_to_cart_button {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 1rem 2.5rem;
	border: none;
	border-radius: var(--radius-lg);
	font-family: var(--font-sans);
	font-size: 1.1rem;
	font-weight: 600;
	line-height: 1;
	text-decoration: none;
	cursor: pointer;
	background: linear-gradient(135deg, var(--color-accent-light) 0%, var(--color-accent) 50%, var(--color-accent-hover) 100%);
	background-size: 200% 200%;
	background-position: 50% 50%;
	color: #ffffff;
	box-shadow: var(--shadow-sm), 0 2px 8px rgba(228, 181, 75, 0.2);
	transition: all var(--duration) var(--ease-out);
}

.woocommerce .single_add_to_cart_button:hover {
	background-position: 100% 100%;
	color: #ffffff;
	transform: translateY(-1px);
	box-shadow: var(--shadow-md), var(--shadow-accent);
}

.woocommerce .single_add_to_cart_button:active {
	transform: translateY(0);
}

.woocommerce-products-header {
	margin-bottom: var(--space-xl);
}

.woocommerce-result-count,
.woocommerce-ordering {
	font-size: 0.85rem;
	color: var(--color-text-light);
}

/* --- Utilities --- */

.text-center {
	text-align: center;
}

.text-muted {
	color: var(--color-text-light);
}

.mt-0 {
	margin-top: 0;
}

.mt-xs {
	margin-top: var(--space-xs);
}

.mt-sm {
	margin-top: var(--space-sm);
}

.mt-md {
	margin-top: var(--space-md);
}

.mt-lg {
	margin-top: var(--space-lg);
}

.mt-xl {
	margin-top: var(--space-xl);
}

.mt-2xl {
	margin-top: var(--space-2xl);
}

.mt-3xl {
	margin-top: var(--space-3xl);
}

.visually-hidden {
	position: absolute;
	width: 1px;
	height: 1px;
	padding: 0;
	margin: -1px;
	overflow: hidden;
	clip: rect(0, 0, 0, 0);
	white-space: nowrap;
	border: 0;
}

/* --- Section Header --- */

.section-header {
	text-align: center;
	max-width: 720px;
	margin: 0 auto var(--space-2xl);
}

.section-header__eyebrow {
	display: inline-block;
	font-family: var(--font-heading);
	font-size: 0.8rem;
	font-weight: 600;
	letter-spacing: 0.15em;
	text-transform: uppercase;
	color: var(--color-accent);
	margin-bottom: var(--space-md);
	padding: 0.3rem 1rem;
	background: rgba(228, 181, 75, 0.1);
	border-radius: 999px;
}

.section-header__title {
	font-size: clamp(1.75rem, 4vw, 2.5rem);
	margin-bottom: var(--space-md);
	letter-spacing: -0.02em;
}

.section-header__subtitle {
	font-size: clamp(1rem, 2vw, 1.1rem);
	color: var(--color-text-light);
	line-height: 1.7;
	margin: 0;
}

/* --- Service cards (homepage) --- */

.services-grid {
	display: grid;
	gap: var(--space-lg);
	grid-template-columns: 1fr;
}

@media (min-width: 576px) {
	.services-grid {
		grid-template-columns: repeat(2, 1fr);
	}
}

@media (min-width: 1024px) {
	.services-grid {
		grid-template-columns: repeat(4, 1fr);
	}
}

.service-card {
	display: flex;
	flex-direction: column;
	padding: var(--space-xl);
	background: var(--color-bg);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-lg);
	text-decoration: none;
	color: inherit;
	transition: all var(--duration) var(--ease-out);
	position: relative;
	overflow: hidden;
}

.service-card::before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	height: 4px;
	background: linear-gradient(90deg, var(--color-accent), var(--color-accent-light));
	opacity: 0;
	transition: opacity var(--duration) var(--ease-out);
}

.service-card:hover {
	transform: translateY(-4px);
	border-color: var(--color-primary);
	box-shadow: var(--shadow-lg);
	color: inherit;
}

.service-card:hover::before {
	opacity: 1;
}

.service-card__icon {
	width: 56px;
	height: 56px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	background: linear-gradient(135deg, rgba(228, 181, 75, 0.15), rgba(20, 42, 79, 0.08));
	color: var(--color-primary);
	border-radius: var(--radius-md);
	margin-bottom: var(--space-md);
	transition: all var(--duration) var(--ease-out);
}

.service-card:hover .service-card__icon {
	background: linear-gradient(135deg, var(--color-accent-light), var(--color-accent));
	color: var(--color-primary);
	transform: scale(1.05);
}

.service-card__icon svg {
	width: 32px;
	height: 32px;
}

.service-card__title {
	font-size: 1.25rem;
	font-weight: 700;
	margin: 0 0 var(--space-sm);
	color: var(--color-primary);
}

.service-card__desc {
	color: var(--color-text-light);
	font-size: 0.92rem;
	line-height: 1.6;
	margin: 0 0 var(--space-lg);
	flex: 1;
}

.service-card__cta {
	display: inline-flex;
	align-items: center;
	gap: var(--space-xs);
	font-weight: 600;
	font-size: 0.95rem;
	color: var(--color-accent);
	transition: gap var(--duration) var(--ease-out);
}

.service-card:hover .service-card__cta {
	gap: calc(var(--space-xs) + 4px);
	color: var(--color-accent-hover);
}

/* --- Why cards --- */

.why-grid {
	display: grid;
	gap: var(--space-lg);
	grid-template-columns: 1fr;
}

@media (min-width: 576px) {
	.why-grid {
		grid-template-columns: repeat(2, 1fr);
	}
}

@media (min-width: 1024px) {
	.why-grid {
		grid-template-columns: repeat(4, 1fr);
	}
}

.why-card {
	background: var(--color-bg);
	padding: var(--space-xl);
	border-radius: var(--radius-lg);
	border: 1px solid var(--color-border);
	transition: all var(--duration) var(--ease-out);
}

.why-card:hover {
	border-color: var(--color-accent);
	transform: translateY(-2px);
	box-shadow: var(--shadow-md);
}

.why-card__icon {
	width: 48px;
	height: 48px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	color: var(--color-accent);
	background: rgba(228, 181, 75, 0.1);
	border-radius: var(--radius-md);
	margin-bottom: var(--space-md);
}

.why-card__icon svg {
	width: 28px;
	height: 28px;
}

.why-card h3 {
	font-size: 1.05rem;
	font-weight: 700;
	margin: 0 0 var(--space-sm);
	color: var(--color-primary);
}

.why-card p {
	color: var(--color-text-light);
	font-size: 0.9rem;
	line-height: 1.6;
	margin: 0;
}

/* --- Testimonials --- */

.testimonials-grid {
	display: grid;
	gap: var(--space-lg);
	grid-template-columns: 1fr;
}

@media (min-width: 768px) {
	.testimonials-grid {
		grid-template-columns: repeat(3, 1fr);
	}
}

.testimonial {
	background: var(--color-bg-alt);
	padding: var(--space-xl);
	border-radius: var(--radius-lg);
	border-left: 3px solid var(--color-accent);
	margin: 0;
	position: relative;
}

.testimonial::before {
	content: "\201C";
	position: absolute;
	top: 12px;
	right: 20px;
	font-size: 4rem;
	font-family: Georgia, serif;
	color: rgba(228, 181, 75, 0.25);
	line-height: 1;
	font-weight: 700;
}

.testimonial blockquote {
	font-size: 1rem;
	line-height: 1.7;
	color: var(--color-text);
	margin: 0 0 var(--space-md);
	position: relative;
	z-index: 1;
	font-style: italic;
}

.testimonial figcaption {
	display: flex;
	flex-direction: column;
	gap: 2px;
	border-top: 1px solid var(--color-border);
	padding-top: var(--space-md);
}

.testimonial__name {
	font-weight: 700;
	color: var(--color-primary);
	font-size: 0.95rem;
}

.testimonial__role {
	font-size: 0.8rem;
	color: var(--color-text-light);
	text-transform: uppercase;
	letter-spacing: 0.05em;
}

.testimonials-section__note {
	text-align: center;
	margin-top: var(--space-xl);
	font-size: 0.8rem;
	color: var(--color-text-light);
	font-style: italic;
}

/* --- CTA section (dark) --- */

.cta-section h2 {
	color: #ffffff;
	font-size: clamp(1.75rem, 4vw, 2.5rem);
	margin-bottom: var(--space-sm);
}

.cta-section__desc {
	color: rgba(237, 240, 245, 0.85);
	font-size: 1.1rem;
	max-width: 560px;
	margin: 0 auto;
	line-height: 1.6;
}

.cta-section__actions {
	margin-top: var(--space-xl);
}

/* --- Responsive header --- */

.site-header__mobile-toggle,
.site-header__nav-head,
.site-header__nav-overlay {
	display: none;
}

@media (max-width: 767px) {
	.site-header .container {
		gap: var(--space-sm);
		justify-content: flex-start;
	}

	/* Hamburger: stesso stile delle altre action-btn (no bordo, hover navy 6%). */
	.site-header__mobile-toggle {
		display: inline-flex;
		align-items: center;
		justify-content: center;
		width: 38px;
		height: 38px;
		background: transparent;
		border: none;
		border-radius: var(--radius-md);
		color: var(--color-primary);
		cursor: pointer;
		padding: 0;
		transition: background var(--duration) var(--ease-out);
		order: 10;
		margin: 0 0 0 auto;
	}

	.site-header__mobile-toggle:hover {
		background: rgba(20, 42, 79, 0.06);
	}

	.site-header__logo {
		flex: 0 0 auto;
		order: 0;
	}

	.site-header__actions {
		order: 11;
		margin-left: 0.4rem;
	}

	/* Nav drawer: apre da destra (coerente con hamburger a destra). */
	.site-header__nav {
		position: fixed;
		top: 0;
		right: 0;
		bottom: 0;
		left: auto;
		width: min(320px, 85vw);
		background: #ffffff;
		padding: var(--space-lg);
		transform: translate3d(100%, 0, 0);
		transition: transform 320ms cubic-bezier(0.16, 1, 0.3, 1);
		box-shadow: -24px 0 60px -20px rgba(20, 42, 79, 0.3);
		z-index: 1000;
		overflow-y: auto;
		display: flex;
		flex-direction: column;
	}

	body.is-menu-open .site-header__nav {
		transform: translate3d(0, 0, 0);
	}

	.site-header__nav-head {
		display: flex;
		align-items: center;
		justify-content: space-between;
		padding-bottom: var(--space-md);
		margin-bottom: var(--space-md);
		border-bottom: 1px solid var(--color-border);
	}

	.site-header__nav-head-title {
		font-family: var(--font-display);
		font-size: 1.15rem;
		font-weight: 700;
		color: var(--color-primary);
		letter-spacing: -0.01em;
	}

	.site-header__nav-close {
		background: transparent;
		border: none;
		color: var(--color-primary);
		cursor: pointer;
		width: 38px;
		height: 38px;
		display: inline-flex;
		align-items: center;
		justify-content: center;
		border-radius: var(--radius-sm);
	}

	.site-header__nav-close:hover {
		background: var(--color-bg-alt);
	}

	/* Lista menu dentro il drawer: items impilati, larghi, tappabili. */
	.site-header__nav ul#primary-menu,
	.site-header__nav ul.menu {
		flex-direction: column;
		gap: 0.25rem;
		align-items: stretch;
	}

	.site-header__nav ul li a {
		display: block;
		padding: 0.9rem 0.75rem;
		font-size: 1rem;
		border-radius: var(--radius-sm);
	}

	.site-header__nav ul li a::after {
		display: none;
	}

	.site-header__nav ul li a:hover,
	.site-header__nav .current-menu-item > a {
		background: var(--color-bg-alt);
	}

	/* Overlay dietro il drawer. */
	.site-header__nav-overlay {
		display: block;
		position: fixed;
		inset: 0;
		background: rgba(20, 42, 79, 0.45);
		opacity: 0;
		visibility: hidden;
		transition: opacity 280ms ease, visibility 0s linear 280ms;
		z-index: 999;
	}

	body.is-menu-open .site-header__nav-overlay {
		opacity: 1;
		visibility: visible;
		transition: opacity 280ms ease, visibility 0s linear 0s;
	}

	body.is-menu-open {
		overflow: hidden;
	}

	.site-header__logo-img {
		height: 36px;
		max-width: 160px;
	}

	.site-header__action-btn {
		width: 38px;
		height: 38px;
	}

	/* Hero trust strip → grid 3 col compatta, niente divider (occuperebbero celle) */
	.hero__trust {
		display: grid;
		grid-template-columns: repeat(3, 1fr);
		gap: 0;
		padding: var(--space-md) 0.5rem;
		border-radius: var(--radius-md);
		width: 100%;
		max-width: 420px;
	}
	.hero__trust-divider { display: none; }
	.hero__trust-item { border-right: 1px solid var(--color-border); padding: 0 0.5rem; }
	.hero__trust-item:last-child { border-right: 0; }
	.hero__trust-item strong { font-size: 1rem; }
	.hero__trust-item span { font-size: 0.62rem; letter-spacing: 0.06em; text-align: center; }

	/* iOS Safari non zooma quando font-size >= 16px sugli input. */
	input[type="text"],
	input[type="email"],
	input[type="tel"],
	input[type="number"],
	input[type="password"],
	input[type="search"],
	input[type="url"],
	input[type="date"],
	input[type="time"],
	select,
	textarea {
		font-size: 16px;
	}
}

/* ===========================================================
   Toast notifiche (add-to-cart e simili)
   =========================================================== */

.innovainm-toast-container {
	position: fixed;
	top: calc(var(--space-lg) + 64px);
	right: var(--space-lg);
	z-index: 1100;
	display: flex;
	flex-direction: column;
	gap: 0.6rem;
	pointer-events: none;
	max-width: calc(100vw - (var(--space-lg) * 2));
}

@media (max-width: 767px) {
	.innovainm-toast-container {
		top: auto;
		bottom: var(--space-lg);
		left: var(--space-md);
		right: var(--space-md);
		max-width: none;
	}
}

.innovainm-toast {
	pointer-events: auto;
	display: flex;
	align-items: flex-start;
	gap: 0.85rem;
	padding: 1rem 1.15rem;
	background: #ffffff;
	border: 1px solid var(--color-border);
	border-left: 3px solid var(--color-success, #1e9e6a);
	border-radius: var(--radius-md);
	box-shadow: 0 20px 40px -20px rgba(20, 42, 79, 0.35), 0 2px 6px -2px rgba(20, 42, 79, 0.1);
	transform: translate3d(20px, 0, 0);
	opacity: 0;
	transition: transform 420ms cubic-bezier(0.16, 1, 0.3, 1), opacity 260ms ease;
	min-width: 320px;
	max-width: 520px;
}

@media (max-width: 767px) {
	.innovainm-toast {
		transform: translate3d(0, 20px, 0);
		min-width: 0;
		max-width: none;
	}
}

.innovainm-toast.is-visible {
	transform: translate3d(0, 0, 0);
	opacity: 1;
}

.innovainm-toast__icon {
	flex: 0 0 auto;
	width: 32px;
	height: 32px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	background: color-mix(in srgb, var(--color-success, #1e9e6a) 12%, transparent);
	color: var(--color-success, #1e9e6a);
	border-radius: 50%;
}

.innovainm-toast__body {
	flex: 1 1 auto;
	min-width: 0;
	display: flex;
	flex-direction: column;
	gap: 0.1rem;
}

.innovainm-toast__title {
	font-family: var(--font-display);
	font-weight: 700;
	font-size: 0.95rem;
	color: var(--color-primary);
	line-height: 1.2;
}

.innovainm-toast__msg {
	font-size: 0.9rem;
	color: var(--color-text-light);
	line-height: 1.4;
	word-wrap: break-word;
	overflow-wrap: anywhere;
}

.innovainm-toast__actions {
	flex: 0 0 auto;
	display: flex;
	align-items: center;
	gap: 0.3rem;
}

.innovainm-toast__cta {
	padding: 0.45rem 0.85rem;
	font-size: 0.82rem;
	font-weight: 700;
	color: var(--color-primary);
	background: transparent;
	border: 1px solid var(--color-border);
	border-radius: 999px;
	cursor: pointer;
	text-decoration: none;
	white-space: nowrap;
	transition: background 160ms ease, border-color 160ms ease;
}

.innovainm-toast__cta:hover {
	background: var(--color-bg-alt);
	border-color: var(--color-primary);
}

.innovainm-toast__close {
	width: 28px;
	height: 28px;
	padding: 0;
	background: transparent;
	border: none;
	color: var(--color-text-light);
	cursor: pointer;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	border-radius: 50%;
	transition: background 160ms ease, color 160ms ease;
}

.innovainm-toast__close:hover {
	background: var(--color-bg-alt);
	color: var(--color-primary);
}

@media (prefers-reduced-motion: reduce) {
	.innovainm-toast { transition: opacity 160ms ease; transform: none; }
	.innovainm-toast.is-visible { transform: none; }
}

/* ===========================================================
   Archive /servizi/ — editorial shop layout
   =========================================================== */

.archive-shop__header {
	padding: calc(var(--space-3xl) * 0.9) 0 var(--space-2xl);
	background:
		linear-gradient(180deg, rgba(244, 246, 250, 0.6) 0%, transparent 100%),
		radial-gradient(ellipse 60% 45% at 20% 0%, rgba(20, 42, 79, 0.07) 0%, transparent 70%),
		radial-gradient(ellipse 40% 35% at 90% 15%, rgba(228, 181, 75, 0.06) 0%, transparent 70%),
		var(--color-bg);
	border-bottom: 1px solid var(--color-border);
	position: relative;
	overflow: hidden;
}

.archive-shop__header::before {
	content: "";
	position: absolute;
	left: 0;
	right: 0;
	bottom: 0;
	height: 2px;
	background: linear-gradient(90deg, transparent 0%, var(--color-accent) 20%, var(--color-primary) 50%, var(--color-accent) 80%, transparent 100%);
	opacity: 0.35;
}

.archive-shop__eyebrow {
	display: inline-block;
	font-family: var(--font-heading);
	font-size: 0.75rem;
	font-weight: 700;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: var(--color-accent-hover);
	margin-bottom: var(--space-md);
	padding: 0.3rem 0.85rem;
	background: rgba(228, 181, 75, 0.12);
	border-radius: 999px;
}

.archive-shop__title {
	font-size: clamp(2rem, 5vw, 3.25rem);
	font-weight: 800;
	letter-spacing: -0.03em;
	line-height: 1.05;
	margin: 0 0 var(--space-md);
	max-width: 820px;
}

.archive-shop__lede {
	max-width: 640px;
	color: var(--color-text-light);
	font-size: 1.05rem;
	line-height: 1.65;
	margin: 0 0 var(--space-xl);
}

.archive-shop__lede strong {
	color: var(--color-primary);
	font-weight: 700;
	font-variant-numeric: tabular-nums;
}

.archive-shop__search {
	display: flex;
	align-items: center;
	gap: var(--space-sm);
	max-width: 720px;
	padding: 0.5rem 0.5rem 0.5rem 1rem;
	background: #ffffff;
	border: 1px solid var(--color-border);
	border-radius: 999px;
	box-shadow: var(--shadow-sm);
	transition: box-shadow var(--duration) var(--ease-out), border-color var(--duration) var(--ease-out);
}

.archive-shop__search:focus-within {
	border-color: var(--color-accent);
	box-shadow: var(--shadow-md), 0 0 0 4px rgba(228, 181, 75, 0.15);
}

.archive-shop__search-icon {
	width: 20px;
	height: 20px;
	color: var(--color-text-light);
	flex-shrink: 0;
}

.archive-shop__search input[type="search"] {
	flex: 1;
	min-width: 0;
	border: none;
	outline: none;
	background: transparent;
	font-family: var(--font-sans);
	font-size: 1rem;
	color: var(--color-text);
	padding: 0.5rem 0.25rem;
}

.archive-shop__search input[type="search"]::placeholder {
	color: var(--color-text-light);
}

.archive-shop__search-submit {
	padding: 0.65rem 1.4rem;
	border-radius: 999px;
	font-size: 0.95rem;
	flex-shrink: 0;
}

/* --- Body layout --- */

.archive-shop__body {
	padding: var(--space-2xl) 0 var(--space-3xl);
	background: var(--color-bg);
}

.archive-shop__layout {
	display: grid;
	gap: var(--space-2xl);
	grid-template-columns: 1fr;
	align-items: start;
}

@media (min-width: 1024px) {
	.archive-shop__layout {
		grid-template-columns: 260px 1fr;
		gap: var(--space-3xl);
	}
}

/* --- Sidebar --- */

.archive-shop__sidebar-toggle {
	display: flex;
	align-items: center;
	justify-content: space-between;
	width: 100%;
	padding: 0.9rem 1.1rem;
	background: var(--color-bg-alt);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-md);
	color: var(--color-primary);
	font-family: var(--font-heading);
	font-weight: 700;
	font-size: 0.95rem;
	cursor: pointer;
	transition: background var(--duration) var(--ease-out);
}

.archive-shop__sidebar-toggle svg {
	width: 18px;
	height: 18px;
	transition: transform var(--duration) var(--ease-out);
}

.archive-shop__sidebar-toggle[aria-expanded="true"] svg {
	transform: rotate(180deg);
}

@media (min-width: 1024px) {
	.archive-shop__sidebar-toggle {
		display: none;
	}
}

.archive-shop__filters {
	display: none;
	margin-top: var(--space-md);
}

.archive-shop__filters.is-open {
	display: block;
}

@media (min-width: 1024px) {
	.archive-shop__filters {
		display: block;
		margin-top: 0;
		position: sticky;
		top: calc(68px + var(--space-lg));
	}
}

.filter-group {
	margin-bottom: var(--space-xl);
	padding-bottom: var(--space-lg);
	border-bottom: 1px solid var(--color-border);
}

.filter-group:last-of-type {
	border-bottom: none;
}

.filter-group--reset {
	border-bottom: none;
	padding-bottom: 0;
}

.filter-group__title {
	font-family: var(--font-heading);
	font-size: 0.75rem;
	font-weight: 700;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: var(--color-text-light);
	margin: 0 0 var(--space-md);
}

.filter-list {
	list-style: none;
	padding: 0;
	margin: 0;
}

.filter-list__item {
	display: flex;
	align-items: center;
	gap: 0.6rem;
	padding: 0.5rem 0.65rem;
	margin: 2px -0.65rem;
	border-radius: var(--radius-sm);
	color: var(--color-text);
	text-decoration: none;
	font-size: 0.93rem;
	font-weight: 500;
	line-height: 1.3;
	transition: background var(--duration) var(--ease-out), color var(--duration) var(--ease-out);
}

.filter-list__item:hover {
	background: var(--color-bg-alt);
	color: var(--color-primary);
}

.filter-list__item.is-active {
	background: linear-gradient(90deg, rgba(20, 42, 79, 0.05) 0%, rgba(228, 181, 75, 0.08) 100%);
	color: var(--color-primary);
	font-weight: 700;
	box-shadow: inset 3px 0 0 var(--hue, var(--color-accent));
	padding-left: 0.9rem;
}

.filter-list__dot {
	width: 8px;
	height: 8px;
	flex-shrink: 0;
	border-radius: 50%;
	background: var(--hue, var(--color-accent));
	opacity: 0.6;
	transition: opacity var(--duration) var(--ease-out), transform var(--duration) var(--ease-out);
}

.filter-list__item:hover .filter-list__dot,
.filter-list__item.is-active .filter-list__dot {
	opacity: 1;
	transform: scale(1.25);
}

.filter-list__label {
	flex: 1;
	min-width: 0;
}

.filter-list__count {
	font-size: 0.78rem;
	font-weight: 600;
	color: var(--color-text-light);
	background: var(--color-bg-alt);
	padding: 1px 8px;
	border-radius: 10px;
	font-variant-numeric: tabular-nums;
}

.filter-list__item.is-active .filter-list__count {
	background: var(--color-primary);
	color: #ffffff;
}

.filter-list--plain .filter-list__item {
	gap: 0;
}

.filter-reset {
	display: inline-block;
	font-size: 0.85rem;
	color: var(--color-danger);
	font-weight: 600;
	text-decoration: none;
	padding: 0.4rem 0;
	border-bottom: 1px solid transparent;
	transition: border-color var(--duration) var(--ease-out);
}

.filter-reset:hover {
	color: var(--color-danger);
	border-bottom-color: currentColor;
}

/* --- Main column --- */

.archive-shop__main {
	min-width: 0;
}

.archive-shop__toolbar {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: space-between;
	gap: var(--space-md);
	margin-bottom: var(--space-xl);
	padding-bottom: var(--space-md);
	border-bottom: 1px solid var(--color-border);
}

.archive-shop__toolbar-left {
	flex: 1;
	min-width: 0;
}

.active-filters {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 0.4rem;
}

.active-filters__label {
	font-size: 0.8rem;
	color: var(--color-text-light);
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	margin-right: 0.25rem;
}

.active-filters__chip {
	display: inline-flex;
	align-items: center;
	gap: 0.35rem;
	padding: 0.3rem 0.65rem 0.3rem 0.85rem;
	background: var(--color-primary);
	color: #ffffff;
	border-radius: 999px;
	font-size: 0.82rem;
	font-weight: 600;
	text-decoration: none;
	transition: background var(--duration) var(--ease-out);
}

.active-filters__chip:hover {
	background: var(--color-danger);
	color: #ffffff;
}

.active-filters__chip svg {
	width: 14px;
	height: 14px;
	flex: 0 0 auto;
}

/* Mobile: chip non più sulla stessa riga del label, con wrap pulito. */
@media (max-width: 767px) {
	.archive-shop__toolbar {
		align-items: stretch;
	}
	.archive-shop__toolbar-left {
		flex: 1 1 100%;
		width: 100%;
	}
	.active-filters {
		gap: 0.35rem 0.4rem;
		padding: 0.25rem 0;
	}
	.active-filters__label {
		flex: 0 0 100%;
		margin-right: 0;
		margin-bottom: 0.25rem;
		font-size: 0.72rem;
	}
	.active-filters__chip {
		padding: 0.28rem 0.55rem 0.28rem 0.75rem;
		font-size: 0.78rem;
		max-width: 100%;
		min-width: 0;
	}
	.active-filters__chip span:not([class]) {
		overflow: hidden;
		text-overflow: ellipsis;
		white-space: nowrap;
		max-width: 180px;
		display: inline-block;
	}
}

.archive-shop__orderby {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
}

.archive-shop__orderby label {
	font-size: 0.8rem;
	color: var(--color-text-light);
	text-transform: uppercase;
	letter-spacing: 0.08em;
	font-weight: 600;
}

.archive-shop__orderby select {
	font-family: var(--font-sans);
	font-size: 0.93rem;
	font-weight: 500;
	color: var(--color-text);
	background-color: #ffffff;
	border: 1px solid var(--color-border);
	border-radius: var(--radius-sm);
	padding: 0.5rem 2rem 0.5rem 0.75rem;
	appearance: none;
	-webkit-appearance: none;
	background-image: url("data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23546479' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");
	background-repeat: no-repeat;
	background-position: right 0.6rem center;
	cursor: pointer;
	transition: border-color var(--duration) var(--ease-out);
}

.archive-shop__orderby select:hover {
	border-color: var(--color-primary);
}

/* --- Service grid (cards) --- */

.service-grid {
	list-style: none;
	padding: 0;
	margin: 0;
	display: grid;
	gap: var(--space-md);
	grid-template-columns: 1fr;
}

@media (min-width: 576px) {
	.service-grid {
		grid-template-columns: repeat(2, 1fr);
	}
}

@media (min-width: 1280px) {
	.service-grid {
		grid-template-columns: repeat(3, 1fr);
	}
}

.woocommerce ul.products.service-grid {
	grid-template-columns: 1fr;
}
@media (min-width: 576px) {
	.woocommerce ul.products.service-grid {
		grid-template-columns: repeat(2, 1fr);
	}
}
@media (min-width: 1280px) {
	.woocommerce ul.products.service-grid {
		grid-template-columns: repeat(3, 1fr);
	}
}

/* Kill WC legacy float clearfix ::before / ::after — diventano grid item fantasma */
ul.service-grid::before,
ul.service-grid::after,
.woocommerce ul.products.service-grid::before,
.woocommerce ul.products.service-grid::after {
	content: none !important;
	display: none !important;
}

.woocommerce ul.products.service-grid li.product {
	width: auto !important;
	margin: 0 !important;
	float: none !important;
	clear: none !important;
}

.service-card-lite {
	list-style: none;
	background: #ffffff;
	border: 1px solid var(--color-border);
	border-radius: var(--radius-md);
	overflow: hidden;
	transition: transform var(--duration) var(--ease-out), box-shadow var(--duration) var(--ease-out), border-color var(--duration) var(--ease-out);
	position: relative;
}

.service-card-lite::before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	bottom: 0;
	width: 3px;
	background: var(--hue, var(--color-accent));
	opacity: 0;
	transform: scaleY(0.4);
	transform-origin: center;
	transition: opacity var(--duration) var(--ease-out), transform var(--duration) var(--ease-out);
}

.service-card-lite:hover {
	transform: translateY(-3px);
	border-color: color-mix(in srgb, var(--hue, #e4b54b) 45%, var(--color-border));
	box-shadow: var(--shadow-md);
}

.service-card-lite:hover::before {
	opacity: 1;
	transform: scaleY(1);
}

.service-card-lite__link {
	display: flex;
	flex-direction: column;
	gap: var(--space-md);
	padding: var(--space-lg);
	text-decoration: none;
	color: inherit;
	height: 100%;
	min-height: 190px;
}

.service-card-lite__head {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: var(--space-sm);
}

.service-card-lite__icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 40px;
	height: 40px;
	color: var(--hue, var(--color-accent));
	background: color-mix(in srgb, var(--hue, #e4b54b) 10%, #ffffff);
	border-radius: var(--radius-sm);
	flex-shrink: 0;
	transition: transform var(--duration) var(--ease-out);
}

.service-card-lite__icon svg {
	width: 24px;
	height: 24px;
}

.service-card-lite:hover .service-card-lite__icon {
	transform: rotate(-4deg) scale(1.05);
}

.service-card-lite__pill {
	font-size: 0.7rem;
	font-weight: 700;
	color: var(--hue, var(--color-accent));
	text-transform: uppercase;
	letter-spacing: 0.08em;
	padding: 3px 8px;
	background: color-mix(in srgb, var(--hue, #e4b54b) 12%, #ffffff);
	border-radius: 10px;
	max-width: 60%;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}

.service-card-lite__title {
	font-size: 1rem;
	font-weight: 700;
	line-height: 1.35;
	color: var(--color-primary);
	margin: 0;
	flex: 1;
	display: -webkit-box;
	-webkit-line-clamp: 3;
	-webkit-box-orient: vertical;
	overflow: hidden;
}

.service-card-lite__foot {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: var(--space-sm);
	padding-top: var(--space-sm);
	border-top: 1px dashed var(--color-border);
}

.service-card-lite__price {
	font-family: var(--font-heading);
	font-size: 1.2rem;
	font-weight: 800;
	color: var(--color-primary);
	letter-spacing: -0.02em;
	font-variant-numeric: tabular-nums;
}

.service-card-lite__price--quote {
	font-family: var(--font-sans);
	font-size: 0.82rem;
	font-weight: 700;
	letter-spacing: 0.04em;
	text-transform: uppercase;
	color: var(--color-accent-hover);
	background: rgba(228, 181, 75, 0.14);
	padding: 5px 10px;
	border-radius: 999px;
}

.service-card-lite__arrow {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 32px;
	height: 32px;
	color: var(--color-primary);
	background: var(--color-bg-alt);
	border-radius: 50%;
	transition: transform var(--duration) var(--ease-out), background var(--duration) var(--ease-out), color var(--duration) var(--ease-out);
}

.service-card-lite__arrow svg {
	width: 16px;
	height: 16px;
}

.service-card-lite:hover .service-card-lite__arrow {
	background: var(--color-primary);
	color: #ffffff;
	transform: translateX(3px);
}

/* --- Pagination --- */

.archive-shop__pagination {
	margin-top: var(--space-2xl);
	padding-top: var(--space-xl);
	border-top: 1px solid var(--color-border);
}

.archive-shop__pagination .woocommerce-pagination,
.archive-shop__pagination nav.woocommerce-pagination {
	text-align: center;
}

.archive-shop__pagination ul.page-numbers {
	list-style: none;
	padding: 0;
	margin: 0;
	display: inline-flex;
	gap: 0.35rem;
	flex-wrap: wrap;
	justify-content: center;
}

.archive-shop__pagination ul.page-numbers li {
	list-style: none;
	margin: 0;
	padding: 0;
}

.archive-shop__pagination ul.page-numbers li > a,
.archive-shop__pagination ul.page-numbers li > span {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 40px;
	height: 40px;
	padding: 0 0.65rem;
	border: 1px solid var(--color-border);
	border-radius: var(--radius-sm);
	color: var(--color-text);
	font-family: var(--font-heading);
	font-weight: 600;
	font-size: 0.95rem;
	text-decoration: none;
	background: #ffffff;
	transition: all var(--duration) var(--ease-out);
	box-sizing: border-box;
}

.archive-shop__pagination ul.page-numbers li > a:hover {
	border-color: var(--color-primary);
	color: var(--color-primary);
	background: var(--color-bg-alt);
	transform: translateY(-1px);
	box-shadow: var(--shadow-sm);
}

.archive-shop__pagination ul.page-numbers li > span.current {
	background: var(--color-primary);
	border-color: var(--color-primary);
	color: #ffffff;
	box-shadow: 0 2px 8px rgba(20, 42, 79, 0.18);
}

.archive-shop__pagination ul.page-numbers li > span.dots {
	border-color: transparent;
	background: transparent;
	color: var(--color-text-light);
	min-width: auto;
	padding: 0 0.35rem;
	letter-spacing: 0.1em;
}

.archive-shop__pagination ul.page-numbers li > a.prev,
.archive-shop__pagination ul.page-numbers li > a.next {
	background: var(--color-bg-alt);
	color: var(--color-primary);
	font-weight: 700;
}

.archive-shop__pagination ul.page-numbers li > a.prev:hover,
.archive-shop__pagination ul.page-numbers li > a.next:hover {
	background: var(--color-primary);
	color: #ffffff;
	border-color: var(--color-primary);
}

/* --- Empty state --- */

.archive-shop__empty {
	padding: var(--space-3xl) var(--space-lg);
	text-align: center;
	background: var(--color-bg-alt);
	border-radius: var(--radius-lg);
}

.archive-shop__empty svg {
	width: 72px;
	height: 72px;
	color: var(--color-text-light);
	margin: 0 auto var(--space-md);
}

.archive-shop__empty h2 {
	font-size: 1.5rem;
	margin: 0 0 var(--space-sm);
}

.archive-shop__empty p {
	color: var(--color-text-light);
	margin: 0 0 var(--space-lg);
}

/* ===========================================================
   Shop filter form — checkboxes, radios, loading, ajax bits
   =========================================================== */

.svz-form {
	display: contents; /* form doesn't break layout */
}

/* Filter checkbox (multi-select categoria) */

.filter-group__header {
	display: flex;
	align-items: baseline;
	justify-content: space-between;
	gap: var(--space-sm);
	margin: 0 0 var(--space-md);
}

.filter-group__header .filter-group__title {
	margin: 0;
}

.filter-group__clear {
	background: none;
	border: none;
	padding: 0;
	font-family: var(--font-sans);
	font-size: 0.75rem;
	font-weight: 600;
	color: var(--color-danger);
	cursor: pointer;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	transition: color var(--duration) var(--ease-out);
}

.filter-group__clear:hover {
	color: var(--color-danger-light);
	text-decoration: underline;
}

.filter-group__clear.is-hidden,
.svz-js .is-hidden {
	display: none;
}

.filter-check {
	display: flex;
	align-items: center;
	gap: 0.6rem;
	padding: 0.45rem 0.6rem;
	margin: 2px -0.6rem;
	border-radius: var(--radius-sm);
	cursor: pointer;
	font-size: 0.93rem;
	font-weight: 500;
	line-height: 1.3;
	color: var(--color-text);
	transition: background var(--duration) var(--ease-out), color var(--duration) var(--ease-out);
	position: relative;
}

.filter-check:hover {
	background: var(--color-bg-alt);
	color: var(--color-primary);
}

.filter-check input[type="checkbox"] {
	position: absolute;
	opacity: 0;
	pointer-events: none;
}

.filter-check__box {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 18px;
	height: 18px;
	flex-shrink: 0;
	border: 1.5px solid var(--color-border);
	border-radius: 4px;
	background: #ffffff;
	color: #ffffff;
	transition: all var(--duration) var(--ease-out);
}

.filter-check__box svg {
	width: 14px;
	height: 14px;
	opacity: 0;
	transform: scale(0.5);
	transition: all var(--duration) var(--ease-out);
}

.filter-check input[type="checkbox"]:focus-visible + .filter-check__box {
	outline: 2px solid var(--color-accent);
	outline-offset: 2px;
}

.filter-check.is-active {
	background: linear-gradient(90deg, rgba(20, 42, 79, 0.05) 0%, rgba(228, 181, 75, 0.06) 100%);
	color: var(--color-primary);
	font-weight: 700;
	box-shadow: inset 3px 0 0 var(--hue, var(--color-accent));
	padding-left: 0.85rem;
}

.filter-check.is-active .filter-check__box {
	background: var(--hue, var(--color-primary));
	border-color: var(--hue, var(--color-primary));
}

.filter-check.is-active .filter-check__box svg {
	opacity: 1;
	transform: scale(1);
}

.filter-check__label {
	flex: 1;
	min-width: 0;
	text-overflow: ellipsis;
	overflow: hidden;
}

.filter-check__count {
	font-size: 0.78rem;
	font-weight: 600;
	color: var(--color-text-light);
	background: var(--color-bg-alt);
	padding: 1px 8px;
	border-radius: 10px;
	font-variant-numeric: tabular-nums;
	transition: all var(--duration) var(--ease-out);
}

.filter-check.is-active .filter-check__count {
	background: var(--color-primary);
	color: #ffffff;
}

/* Radio (quote_only) */

.filter-radio {
	display: flex;
	align-items: center;
	gap: 0.65rem;
	padding: 0.45rem 0.6rem;
	margin: 2px -0.6rem;
	border-radius: var(--radius-sm);
	cursor: pointer;
	font-size: 0.93rem;
	font-weight: 500;
	line-height: 1.3;
	color: var(--color-text);
	transition: background var(--duration) var(--ease-out), color var(--duration) var(--ease-out);
	position: relative;
}

.filter-radio:hover {
	background: var(--color-bg-alt);
	color: var(--color-primary);
}

.filter-radio input[type="radio"] {
	position: absolute;
	opacity: 0;
	pointer-events: none;
}

.filter-radio__dot {
	position: relative;
	width: 16px;
	height: 16px;
	border: 1.5px solid var(--color-border);
	border-radius: 50%;
	background: #ffffff;
	flex-shrink: 0;
	transition: all var(--duration) var(--ease-out);
}

.filter-radio__dot::after {
	content: "";
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%) scale(0);
	width: 8px;
	height: 8px;
	background: var(--color-primary);
	border-radius: 50%;
	transition: transform var(--duration) var(--ease-out);
}

.filter-radio input[type="radio"]:checked + .filter-radio__dot {
	border-color: var(--color-primary);
}

.filter-radio input[type="radio"]:checked + .filter-radio__dot::after {
	transform: translate(-50%, -50%) scale(1);
}

.filter-radio input[type="radio"]:focus-visible + .filter-radio__dot {
	outline: 2px solid var(--color-accent);
	outline-offset: 2px;
}

/* Submit / apply — hidden when JS on (auto-submit handles it) */

.filter-apply {
	display: block;
	width: 100%;
	margin-top: var(--space-sm);
	padding: 0.7rem 1rem;
}

.svz-js .filter-apply {
	display: none;
}

/* Filter reset button */

.filter-group--reset {
	display: flex;
	flex-direction: column;
	gap: var(--space-sm);
	align-items: flex-start;
	border-bottom: none;
	padding-bottom: 0;
}

button.filter-reset {
	background: none;
	border: none;
	padding: 0.4rem 0;
	font-family: var(--font-sans);
	font-size: 0.85rem;
	font-weight: 600;
	color: var(--color-danger);
	cursor: pointer;
	border-bottom: 1px solid transparent;
	transition: border-color var(--duration) var(--ease-out);
}

button.filter-reset:hover {
	border-bottom-color: currentColor;
}

/* Search bar — spinner and submit button responsive */

.archive-shop__search {
	position: relative;
}

.archive-shop__search-spinner {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 22px;
	height: 22px;
	color: var(--color-accent);
	opacity: 0;
	transition: opacity 0.2s var(--ease-out);
	flex-shrink: 0;
}

.archive-shop__search-spinner.is-active {
	opacity: 1;
}

.archive-shop__search-spinner svg {
	width: 20px;
	height: 20px;
	animation: svz-spin 0.8s linear infinite;
}

@keyframes svz-spin {
	to { transform: rotate(360deg); }
}

.svz-js .archive-shop__search-submit {
	display: none;
}

@media (max-width: 576px) {
	.archive-shop__search-submit {
		padding: 0.55rem 1rem;
		font-size: 0.9rem;
	}
}

/* Results region — loading state */

.archive-shop__results {
	position: relative;
	min-height: 300px;
	transition: opacity 0.2s var(--ease-out);
}

.archive-shop__results.is-loading {
	opacity: 0.55;
	pointer-events: none;
}

.archive-shop__results.is-loading::before {
	content: "";
	position: absolute;
	top: 20px;
	left: 50%;
	transform: translateX(-50%);
	width: 36px;
	height: 36px;
	border: 3px solid rgba(20, 42, 79, 0.15);
	border-top-color: var(--color-accent);
	border-radius: 50%;
	animation: svz-spin 0.8s linear infinite;
	z-index: 5;
}

/* Staggered entrance animation for grid cards */

@media (prefers-reduced-motion: no-preference) {
	.service-grid .service-card-lite {
		animation: svz-card-in 0.4s var(--ease-out) both;
	}
	.service-grid .service-card-lite:nth-child(1)  { animation-delay: 0.00s; }
	.service-grid .service-card-lite:nth-child(2)  { animation-delay: 0.03s; }
	.service-grid .service-card-lite:nth-child(3)  { animation-delay: 0.06s; }
	.service-grid .service-card-lite:nth-child(4)  { animation-delay: 0.09s; }
	.service-grid .service-card-lite:nth-child(5)  { animation-delay: 0.12s; }
	.service-grid .service-card-lite:nth-child(6)  { animation-delay: 0.15s; }
	.service-grid .service-card-lite:nth-child(7)  { animation-delay: 0.18s; }
	.service-grid .service-card-lite:nth-child(8)  { animation-delay: 0.21s; }
	.service-grid .service-card-lite:nth-child(9)  { animation-delay: 0.24s; }
	.service-grid .service-card-lite:nth-child(n+10) { animation-delay: 0.27s; }
}

@keyframes svz-card-in {
	from { opacity: 0; transform: translateY(6px); }
	to   { opacity: 1; transform: translateY(0); }
}


/* ===========================================================
   Breadcrumb
   =========================================================== */

.breadcrumb {
	background: var(--color-bg-alt);
	border-bottom: 1px solid var(--color-border);
	font-size: 0.82rem;
}

.breadcrumb .container {
	padding-top: 0.65rem;
	padding-bottom: 0.65rem;
}

.breadcrumb__list {
	list-style: none;
	padding: 0;
	margin: 0;
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 0.3rem 0.25rem;
}

.breadcrumb__item {
	display: inline-flex;
	align-items: center;
	gap: 0.25rem;
	min-width: 0;
}

.breadcrumb__link {
	color: var(--color-text-light);
	text-decoration: none;
	font-weight: 500;
	transition: color var(--duration) var(--ease-out);
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
	max-width: 220px;
}

.breadcrumb__link:hover {
	color: var(--color-primary);
}

.breadcrumb__current {
	color: var(--color-primary);
	font-weight: 600;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
	max-width: 340px;
}

.breadcrumb__sep {
	width: 12px;
	height: 12px;
	color: var(--color-border);
	flex-shrink: 0;
}

@media (max-width: 576px) {
	.breadcrumb__link { max-width: 110px; }
	.breadcrumb__current { max-width: 180px; }
}

/* ===========================================================
   Single product (scheda servizio)
   =========================================================== */

.service-single {
	padding-bottom: var(--space-3xl);
}

.service-single__hero {
	background:
		radial-gradient(ellipse 50% 40% at 15% 0%, color-mix(in srgb, var(--hue) 10%, transparent) 0%, transparent 70%),
		radial-gradient(ellipse 40% 35% at 95% 20%, rgba(228, 181, 75, 0.05) 0%, transparent 70%),
		var(--color-bg);
	border-bottom: 1px solid var(--color-border);
	padding: var(--space-2xl) 0 var(--space-xl);
	position: relative;
}

.service-single__hero::after {
	content: "";
	position: absolute;
	left: 0;
	right: 0;
	bottom: -1px;
	height: 3px;
	background: linear-gradient(90deg, transparent, var(--hue) 50%, transparent);
	opacity: 0.4;
}

.service-single__hero-inner {
	max-width: var(--container-max);
	margin: 0 auto;
	padding: 0 var(--container-padding);
}

.service-single__kicker {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	padding: 0.35rem 0.85rem 0.35rem 0.55rem;
	background: color-mix(in srgb, var(--hue) 12%, #ffffff);
	color: var(--hue);
	border-radius: 999px;
	text-decoration: none;
	font-weight: 700;
	font-size: 0.78rem;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	transition: all var(--duration) var(--ease-out);
	margin-bottom: var(--space-md);
}

.service-single__kicker:hover {
	background: color-mix(in srgb, var(--hue) 20%, #ffffff);
	color: var(--hue);
	transform: translateY(-1px);
}

.service-single__kicker-icon svg {
	width: 16px;
	height: 16px;
}

.service-single__title {
	font-size: clamp(1.9rem, 4.5vw, 3rem);
	font-weight: 800;
	letter-spacing: -0.025em;
	line-height: 1.1;
	color: var(--color-primary);
	margin: 0 0 var(--space-md);
	max-width: 900px;
}

.service-single__lede {
	font-size: 1.1rem;
	line-height: 1.65;
	color: var(--color-text-light);
	max-width: 720px;
}

/* ===== Hero split: titolo a sx + purchase card a dx (solo acquistabili) ===== */

.service-single__hero--split {
	padding-bottom: var(--space-2xl);
}

.service-single__hero-inner--split {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--space-xl);
	align-items: start;
}

.service-single__hero-text {
	min-width: 0;
}

.service-single__hero--split .service-single__title {
	max-width: none;
}

@media (min-width: 960px) {
	.service-single__hero-inner--split {
		grid-template-columns: minmax(0, 1fr) minmax(340px, 420px);
		gap: var(--space-2xl);
	}
	.service-single__hero--split .service-single__title {
		font-size: clamp(1.75rem, 3vw, 2.4rem);
	}
}

.service-single__hero-buy {
	min-width: 0;
}

/* Variante compatta della price card: sta bene in col stretta nell'hero. */
.service-single__price-card--compact {
	max-width: none;
	padding: var(--space-lg);
}

@media (min-width: 640px) {
	.service-single__price-card--compact { padding: var(--space-xl); }
}

.service-single__price-card--compact .service-single__price-amount {
	margin-top: var(--space-md);
	padding-top: var(--space-md);
	border-top: 1px solid var(--color-border);
}

.service-single__price-card--compact .service-single__price-amount .service-single__price-value {
	font-size: clamp(1.75rem, 3.5vw, 2.25rem);
	margin: 0.2rem 0;
}

.service-single__price-card--compact .service-single__price-cta {
	margin-top: var(--space-md);
}

.service-single__price-card--compact .service-single__price-cta form.cart {
	display: flex;
	align-items: stretch;
	gap: 0.65rem;
	flex-wrap: nowrap;
	width: 100%;
}

.service-single__price-card--compact .service-single__price-cta .quantity {
	flex: 0 0 auto;
}

.service-single__price-card--compact .service-single__price-cta .single_add_to_cart_button {
	flex: 1 1 auto;
	justify-content: center;
}

/* ===== Payment gateways icons (WC dinamico) ===== */

.service-single__payments {
	margin-top: var(--space-md);
	padding-top: var(--space-md);
	border-top: 1px solid var(--color-border);
}

.service-single__payments-label {
	display: block;
	font-size: 0.7rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.12em;
	color: var(--color-text-light);
	margin-bottom: 0.55rem;
}

.service-single__payments-list {
	display: flex;
	align-items: center;
	flex-wrap: wrap;
	gap: 0.5rem;
	list-style: none;
	margin: 0;
	padding: 0;
}

.service-single__payments-item {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 26px;
	padding: 3px 6px;
	background: #fff;
	border: 1px solid var(--color-border);
	border-radius: 6px;
	line-height: 0;
}

.service-single__payments-item img {
	max-height: 20px;
	width: auto;
	display: block;
	object-fit: contain;
}

.service-single__payments-fallback {
	font-size: 0.72rem;
	font-weight: 600;
	color: var(--color-text-light);
	line-height: 1.2;
	padding: 0 2px;
}

.service-single__price-card--compact .service-single__price-trust {
	margin-top: var(--space-md);
	padding-top: var(--space-md);
	border-top: 1px solid var(--color-border);
	grid-template-columns: 1fr;
}

/* Layout */

.service-single__layout {
	max-width: var(--container-max);
	margin: 0 auto;
	padding: var(--space-2xl) var(--container-padding) 0;
	display: grid;
	gap: var(--space-2xl);
	grid-template-columns: 1fr;
	align-items: start;
}

@media (min-width: 1024px) {
	.service-single__layout {
		grid-template-columns: minmax(0, 1fr) 360px;
		gap: var(--space-3xl);
	}
}

/* Main content */

.service-single__main {
	min-width: 0;
}

.service-single__section {
	margin-bottom: var(--space-2xl);
	padding-bottom: var(--space-2xl);
	border-bottom: 1px solid var(--color-border);
}

.service-single__section:last-child {
	border-bottom: none;
	padding-bottom: 0;
}

.service-single__section-title {
	font-size: clamp(1.25rem, 2.5vw, 1.6rem);
	font-weight: 700;
	letter-spacing: -0.015em;
	color: var(--color-primary);
	margin: 0 0 var(--space-lg);
	position: relative;
	padding-left: var(--space-md);
}

.service-single__section-title::before {
	content: "";
	position: absolute;
	left: 0;
	top: 0.3em;
	bottom: 0.3em;
	width: 3px;
	border-radius: 2px;
	background: var(--hue);
}

.service-single__prose {
	font-size: 1.02rem;
	line-height: 1.75;
	color: var(--color-text);
}

.service-single__prose p { margin: 0 0 1em; }
.service-single__prose p:last-child { margin-bottom: 0; }
.service-single__prose h2,
.service-single__prose h3 {
	margin-top: 1.5em;
	margin-bottom: 0.5em;
}
.service-single__prose ul,
.service-single__prose ol {
	padding-left: 1.25rem;
	margin: 0 0 1em;
}
.service-single__prose li + li {
	margin-top: 0.35em;
}
.service-single__prose a {
	color: var(--color-primary);
	border-bottom: 1px solid var(--color-accent);
}
.service-single__prose a:hover {
	color: var(--color-accent-hover);
}

/* Documenti richiesti */

.service-docs {
	list-style: none;
	padding: 0;
	margin: 0;
	display: grid;
	gap: 0.5rem;
	grid-template-columns: 1fr;
}

@media (min-width: 576px) {
	.service-docs { grid-template-columns: repeat(2, 1fr); }
}

.service-docs li {
	display: flex;
	align-items: center;
	gap: 0.65rem;
	padding: 0.7rem 0.9rem;
	background: var(--color-bg-alt);
	border-left: 3px solid var(--hue);
	border-radius: var(--radius-sm);
	font-size: 0.93rem;
	font-weight: 500;
	color: var(--color-text);
}

.service-docs li svg {
	width: 18px;
	height: 18px;
	flex-shrink: 0;
	color: var(--hue);
}

/* Sidebar card */

.service-single__aside {
	min-width: 0;
}

@media (min-width: 1024px) {
	.service-single__card {
		position: sticky;
		top: calc(68px + var(--space-md));
	}
}

.service-single__card {
	background: #ffffff;
	border: 1px solid var(--color-border);
	border-radius: var(--radius-lg);
	padding: var(--space-xl);
	box-shadow: var(--shadow-md);
	position: relative;
	overflow: hidden;
}

.service-single__card::before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	height: 4px;
	background: linear-gradient(90deg, var(--hue), color-mix(in srgb, var(--hue) 60%, var(--color-accent)));
}

.service-single__price-block {
	margin-bottom: var(--space-lg);
	text-align: left;
}

.service-single__price-label {
	display: block;
	font-size: 0.72rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.12em;
	color: var(--color-text-light);
	margin-bottom: var(--space-xs);
}

.service-single__price-value {
	display: block;
	font-family: var(--font-heading);
	font-size: 2.25rem;
	font-weight: 800;
	color: var(--color-primary);
	letter-spacing: -0.025em;
	line-height: 1.1;
	font-variant-numeric: tabular-nums;
}

.service-single__price-value .woocommerce-Price-currencySymbol {
	font-size: 0.8em;
	opacity: 0.75;
	margin-right: 2px;
}

.service-single__price-value--quote {
	font-size: 1.7rem;
	color: var(--color-accent-hover);
	letter-spacing: -0.01em;
}

.service-single__price-hint {
	margin: var(--space-xs) 0 0;
	font-size: 0.82rem;
	color: var(--color-text-light);
	line-height: 1.5;
}

.service-single__cta {
	display: flex;
	width: 100%;
	justify-content: center;
	gap: 0.5rem;
	margin-bottom: var(--space-lg);
}

.service-single__cta svg {
	width: 18px;
	height: 18px;
	transition: transform var(--duration) var(--ease-out);
}

.service-single__cta:hover svg {
	transform: translateX(3px);
}

.service-single__add-to-cart {
	margin-bottom: var(--space-lg);
}

.service-single__add-to-cart form.cart {
	display: flex;
	flex-direction: column;
	gap: var(--space-sm);
	margin: 0;
}

.service-single__add-to-cart .quantity {
	display: inline-flex;
	align-items: center;
	gap: 0.35rem;
	margin: 0;
}

.service-single__add-to-cart .quantity::before {
	content: "Quantità";
	font-size: 0.72rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.12em;
	color: var(--color-text-light);
	margin-right: 0.5rem;
}

.service-single__add-to-cart .quantity input.qty,
.service-single__add-to-cart input[type="number"].qty {
	width: 70px;
	padding: 0.55rem 0.65rem;
	text-align: center;
	font-family: var(--font-heading);
	font-size: 1rem;
	font-weight: 700;
	color: var(--color-primary);
	background: #ffffff;
	border: 1.5px solid var(--color-border);
	border-radius: var(--radius-sm);
	transition: border-color var(--duration) var(--ease-out), box-shadow var(--duration) var(--ease-out);
	appearance: textfield;
	-moz-appearance: textfield;
}

.service-single__add-to-cart .quantity input.qty:focus {
	outline: none;
	border-color: var(--color-accent);
	box-shadow: 0 0 0 4px rgba(228, 181, 75, 0.15);
}

/* Override WC + Gutenberg purple default */
.service-single__add-to-cart .single_add_to_cart_button,
.service-single button.single_add_to_cart_button,
.woocommerce-page .service-single__add-to-cart .single_add_to_cart_button {
	width: 100%;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 0.95rem 1.5rem !important;
	border: none !important;
	border-radius: var(--radius-md) !important;
	font-family: var(--font-sans) !important;
	font-size: 1rem !important;
	font-weight: 700 !important;
	line-height: 1 !important;
	text-transform: none !important;
	letter-spacing: 0 !important;
	background: linear-gradient(135deg, var(--color-accent-light) 0%, var(--color-accent) 50%, var(--color-accent-hover) 100%) !important;
	background-size: 200% 200% !important;
	background-position: 50% 50% !important;
	color: var(--color-primary) !important;
	box-shadow: var(--shadow-sm), 0 2px 8px rgba(228, 181, 75, 0.25) !important;
	transition: all var(--duration) var(--ease-out) !important;
	cursor: pointer;
}

.service-single__add-to-cart .single_add_to_cart_button:hover,
.service-single button.single_add_to_cart_button:hover {
	background-position: 100% 100% !important;
	transform: translateY(-1px) !important;
	box-shadow: var(--shadow-md), var(--shadow-accent) !important;
	color: var(--color-primary) !important;
}

.service-single__add-to-cart .single_add_to_cart_button:active {
	transform: translateY(0) !important;
}

/* Le notice WC flash vengono convertite in toast dal JS ui-enhance al page
   load. Eccezione: le info dentro .woocommerce-form-coupon-toggle (e login)
   NON sono flash ma UI persistenti WC (link toggle form) — restano visibili
   e le stiliamo col brand qui sotto. */
html.js .woocommerce-notices-wrapper,
html.js .woocommerce-message,
html.js .woocommerce-info,
html.js .woocommerce-error,
html.js .added_to_cart {
	display: none !important;
}

/* Coupon / login toggle banner: versione brandata compatta.
   Override della regola hide sopra con specificity maggiore. */
html.js .woocommerce-form-coupon-toggle .woocommerce-info,
html.js .woocommerce-form-login-toggle .woocommerce-info,
.woocommerce-form-coupon-toggle .woocommerce-info,
.woocommerce-form-login-toggle .woocommerce-info {
	display: flex !important;
	align-items: center;
	gap: 0.75rem;
	padding: 0.85rem 1.1rem;
	margin: 0 0 var(--space-lg);
	background: rgba(228, 181, 75, 0.08);
	border: 1px solid rgba(228, 181, 75, 0.4);
	border-left: 3px solid var(--color-accent);
	border-radius: var(--radius-md);
	color: var(--color-primary);
	font-size: 0.92rem;
	line-height: 1.4;
	list-style: none;
}

.woocommerce-form-coupon-toggle .woocommerce-info::before,
.woocommerce-form-login-toggle .woocommerce-info::before {
	content: "";
	flex: 0 0 auto;
	width: 22px;
	height: 22px;
	background: var(--color-accent);
	-webkit-mask: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><path d='M20.59 13.41l-7.17 7.17a2 2 0 0 1-2.83 0L2 12V2h10l8.59 8.59a2 2 0 0 1 0 2.82z'/><line x1='7' y1='7' x2='7.01' y2='7'/></svg>") center / 18px no-repeat;
	mask: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><path d='M20.59 13.41l-7.17 7.17a2 2 0 0 1-2.83 0L2 12V2h10l8.59 8.59a2 2 0 0 1 0 2.82z'/><line x1='7' y1='7' x2='7.01' y2='7'/></svg>") center / 18px no-repeat;
}

.woocommerce-form-coupon-toggle .woocommerce-info a.showcoupon,
.woocommerce-form-login-toggle .woocommerce-info a.showlogin {
	color: var(--color-primary);
	font-weight: 700;
	text-decoration: underline;
	text-underline-offset: 3px;
	cursor: pointer;
}

.woocommerce-form-coupon-toggle .woocommerce-info a.showcoupon:hover,
.woocommerce-form-login-toggle .woocommerce-info a.showlogin:hover {
	color: var(--color-accent);
}

/* Meta list */

.service-single__meta {
	list-style: none;
	padding: var(--space-md) 0 0;
	margin: 0;
	border-top: 1px solid var(--color-border);
	display: flex;
	flex-direction: column;
	gap: var(--space-md);
}

.service-single__meta li {
	display: flex;
	align-items: flex-start;
	gap: 0.65rem;
}

.service-single__meta-icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 32px;
	height: 32px;
	flex-shrink: 0;
	background: color-mix(in srgb, var(--hue) 10%, #ffffff);
	color: var(--hue);
	border-radius: var(--radius-sm);
}

.service-single__meta-icon svg {
	width: 18px;
	height: 18px;
}

.service-single__meta-text {
	display: flex;
	flex-direction: column;
	gap: 1px;
	min-width: 0;
}

.service-single__meta-label {
	font-size: 0.72rem;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	color: var(--color-text-light);
	font-weight: 600;
}

.service-single__meta-value {
	font-size: 0.93rem;
	font-weight: 600;
	color: var(--color-primary);
}

/* Trust strip */

.service-single__trust {
	margin-top: var(--space-lg);
	padding-top: var(--space-md);
	border-top: 1px solid var(--color-border);
	display: flex;
	flex-wrap: wrap;
	gap: var(--space-sm);
	justify-content: space-between;
}

.service-single__trust-item {
	display: inline-flex;
	align-items: center;
	gap: 0.35rem;
	font-size: 0.78rem;
	font-weight: 600;
	color: var(--color-text-light);
}

.service-single__trust-item svg {
	width: 14px;
	height: 14px;
	color: var(--color-accent);
}

/* ===========================================================
   Quote form
   =========================================================== */

.service-single__section--form {
	background: var(--color-bg-alt);
	padding: var(--space-xl);
	border-radius: var(--radius-lg);
	border: 1px solid var(--color-border);
	margin-top: var(--space-xl);
}

.service-single__form-lede {
	color: var(--color-text-light);
	margin-bottom: var(--space-lg);
	max-width: 680px;
	line-height: 1.6;
}

/* ===== Quote-only layout: purchase zone above the fold ===== */

.service-single__purchase {
	max-width: var(--container-max);
	margin: 0 auto;
	padding: var(--space-2xl) var(--container-padding) 0;
	display: block;
}

.service-single__purchase-main {
	width: 100%;
}

.service-single__form-card {
	background: #fff;
	border-radius: var(--radius-lg);
	border: 1px solid var(--color-border);
	box-shadow: 0 24px 60px -30px rgba(20, 42, 79, 0.28), 0 2px 6px -2px rgba(20, 42, 79, 0.08);
	padding: var(--space-xl);
	position: relative;
	overflow: hidden;
	max-width: 1040px;
	margin: 0 auto;
}

.service-single__form-card::before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	height: 3px;
	background: linear-gradient(90deg, var(--color-primary) 0%, var(--color-accent) 100%);
}

@media (min-width: 640px) {
	.service-single__form-card { padding: var(--space-2xl); }
}

.service-single__form-head {
	margin-bottom: var(--space-lg);
	padding-bottom: var(--space-lg);
	border-bottom: 1px solid var(--color-border);
}

.service-single__form-eyebrow {
	display: inline-block;
	font-size: 0.72rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.14em;
	color: var(--color-accent);
	background: rgba(228, 181, 75, 0.12);
	padding: 0.35rem 0.75rem;
	border-radius: 999px;
	margin-bottom: var(--space-sm);
}

/* Variante "Acquisto online": stessa forma ma palette navy invece di oro. */
.service-single__form-eyebrow--buy {
	color: var(--color-primary);
	background: rgba(20, 42, 79, 0.08);
}

/* Price card: analogo visivo del form-card per i servizi acquistabili. */
.service-single__price-card {
	background: #fff;
	border-radius: var(--radius-lg);
	border: 1px solid var(--color-border);
	box-shadow: 0 24px 60px -30px rgba(20, 42, 79, 0.28), 0 2px 6px -2px rgba(20, 42, 79, 0.08);
	padding: var(--space-xl);
	position: relative;
	overflow: hidden;
	max-width: 1040px;
	margin: 0 auto;
}

.service-single__price-card::before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	height: 3px;
	background: linear-gradient(90deg, var(--color-primary) 0%, var(--color-accent) 100%);
}

@media (min-width: 640px) {
	.service-single__price-card { padding: var(--space-2xl); }
}

.service-single__price-row {
	display: flex;
	flex-direction: column;
	gap: var(--space-lg);
	padding-top: var(--space-lg);
	margin-top: var(--space-md);
}

/* Mostra il separatore solo se sotto c'è la trust row */
.service-single__price-card:has(.service-single__price-trust) .service-single__price-row {
	padding-bottom: var(--space-lg);
	margin-bottom: var(--space-lg);
	border-bottom: 1px solid var(--color-border);
}

@media (min-width: 720px) {
	.service-single__price-row {
		flex-direction: row;
		align-items: center;
		justify-content: space-between;
		gap: var(--space-xl);
	}
}

.service-single__price-amount {
	display: flex;
	flex-direction: column;
	gap: 0.25rem;
}

.service-single__price-amount .service-single__price-label {
	font-size: 0.72rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	color: var(--color-text-light);
}

.service-single__price-amount .service-single__price-value {
	font-family: var(--font-display);
	font-size: clamp(2rem, 4vw, 2.75rem);
	font-weight: 700;
	color: var(--color-primary);
	line-height: 1;
	letter-spacing: -0.02em;
}

.service-single__price-amount .service-single__price-hint {
	font-size: 0.82rem;
	color: var(--color-text-light);
}

.service-single__price-cta {
	flex: 0 0 auto;
}

.service-single__price-cta form.cart {
	display: flex;
	align-items: center;
	gap: 0.75rem;
	flex-wrap: wrap;
}

.service-single__price-cta .quantity input.qty {
	width: 72px;
	padding: 0.75rem;
	border: 1px solid var(--color-border);
	border-radius: var(--radius-md);
	font-size: 1rem;
	text-align: center;
}

.service-single__price-cta .single_add_to_cart_button {
	padding: 1rem 1.75rem;
	font-size: 1rem;
	font-weight: 700;
	background: var(--color-primary);
	color: #fff;
	border: none;
	border-radius: var(--radius-md);
	cursor: pointer;
	transition: transform 160ms ease, box-shadow 200ms ease, background 160ms ease;
	box-shadow: 0 12px 30px -12px rgba(20, 42, 79, 0.4);
}

.service-single__price-cta .single_add_to_cart_button:hover {
	background: #1a3563;
	transform: translateY(-1px);
	box-shadow: 0 18px 40px -12px rgba(20, 42, 79, 0.5);
}

.service-single__price-trust {
	list-style: none;
	margin: 0;
	padding: 0;
	display: grid;
	grid-template-columns: 1fr;
	gap: 0.6rem;
}

@media (min-width: 640px) {
	.service-single__price-trust { grid-template-columns: repeat(2, 1fr); }
}

@media (min-width: 960px) {
	.service-single__price-trust { grid-template-columns: repeat(3, 1fr); }
}

.service-single__price-trust li {
	display: flex;
	align-items: center;
	gap: 0.55rem;
	font-size: 0.88rem;
	color: var(--color-text-light);
}

.service-single__price-trust li svg {
	width: 18px;
	height: 18px;
	flex: 0 0 auto;
	color: var(--color-accent);
}

/* ===== Floating buy bar: appare quando la price card esce dal viewport ===== */

.service-floating-buy {
	position: fixed;
	left: 0;
	right: 0;
	bottom: 0;
	z-index: 950;
	transform: translate3d(0, 110%, 0);
	opacity: 0;
	visibility: hidden;
	pointer-events: none;
	transition:
		transform 520ms cubic-bezier(0.16, 1, 0.3, 1),
		opacity 320ms ease,
		visibility 0s linear 520ms;
	background: rgba(255, 255, 255, 0.96);
	backdrop-filter: saturate(140%) blur(12px);
	-webkit-backdrop-filter: saturate(140%) blur(12px);
	border-top: 1px solid rgba(20, 42, 79, 0.08);
	box-shadow: 0 -18px 40px -20px rgba(20, 42, 79, 0.22);
}

.service-floating-buy.is-visible {
	transform: translate3d(0, 0, 0);
	opacity: 1;
	visibility: visible;
	pointer-events: auto;
	transition:
		transform 520ms cubic-bezier(0.16, 1, 0.3, 1),
		opacity 320ms ease,
		visibility 0s linear 0s;
}

.service-floating-buy__inner {
	max-width: var(--container-max);
	margin: 0 auto;
	padding: 0.75rem var(--container-padding);
	display: flex;
	align-items: center;
	gap: 1rem;
}

.service-floating-buy__info {
	flex: 1 1 auto;
	min-width: 0;
	display: flex;
	flex-direction: column;
	gap: 0.15rem;
}

.service-floating-buy__kicker {
	display: inline-flex;
	align-items: center;
	gap: 0.35rem;
	font-size: 0.7rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	color: var(--hue, var(--color-accent));
	white-space: nowrap;
}

.service-floating-buy__kicker svg {
	width: 12px;
	height: 12px;
	flex: 0 0 auto;
}

.service-floating-buy__name {
	font-family: var(--font-display);
	font-size: 1rem;
	font-weight: 700;
	color: var(--color-primary);
	line-height: 1.2;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}

.service-floating-buy__price {
	font-family: var(--font-display);
	font-size: 1.15rem;
	font-weight: 700;
	color: var(--color-primary);
	white-space: nowrap;
	letter-spacing: -0.01em;
}

.service-floating-buy__price .woocommerce-Price-currencySymbol {
	font-weight: 500;
	opacity: 0.7;
	margin-right: 0.1rem;
}

.service-floating-buy__form {
	flex: 0 0 auto;
	margin: 0;
}

.service-floating-buy__form button {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	padding: 0.75rem 1.25rem;
	background: var(--color-primary);
	color: #fff;
	border: none;
	border-radius: 999px;
	font-size: 0.9rem;
	font-weight: 700;
	cursor: pointer;
	transition: transform 160ms ease, background 160ms ease, box-shadow 200ms ease;
	box-shadow: 0 10px 24px -10px rgba(20, 42, 79, 0.5);
}

.service-floating-buy__form button:hover {
	background: #1a3563;
	transform: translateY(-1px);
	box-shadow: 0 14px 30px -10px rgba(20, 42, 79, 0.6);
}

.service-floating-buy__form button svg {
	transition: transform 200ms ease;
}

.service-floating-buy__form button:hover svg {
	transform: translateX(3px);
}

/* Mobile: sticky bar = sola decisione d'acquisto. Categoria e titolo sono
   già sopra nella pagina, qui sono rumore. Restano prezzo + azione. */
@media (max-width: 640px) {
	.service-floating-buy__inner {
		gap: 0.85rem;
		padding: 0.7rem var(--container-padding);
		padding-bottom: max(0.7rem, env(safe-area-inset-bottom));
	}
	.service-floating-buy__kicker,
	.service-floating-buy__name {
		display: none;
	}
	.service-floating-buy__info {
		flex: 0 0 auto;
	}
	.service-floating-buy__price {
		display: block;
		font-size: 1.2rem;
	}
	.service-floating-buy__form {
		flex: 1 1 auto;
	}
	.service-floating-buy__form button {
		width: 100%;
		justify-content: center;
		padding: 0.85rem 1rem;
		font-size: 0.95rem;
		min-height: 50px;
	}
}

/* Lascia spazio al fondo pagina così il contenuto non resta nascosto sotto */
body.has-floating-buy {
	padding-bottom: 72px;
}

@media (max-width: 640px) {
	body.has-floating-buy {
		padding-bottom: calc(66px + env(safe-area-inset-bottom));
	}
}

@media (prefers-reduced-motion: reduce) {
	.service-floating-buy {
		transition: opacity 160ms ease, visibility 0s linear 160ms;
		transform: none;
	}
	.service-floating-buy.is-visible {
		transition: opacity 160ms ease, visibility 0s;
	}
}

.service-single__form-title {
	font-family: var(--font-display);
	font-size: clamp(1.5rem, 2.4vw, 1.9rem);
	line-height: 1.2;
	color: var(--color-primary);
	margin: 0 0 var(--space-xs);
	letter-spacing: -0.01em;
}

.service-single__info-card {
	background: var(--color-bg-alt);
	border-radius: var(--radius-lg);
	border: 1px solid var(--color-border);
	padding: var(--space-lg);
	position: sticky;
	top: calc(var(--space-xl) + 60px);
}

.service-single__info-card .service-single__meta {
	margin: 0;
	padding: 0;
	list-style: none;
}

.service-single__info-card .service-single__meta li + li {
	margin-top: var(--space-md);
	padding-top: var(--space-md);
	border-top: 1px solid var(--color-border);
}

.service-single__info-title {
	font-family: var(--font-display);
	font-size: 0.95rem;
	font-weight: 700;
	color: var(--color-primary);
	text-transform: uppercase;
	letter-spacing: 0.06em;
	margin: 0 0 var(--space-sm);
}

.service-single__info-card .service-single__info-title {
	margin-bottom: var(--space-md);
}

.service-single__info-docs {
	margin-top: var(--space-lg);
	padding-top: var(--space-lg);
	border-top: 1px solid var(--color-border);
}

.service-single__info-foot {
	margin-top: var(--space-lg);
	padding-top: var(--space-lg);
	border-top: 1px solid var(--color-border);
	display: flex;
	gap: 0.6rem;
	align-items: flex-start;
	font-size: 0.82rem;
	line-height: 1.5;
	color: var(--color-text-light);
}

.service-single__info-foot svg {
	width: 16px;
	height: 16px;
	flex: 0 0 auto;
	color: var(--color-accent);
	margin-top: 2px;
}

.service-docs--compact {
	font-size: 0.88rem;
}

.service-docs--compact li {
	padding: 0.4rem 0;
	gap: 0.5rem;
}

.service-docs--compact li svg {
	width: 16px;
	height: 16px;
	flex: 0 0 auto;
}

.service-single__longform {
	max-width: var(--container-max);
	margin: var(--space-2xl) auto 0;
	padding: 0 var(--container-padding);
}

/* Editorial 2-col per le sezioni del longform: titolo a sx (sticky desktop)
   + contenuto fluido a dx. Ogni sezione ha esattamente 2 children diretti
   (h2 + body) quindi la grid si autoconfigura pulita. */
.service-single__longform > .service-single__section {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--space-md);
	padding-top: var(--space-xl);
	padding-bottom: var(--space-xl);
	border-bottom: 1px solid var(--color-border);
}

.service-single__longform > .service-single__section:last-child {
	border-bottom: none;
}

.service-single__longform > .service-single__section > .service-single__section-title {
	margin: 0;
	padding-left: var(--space-md);
}

.service-single__longform > .service-single__section > *:not(.service-single__section-title) {
	min-width: 0;
}

.service-single__longform .service-single__prose {
	max-width: 72ch;
}

@media (min-width: 900px) {
	.service-single__longform > .service-single__section {
		grid-template-columns: minmax(0, 240px) minmax(0, 1fr);
		gap: var(--space-2xl);
		align-items: start;
		padding-top: var(--space-2xl);
		padding-bottom: var(--space-2xl);
	}

	.service-single__longform > .service-single__section > .service-single__section-title {
		position: sticky;
		top: 100px;
		font-size: 1.1rem;
		line-height: 1.25;
		text-transform: uppercase;
		letter-spacing: 0.08em;
		padding-left: var(--space-sm);
	}

	.service-single__longform > .service-single__section > .service-single__section-title::before {
		top: 0.15em;
		bottom: 0.15em;
	}
}

/* Service chip: pre-fill esplicito dentro il form */
.quote-form__service {
	display: flex;
	align-items: flex-start;
	gap: 0.75rem;
	padding: 0.85rem 1rem;
	background: linear-gradient(135deg, rgba(20, 42, 79, 0.04) 0%, rgba(228, 181, 75, 0.06) 100%);
	border: 1px solid rgba(20, 42, 79, 0.14);
	border-radius: var(--radius-md);
	margin-bottom: var(--space-sm);
}

.quote-form__service svg {
	width: 20px;
	height: 20px;
	color: var(--color-accent);
	flex: 0 0 auto;
	margin-top: 2px;
}

.quote-form__service-label {
	display: block;
	font-size: 0.72rem;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	color: var(--color-text-light);
	margin-bottom: 0.15rem;
}

.quote-form__service-name {
	display: block;
	font-family: var(--font-display);
	font-size: 1.05rem;
	color: var(--color-primary);
	line-height: 1.3;
	letter-spacing: -0.005em;
}

.quote-form-wrap { width: 100%; }

.innovainm-quote-form {
	display: flex;
	flex-direction: column;
	gap: var(--space-md);
}

/* Honeypot: hidden for humans, present for bots */
.innovainm-hp {
	position: absolute !important;
	left: -9999px !important;
	top: auto !important;
	width: 1px !important;
	height: 1px !important;
	overflow: hidden !important;
}

.quote-form__grid {
	display: grid;
	gap: var(--space-md);
	grid-template-columns: 1fr;
}

@media (min-width: 640px) {
	.quote-form__grid {
		grid-template-columns: repeat(2, 1fr);
	}
}

.quote-form__field {
	display: flex;
	flex-direction: column;
	gap: 0.35rem;
}

.quote-form__field label,
.quote-form__consent > span {
	font-size: 0.82rem;
	font-weight: 600;
	color: var(--color-primary);
	letter-spacing: 0.01em;
}

.quote-form__field label .required {
	color: var(--color-danger);
}

.quote-form__field input,
.quote-form__field textarea {
	width: 100%;
	padding: 0.75rem 0.95rem;
	border: 1.5px solid var(--color-border);
	border-radius: var(--radius-sm);
	font-family: var(--font-sans);
	font-size: 0.97rem;
	color: var(--color-text);
	background: #ffffff;
	transition: border-color var(--duration) var(--ease-out), box-shadow var(--duration) var(--ease-out);
}

.quote-form__field textarea {
	resize: vertical;
	min-height: 120px;
	line-height: 1.55;
}

.quote-form__field input:focus,
.quote-form__field textarea:focus {
	outline: none;
	border-color: var(--color-accent);
	box-shadow: 0 0 0 4px rgba(228, 181, 75, 0.12);
}

.quote-form__consent {
	display: flex;
	align-items: flex-start;
	gap: 0.6rem;
	padding: 0.5rem 0;
	cursor: pointer;
	font-weight: 400;
}

.quote-form__consent input[type="checkbox"] {
	flex-shrink: 0;
	width: 18px;
	height: 18px;
	margin-top: 2px;
	accent-color: var(--color-primary);
}

.quote-form__consent > span {
	font-weight: 400;
	color: var(--color-text-light);
	font-size: 0.85rem;
	line-height: 1.5;
}

.quote-form__consent > span a {
	color: var(--color-primary);
	text-decoration: underline;
}

.quote-form__actions {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: var(--space-md);
	margin-top: var(--space-sm);
}

.quote-form__actions .btn {
	flex: 1 1 auto;
	min-width: 220px;
}

.quote-form__reply-note {
	display: inline-flex;
	align-items: center;
	gap: 0.35rem;
	margin: 0;
	font-size: 0.82rem;
	color: var(--color-text-light);
}

.quote-form__reply-note svg {
	width: 16px;
	height: 16px;
	color: var(--color-accent);
}

.quote-form__recaptcha-note {
	margin: 0;
	font-size: 0.72rem;
	color: var(--color-text-light);
	line-height: 1.4;
}

.quote-form__recaptcha-note a {
	color: var(--color-text-light);
	text-decoration: underline;
}

/* Success / error states */

.quote-form__success,
.quote-form__error {
	padding: var(--space-lg);
	border-radius: var(--radius-md);
	display: flex;
	flex-direction: column;
	align-items: center;
	text-align: center;
	gap: var(--space-sm);
}

.quote-form__success {
	background: rgba(26, 138, 92, 0.08);
	border: 1px solid rgba(26, 138, 92, 0.25);
	color: var(--color-success);
}

.quote-form__success svg {
	width: 48px;
	height: 48px;
	color: var(--color-success);
}

.quote-form__success h3 {
	margin: 0;
	color: var(--color-success);
	font-size: 1.25rem;
}

.quote-form__success p {
	margin: 0;
	color: var(--color-text);
	max-width: 520px;
}

.quote-form__error {
	background: rgba(181, 42, 28, 0.08);
	border: 1px solid rgba(181, 42, 28, 0.25);
	color: var(--color-danger);
	padding: var(--space-md);
}


/* ===========================================================
   Single product — extra sections (steps, why, faq, related)
   =========================================================== */

/* --- Come procediamo (timeline) --- */

.service-steps {
	list-style: none;
	padding: 0;
	margin: 0;
	display: grid;
	gap: var(--space-md);
	grid-template-columns: 1fr;
	counter-reset: step;
}

@media (min-width: 640px) {
	.service-steps {
		grid-template-columns: repeat(2, 1fr);
	}
}

.service-steps__item {
	display: flex;
	gap: var(--space-md);
	padding: var(--space-lg);
	background: #ffffff;
	border: 1px solid var(--color-border);
	border-radius: var(--radius-md);
	transition: border-color var(--duration) var(--ease-out), transform var(--duration) var(--ease-out), box-shadow var(--duration) var(--ease-out);
	position: relative;
	overflow: hidden;
}

.service-steps__item::before {
	content: "";
	position: absolute;
	left: 0;
	top: 0;
	bottom: 0;
	width: 3px;
	background: var(--hue);
	opacity: 0.25;
	transition: opacity var(--duration) var(--ease-out);
}

.service-steps__item:hover {
	transform: translateY(-2px);
	border-color: color-mix(in srgb, var(--hue) 30%, var(--color-border));
	box-shadow: var(--shadow-sm);
}

.service-steps__item:hover::before {
	opacity: 1;
}

.service-steps__num {
	flex-shrink: 0;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 36px;
	height: 36px;
	background: color-mix(in srgb, var(--hue) 12%, #ffffff);
	color: var(--hue);
	border-radius: 50%;
	font-family: var(--font-heading);
	font-size: 1rem;
	font-weight: 800;
	letter-spacing: -0.02em;
}

.service-steps__body {
	flex: 1;
	min-width: 0;
}

.service-steps__title {
	font-size: 1.02rem;
	font-weight: 700;
	color: var(--color-primary);
	margin: 0 0 0.3rem;
	letter-spacing: -0.01em;
}

.service-steps__desc {
	font-size: 0.9rem;
	color: var(--color-text-light);
	line-height: 1.55;
	margin: 0;
}

/* --- Perché affidarti (why us) --- */

.service-why {
	display: grid;
	gap: var(--space-md);
	grid-template-columns: 1fr;
}

@media (min-width: 640px) {
	.service-why {
		grid-template-columns: repeat(2, 1fr);
	}
}

.service-why__card {
	padding: var(--space-lg);
	background: var(--color-bg-alt);
	border-radius: var(--radius-md);
	transition: transform var(--duration) var(--ease-out), box-shadow var(--duration) var(--ease-out);
}

.service-why__card:hover {
	transform: translateY(-2px);
	box-shadow: var(--shadow-sm);
}

.service-why__icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 40px;
	height: 40px;
	margin-bottom: var(--space-sm);
	background: #ffffff;
	color: var(--hue);
	border-radius: var(--radius-sm);
	border: 1px solid color-mix(in srgb, var(--hue) 20%, var(--color-border));
}

.service-why__icon svg {
	width: 22px;
	height: 22px;
}

.service-why__title {
	font-size: 1rem;
	font-weight: 700;
	color: var(--color-primary);
	margin: 0 0 0.3rem;
	letter-spacing: -0.01em;
}

.service-why__desc {
	font-size: 0.9rem;
	color: var(--color-text-light);
	line-height: 1.55;
	margin: 0;
}

/* --- FAQ accordion --- */

.service-faq {
	display: flex;
	flex-direction: column;
	gap: 0.5rem;
}

.service-faq__item {
	background: #ffffff;
	border: 1px solid var(--color-border);
	border-radius: var(--radius-md);
	overflow: hidden;
	transition: border-color var(--duration) var(--ease-out), box-shadow var(--duration) var(--ease-out);
}

.service-faq__item[open],
.service-faq__item:hover {
	border-color: color-mix(in srgb, var(--hue) 35%, var(--color-border));
}

.service-faq__item[open] {
	box-shadow: var(--shadow-sm);
}

.service-faq__q {
	list-style: none;
	cursor: pointer;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: var(--space-md);
	padding: var(--space-md) var(--space-lg);
	font-family: var(--font-heading);
	font-weight: 700;
	font-size: 1.02rem;
	color: var(--color-primary);
	letter-spacing: -0.01em;
	line-height: 1.4;
}

.service-faq__q::-webkit-details-marker {
	display: none;
}

.service-faq__q::marker {
	display: none;
	content: "";
}

.service-faq__chevron {
	width: 18px;
	height: 18px;
	color: var(--hue);
	flex-shrink: 0;
	transition: transform var(--duration) var(--ease-out);
}

.service-faq__item[open] .service-faq__chevron {
	transform: rotate(180deg);
}

.service-faq__a {
	padding: 0 var(--space-lg) var(--space-lg);
	color: var(--color-text-light);
	line-height: 1.65;
	font-size: 0.97rem;
}

.service-faq__a p {
	margin: 0 0 0.75em;
}

.service-faq__a p:last-child {
	margin-bottom: 0;
}

/* --- Related services --- */

.service-related {
	background: linear-gradient(180deg, transparent 0%, var(--color-bg-alt) 100%);
	padding: var(--space-3xl) 0;
	margin-top: var(--space-3xl);
}

.service-related__inner {
	max-width: var(--container-max);
	margin: 0 auto;
	padding: 0 var(--container-padding);
}

.service-related__head {
	margin-bottom: var(--space-xl);
	max-width: 680px;
}

.service-related__title {
	font-size: clamp(1.5rem, 3vw, 2rem);
	font-weight: 800;
	color: var(--color-primary);
	letter-spacing: -0.02em;
	margin: 0 0 var(--space-xs);
}

.service-related__lede {
	color: var(--color-text-light);
	font-size: 1rem;
	line-height: 1.6;
	margin: 0;
}


/* ===========================================================
   Generic page + WC cart/checkout/account hero
   =========================================================== */

.page-hero {
	background:
		radial-gradient(ellipse 50% 40% at 15% 0%, rgba(20, 42, 79, 0.07) 0%, transparent 70%),
		radial-gradient(ellipse 40% 35% at 95% 20%, rgba(228, 181, 75, 0.06) 0%, transparent 70%),
		var(--color-bg);
	border-bottom: 1px solid var(--color-border);
	padding: var(--space-2xl) 0 var(--space-xl);
	position: relative;
}

.page-hero::after {
	content: "";
	position: absolute;
	left: 0;
	right: 0;
	bottom: -1px;
	height: 2px;
	background: linear-gradient(90deg, transparent, var(--color-accent) 50%, transparent);
	opacity: 0.4;
}

.page-hero__title {
	font-size: clamp(2rem, 4.5vw, 3rem);
	font-weight: 800;
	letter-spacing: -0.025em;
	line-height: 1.1;
	color: var(--color-primary);
	margin: 0;
}

.page-hero__lede {
	margin: var(--space-sm) 0 0;
	font-size: 1.05rem;
	color: var(--color-text-light);
	line-height: 1.6;
	max-width: 680px;
}

.page-body {
	padding: var(--space-2xl) 0 var(--space-3xl);
}

.page-content {
	font-size: 1rem;
	line-height: 1.7;
}

.page-content > * + * {
	margin-top: var(--space-md);
}

/* --- Cart: 2-col layout (solo cart — checkout ha il proprio grid interno) --- */

body.woocommerce-cart .page-content > .woocommerce {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--space-xl);
	align-items: start;
}

@media (min-width: 1024px) {
	body.woocommerce-cart .page-content > .woocommerce {
		grid-template-columns: minmax(0, 1fr) 380px;
		gap: var(--space-2xl);
	}
}

body.woocommerce-cart .page-content > .woocommerce > * {
	margin: 0;
}

.page-main--wc .page-content h1,
.page-main--wc .page-content h2:not(.innovainm-summary__title):not(.innovainm-cart-empty__title) {
	font-family: var(--font-heading);
	letter-spacing: -0.015em;
}

/* Default woo notices */
.page-main--wc .woocommerce-notices-wrapper:empty {
	display: none;
}

/* ===========================================================
   Cart page — items list
   =========================================================== */

.innovainm-cart__form {
	min-width: 0;
}

.innovainm-cart__items {
	display: flex;
	flex-direction: column;
	gap: var(--space-md);
}

.innovainm-cart-item {
	display: grid;
	grid-template-columns: 52px 1fr auto;
	grid-template-areas:
		"icon body remove"
		"icon qty total";
	column-gap: var(--space-md);
	row-gap: var(--space-sm);
	padding: var(--space-lg);
	background: #ffffff;
	border: 1px solid var(--color-border);
	border-left: 3px solid var(--hue);
	border-radius: var(--radius-md);
	box-shadow: var(--shadow-sm);
	transition: box-shadow var(--duration) var(--ease-out);
}

.innovainm-cart-item:hover {
	box-shadow: var(--shadow-md);
}

@media (min-width: 768px) {
	.innovainm-cart-item {
		grid-template-columns: 52px minmax(0, 1fr) auto auto auto;
		grid-template-areas: "icon body qty total remove";
		align-items: center;
		column-gap: var(--space-lg);
	}
}


.innovainm-cart-item__icon {
	grid-area: icon;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 52px;
	height: 52px;
	background: color-mix(in srgb, var(--hue) 12%, #ffffff);
	color: var(--hue);
	border-radius: var(--radius-sm);
	align-self: start;
}

.innovainm-cart-item__icon svg {
	width: 28px;
	height: 28px;
}

.innovainm-cart-item__body {
	grid-area: body;
	min-width: 0;
	display: flex;
	flex-direction: column;
	gap: 0.3rem;
}

.innovainm-cart-item__pill {
	align-self: flex-start;
	font-size: 0.68rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	padding: 2px 8px;
	background: color-mix(in srgb, var(--hue) 12%, #ffffff);
	color: var(--hue);
	border-radius: 10px;
}

a.innovainm-cart-item__title,
.innovainm-cart-item__title {
	font-family: var(--font-heading);
	font-size: 1.08rem;
	font-weight: 700;
	color: var(--color-primary) !important;
	letter-spacing: -0.015em;
	line-height: 1.3;
	text-decoration: none;
	border-bottom: none;
	transition: color var(--duration) var(--ease-out);
}

a.innovainm-cart-item__title:hover {
	color: var(--color-accent-hover) !important;
}

.innovainm-cart-item__meta {
	display: inline-flex;
	align-items: center;
	gap: 0.35rem;
	margin: 0;
	font-size: 0.82rem;
	color: var(--color-text-light);
}

.innovainm-cart-item__meta svg {
	width: 14px;
	height: 14px;
	color: var(--color-accent);
}

.innovainm-cart-item__qty {
	grid-area: qty;
}

.innovainm-cart-item__qty .quantity {
	display: inline-flex;
	align-items: center;
	gap: 0;
	border: 1.5px solid var(--color-border);
	border-radius: var(--radius-sm);
	overflow: hidden;
	background: #ffffff;
}

.innovainm-cart-item__qty input.qty {
	width: 48px;
	padding: 0.45rem 0.4rem;
	text-align: center;
	font-family: var(--font-heading);
	font-weight: 700;
	font-size: 0.95rem;
	color: var(--color-primary);
	background: #ffffff;
	border: none;
	outline: none;
	appearance: textfield;
	-moz-appearance: textfield;
}

.innovainm-cart-item__qty .quantity button,
.innovainm-cart-item__qty .qty-button {
	width: 34px;
	height: 34px;
	background: var(--color-bg-alt);
	border: none;
	color: var(--color-primary);
	font-size: 1.1rem;
	font-weight: 700;
	cursor: pointer;
	line-height: 1;
	transition: background var(--duration) var(--ease-out);
}

.innovainm-cart-item__qty .quantity button:hover {
	background: color-mix(in srgb, var(--color-primary) 10%, var(--color-bg-alt));
}

.innovainm-cart-item__total {
	grid-area: total;
	display: flex;
	flex-direction: column;
	gap: 2px;
	text-align: right;
	min-width: 90px;
}

.innovainm-cart-item__total-label {
	font-size: 0.7rem;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	font-weight: 600;
	color: var(--color-text-light);
}

.innovainm-cart-item__total-value {
	font-family: var(--font-heading);
	font-size: 1.15rem;
	font-weight: 800;
	color: var(--color-primary) !important;
	letter-spacing: -0.015em;
	font-variant-numeric: tabular-nums;
}

.innovainm-cart-item__total-value bdi,
.innovainm-cart-item__total-value .woocommerce-Price-amount {
	color: var(--color-primary) !important;
}

a.innovainm-cart-item__remove {
	grid-area: remove;
	display: inline-flex;
	align-items: center;
	gap: 0.35rem;
	padding: 0.5rem 0.75rem;
	font-size: 0.82rem;
	font-weight: 600;
	color: var(--color-text-light) !important;
	background: transparent;
	border: 1px solid transparent;
	border-radius: var(--radius-sm);
	text-decoration: none;
	transition: all var(--duration) var(--ease-out);
	align-self: center;
	justify-self: end;
	line-height: 1;
}

a.innovainm-cart-item__remove:hover {
	color: var(--color-danger) !important;
	border-color: var(--color-danger);
	background: rgba(181, 42, 28, 0.05);
}

.innovainm-cart-item__remove svg {
	width: 16px;
	height: 16px;
}

@media (max-width: 767px) {
	.innovainm-cart-item__remove-label {
		display: none;
	}
	.innovainm-cart-item__total {
		text-align: left;
	}
}

/* Mobile ≤640: layout cart-item completamente ridisegnato.
   Posizionato DOPO tutte le regole base cart-item__* per vincere nel
   cascade (stesso specificity, ultima regola applicata wins). */
@media (max-width: 640px) {
	.innovainm-cart-item {
		padding: var(--space-lg) var(--space-md);
		grid-template-columns: minmax(0, 1fr) auto;
		grid-template-areas:
			"body  remove"
			"sep   sep"
			"qty   total";
		column-gap: var(--space-md);
		row-gap: var(--space-sm);
		align-items: start;
	}

	/* Separator unico continuo che spans 2 col (niente più linee spezzate). */
	.innovainm-cart-item::before {
		content: "";
		grid-area: sep;
		height: 0;
		border-top: 1px dashed var(--color-border);
		align-self: stretch;
	}

	.innovainm-cart-item__icon {
		display: none;
	}

	.innovainm-cart-item__body {
		gap: 0.4rem;
	}

	.innovainm-cart-item__pill {
		font-size: 0.62rem;
		padding: 3px 8px;
		letter-spacing: 0.08em;
		max-width: 100%;
	}

	a.innovainm-cart-item__title,
	.innovainm-cart-item__title {
		font-size: 1rem;
		line-height: 1.3;
		word-break: normal;
		overflow-wrap: break-word;
	}

	.innovainm-cart-item__qty {
		grid-area: qty;
		align-self: center;
	}

	.innovainm-cart-item__total {
		grid-area: total;
		text-align: right;
		align-self: center;
		padding-right: 0;
	}

	a.innovainm-cart-item__remove {
		grid-area: remove;
		align-self: start;
		padding: 0.35rem;
	}
}

/* --- Cart actions (coupon, update) --- */

.innovainm-cart__actions {
	margin-top: var(--space-lg);
	padding: var(--space-md) var(--space-lg);
	background: var(--color-bg-alt);
	border-radius: var(--radius-md);
	display: flex;
	flex-wrap: wrap;
	gap: var(--space-md);
	align-items: center;
	justify-content: space-between;
}

.innovainm-cart__coupon {
	display: flex;
	gap: 0.5rem;
	align-items: center;
	flex: 1;
	min-width: 280px;
}

.innovainm-cart__coupon input {
	flex: 1;
	padding: 0.55rem 0.85rem;
	border: 1.5px solid var(--color-border);
	border-radius: var(--radius-sm);
	font-family: var(--font-sans);
	font-size: 0.93rem;
	background: #ffffff;
	color: var(--color-text);
}

.innovainm-cart__coupon input:focus {
	outline: none;
	border-color: var(--color-accent);
	box-shadow: 0 0 0 4px rgba(228, 181, 75, 0.15);
}

.innovainm-cart__update {
	font-size: 0.88rem;
	padding: 0.55rem 1rem;
}

/* ===========================================================
   Cart summary sidebar
   =========================================================== */

.innovainm-cart__summary {
	min-width: 0;
	width: 100%;
}

@media (min-width: 1024px) {
	.innovainm-cart__summary {
		position: sticky;
		top: calc(68px + var(--space-md));
	}
}

/* Kill WC default float / 48% width on cart-collaterals so our summary fills the grid cell */
.woocommerce-cart .cart-collaterals,
.innovainm-cart__summary .cart-collaterals,
.innovainm-cart__collaterals {
	width: 100% !important;
	float: none !important;
	display: block !important;
}

.woocommerce-cart .cart-collaterals .cart_totals,
.innovainm-cart__summary .cart-collaterals .cart_totals,
.innovainm-summary {
	width: 100% !important;
	float: none !important;
	max-width: none !important;
}

.innovainm-summary {
	background: #ffffff;
	border: 1px solid var(--color-border);
	border-radius: var(--radius-lg);
	padding: var(--space-xl);
	box-shadow: var(--shadow-md);
	position: relative;
	overflow: hidden;
}

.innovainm-summary::before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	height: 4px;
	background: linear-gradient(90deg, var(--color-accent-light), var(--color-accent), var(--color-accent-hover));
}

.innovainm-summary__title {
	font-size: 1.15rem;
	font-weight: 700;
	color: var(--color-primary);
	margin: 0 0 var(--space-md);
	letter-spacing: -0.01em;
	text-transform: none;
}

.innovainm-summary__lines {
	margin: 0 0 var(--space-md);
	padding: 0 0 var(--space-md);
	border-bottom: 1px dashed var(--color-border);
	display: grid;
	grid-template-columns: 1fr auto;
	gap: 0.5rem 1rem;
	font-size: 0.95rem;
}

.innovainm-summary__line-label {
	color: var(--color-text-light);
	font-weight: 500;
	margin: 0;
}

.innovainm-summary__line-value {
	color: var(--color-primary);
	font-weight: 600;
	margin: 0;
	text-align: right;
	font-variant-numeric: tabular-nums;
}

.innovainm-summary__line-label--coupon {
	color: var(--color-success);
}

.innovainm-summary__total {
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	gap: 0.35rem;
	margin-bottom: var(--space-lg);
	padding: var(--space-md) 0;
	border-top: 2px solid var(--color-border);
	border-bottom: 2px solid var(--color-border);
}

.innovainm-summary__total-label {
	font-family: var(--font-heading);
	font-size: 0.72rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	color: var(--color-text-light);
}

.innovainm-summary__total-value {
	display: block;
	font-family: var(--font-heading);
	font-size: 1.8rem;
	font-weight: 800;
	color: var(--color-primary);
	letter-spacing: -0.02em;
	font-variant-numeric: tabular-nums;
	line-height: 1.1;
	width: 100%;
}

.innovainm-summary__total-value strong {
	font-weight: 800;
}

.innovainm-summary__total-value .woocommerce-Price-currencySymbol {
	font-size: 0.8em;
	opacity: 0.75;
	margin-left: 2px;
}

/* WC adds <small class="includes_tax"> dopo il totale — va isolata, piccola */
.innovainm-summary__total-value small,
.innovainm-summary__total-value .includes_tax {
	display: block;
	margin-top: 0.35rem;
	font-family: var(--font-sans);
	font-size: 0.78rem;
	font-weight: 500;
	letter-spacing: 0;
	color: var(--color-text-light);
	line-height: 1.4;
}

.innovainm-summary__total-value small .woocommerce-Price-amount,
.innovainm-summary__total-value small .woocommerce-Price-currencySymbol {
	font-family: var(--font-sans);
	font-size: 1em;
	font-weight: 600;
	color: var(--color-text-light);
}

/* Proceed to checkout button */
.innovainm-summary__checkout {
	margin-bottom: var(--space-lg);
}

.innovainm-summary__checkout .checkout-button,
.innovainm-summary__checkout a.checkout-button {
	display: inline-flex !important;
	align-items: center;
	justify-content: center;
	width: 100%;
	padding: 1rem 1.5rem !important;
	border: none !important;
	border-radius: var(--radius-md) !important;
	font-family: var(--font-sans) !important;
	font-size: 1rem !important;
	font-weight: 700 !important;
	line-height: 1 !important;
	text-transform: none !important;
	letter-spacing: 0 !important;
	background: linear-gradient(135deg, var(--color-accent-light) 0%, var(--color-accent) 50%, var(--color-accent-hover) 100%) !important;
	background-size: 200% 200% !important;
	background-position: 50% 50% !important;
	color: var(--color-primary) !important;
	box-shadow: var(--shadow-sm), 0 2px 8px rgba(228, 181, 75, 0.25) !important;
	transition: all var(--duration) var(--ease-out) !important;
	text-decoration: none;
}

.innovainm-summary__checkout .checkout-button:hover {
	background-position: 100% 100% !important;
	transform: translateY(-1px);
	box-shadow: var(--shadow-md), var(--shadow-accent) !important;
	color: var(--color-primary) !important;
}

/* Trust list */
.innovainm-summary__trust {
	list-style: none;
	padding: var(--space-md) 0 0;
	margin: 0;
	border-top: 1px solid var(--color-border);
	display: flex;
	flex-direction: column;
	gap: 0.5rem;
}

.innovainm-summary__trust li {
	display: flex;
	align-items: flex-start;
	gap: 0.5rem;
	font-size: 0.82rem;
	color: var(--color-text-light);
	line-height: 1.45;
}

.innovainm-summary__trust svg {
	width: 16px;
	height: 16px;
	color: var(--color-accent);
	flex-shrink: 0;
	margin-top: 2px;
}

/* Empty cart */

.innovainm-cart-empty {
	padding: var(--space-3xl) var(--space-lg);
	text-align: center;
	background: var(--color-bg-alt);
	border-radius: var(--radius-lg);
	max-width: 680px;
	margin: 0 auto;
}

.innovainm-cart-empty svg {
	width: 96px;
	height: 96px;
	color: var(--color-text-light);
	margin: 0 auto var(--space-md);
}

.innovainm-cart-empty__title {
	font-size: 1.75rem;
	color: var(--color-primary);
	margin: 0 0 var(--space-sm);
}

.innovainm-cart-empty__text {
	color: var(--color-text-light);
	margin: 0 0 var(--space-xl);
	max-width: 480px;
	margin-left: auto;
	margin-right: auto;
}

/* ===========================================================
   Mini-cart (header dropdown)
   =========================================================== */

/* Override old widget styles */
.site-header__dropdown--cart .widget_shopping_cart_content {
	padding: 0;
}

.site-header__dropdown--cart .widget_shopping_cart_content ul.woocommerce-mini-cart {
	list-style: none;
	padding: 0;
	margin: 0 0 var(--space-sm);
	max-height: 340px;
	overflow-y: auto;
	border-bottom: 1px solid var(--color-border);
}

.innovainm-minicart-item {
	position: relative;
	display: grid;
	grid-template-columns: 40px minmax(0, 1fr) 24px;
	gap: 0.6rem;
	padding: 0.7rem 0.5rem;
	align-items: center;
	border-bottom: 1px solid var(--color-border);
}

.innovainm-minicart-item:last-child {
	border-bottom: none;
}

.innovainm-minicart-item__icon {
	grid-column: 1;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 40px;
	height: 40px;
	background: color-mix(in srgb, var(--hue) 12%, #ffffff);
	color: var(--hue);
	border-radius: var(--radius-sm);
	flex-shrink: 0;
}

.innovainm-minicart-item__icon svg {
	width: 22px;
	height: 22px;
}

.innovainm-minicart-item__body {
	grid-column: 2;
	min-width: 0;
	display: flex;
	flex-direction: column;
	gap: 2px;
}

a.innovainm-minicart-item__title,
.innovainm-minicart-item__title {
	font-family: var(--font-sans);
	font-size: 0.9rem;
	font-weight: 600;
	color: var(--color-primary);
	line-height: 1.35;
	text-decoration: none;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}

a.innovainm-minicart-item__title:hover {
	color: var(--color-accent-hover) !important;
}

.innovainm-minicart-item__meta {
	display: flex;
	align-items: baseline;
	justify-content: space-between;
	gap: 0.5rem;
	font-size: 0.82rem;
	color: var(--color-text-light);
}

.innovainm-minicart-item__meta .quantity {
	font-variant-numeric: tabular-nums;
	color: var(--color-text-light);
}

.innovainm-minicart-item__price,
.innovainm-minicart-item__price .woocommerce-Price-amount {
	font-family: var(--font-heading);
	font-weight: 700;
	color: var(--color-primary);
}

a.innovainm-minicart-item__remove {
	grid-column: 3;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 24px;
	height: 24px;
	background: transparent;
	color: var(--color-text-light);
	border-radius: 50%;
	transition: all 0.2s ease;
	text-decoration: none;
	font-size: 0;
	align-self: start;
	margin-top: 2px;
}

a.innovainm-minicart-item__remove:hover {
	background: rgba(181, 42, 28, 0.1);
	color: var(--color-danger) !important;
}

.innovainm-minicart-item__remove svg {
	width: 12px;
	height: 12px;
}

.innovainm-minicart-total {
	display: flex;
	justify-content: space-between;
	align-items: baseline;
	margin: var(--space-sm) 0;
	padding: var(--space-sm) 0.25rem;
	font-size: 0.9rem;
}

.innovainm-minicart-total__label {
	font-family: var(--font-heading);
	font-size: 0.72rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	color: var(--color-text-light);
}

.innovainm-minicart-total__value,
.innovainm-minicart-total__value .woocommerce-Price-amount {
	font-family: var(--font-heading);
	font-size: 1.15rem;
	font-weight: 800;
	color: var(--color-primary);
	letter-spacing: -0.015em;
}

.innovainm-minicart-buttons {
	display: flex;
	flex-direction: column;
	gap: 0.4rem;
}

.innovainm-minicart-buttons .btn {
	width: 100%;
	padding: 0.7rem 1rem;
	font-size: 0.93rem;
	text-align: center;
	justify-content: center;
}

/* Empty state */
.innovainm-minicart-empty {
	text-align: center;
	padding: var(--space-md) 0.5rem;
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: var(--space-sm);
}

.innovainm-minicart-empty svg {
	width: 40px;
	height: 40px;
	color: var(--color-text-light);
}

.innovainm-minicart-empty p {
	color: var(--color-text-light);
	font-size: 0.92rem;
	margin: 0;
}

.innovainm-minicart-empty .btn {
	margin-top: 0.25rem;
}

.btn--sm {
	padding: 0.5rem 1rem;
	font-size: 0.88rem;
}

.btn--ghost {
	background: transparent;
	border: 1px solid var(--color-border);
	color: var(--color-text);
	box-shadow: none;
}

.btn--ghost:hover {
	border-color: var(--color-primary);
	color: var(--color-primary);
	background: var(--color-bg-alt);
	transform: none;
	box-shadow: none;
}


/* ===========================================================
   Cart drawer — off-canvas right side
   =========================================================== */

.innovainm-cart-drawer {
	position: fixed;
	inset: 0;
	z-index: 1000;
	pointer-events: none;
	display: flex;
	justify-content: flex-end;
}

.innovainm-cart-drawer[aria-hidden="true"] {
	pointer-events: none;
}

.innovainm-cart-drawer.is-open {
	pointer-events: auto;
}

.innovainm-cart-drawer__backdrop {
	position: absolute;
	inset: 0;
	background: rgba(10, 26, 53, 0.55);
	backdrop-filter: blur(4px);
	-webkit-backdrop-filter: blur(4px);
	opacity: 0;
	transition: opacity 0.3s var(--ease-out);
	cursor: pointer;
}

.innovainm-cart-drawer.is-open .innovainm-cart-drawer__backdrop {
	opacity: 1;
}

.innovainm-cart-drawer__panel {
	position: relative;
	width: 100%;
	max-width: 420px;
	height: 100%;
	background: #ffffff;
	display: flex;
	flex-direction: column;
	transform: translateX(100%);
	transition: transform 0.32s cubic-bezier(0.2, 0, 0, 1);
	box-shadow: -24px 0 60px rgba(10, 26, 53, 0.18);
}

.innovainm-cart-drawer.is-open .innovainm-cart-drawer__panel {
	transform: translateX(0);
}

@media (max-width: 520px) {
	.innovainm-cart-drawer__panel {
		max-width: 100%;
	}
}

/* Header */

.innovainm-cart-drawer__header {
	flex-shrink: 0;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: var(--space-md);
	padding: var(--space-lg) var(--space-lg);
	border-bottom: 1px solid var(--color-border);
	background: #ffffff;
	position: relative;
}

.innovainm-cart-drawer__header::after {
	content: "";
	position: absolute;
	left: var(--space-lg);
	right: var(--space-lg);
	bottom: -1px;
	height: 2px;
	background: linear-gradient(90deg, transparent, var(--color-accent) 50%, transparent);
	opacity: 0.35;
}

.innovainm-cart-drawer__title {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	margin: 0;
	font-family: var(--font-heading);
	font-size: 1.25rem;
	font-weight: 800;
	color: var(--color-primary);
	letter-spacing: -0.02em;
}

.innovainm-cart-drawer__count {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 22px;
	height: 22px;
	padding: 0 6px;
	border-radius: 11px;
	background: var(--color-accent);
	color: var(--color-primary);
	font-family: var(--font-heading);
	font-size: 0.78rem;
	font-weight: 700;
	font-variant-numeric: tabular-nums;
}

.innovainm-cart-drawer__count.is-hidden {
	display: none;
}

.innovainm-cart-drawer__close {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 40px;
	height: 40px;
	background: var(--color-bg-alt);
	border: none;
	border-radius: 50%;
	color: var(--color-primary);
	cursor: pointer;
	transition: background 0.2s var(--ease-out), transform 0.2s var(--ease-out);
}

.innovainm-cart-drawer__close:hover {
	background: var(--color-primary);
	color: #ffffff;
	transform: rotate(90deg);
}

.innovainm-cart-drawer__close svg {
	width: 18px;
	height: 18px;
}

/* Content area — flex column so mini-cart list scrolls and total/buttons stick to bottom */

.innovainm-cart-drawer__content {
	flex: 1;
	min-height: 0;
	display: flex;
	flex-direction: column;
	overflow: hidden;
}

.innovainm-cart-drawer__content ul.woocommerce-mini-cart {
	flex: 1;
	min-height: 0;
	list-style: none;
	padding: 0 var(--space-lg);
	margin: 0;
	overflow-y: auto;
	overflow-x: hidden;
	scrollbar-width: thin;
}

.innovainm-cart-drawer__content ul.woocommerce-mini-cart::-webkit-scrollbar {
	width: 6px;
}

.innovainm-cart-drawer__content ul.woocommerce-mini-cart::-webkit-scrollbar-thumb {
	background: var(--color-border);
	border-radius: 3px;
}

/* Adjust items inside drawer */

.innovainm-cart-drawer .innovainm-minicart-item {
	padding: var(--space-md) 0;
	border-bottom: 1px solid var(--color-border);
	grid-template-columns: 48px minmax(0, 1fr) 28px;
	gap: var(--space-md);
}

.innovainm-cart-drawer .innovainm-minicart-item__icon {
	width: 48px;
	height: 48px;
}

.innovainm-cart-drawer .innovainm-minicart-item__icon svg {
	width: 26px;
	height: 26px;
}

.innovainm-cart-drawer .innovainm-minicart-item__body {
	width: 100%;
}

.innovainm-cart-drawer .innovainm-minicart-item__title,
.innovainm-cart-drawer a.innovainm-minicart-item__title {
	font-size: 0.95rem;
	font-weight: 700;
	white-space: normal;
	overflow: hidden;
	text-overflow: ellipsis;
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	line-height: 1.3;
	margin-bottom: 0.3rem;
}

.innovainm-cart-drawer .innovainm-minicart-item__meta {
	margin-top: 2px;
	font-size: 0.88rem;
}

.innovainm-cart-drawer .innovainm-minicart-item__price {
	font-size: 1rem;
}

.innovainm-cart-drawer .innovainm-minicart-item__remove {
	width: 28px;
	height: 28px;
}

.innovainm-cart-drawer .innovainm-minicart-item__remove.is-loading {
	opacity: 0.4;
	pointer-events: none;
}

/* Total + buttons footer — sticky bottom */

.innovainm-cart-drawer__content .innovainm-minicart-total {
	flex-shrink: 0;
	display: flex;
	justify-content: space-between;
	align-items: baseline;
	margin: 0;
	padding: var(--space-md) var(--space-lg);
	background: var(--color-bg-alt);
	border-top: 1px solid var(--color-border);
	font-size: 0.95rem;
}

.innovainm-cart-drawer__content .innovainm-minicart-total__label {
	font-family: var(--font-heading);
	font-size: 0.72rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	color: var(--color-text-light);
}

.innovainm-cart-drawer__content .innovainm-minicart-total__value {
	font-family: var(--font-heading);
	font-size: 1.45rem;
	font-weight: 800;
	color: var(--color-primary);
	letter-spacing: -0.015em;
	font-variant-numeric: tabular-nums;
}

.innovainm-cart-drawer__content .innovainm-minicart-buttons {
	flex-shrink: 0;
	display: flex;
	flex-direction: column;
	gap: 0.5rem;
	padding: var(--space-md) var(--space-lg) var(--space-lg);
	background: #ffffff;
	border-top: 1px solid var(--color-border);
}

.innovainm-cart-drawer__content .innovainm-minicart-buttons .btn {
	width: 100%;
	padding: 0.85rem 1rem;
	font-size: 0.95rem;
	justify-content: center;
}

/* Empty state inside drawer */

.innovainm-cart-drawer__content .innovainm-minicart-empty {
	flex: 1;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	padding: var(--space-2xl) var(--space-lg);
	text-align: center;
	gap: var(--space-md);
}

.innovainm-cart-drawer__content .innovainm-minicart-empty svg {
	width: 72px;
	height: 72px;
	color: var(--color-text-light);
}

.innovainm-cart-drawer__content .innovainm-minicart-empty p {
	color: var(--color-text-light);
	font-size: 1rem;
	margin: 0;
}

.innovainm-cart-drawer__content .innovainm-minicart-empty .btn {
	min-width: 220px;
}

/* Body scroll lock while drawer open */

body.cart-drawer-open {
	overflow: hidden;
}

/* Hide cart badge helper */

.site-header__cart-count.is-hidden {
	display: none;
}


/* ===========================================================
   Checkout — 2-col layout
   =========================================================== */

.innovainm-checkout {
	width: 100%;
}

.innovainm-checkout__grid {
	display: grid;
	gap: var(--space-xl);
	grid-template-columns: 1fr;
	align-items: start;
}

@media (min-width: 1024px) {
	.innovainm-checkout__grid {
		grid-template-columns: minmax(0, 1fr) 420px;
		gap: var(--space-2xl);
	}
}

.innovainm-checkout__main {
	min-width: 0;
	display: flex;
	flex-direction: column;
	gap: var(--space-xl);
}

.innovainm-checkout__section {
	background: #ffffff;
	border: 1px solid var(--color-border);
	border-radius: var(--radius-lg);
	padding: var(--space-xl);
	box-shadow: var(--shadow-sm);
}

.innovainm-checkout__section-head {
	display: flex;
	align-items: center;
	gap: var(--space-md);
	margin-bottom: var(--space-lg);
	padding-bottom: var(--space-md);
	border-bottom: 1px solid var(--color-border);
}

.innovainm-checkout__step {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 32px;
	height: 32px;
	background: linear-gradient(135deg, var(--color-accent-light), var(--color-accent));
	color: var(--color-primary);
	border-radius: 50%;
	font-family: var(--font-heading);
	font-weight: 800;
	font-size: 0.95rem;
	flex-shrink: 0;
	box-shadow: 0 2px 6px rgba(228, 181, 75, 0.3);
}

.innovainm-checkout__section-title {
	margin: 0;
	font-family: var(--font-heading);
	font-size: 1.2rem;
	font-weight: 700;
	color: var(--color-primary);
	letter-spacing: -0.015em;
}

/* Billing/shipping field styling */

.innovainm-checkout #customer_details {
	display: grid;
	gap: var(--space-lg);
	grid-template-columns: 1fr;
}

.innovainm-checkout .form-row {
	margin-bottom: var(--space-md);
}

.innovainm-checkout .form-row-first,
.innovainm-checkout .form-row-last {
	float: none;
	width: 100%;
}

@media (min-width: 600px) {
	.innovainm-checkout .form-row-first,
	.innovainm-checkout .form-row-last {
		display: inline-block;
		width: calc(50% - 8px);
	}
	.innovainm-checkout .form-row-first { margin-right: 8px; }
	.innovainm-checkout .form-row-last { margin-left: 8px; }
}

.innovainm-checkout label {
	display: block;
	margin-bottom: 0.35rem;
	font-family: var(--font-sans);
	font-size: 0.82rem;
	font-weight: 600;
	color: var(--color-primary);
	letter-spacing: 0.01em;
}

.innovainm-checkout label .required {
	color: var(--color-danger);
	text-decoration: none;
}

.innovainm-checkout label .optional {
	color: var(--color-text-light);
	font-weight: 400;
	font-size: 0.76rem;
}

.innovainm-checkout input[type="text"],
.innovainm-checkout input[type="email"],
.innovainm-checkout input[type="tel"],
.innovainm-checkout input[type="number"],
.innovainm-checkout input[type="password"],
.innovainm-checkout textarea,
.innovainm-checkout select,
.innovainm-checkout .select2-selection--single {
	width: 100%;
	padding: 0.7rem 0.9rem;
	border: 1.5px solid var(--color-border);
	border-radius: var(--radius-sm);
	font-family: var(--font-sans);
	font-size: 0.95rem;
	color: var(--color-text);
	background: #ffffff;
	transition: border-color var(--duration) var(--ease-out), box-shadow var(--duration) var(--ease-out);
	line-height: 1.3;
	height: auto;
	min-height: 44px;
}

.innovainm-checkout .select2-selection--single {
	padding: 0;
	display: flex;
	align-items: center;
}

.innovainm-checkout .select2-selection--single .select2-selection__rendered {
	padding: 0 0.9rem;
	line-height: 1.3;
	color: var(--color-text);
}

.innovainm-checkout input:focus,
.innovainm-checkout textarea:focus,
.innovainm-checkout select:focus,
.innovainm-checkout .select2-container--open .select2-selection--single {
	outline: none;
	border-color: var(--color-accent);
	box-shadow: 0 0 0 4px rgba(228, 181, 75, 0.14);
}

.innovainm-checkout .woocommerce-input-wrapper {
	width: 100%;
}

/* Invoice toggle + fields */

.innovainm-invoice-toggle {
	padding: var(--space-md) var(--space-lg);
	background: var(--color-bg-alt);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-md);
	margin-top: var(--space-md) !important;
	margin-bottom: var(--space-md) !important;
	transition: border-color var(--duration) var(--ease-out), background var(--duration) var(--ease-out);
}

.innovainm-invoice-toggle:has(input[type="checkbox"]:checked) {
	border-color: var(--color-accent);
	background: rgba(228, 181, 75, 0.06);
}

.innovainm-invoice-toggle label {
	display: flex !important;
	align-items: center;
	gap: 0.7rem;
	flex-wrap: nowrap;
	margin: 0 !important;
	font-size: 0.95rem;
	line-height: 1.35;
	color: var(--color-primary);
	cursor: pointer;
	font-weight: 600;
	width: 100%;
}

.innovainm-invoice-toggle input[type="checkbox"] {
	width: 20px;
	height: 20px;
	margin: 0;
	flex: 0 0 auto;
	accent-color: var(--color-accent-hover);
	cursor: pointer;
}

.innovainm-invoice-toggle label .optional {
	font-size: 0.78rem;
	font-weight: 500;
	color: var(--color-text-light);
	font-style: normal;
	margin-left: auto;
	flex: 0 0 auto;
	padding-left: 0.5rem;
}

@media (max-width: 480px) {
	.innovainm-invoice-toggle label {
		gap: 0.55rem;
		font-size: 0.9rem;
	}
	.innovainm-invoice-toggle label .optional {
		font-size: 0.72rem;
	}
}

.innovainm-invoice-field {
	border-left: 3px solid var(--color-accent-light);
	padding-left: var(--space-md);
	background: rgba(228, 181, 75, 0.04);
	border-radius: 0 var(--radius-sm) var(--radius-sm) 0;
	padding-top: 0.5rem;
	padding-bottom: 0.5rem;
	padding-right: 0.5rem;
}

.innovainm-invoice-field label {
	color: var(--color-accent-hover);
}

/* Tutto il gruppo "Richiedi fattura elettronica" è opzionale per definizione
   (si compila solo se l'utente spunta il toggle). Nascondiamo le label
   "(facoltativo)" interne per ridurre rumore e migliorare la wrap su mobile. */
.innovainm-invoice-toggle label .optional,
.innovainm-invoice-field label .optional {
	display: none;
}

/* Mobile: MAI affiancare campi WC (Nome/Cognome, P.IVA/CF, PEC/SDI, ecc.).
   Regola generale su TUTTI i form-row-first/last dentro WC checkout,
   billing address, edit-account. !important per vincere su WC default
   `.form-row-first { float: left; width: 48% }`. */
@media (max-width: 767px) {
	.woocommerce form .form-row-first,
	.woocommerce form .form-row-last,
	.woocommerce-page form .form-row-first,
	.woocommerce-page form .form-row-last,
	form.woocommerce-form .form-row-first,
	form.woocommerce-form .form-row-last,
	.innovainm-invoice-field.form-row-first,
	.innovainm-invoice-field.form-row-last,
	.innovainm-invoice-field.form-row-wide {
		float: none !important;
		width: 100% !important;
		clear: both !important;
		margin-right: 0 !important;
		margin-left: 0 !important;
	}
}

/* Right column: review sidebar */

.innovainm-checkout__aside {
	min-width: 0;
}

@media (min-width: 1024px) {
	.innovainm-checkout__aside {
		position: sticky;
		top: calc(68px + var(--space-md));
	}
}

.innovainm-checkout__aside-inner {
	background: #ffffff;
	border: 1px solid var(--color-border);
	border-radius: var(--radius-lg);
	padding: var(--space-xl);
	box-shadow: var(--shadow-md);
	position: relative;
	overflow: hidden;
}

.innovainm-checkout__aside-inner::before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	height: 4px;
	background: linear-gradient(90deg, var(--color-accent-light), var(--color-accent), var(--color-accent-hover));
}

.innovainm-checkout__aside-title {
	display: flex;
	align-items: center;
	gap: 0.6rem;
	font-family: var(--font-heading);
	font-size: 1.15rem;
	font-weight: 700;
	color: var(--color-primary);
	letter-spacing: -0.01em;
	margin: 0 0 var(--space-md);
}

.innovainm-checkout__step--sidebar {
	width: 28px;
	height: 28px;
	font-size: 0.85rem;
}

/* Items list in review */

.innovainm-review__items {
	list-style: none;
	margin: 0 0 var(--space-md);
	padding: 0 0 var(--space-md);
	border-bottom: 1px dashed var(--color-border);
	max-height: 280px;
	overflow-y: auto;
}

.innovainm-review__item {
	display: grid;
	grid-template-columns: 36px minmax(0, 1fr);
	gap: 0.6rem;
	padding: 0.5rem 0;
	align-items: center;
}

.innovainm-review__item + .innovainm-review__item {
	border-top: 1px solid var(--color-border);
}

.innovainm-review__icon {
	grid-column: 1;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 36px;
	height: 36px;
	background: color-mix(in srgb, var(--hue) 12%, #ffffff);
	color: var(--hue);
	border-radius: var(--radius-sm);
}

.innovainm-review__icon svg {
	width: 20px;
	height: 20px;
}

.innovainm-review__body {
	grid-column: 2;
	display: flex;
	flex-direction: column;
	gap: 0.15rem;
	min-width: 0;
}

.innovainm-review__title {
	font-size: 0.9rem;
	font-weight: 600;
	color: var(--color-primary);
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
	line-height: 1.3;
}

.innovainm-review__meta {
	display: flex;
	align-items: baseline;
	justify-content: space-between;
	gap: 0.5rem;
	font-size: 0.82rem;
	color: var(--color-text-light);
}

.innovainm-review__qty {
	color: var(--color-text-light);
	font-variant-numeric: tabular-nums;
}

.innovainm-review__price {
	font-family: var(--font-heading);
	font-weight: 700;
	color: var(--color-primary);
}

/* Lines */

.innovainm-review__lines {
	margin: 0 0 var(--space-md);
	padding: 0 0 var(--space-md);
	border-bottom: 1px dashed var(--color-border);
	display: grid;
	grid-template-columns: 1fr auto;
	gap: 0.5rem 1rem;
	font-size: 0.92rem;
}

.innovainm-review__lines dt {
	color: var(--color-text-light);
	font-weight: 500;
	margin: 0;
}

.innovainm-review__lines dd {
	color: var(--color-primary);
	font-weight: 600;
	margin: 0;
	text-align: right;
	font-variant-numeric: tabular-nums;
}

.innovainm-review__lines .coupon,
.innovainm-review__lines dt.coupon,
.innovainm-review__lines dd.coupon {
	color: var(--color-success);
}

/* Total */

.innovainm-review__total {
	display: flex;
	flex-direction: column;
	gap: 0.35rem;
	margin-bottom: var(--space-md);
	padding: var(--space-md) 0;
	border-top: 2px solid var(--color-border);
	border-bottom: 2px solid var(--color-border);
}

.innovainm-review__total-label {
	font-family: var(--font-heading);
	font-size: 0.72rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	color: var(--color-text-light);
}

.innovainm-review__total-value {
	font-family: var(--font-heading);
	font-size: 1.65rem;
	font-weight: 800;
	color: var(--color-primary);
	letter-spacing: -0.02em;
	font-variant-numeric: tabular-nums;
	line-height: 1.1;
}

.innovainm-review__total-value strong {
	font-weight: 800;
}

.innovainm-review__total-value small,
.innovainm-review__total-value .includes_tax {
	display: block;
	margin-top: 0.3rem;
	font-family: var(--font-sans);
	font-size: 0.74rem;
	font-weight: 500;
	letter-spacing: 0;
	color: var(--color-text-light);
	line-height: 1.4;
}

.innovainm-review__total-value small .woocommerce-Price-amount,
.innovainm-review__total-value small .woocommerce-Price-currencySymbol {
	font-family: var(--font-sans);
	font-weight: 600;
	color: var(--color-text-light);
}

/* Payment methods */

.innovainm-review__payment {
	margin-top: var(--space-md);
}

.innovainm-review__payment .payment_methods,
.innovainm-review__payment #payment ul.payment_methods {
	list-style: none;
	padding: 0;
	margin: 0 0 var(--space-md);
	display: flex;
	flex-direction: column;
	gap: 0.5rem;
	border-bottom: 0;
	text-align: left;
}

.innovainm-review__payment .payment_methods > li {
	position: relative;
	background: #ffffff;
	border: 1.5px solid var(--color-border);
	border-radius: var(--radius-md);
	padding: var(--space-md);
	transition: border-color 0.2s var(--ease-out), box-shadow 0.2s var(--ease-out);
}

/* Mobile: padding ZERO sul container metodo → il form del gateway dentro
   (Stripe, bonifico, ecc.) si gestisce da solo i propri margini interni.
   Selector con specificity boost per battere Payment Plugins Stripe
   (assets/build/stripe.css) che applica `ul.payment_methods li[class*="payment_method"] { padding: 10px 0 }`. */
@media (max-width: 640px) {
	.innovainm-review__payment ul.payment_methods > li[class*="payment_method"],
	.innovainm-review__payment .payment_methods > li {
		padding: 0;
	}
}

.innovainm-review__payment .payment_methods > li:hover {
	border-color: color-mix(in srgb, var(--color-accent) 50%, var(--color-border));
}

.innovainm-review__payment .payment_methods > li.wc_payment_method_selected,
.innovainm-review__payment .payment_methods > li:has(input:checked) {
	border-color: var(--color-accent);
	box-shadow: 0 0 0 3px rgba(228, 181, 75, 0.14);
}

/* Hide native radio — painted indicator lives on the label */
.innovainm-review__payment .payment_methods input[type="radio"] {
	position: absolute;
	opacity: 0;
	pointer-events: none;
	width: 1px;
	height: 1px;
}

.innovainm-review__payment .payment_methods label {
	display: inline-flex;
	align-items: center;
	gap: 0.6rem;
	font-weight: 600;
	color: var(--color-primary);
	cursor: pointer;
	margin: 0;
	line-height: 1.3;
	flex-wrap: wrap;
}

/* Radio indicator rendered as first flex item inside label */
.innovainm-review__payment .payment_methods label::before {
	content: "";
	flex-shrink: 0;
	width: 18px;
	height: 18px;
	border: 2px solid var(--color-border);
	border-radius: 50%;
	background: #ffffff;
	transition: border-color 0.2s var(--ease-out), background 0.2s var(--ease-out), box-shadow 0.2s var(--ease-out);
}

.innovainm-review__payment .payment_methods > li:hover label::before {
	border-color: color-mix(in srgb, var(--color-accent) 60%, var(--color-border));
}

.innovainm-review__payment .payment_methods input[type="radio"]:checked + label::before,
.innovainm-review__payment .payment_methods > li.wc_payment_method_selected label::before {
	border-color: var(--color-primary);
	background: var(--color-primary);
	box-shadow: inset 0 0 0 3px #ffffff;
}

.innovainm-review__payment .payment_methods input[type="radio"]:focus-visible + label::before {
	outline: 2px solid var(--color-accent);
	outline-offset: 2px;
}

/* Payment gateway logos — visa, mastercard, etc */
.innovainm-review__payment .payment_methods label img {
	height: 22px;
	width: auto;
	max-width: 38px;
	vertical-align: middle;
	object-fit: contain;
	display: inline-block;
}

/* Payment box: nessuno stile nostro — lasciamo il plugin gateway (Stripe,
   bonifico, PayPal, ecc.) renderizzare il proprio form con i suoi stili
   nativi. Solo uno spacer minimo sopra per staccarlo dal label metodo. */
.innovainm-review__payment .payment_box {
	margin-top: 0.75rem;
}

/* Terms checkbox */

.innovainm-review__payment .form-row.terms,
.innovainm-review__payment .woocommerce-terms-and-conditions-wrapper {
	margin: var(--space-md) 0;
	font-size: 0.85rem;
}

/* Submit order button */

.innovainm-review__submit,
button#place_order {
	display: inline-flex !important;
	align-items: center;
	justify-content: center;
	width: 100%;
	padding: 1rem 1.5rem !important;
	border: none !important;
	border-radius: var(--radius-md) !important;
	font-family: var(--font-sans) !important;
	font-size: 1.02rem !important;
	font-weight: 700 !important;
	line-height: 1 !important;
	text-transform: none !important;
	letter-spacing: 0 !important;
	background: linear-gradient(135deg, var(--color-accent-light) 0%, var(--color-accent) 50%, var(--color-accent-hover) 100%) !important;
	background-size: 200% 200% !important;
	background-position: 50% 50% !important;
	color: var(--color-primary) !important;
	box-shadow: var(--shadow-sm), 0 2px 8px rgba(228, 181, 75, 0.25) !important;
	transition: all var(--duration) var(--ease-out) !important;
	cursor: pointer;
	margin-top: var(--space-md);
}

.innovainm-review__submit:hover,
button#place_order:hover {
	background-position: 100% 100% !important;
	transform: translateY(-1px);
	box-shadow: var(--shadow-md), var(--shadow-accent) !important;
	color: var(--color-primary) !important;
}

/* Trust strip at bottom */

.innovainm-review__trust {
	list-style: none;
	padding: var(--space-md) 0 0;
	margin: 0;
	border-top: 1px solid var(--color-border);
	display: flex;
	flex-direction: column;
	gap: 0.35rem;
}

.innovainm-review__trust li {
	display: flex;
	align-items: center;
	gap: 0.4rem;
	font-size: 0.78rem;
	color: var(--color-text-light);
}

.innovainm-review__trust svg {
	width: 14px;
	height: 14px;
	color: var(--color-accent);
	flex-shrink: 0;
}


/* ===========================================================
   Account area — layout 2-col + sidebar brand
   =========================================================== */

body.woocommerce-account .page-content > .woocommerce {
	min-width: 0;
}

.innovainm-account {
	display: grid;
	gap: var(--space-xl);
	grid-template-columns: 1fr;
	align-items: start;
}

@media (min-width: 1024px) {
	.innovainm-account {
		grid-template-columns: 280px minmax(0, 1fr);
		gap: var(--space-2xl);
	}
}

/* --- Sidebar --- */

.innovainm-account__sidebar {
	min-width: 0;
}

@media (min-width: 1024px) {
	.innovainm-account__sidebar {
		position: sticky;
		top: calc(68px + var(--space-md));
	}
}

.innovainm-account__profile {
	display: flex;
	align-items: center;
	gap: var(--space-sm);
	padding: var(--space-md);
	background: #ffffff;
	border: 1px solid var(--color-border);
	border-radius: var(--radius-lg);
	box-shadow: var(--shadow-sm);
	margin-bottom: var(--space-md);
	position: relative;
	overflow: hidden;
}

.innovainm-account__profile::before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	height: 3px;
	background: linear-gradient(90deg, var(--color-accent-light), var(--color-accent), var(--color-primary));
}

.innovainm-account__avatar {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 44px;
	height: 44px;
	border-radius: 50%;
	background: linear-gradient(135deg, var(--color-primary), var(--color-primary-light));
	color: #ffffff;
	font-family: var(--font-heading);
	font-weight: 800;
	font-size: 1.15rem;
	flex-shrink: 0;
	letter-spacing: -0.02em;
	box-shadow: 0 4px 10px rgba(20, 42, 79, 0.25);
}

.innovainm-account__profile-info {
	display: flex;
	flex-direction: column;
	gap: 2px;
	min-width: 0;
}

.innovainm-account__profile-name {
	font-family: var(--font-heading);
	font-size: 0.98rem;
	font-weight: 700;
	color: var(--color-primary);
	letter-spacing: -0.01em;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}

.innovainm-account__profile-email {
	font-size: 0.78rem;
	color: var(--color-text-light);
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}

/* Menu nav */

.innovainm-account__menu {
	list-style: none;
	padding: 0;
	margin: 0;
	display: flex;
	flex-direction: column;
	gap: 2px;
	background: #ffffff;
	border: 1px solid var(--color-border);
	border-radius: var(--radius-lg);
	padding: 0.5rem;
}

.innovainm-account__menu-item {
	margin: 0;
	padding: 0;
}

.innovainm-account__menu-link {
	display: flex;
	align-items: center;
	gap: 0.65rem;
	padding: 0.65rem 0.8rem;
	border-radius: var(--radius-sm);
	color: var(--color-text);
	text-decoration: none;
	font-size: 0.92rem;
	font-weight: 500;
	line-height: 1.3;
	transition: all var(--duration) var(--ease-out);
}

.innovainm-account__menu-link:hover {
	background: var(--color-bg-alt);
	color: var(--color-primary);
}

.innovainm-account__menu-item.is-active .innovainm-account__menu-link {
	background: linear-gradient(90deg, rgba(20, 42, 79, 0.05) 0%, rgba(228, 181, 75, 0.08) 100%);
	color: var(--color-primary);
	font-weight: 700;
	box-shadow: inset 3px 0 0 var(--color-accent);
}

.innovainm-account__menu-icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 24px;
	height: 24px;
	color: var(--color-text-light);
	flex-shrink: 0;
	transition: color var(--duration) var(--ease-out);
}

.innovainm-account__menu-icon svg {
	width: 20px;
	height: 20px;
}

.innovainm-account__menu-link:hover .innovainm-account__menu-icon,
.innovainm-account__menu-item.is-active .innovainm-account__menu-icon {
	color: var(--color-accent-hover);
}

/* Customer-logout red tint */
.innovainm-account__menu-item--customer-logout .innovainm-account__menu-link {
	color: var(--color-danger);
}

.innovainm-account__menu-item--customer-logout:hover .innovainm-account__menu-icon,
.innovainm-account__menu-item--customer-logout .innovainm-account__menu-icon {
	color: var(--color-danger);
}

/* --- Main content --- */

.innovainm-account__content {
	min-width: 0;
}

.innovainm-account__hello {
	margin-bottom: var(--space-xl);
}

.innovainm-account__hello-title {
	font-family: var(--font-heading);
	font-size: clamp(1.5rem, 3vw, 2rem);
	font-weight: 800;
	color: var(--color-primary);
	letter-spacing: -0.02em;
	margin: 0 0 var(--space-xs);
}

.innovainm-account__hello-lede,
.innovainm-account__lede {
	color: var(--color-text-light);
	font-size: 1rem;
	line-height: 1.6;
	margin: 0 0 var(--space-lg);
	max-width: 680px;
}

.innovainm-account__section-head {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: var(--space-md);
	margin-bottom: var(--space-md);
}

.innovainm-account__section-head > div {
	display: flex;
	flex-direction: column;
	gap: 0.25rem;
}

.innovainm-account__section-title {
	font-family: var(--font-heading);
	font-size: 1.25rem;
	font-weight: 700;
	color: var(--color-primary);
	letter-spacing: -0.015em;
	margin: 0;
}

.innovainm-account__see-all {
	display: inline-flex;
	align-items: center;
	gap: 0.35rem;
	font-size: 0.88rem;
	font-weight: 600;
	color: var(--color-accent-hover);
	text-decoration: none;
	transition: gap var(--duration) var(--ease-out);
}

.innovainm-account__see-all:hover {
	gap: 0.55rem;
	color: var(--color-accent-hover);
}

.innovainm-account__see-all svg {
	width: 14px;
	height: 14px;
}

.innovainm-account__back {
	display: inline-flex;
	align-items: center;
	gap: 0.3rem;
	font-size: 0.82rem;
	color: var(--color-text-light);
	text-decoration: none;
	margin-bottom: 0.25rem;
}

.innovainm-account__back:hover {
	color: var(--color-primary);
}

.innovainm-account__back svg {
	width: 14px;
	height: 14px;
}

.innovainm-account__subtitle {
	font-family: var(--font-heading);
	font-size: 0.82rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	color: var(--color-text-light);
	margin: 0 0 var(--space-sm);
}

/* --- Summary cards --- */

.innovainm-account__stats {
	display: grid;
	gap: var(--space-md);
	grid-template-columns: 1fr;
	margin-bottom: var(--space-2xl);
}

@media (min-width: 576px) {
	.innovainm-account__stats {
		grid-template-columns: repeat(2, 1fr);
	}
}

@media (min-width: 1200px) {
	.innovainm-account__stats {
		grid-template-columns: repeat(4, 1fr);
	}
}

.innovainm-account-card {
	position: relative;
	display: flex;
	flex-direction: column;
	gap: 0.35rem;
	padding: var(--space-lg);
	background: #ffffff;
	border: 1px solid var(--color-border);
	border-radius: var(--radius-md);
	box-shadow: var(--shadow-sm);
	transition: transform var(--duration) var(--ease-out), box-shadow var(--duration) var(--ease-out);
}

.innovainm-account-card:hover {
	transform: translateY(-2px);
	box-shadow: var(--shadow-md);
}

.innovainm-account-card__icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 40px;
	height: 40px;
	color: var(--color-primary);
	background: rgba(20, 42, 79, 0.06);
	border-radius: var(--radius-sm);
	margin-bottom: var(--space-xs);
}

.innovainm-account-card__icon svg {
	width: 22px;
	height: 22px;
}

.innovainm-account-card--accent .innovainm-account-card__icon {
	color: var(--color-accent-hover);
	background: rgba(228, 181, 75, 0.15);
}

.innovainm-account-card__value {
	font-family: var(--font-heading);
	font-size: 2rem;
	font-weight: 800;
	color: var(--color-primary);
	letter-spacing: -0.025em;
	line-height: 1.1;
	font-variant-numeric: tabular-nums;
}

.innovainm-account-card__label {
	font-size: 0.85rem;
	color: var(--color-text-light);
	font-weight: 500;
}

.innovainm-account-card__badge {
	position: absolute;
	top: var(--space-md);
	right: var(--space-md);
	padding: 2px 8px;
	background: rgba(20, 42, 79, 0.06);
	color: var(--color-text-light);
	font-size: 0.68rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	border-radius: 10px;
}

.innovainm-account-card--muted {
	opacity: 0.78;
}

.innovainm-account-card--muted .innovainm-account-card__value {
	color: var(--color-text-light);
}

/* Variante "link": la card è un <a> cliccabile verso una sezione dell'account. */
a.innovainm-account-card,
.innovainm-account-card--link {
	text-decoration: none;
	color: inherit;
	cursor: pointer;
}

a.innovainm-account-card:hover .innovainm-account-card__value,
.innovainm-account-card--link:hover .innovainm-account-card__value {
	color: var(--color-accent);
	transition: color var(--duration) var(--ease-out);
}

/* --- Order card --- */

.innovainm-orders-list {
	list-style: none;
	padding: 0;
	margin: 0;
	display: flex;
	flex-direction: column;
	gap: var(--space-md);
}

.innovainm-order-card {
	background: #ffffff;
	border: 1px solid var(--color-border);
	border-radius: var(--radius-md);
	padding: var(--space-lg);
	box-shadow: var(--shadow-sm);
	transition: box-shadow var(--duration) var(--ease-out);
	display: flex;
	flex-direction: column;
	gap: var(--space-md);
}

.innovainm-order-card:hover {
	box-shadow: var(--shadow-md);
}

.innovainm-order-card__head {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: var(--space-sm);
	flex-wrap: wrap;
}

.innovainm-order-card__number {
	font-family: var(--font-heading);
	font-size: 1.05rem;
	font-weight: 800;
	color: var(--color-primary);
	letter-spacing: -0.01em;
}

.innovainm-order-card__status {
	display: inline-flex;
	align-items: center;
	gap: 0.35rem;
	padding: 3px 10px;
	border-radius: 999px;
	font-family: var(--font-heading);
	font-size: 0.72rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	background: var(--color-bg-alt);
	color: var(--color-text-light);
}

.innovainm-order-card__status--processing,
.innovainm-order-card__status--on-hold,
.innovainm-order-card__status--pending {
	background: rgba(228, 181, 75, 0.18);
	color: var(--color-accent-hover);
}

.innovainm-order-card__status--completed {
	background: rgba(26, 138, 92, 0.14);
	color: var(--color-success);
}

.innovainm-order-card__status--cancelled,
.innovainm-order-card__status--failed,
.innovainm-order-card__status--refunded {
	background: rgba(181, 42, 28, 0.1);
	color: var(--color-danger);
}

.innovainm-order-card__meta {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 0.4rem;
	font-size: 0.85rem;
	color: var(--color-text-light);
}

.innovainm-order-card__total {
	font-family: var(--font-heading);
	font-weight: 700;
	color: var(--color-primary);
	margin-left: auto;
	font-variant-numeric: tabular-nums;
}

.innovainm-order-card__items {
	list-style: none;
	padding: 0;
	margin: 0;
	display: flex;
	flex-direction: column;
	gap: 0.5rem;
}

.innovainm-order-card__item {
	display: grid;
	grid-template-columns: 30px minmax(0, 1fr) auto;
	gap: 0.6rem;
	align-items: center;
	padding: 0.5rem 0.65rem;
	background: var(--color-bg-alt);
	border-left: 3px solid var(--hue, var(--color-accent));
	border-radius: var(--radius-sm);
	font-size: 0.88rem;
}

.innovainm-order-card__item-icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 30px;
	height: 30px;
	color: var(--hue, var(--color-accent));
}

.innovainm-order-card__item-icon svg {
	width: 18px;
	height: 18px;
}

.innovainm-order-card__item-name {
	color: var(--color-text);
	font-weight: 500;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}

.innovainm-order-card__item-qty {
	color: var(--color-text-light);
	font-variant-numeric: tabular-nums;
	font-weight: 600;
}

.innovainm-order-card__item--more {
	display: flex;
	justify-content: center;
	background: transparent;
	border: 1px dashed var(--color-border);
	color: var(--color-text-light);
	font-size: 0.82rem;
	font-weight: 500;
	padding: 0.4rem;
}

.innovainm-order-card__foot {
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem;
	padding-top: var(--space-sm);
	border-top: 1px dashed var(--color-border);
}

.innovainm-order-card__foot .btn {
	font-size: 0.88rem;
	padding: 0.55rem 1rem;
}

/* --- View single order --- */

.innovainm-order-view {
	display: flex;
	flex-direction: column;
	gap: var(--space-xl);
}

.innovainm-order-view__hero {
	display: grid;
	gap: var(--space-md);
	grid-template-columns: 1fr;
	padding: var(--space-lg);
	background: linear-gradient(135deg, var(--color-primary) 0%, var(--color-primary-light) 100%);
	color: #ffffff;
	border-radius: var(--radius-lg);
	position: relative;
	overflow: hidden;
}

.innovainm-order-view__hero::before {
	content: "";
	position: absolute;
	right: -30px;
	top: -30px;
	width: 180px;
	height: 180px;
	background: radial-gradient(circle, rgba(228, 181, 75, 0.25), transparent 70%);
	pointer-events: none;
}

@media (min-width: 640px) {
	.innovainm-order-view__hero {
		grid-template-columns: repeat(3, 1fr);
	}
}

.innovainm-order-view__hero-row {
	display: flex;
	flex-direction: column;
	gap: 0.25rem;
	position: relative;
	z-index: 1;
}

.innovainm-order-view__hero-label {
	font-size: 0.72rem;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	color: rgba(255, 255, 255, 0.65);
	font-weight: 600;
}

.innovainm-order-view__hero-value {
	font-size: 1rem;
	font-weight: 600;
}

.innovainm-order-view__hero-value--total {
	font-family: var(--font-heading);
	font-size: 1.5rem;
	font-weight: 800;
	letter-spacing: -0.02em;
	color: var(--color-accent-light);
}

.innovainm-order-view__items-list {
	list-style: none;
	padding: 0;
	margin: 0 0 var(--space-md);
	display: flex;
	flex-direction: column;
	gap: 0.5rem;
}

.innovainm-order-view__item {
	display: grid;
	grid-template-columns: 40px minmax(0, 1fr) auto auto;
	gap: var(--space-sm);
	align-items: center;
	padding: var(--space-md);
	background: #ffffff;
	border: 1px solid var(--color-border);
	border-left: 3px solid var(--hue);
	border-radius: var(--radius-sm);
}

.innovainm-order-view__item-icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 40px;
	height: 40px;
	background: color-mix(in srgb, var(--hue) 10%, #ffffff);
	color: var(--hue);
	border-radius: var(--radius-sm);
}

.innovainm-order-view__item-icon svg {
	width: 22px;
	height: 22px;
}

.innovainm-order-view__item-body {
	display: flex;
	flex-direction: column;
	gap: 0.2rem;
	min-width: 0;
}

.innovainm-order-view__item-pill {
	align-self: flex-start;
	font-size: 0.68rem;
	font-weight: 700;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	padding: 2px 8px;
	background: color-mix(in srgb, var(--hue) 12%, #ffffff);
	color: var(--hue);
	border-radius: 10px;
}

a.innovainm-order-view__item-name,
.innovainm-order-view__item-name {
	font-weight: 600;
	color: var(--color-primary) !important;
	text-decoration: none;
	border-bottom: none;
}

a.innovainm-order-view__item-name:hover {
	color: var(--color-accent-hover) !important;
}

.innovainm-order-view__item-qty {
	color: var(--color-text-light);
	font-weight: 600;
	font-variant-numeric: tabular-nums;
}

.innovainm-order-view__item-total {
	font-family: var(--font-heading);
	font-weight: 700;
	color: var(--color-primary);
	font-variant-numeric: tabular-nums;
	text-align: right;
}

@media (max-width: 600px) {
	.innovainm-order-view__item {
		grid-template-columns: 40px minmax(0, 1fr);
		grid-template-rows: auto auto;
	}
	.innovainm-order-view__item-qty,
	.innovainm-order-view__item-total {
		grid-column: 2;
		justify-self: end;
	}
}

.innovainm-order-view__totals {
	display: grid;
	grid-template-columns: 1fr auto;
	gap: 0.4rem 1rem;
	padding: var(--space-md);
	background: var(--color-bg-alt);
	border-radius: var(--radius-sm);
}

.innovainm-order-view__totals dt {
	color: var(--color-text-light);
	margin: 0;
	font-size: 0.92rem;
}

.innovainm-order-view__totals dd {
	color: var(--color-primary);
	font-weight: 600;
	text-align: right;
	margin: 0;
	font-variant-numeric: tabular-nums;
}

.innovainm-order-view__totals dt:last-of-type,
.innovainm-order-view__totals dd:last-of-type {
	padding-top: 0.4rem;
	border-top: 2px solid var(--color-border);
	font-family: var(--font-heading);
	font-size: 1.1rem;
	font-weight: 800;
}

.innovainm-order-view__addresses-grid {
	display: grid;
	gap: var(--space-md);
	grid-template-columns: 1fr;
}

@media (min-width: 640px) {
	.innovainm-order-view__addresses-grid {
		grid-template-columns: repeat(2, 1fr);
	}
}

.innovainm-order-view__address-card {
	padding: var(--space-md);
	background: #ffffff;
	border: 1px solid var(--color-border);
	border-radius: var(--radius-sm);
	font-size: 0.92rem;
	line-height: 1.6;
	color: var(--color-text);
}

.innovainm-order-view__address-card address {
	font-style: normal;
	color: var(--color-text);
}

.innovainm-order-view__address-label {
	display: block;
	font-family: var(--font-heading);
	font-size: 0.72rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	color: var(--color-text-light);
	margin-bottom: 0.4rem;
}

.innovainm-order-view__address-line {
	margin: 0.2rem 0 0;
	font-size: 0.88rem;
	color: var(--color-text-light);
}

.innovainm-order-view__notes-list {
	list-style: none;
	padding: 0;
	margin: 0;
	display: flex;
	flex-direction: column;
	gap: var(--space-sm);
	padding-left: var(--space-md);
	border-left: 2px solid var(--color-border);
}

.innovainm-order-view__note {
	position: relative;
}

.innovainm-order-view__note::before {
	content: "";
	position: absolute;
	left: calc(-1 * var(--space-md) - 5px);
	top: 8px;
	width: 10px;
	height: 10px;
	background: var(--color-accent);
	border-radius: 50%;
	border: 2px solid #ffffff;
	box-shadow: 0 0 0 2px var(--color-accent);
}

.innovainm-order-view__note-date {
	display: block;
	font-size: 0.78rem;
	color: var(--color-text-light);
	font-weight: 500;
	margin-bottom: 0.15rem;
}

.innovainm-order-view__note-body p {
	margin: 0 0 0.4em;
	color: var(--color-text);
}

/* --- Addresses list --- */

.innovainm-address-grid {
	display: grid;
	gap: var(--space-md);
	grid-template-columns: 1fr;
}

@media (min-width: 768px) {
	.innovainm-address-grid {
		grid-template-columns: repeat(2, 1fr);
	}
}

.innovainm-address-card {
	background: #ffffff;
	border: 1px solid var(--color-border);
	border-radius: var(--radius-md);
	padding: var(--space-lg);
	box-shadow: var(--shadow-sm);
}

.innovainm-address-card__head {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: var(--space-sm);
	margin-bottom: var(--space-sm);
}

.innovainm-address-card__title {
	font-family: var(--font-heading);
	font-size: 1.02rem;
	font-weight: 700;
	color: var(--color-primary);
	letter-spacing: -0.01em;
	margin: 0;
}

.innovainm-address-card__body {
	font-style: normal;
	color: var(--color-text);
	line-height: 1.65;
	font-size: 0.95rem;
}

.innovainm-address-card__empty {
	color: var(--color-text-light);
	font-style: italic;
	margin: 0;
}

/* --- Account form (edit-account / edit-address) --- */

.innovainm-account-form {
	display: flex;
	flex-direction: column;
	gap: var(--space-md);
}

.innovainm-account-form__actions {
	display: flex;
	flex-wrap: wrap;
	gap: var(--space-sm);
	align-items: center;
}

.innovainm-account-form__hint {
	display: block;
	margin-top: 0.35rem;
	color: var(--color-text-light);
	font-size: 0.82rem;
	line-height: 1.45;
	font-weight: 400;
}

/* --- Shortcuts --- */

.innovainm-account__shortcuts {
	margin-top: var(--space-2xl);
}

.innovainm-account__shortcuts-grid {
	display: grid;
	gap: var(--space-md);
	grid-template-columns: 1fr;
	margin-top: var(--space-md);
}

@media (min-width: 640px) {
	.innovainm-account__shortcuts-grid {
		grid-template-columns: repeat(3, 1fr);
	}
}

.innovainm-account-shortcut {
	display: flex;
	flex-direction: column;
	gap: 0.35rem;
	padding: var(--space-lg);
	background: #ffffff;
	border: 1px solid var(--color-border);
	border-radius: var(--radius-md);
	text-decoration: none;
	color: inherit;
	transition: transform var(--duration) var(--ease-out), border-color var(--duration) var(--ease-out), box-shadow var(--duration) var(--ease-out);
}

.innovainm-account-shortcut:hover {
	transform: translateY(-2px);
	border-color: var(--color-accent);
	box-shadow: var(--shadow-md);
	color: inherit;
}

.innovainm-account-shortcut__icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 36px;
	height: 36px;
	color: var(--color-accent-hover);
	background: rgba(228, 181, 75, 0.1);
	border-radius: var(--radius-sm);
	margin-bottom: 0.4rem;
}

.innovainm-account-shortcut__icon svg {
	width: 18px;
	height: 18px;
}

.innovainm-account-shortcut__title {
	font-family: var(--font-heading);
	font-size: 1rem;
	font-weight: 700;
	color: var(--color-primary);
	letter-spacing: -0.01em;
}

.innovainm-account-shortcut__desc {
	font-size: 0.88rem;
	color: var(--color-text-light);
	line-height: 1.5;
}

/* --- Empty state --- */

.innovainm-account__empty {
	padding: var(--space-2xl) var(--space-lg);
	text-align: center;
	background: var(--color-bg-alt);
	border-radius: var(--radius-lg);
}

.innovainm-account__empty svg {
	width: 72px;
	height: 72px;
	color: var(--color-text-light);
	margin: 0 auto var(--space-md);
}

.innovainm-account__empty h3 {
	font-size: 1.35rem;
	color: var(--color-primary);
	margin: 0 0 var(--space-xs);
}

.innovainm-account__empty p {
	color: var(--color-text-light);
	margin: 0 0 var(--space-md);
	max-width: 480px;
	margin-left: auto;
	margin-right: auto;
}

/* --- Pagination --- */

.innovainm-account__pagination {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: var(--space-md);
	margin-top: var(--space-xl);
	padding-top: var(--space-md);
	border-top: 1px solid var(--color-border);
}

.innovainm-account__pagination-info {
	font-size: 0.88rem;
	color: var(--color-text-light);
}

/* --- Login / Register split --- */

.innovainm-auth {
	display: grid;
	gap: var(--space-xl);
	grid-template-columns: 1fr;
	align-items: start;
}

@media (min-width: 900px) {
	.innovainm-auth {
		grid-template-columns: repeat(2, 1fr);
		gap: var(--space-2xl);
	}
}

.innovainm-auth__panel {
	background: #ffffff;
	border: 1px solid var(--color-border);
	border-radius: var(--radius-lg);
	padding: var(--space-xl);
	box-shadow: var(--shadow-sm);
	position: relative;
	overflow: hidden;
}

.innovainm-auth__panel::before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	height: 4px;
	background: linear-gradient(90deg, var(--color-primary), var(--color-primary-light));
}

.innovainm-auth__panel--register::before {
	background: linear-gradient(90deg, var(--color-accent-light), var(--color-accent), var(--color-accent-hover));
}

.innovainm-auth__head {
	margin-bottom: var(--space-lg);
}

.innovainm-auth__title {
	font-family: var(--font-heading);
	font-size: 1.5rem;
	font-weight: 800;
	color: var(--color-primary);
	letter-spacing: -0.02em;
	margin: 0 0 0.35rem;
}

.innovainm-auth__lede {
	color: var(--color-text-light);
	font-size: 0.95rem;
	line-height: 1.55;
	margin: 0;
}

.innovainm-auth__form {
	display: flex;
	flex-direction: column;
	gap: var(--space-md);
}

.innovainm-auth__actions {
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: var(--space-sm);
	flex-wrap: wrap;
	margin: 0;
}

.innovainm-auth__remember {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	font-size: 0.88rem;
	color: var(--color-text-light);
	cursor: pointer;
}

.innovainm-auth__remember input {
	accent-color: var(--color-accent-hover);
}

.innovainm-auth__lost {
	font-size: 0.88rem;
	color: var(--color-accent-hover);
	text-decoration: none;
}

.innovainm-auth__lost:hover {
	text-decoration: underline;
}

.innovainm-auth__form .btn {
	width: 100%;
	padding: 0.85rem 1rem;
}

/* Woocommerce notices inside account */
.woocommerce-account .woocommerce-notices-wrapper {
	margin-bottom: var(--space-md);
}


/* ===========================================================
   Documenti cliente (view-order + account)
   =========================================================== */

.innovainm-order-docs {
	margin-top: var(--space-xl);
	padding: var(--space-xl);
	background: #ffffff;
	border: 1px solid var(--color-border);
	border-radius: var(--radius-lg);
	box-shadow: var(--shadow-sm);
	position: relative;
	overflow: hidden;
}

.innovainm-order-docs::before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	height: 4px;
	background: linear-gradient(90deg, var(--color-accent-light), var(--color-accent));
}

.innovainm-order-docs__notice {
	padding: 0.7rem 1rem;
	border-radius: var(--radius-sm);
	font-size: 0.92rem;
	margin-bottom: var(--space-md);
	background: var(--color-bg-alt);
	color: var(--color-text);
}

.innovainm-order-docs__notice--success {
	background: rgba(26, 138, 92, 0.1);
	color: var(--color-success);
	border: 1px solid rgba(26, 138, 92, 0.25);
}

.innovainm-order-docs__notice--error {
	background: rgba(181, 42, 28, 0.08);
	color: var(--color-danger);
	border: 1px solid rgba(181, 42, 28, 0.25);
}

.innovainm-order-docs__grid {
	display: grid;
	gap: var(--space-xl);
	grid-template-columns: 1fr;
	margin-top: var(--space-md);
}

@media (min-width: 900px) {
	.innovainm-order-docs__grid {
		grid-template-columns: repeat(2, 1fr);
	}
}

.innovainm-order-docs__col {
	min-width: 0;
}

.innovainm-order-docs__col-title {
	display: inline-flex;
	align-items: center;
	gap: 0.45rem;
	font-family: var(--font-heading);
	font-size: 0.88rem;
	font-weight: 700;
	letter-spacing: 0.01em;
	color: var(--color-primary);
	margin: 0 0 var(--space-sm);
	text-transform: none;
}

.innovainm-order-docs__col-title svg {
	width: 18px;
	height: 18px;
	color: var(--color-accent-hover);
}

.innovainm-order-docs__empty {
	padding: var(--space-md);
	color: var(--color-text-light);
	font-size: 0.88rem;
	background: var(--color-bg-alt);
	border: 1px dashed var(--color-border);
	border-radius: var(--radius-sm);
	margin: 0 0 var(--space-sm);
}

/* --- Doc list --- */

.innovainm-doc-list {
	list-style: none;
	padding: 0;
	margin: 0 0 var(--space-md);
	display: flex;
	flex-direction: column;
	gap: 0.4rem;
}

.innovainm-doc-item {
	display: grid;
	grid-template-columns: 40px minmax(0, 1fr) auto;
	gap: 0.65rem;
	align-items: center;
	padding: 0.65rem 0.85rem;
	background: var(--color-bg-alt);
	border: 1px solid var(--color-border);
	border-left: 3px solid var(--color-accent);
	border-radius: var(--radius-sm);
	transition: all var(--duration) var(--ease-out);
}

.innovainm-doc-item:hover {
	background: #ffffff;
	border-color: var(--color-accent);
	box-shadow: var(--shadow-sm);
}

.innovainm-doc-item__icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 40px;
	height: 40px;
	background: rgba(228, 181, 75, 0.12);
	color: var(--color-accent-hover);
	border-radius: var(--radius-sm);
}

.innovainm-doc-item__icon svg {
	width: 20px;
	height: 20px;
}

.innovainm-doc-item__body {
	display: flex;
	flex-direction: column;
	gap: 2px;
	min-width: 0;
}

a.innovainm-doc-item__name,
.innovainm-doc-item__name {
	font-weight: 600;
	color: var(--color-primary);
	text-decoration: none;
	border-bottom: none;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}

a.innovainm-doc-item__name:hover {
	color: var(--color-accent-hover);
	text-decoration: underline;
}

.innovainm-doc-item__sub {
	font-size: 0.78rem;
	color: var(--color-text-light);
}

/* Delete button */

.innovainm-doc-item__delete-form {
	margin: 0;
}

.innovainm-doc-item__delete {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 32px;
	height: 32px;
	background: transparent;
	color: var(--color-text-light);
	border: 1px solid transparent;
	border-radius: var(--radius-sm);
	cursor: pointer;
	transition: all var(--duration) var(--ease-out);
}

.innovainm-doc-item__delete:hover {
	color: var(--color-danger);
	background: rgba(181, 42, 28, 0.08);
	border-color: rgba(181, 42, 28, 0.25);
}

.innovainm-doc-item__delete svg {
	width: 16px;
	height: 16px;
}

/* --- Drop zone upload --- */

.innovainm-order-docs__upload {
	display: flex;
	flex-direction: column;
	gap: var(--space-sm);
}

.innovainm-doc-drop {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 0.6rem;
	padding: var(--space-xl) var(--space-md);
	background: #ffffff;
	border: 2px dashed var(--color-border);
	border-radius: var(--radius-md);
	text-align: center;
	cursor: pointer;
	transition: all var(--duration) var(--ease-out);
	position: relative;
}

.innovainm-doc-drop input[type="file"] {
	position: absolute;
	inset: 0;
	opacity: 0;
	cursor: pointer;
}

.innovainm-doc-drop:hover,
.innovainm-doc-drop.is-drag {
	border-color: var(--color-accent);
	background: rgba(228, 181, 75, 0.05);
	transform: translateY(-1px);
}

.innovainm-doc-drop__icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 48px;
	height: 48px;
	background: rgba(228, 181, 75, 0.12);
	color: var(--color-accent-hover);
	border-radius: 50%;
}

.innovainm-doc-drop__icon svg {
	width: 26px;
	height: 26px;
}

.innovainm-doc-drop__text {
	display: flex;
	flex-direction: column;
	gap: 2px;
	color: var(--color-text);
}

.innovainm-doc-drop__text strong {
	font-family: var(--font-heading);
	font-weight: 700;
	color: var(--color-primary);
	font-size: 1rem;
}

.innovainm-doc-drop__text span {
	font-size: 0.88rem;
	color: var(--color-text-light);
}

.innovainm-doc-drop__hint {
	font-size: 0.78rem !important;
	color: var(--color-text-light);
	margin-top: 0.3rem;
}

.innovainm-doc-drop__filename {
	display: inline-flex;
	align-items: center;
	padding: 0.35rem 0.85rem;
	background: var(--color-accent);
	color: var(--color-primary);
	border-radius: 999px;
	font-size: 0.85rem;
	font-weight: 600;
	margin-top: 0.35rem;
}

.innovainm-order-docs__submit {
	align-self: flex-start;
	padding: 0.7rem 1.4rem;
}

/* Admin metabox style tweaks */
.innovainm-doc-list--admin .innovainm-doc-item {
	background: #f9fafc;
}

/* ===========================================================
   BOOKING — pagina /prenota/ + endpoint /account/appuntamenti/
   =========================================================== */

.innovainm-booking {
	display: block;
	margin: 0 auto;
}

.innovainm-booking__notice {
	display: flex;
	align-items: flex-start;
	gap: 1rem;
	padding: 1.1rem 1.3rem;
	border-radius: var(--radius-lg);
	margin-bottom: var(--space-xl);
	font-size: 0.95rem;
	line-height: 1.5;
	box-shadow: var(--shadow-sm);
}

.innovainm-booking__notice svg {
	width: 28px;
	height: 28px;
	flex: 0 0 auto;
}

.innovainm-booking__notice--success {
	background: #e9f7f0;
	color: #0c5c3c;
	border: 1px solid #b7e3cb;
}

.innovainm-booking__notice--success h3 {
	font-family: var(--font-heading);
	font-size: 1.1rem;
	margin-bottom: 0.2rem;
}

.innovainm-booking__notice--error {
	background: #fdecea;
	color: #8a1e13;
	border: 1px solid #f3b8af;
}

.innovainm-booking__layout {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--space-xl);
	align-items: start;
}

@media (min-width: 900px) {
	.innovainm-booking__layout {
		grid-template-columns: 1.05fr 0.95fr;
		gap: var(--space-2xl);
	}
}

.innovainm-booking__pane {
	background: var(--color-bg);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-lg);
	padding: var(--space-xl);
	box-shadow: var(--shadow-md);
}

.innovainm-booking__pane-title {
	display: flex;
	align-items: center;
	gap: 0.6rem;
	font-family: var(--font-heading);
	font-size: 1.2rem;
	font-weight: 700;
	color: var(--color-primary);
	margin-bottom: 0.4rem;
}

.innovainm-booking__pane-title svg {
	width: 22px;
	height: 22px;
	color: var(--color-accent);
}

.innovainm-booking__pane-lede {
	font-size: 0.92rem;
	color: var(--color-text-light);
	margin-bottom: var(--space-lg);
	line-height: 1.5;
}

/* -- Calendario -- */

.innovainm-booking-cal {
	margin-bottom: var(--space-lg);
}

.innovainm-booking-cal__nav {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 0.8rem;
	margin-bottom: 0.9rem;
}

.innovainm-booking-cal__label {
	font-family: var(--font-heading);
	font-weight: 700;
	font-size: 1rem;
	color: var(--color-primary);
	text-transform: capitalize;
}

.innovainm-booking-cal__arrow {
	width: 36px;
	height: 36px;
	border-radius: 50%;
	border: 1px solid var(--color-border);
	background: var(--color-bg);
	color: var(--color-primary);
	display: inline-flex;
	align-items: center;
	justify-content: center;
	cursor: pointer;
	transition: background var(--duration) var(--ease-out), border-color var(--duration) var(--ease-out);
}

.innovainm-booking-cal__arrow svg {
	width: 16px;
	height: 16px;
}

.innovainm-booking-cal__arrow:hover:not(:disabled) {
	background: var(--color-bg-alt);
	border-color: var(--color-primary);
}

.innovainm-booking-cal__arrow:disabled {
	opacity: 0.35;
	cursor: not-allowed;
}

.innovainm-booking-cal__week {
	display: grid;
	grid-template-columns: repeat(7, minmax(0, 1fr));
	gap: 0.4rem;
}

.innovainm-booking-cal__day {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	gap: 0.1rem;
	padding: 0.65rem 0.2rem;
	border-radius: var(--radius-md);
	border: 1px solid var(--color-border);
	background: var(--color-bg);
	color: var(--color-primary);
	cursor: pointer;
	font-family: var(--font-sans);
	line-height: 1.1;
	transition: all var(--duration) var(--ease-out);
}

.innovainm-booking-cal__dow {
	font-size: 0.7rem;
	font-weight: 600;
	color: var(--color-text-light);
	text-transform: uppercase;
	letter-spacing: 0.04em;
}

.innovainm-booking-cal__num {
	font-family: var(--font-heading);
	font-size: 1.25rem;
	font-weight: 700;
	color: var(--color-primary);
}

.innovainm-booking-cal__mon {
	font-size: 0.68rem;
	color: var(--color-text-light);
	text-transform: uppercase;
	letter-spacing: 0.04em;
}

.innovainm-booking-cal__day:hover:not(:disabled):not(.is-selected) {
	border-color: var(--color-accent);
	background: var(--color-bg-alt);
	transform: translateY(-1px);
}

.innovainm-booking-cal__day.is-today:not(.is-selected) {
	border-color: var(--color-accent);
	box-shadow: 0 0 0 2px rgba(228, 181, 75, 0.18);
}

.innovainm-booking-cal__day.is-selected {
	background: var(--color-primary);
	border-color: var(--color-primary);
	color: #fff;
	box-shadow: var(--shadow-accent);
}

.innovainm-booking-cal__day.is-selected .innovainm-booking-cal__dow,
.innovainm-booking-cal__day.is-selected .innovainm-booking-cal__num,
.innovainm-booking-cal__day.is-selected .innovainm-booking-cal__mon {
	color: #fff;
}

.innovainm-booking-cal__day.is-past,
.innovainm-booking-cal__day:disabled {
	opacity: 0.35;
	cursor: not-allowed;
}

/* -- Slot grid -- */

.innovainm-booking-slots {
	border-top: 1px dashed var(--color-border);
	padding-top: var(--space-md);
	min-height: 100px;
}

.innovainm-booking-slots__hint,
.innovainm-booking-slots__empty,
.innovainm-booking-slots__error {
	font-size: 0.88rem;
	color: var(--color-text-light);
	padding: 0.6rem 0;
}

.innovainm-booking-slots__error {
	color: var(--color-danger);
}

.innovainm-booking-slots__loader {
	display: flex;
	align-items: center;
	gap: 0.6rem;
	font-size: 0.88rem;
	color: var(--color-text-light);
	padding: 0.6rem 0;
}

.innovainm-booking-slots__spinner {
	width: 16px;
	height: 16px;
	border: 2px solid var(--color-border);
	border-top-color: var(--color-primary);
	border-radius: 50%;
	animation: innovainm-booking-spin 0.8s linear infinite;
}

@keyframes innovainm-booking-spin {
	to { transform: rotate(360deg); }
}

.innovainm-booking-slots__grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(88px, 1fr));
	gap: 0.55rem;
	padding: 0.3rem 0;
}

.innovainm-booking-slots__pill {
	appearance: none;
	border: 1px solid var(--color-border);
	background: var(--color-bg);
	color: var(--color-primary);
	border-radius: 999px;
	padding: 0.55rem 0.9rem;
	font-family: var(--font-sans);
	font-weight: 600;
	font-size: 0.9rem;
	cursor: pointer;
	transition: all var(--duration) var(--ease-out);
}

.innovainm-booking-slots__pill:hover:not(.is-selected) {
	border-color: var(--color-accent);
	background: var(--color-bg-alt);
}

.innovainm-booking-slots__pill.is-selected {
	background: var(--color-accent);
	border-color: var(--color-accent);
	color: var(--color-primary);
	box-shadow: var(--shadow-accent);
}

/* -- Form -- */

.innovainm-booking-summary {
	display: flex;
	flex-direction: column;
	gap: 0.15rem;
	padding: 0.75rem 1rem;
	border-radius: var(--radius-md);
	background: linear-gradient(90deg, rgba(228, 181, 75, 0.14), rgba(228, 181, 75, 0.04));
	border: 1px solid rgba(228, 181, 75, 0.4);
	margin-bottom: var(--space-md);
}

.innovainm-booking-summary__label {
	font-size: 0.75rem;
	text-transform: uppercase;
	letter-spacing: 0.06em;
	color: var(--color-text-light);
	font-weight: 600;
}

.innovainm-booking-summary__value {
	font-family: var(--font-heading);
	font-weight: 700;
	color: var(--color-primary);
	font-size: 1.02rem;
}

.innovainm-booking-form__grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--space-md);
	margin-bottom: var(--space-md);
}

@media (min-width: 560px) {
	.innovainm-booking-form__grid {
		grid-template-columns: 1fr 1fr;
	}
}

.innovainm-booking-form__field {
	display: flex;
	flex-direction: column;
	gap: 0.35rem;
}

.innovainm-booking-form__field label,
.innovainm-booking-form__types legend {
	font-size: 0.85rem;
	font-weight: 600;
	color: var(--color-primary);
}

.innovainm-booking-form__field .required {
	color: var(--color-danger);
	margin-left: 0.15rem;
}

.innovainm-booking-form input[type="text"],
.innovainm-booking-form input[type="email"],
.innovainm-booking-form input[type="tel"],
.innovainm-booking-form textarea {
	width: 100%;
	padding: 0.7rem 0.9rem;
	border-radius: var(--radius-md);
	border: 1px solid var(--color-border);
	background: var(--color-bg);
	color: var(--color-text);
	font-family: var(--font-sans);
	font-size: 0.95rem;
	transition: border-color var(--duration) var(--ease-out), box-shadow var(--duration) var(--ease-out);
}

.innovainm-booking-form input:focus,
.innovainm-booking-form textarea:focus {
	outline: none;
	border-color: var(--color-accent);
	box-shadow: 0 0 0 3px rgba(228, 181, 75, 0.18);
}

.innovainm-booking-form textarea {
	resize: vertical;
	min-height: 96px;
}

.innovainm-booking-form__types {
	border: 0;
	padding: 0;
	margin: 0 0 var(--space-md);
	display: flex;
	flex-direction: column;
	gap: 0.5rem;
}

.innovainm-booking-form__types legend {
	margin-bottom: 0.4rem;
}

.innovainm-booking-form__type {
	display: flex;
	align-items: flex-start;
	gap: 0.7rem;
	padding: 0.75rem 0.9rem;
	border: 1px solid var(--color-border);
	border-radius: var(--radius-md);
	cursor: pointer;
	transition: all var(--duration) var(--ease-out);
}

.innovainm-booking-form__type:hover {
	border-color: var(--color-accent);
	background: var(--color-bg-alt);
}

.innovainm-booking-form__type input[type="radio"] {
	margin-top: 0.2rem;
	accent-color: var(--color-primary);
}

.innovainm-booking-form__type:has(input[type="radio"]:checked) {
	border-color: var(--color-primary);
	background: rgba(20, 42, 79, 0.04);
	box-shadow: 0 0 0 2px rgba(20, 42, 79, 0.1);
}

.innovainm-booking-form__type-body {
	display: flex;
	flex-direction: column;
	gap: 0.1rem;
}

.innovainm-booking-form__type-body strong {
	font-family: var(--font-heading);
	color: var(--color-primary);
	font-size: 0.98rem;
}

.innovainm-booking-form__type-body span {
	font-size: 0.82rem;
	color: var(--color-text-light);
	line-height: 1.4;
}

.innovainm-booking-form__consent {
	display: flex;
	gap: 0.6rem;
	align-items: flex-start;
	font-size: 0.85rem;
	color: var(--color-text-light);
	line-height: 1.5;
	margin: var(--space-md) 0;
}

.innovainm-booking-form__consent input[type="checkbox"] {
	margin-top: 0.2rem;
	accent-color: var(--color-primary);
	flex: 0 0 auto;
}

.innovainm-booking-form__consent a {
	color: var(--color-primary);
	text-decoration: underline;
}

.innovainm-booking-form__actions {
	display: flex;
	flex-direction: column;
	gap: 0.55rem;
	margin-top: var(--space-sm);
}

.innovainm-booking-form__actions .btn[disabled] {
	opacity: 0.55;
	cursor: not-allowed;
}

.innovainm-booking-form__hint {
	font-size: 0.82rem;
	color: var(--color-text-light);
}

/* ===========================================================
   ACCOUNT — endpoint /account/appuntamenti/
   =========================================================== */

.innovainm-account-appts__cta {
	margin: var(--space-md) 0 var(--space-lg);
}

.innovainm-account-appts__sub {
	font-family: var(--font-heading);
	font-weight: 700;
	color: var(--color-primary);
	font-size: 1.05rem;
	margin: var(--space-lg) 0 var(--space-sm);
	padding-bottom: 0.4rem;
	border-bottom: 1px solid var(--color-border);
}

.innovainm-account-appts__empty {
	padding: var(--space-lg);
	background: var(--color-bg-alt);
	border-radius: var(--radius-lg);
	color: var(--color-text-light);
	text-align: center;
}

.innovainm-appointment-list {
	list-style: none;
	padding: 0;
	margin: 0;
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--space-md);
}

.innovainm-appointment-card {
	display: grid;
	grid-template-columns: 88px 1fr;
	gap: var(--space-md);
	padding: var(--space-md);
	background: var(--color-bg);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-lg);
	box-shadow: var(--shadow-sm);
	transition: box-shadow var(--duration) var(--ease-out);
}

.innovainm-appointment-card:hover {
	box-shadow: var(--shadow-md);
}

.innovainm-appointment-card--past {
	opacity: 0.82;
}

.innovainm-appointment-card__date {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	gap: 0.1rem;
	padding: 0.6rem 0.3rem;
	background: var(--color-primary);
	color: #fff;
	border-radius: var(--radius-md);
	line-height: 1;
}

.innovainm-appointment-card__month {
	font-size: 0.75rem;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	font-weight: 600;
	color: var(--color-accent);
}

.innovainm-appointment-card__day {
	font-family: var(--font-heading);
	font-size: 2rem;
	font-weight: 800;
	color: #fff;
}

.innovainm-appointment-card__year {
	font-size: 0.7rem;
	opacity: 0.7;
}

.innovainm-appointment-card__body {
	display: flex;
	flex-direction: column;
	gap: 0.5rem;
	min-width: 0;
}

.innovainm-appointment-card__head {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 0.5rem;
}

.innovainm-appointment-card__time {
	font-family: var(--font-heading);
	font-weight: 700;
	color: var(--color-primary);
	font-size: 1.05rem;
	margin-right: 0.3rem;
}

.innovainm-appointment-card__badge {
	display: inline-flex;
	align-items: center;
	gap: 0.3rem;
	padding: 0.22rem 0.6rem;
	border-radius: 999px;
	font-size: 0.76rem;
	font-weight: 600;
	line-height: 1.2;
}

.innovainm-appointment-card__badge svg {
	width: 14px;
	height: 14px;
}

.innovainm-appointment-card__badge--type {
	background: var(--color-bg-alt);
	color: var(--color-primary);
	border: 1px solid var(--color-border);
}

.innovainm-appointment-card__badge--online {
	background: #eaf2fb;
	color: #154a8a;
	border-color: #c6dbf3;
}

.innovainm-appointment-card__badge--in_person {
	background: #fbf2de;
	color: #7a5311;
	border-color: #eed8a1;
}

.innovainm-appointment-card__badge--status {
	text-transform: uppercase;
	letter-spacing: 0.04em;
	font-size: 0.7rem;
}

.innovainm-appointment-card__badge--pending {
	background: #fff3d6;
	color: #7a5311;
}

.innovainm-appointment-card__badge--confirmed {
	background: #e1f3e9;
	color: #0c5c3c;
}

.innovainm-appointment-card__badge--cancelled {
	background: #fbe1dd;
	color: #8a1e13;
}

.innovainm-appointment-card__badge--completed {
	background: var(--color-bg-alt);
	color: var(--color-text-light);
}

.innovainm-appointment-card__notes {
	font-size: 0.88rem;
	color: var(--color-text-light);
	line-height: 1.5;
}

.innovainm-appointment-card__actions {
	margin-top: 0.2rem;
}

.innovainm-appointment-card__actions .btn {
	display: inline-flex;
	align-items: center;
	gap: 0.4rem;
}

.innovainm-appointment-card__actions svg {
	width: 15px;
	height: 15px;
}

/* Responsive tweaks */
@media (max-width: 560px) {
	.innovainm-appointment-card {
		grid-template-columns: 72px 1fr;
		gap: 0.8rem;
	}
	.innovainm-appointment-card__day {
		font-size: 1.6rem;
	}
}


/* Fix: attributo hidden HTML deve vincere anche su display:flex dei booking slots */
.innovainm-booking-slots [hidden],
.innovainm-booking-form [hidden],
.innovainm-booking-cal [hidden] {
	display: none !important;
}


/* ==========================================================================
   Service Ticker — marquee auto-scroll per servizi correlati / featured
   ========================================================================== */

.service-ticker {
	max-width: var(--container-max);
	margin: 0 auto;
	padding: var(--space-2xl) var(--container-padding);
}

.service-ticker__head {
	display: flex;
	align-items: flex-end;
	justify-content: space-between;
	gap: var(--space-lg);
	margin: 0 0 var(--space-xl);
	flex-wrap: wrap;
}

.service-ticker__head-text {
	max-width: 780px;
	min-width: 0;
}

.service-ticker__title {
	font-family: var(--font-display);
	font-size: clamp(1.75rem, 3vw, 2.25rem);
	line-height: 1.15;
	color: var(--color-primary);
	letter-spacing: -0.01em;
	margin: 0 0 var(--space-sm);
}

.service-ticker__lede {
	color: var(--color-text-light);
	line-height: 1.55;
	margin: 0;
	font-size: 1rem;
}

.service-ticker__view-all {
	display: inline-flex;
	align-items: center;
	gap: 0.4rem;
	padding: 0.6rem 1rem;
	font-size: 0.85rem;
	font-weight: 600;
	letter-spacing: 0.01em;
	color: var(--color-primary);
	background: transparent;
	border: 1px solid var(--color-border);
	border-radius: 999px;
	text-decoration: none;
	white-space: nowrap;
	transition: border-color 160ms ease, color 160ms ease, background 160ms ease, transform 160ms ease;
}

.service-ticker__view-all:hover,
.service-ticker__view-all:focus-visible {
	border-color: var(--color-accent);
	color: var(--color-accent);
	background: rgba(228, 181, 75, 0.08);
	outline: none;
}

.service-ticker__view-all svg {
	transition: transform 200ms ease;
}

.service-ticker__view-all:hover svg,
.service-ticker__view-all:focus-visible svg {
	transform: translateX(3px);
}

.service-ticker__viewport {
	overflow-x: auto;
	overflow-y: hidden;
	touch-action: pan-x;
	cursor: grab;
	-webkit-overflow-scrolling: touch;
	scrollbar-width: none;
	-ms-overflow-style: none;
	-webkit-user-select: none;
	user-select: none;
	-webkit-mask-image: linear-gradient(
		to right,
		transparent 0,
		#000 40px,
		#000 calc(100% - 40px),
		transparent 100%
	);
	mask-image: linear-gradient(
		to right,
		transparent 0,
		#000 40px,
		#000 calc(100% - 40px),
		transparent 100%
	);
}

.service-ticker__viewport::-webkit-scrollbar {
	display: none;
}

.service-ticker__viewport.is-dragging {
	cursor: grabbing;
}

.service-ticker__viewport.is-dragging a {
	pointer-events: none;
}

.service-ticker__track {
	display: flex;
	gap: 1.25rem;
	width: max-content;
}

.service-ticker__track > * {
	flex-shrink: 0;
}

.service-ticker__card {
	display: flex;
	flex-direction: column;
	gap: 0.5rem;
	flex: 0 0 320px;
	min-width: 0;
	padding: var(--space-lg);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-lg);
	background: #fff;
	text-decoration: none;
	color: inherit;
	position: relative;
	overflow: hidden;
	transition: border-color 200ms ease, transform 200ms ease, box-shadow 200ms ease;
}

.service-ticker__card::before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	height: 3px;
	background: var(--hue, var(--color-accent));
	opacity: 0.9;
}

.service-ticker__card:hover,
.service-ticker__card:focus-visible {
	border-color: var(--color-accent);
	transform: translateY(-2px);
	box-shadow: 0 18px 40px -24px rgba(20, 42, 79, 0.28), 0 2px 6px -2px rgba(20, 42, 79, 0.08);
	outline: none;
}

.service-ticker__kicker {
	display: inline-flex;
	align-items: center;
	gap: 0.4rem;
	font-size: 0.72rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.12em;
	color: var(--hue, var(--color-accent));
}

.service-ticker__kicker svg {
	width: 14px;
	height: 14px;
	flex-shrink: 0;
}

.service-ticker__name {
	font-family: var(--font-display);
	font-size: 1.1rem;
	line-height: 1.25;
	color: var(--color-primary);
	margin: 0.5rem 0;
	letter-spacing: -0.005em;
}

.service-ticker__excerpt {
	font-size: 0.88rem;
	line-height: 1.5;
	color: var(--color-text-light);
	margin: 0 0 var(--space-sm);
	display: -webkit-box;
	-webkit-line-clamp: 3;
	line-clamp: 3;
	-webkit-box-orient: vertical;
	overflow: hidden;
}

.service-ticker__cta {
	display: inline-flex;
	align-items: center;
	gap: 0.35rem;
	margin-top: auto;
	font-size: 0.82rem;
	font-weight: 600;
	color: var(--color-primary);
}

.service-ticker__cta svg {
	width: 14px;
	height: 14px;
	transition: transform 200ms ease;
}

.service-ticker__card:hover .service-ticker__cta svg,
.service-ticker__card:focus-visible .service-ticker__cta svg {
	transform: translateX(3px);
}

/* Static / reduced-motion fallback */
.service-ticker--static .service-ticker__viewport {
	overflow: visible;
	-webkit-mask-image: none;
	mask-image: none;
	cursor: default;
	touch-action: auto;
	user-select: auto;
}

.service-ticker--static .service-ticker__track {
	flex-wrap: wrap;
	width: auto;
	transform: none !important;
}

@media (max-width: 640px) {
	.service-ticker {
		padding: var(--space-xl) var(--container-padding);
	}
	.service-ticker__card {
		flex: 0 0 260px;
		padding: var(--space-md);
	}
	.service-ticker__viewport {
		-webkit-mask-image: linear-gradient(
			to right,
			transparent 0,
			#000 20px,
			#000 calc(100% - 20px),
			transparent 100%
		);
		mask-image: linear-gradient(
			to right,
			transparent 0,
			#000 20px,
			#000 calc(100% - 20px),
			transparent 100%
		);
	}
}

@media (prefers-reduced-motion: reduce) {
	.service-ticker__viewport {
		overflow-x: auto;
		overflow-y: hidden;
		-webkit-mask-image: none;
		mask-image: none;
	}
}

/* ===========================================================
   Blog — hero, lista post, singolo, home-featured
   =========================================================== */

.blog-hero {
	background:
		radial-gradient(ellipse 50% 40% at 15% 0%, rgba(20, 42, 79, 0.04) 0%, transparent 70%),
		radial-gradient(ellipse 40% 35% at 95% 20%, rgba(228, 181, 75, 0.05) 0%, transparent 70%),
		var(--color-bg);
	border-bottom: 1px solid var(--color-border);
	padding: var(--space-2xl) 0 var(--space-xl);
	position: relative;
}

.blog-hero::after {
	content: "";
	position: absolute;
	left: 0;
	right: 0;
	bottom: -1px;
	height: 3px;
	background: linear-gradient(90deg, transparent, var(--color-accent) 50%, transparent);
	opacity: 0.5;
}

.blog-hero__eyebrow {
	font-family: var(--font-heading);
	font-size: 0.72rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.14em;
	color: var(--color-accent);
	margin: 0 0 var(--space-sm);
}

.blog-hero__title {
	font-family: var(--font-heading);
	font-size: clamp(2rem, 5vw, 3rem);
	font-weight: 800;
	letter-spacing: -0.025em;
	line-height: 1.1;
	color: var(--color-primary);
	margin: 0 0 var(--space-md);
	max-width: 900px;
}

.blog-hero__lede {
	color: var(--color-text-light);
	font-size: 1.05rem;
	line-height: 1.65;
	max-width: 720px;
	margin: 0;
}

.blog-list {
	padding-top: var(--space-2xl);
	padding-bottom: var(--space-3xl);
}

.blog-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--space-xl);
}

@media (min-width: 768px) {
	.blog-grid {
		grid-template-columns: repeat(2, 1fr);
		gap: var(--space-xl);
	}
}

@media (min-width: 1100px) {
	.blog-grid {
		grid-template-columns: repeat(3, 1fr);
	}
}

.post-card {
	display: flex;
	flex-direction: column;
	background: #ffffff;
	border: 1px solid var(--color-border);
	border-radius: var(--radius-lg);
	overflow: hidden;
	transition: transform var(--duration) var(--ease-out), box-shadow var(--duration) var(--ease-out), border-color var(--duration) var(--ease-out);
}

.post-card:hover {
	transform: translateY(-3px);
	box-shadow: 0 18px 40px -20px rgba(20, 42, 79, 0.25);
	border-color: color-mix(in srgb, var(--color-accent) 40%, var(--color-border));
}

.post-card__thumb {
	display: block;
	aspect-ratio: 16 / 9;
	overflow: hidden;
	background: var(--color-bg-alt);
}

.post-card__thumb img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform 400ms var(--ease-out);
}

.post-card:hover .post-card__thumb img {
	transform: scale(1.04);
}

.post-card__body {
	padding: var(--space-lg);
	display: flex;
	flex-direction: column;
	gap: 0.6rem;
	flex: 1 1 auto;
}

.post-card__meta {
	display: inline-flex;
	align-items: center;
	gap: 0.55rem;
	font-size: 0.78rem;
	color: var(--color-text-light);
}

.post-card__cat {
	text-decoration: none;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	font-size: 0.68rem;
	color: var(--color-accent);
	padding: 3px 8px;
	background: rgba(228, 181, 75, 0.12);
	border-radius: 999px;
}

.post-card__cat:hover {
	background: rgba(228, 181, 75, 0.22);
}

.post-card__date {
	font-variant-numeric: tabular-nums;
}

.post-card__title {
	font-family: var(--font-heading);
	font-size: 1.2rem;
	font-weight: 700;
	line-height: 1.3;
	margin: 0;
	letter-spacing: -0.01em;
}

.post-card__title a {
	color: var(--color-primary);
	text-decoration: none;
	transition: color var(--duration) var(--ease-out);
}

.post-card__title a:hover {
	color: var(--color-accent);
}

.post-card__excerpt {
	color: var(--color-text-light);
	font-size: 0.92rem;
	line-height: 1.55;
	margin: 0;
}

.post-card__cta {
	display: inline-flex;
	align-items: center;
	gap: 0.35rem;
	margin-top: auto;
	padding-top: var(--space-xs);
	font-size: 0.85rem;
	font-weight: 600;
	color: var(--color-primary);
	text-decoration: none;
}

.post-card__cta svg {
	transition: transform 200ms var(--ease-out);
}

.post-card:hover .post-card__cta svg {
	transform: translateX(3px);
}

.blog-pagination {
	margin-top: var(--space-2xl);
	display: flex;
	justify-content: center;
}

.blog-pagination .page-numbers {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 40px;
	height: 40px;
	padding: 0 0.85rem;
	border-radius: var(--radius-sm);
	color: var(--color-primary);
	text-decoration: none;
	font-weight: 600;
	background: transparent;
	border: 1px solid var(--color-border);
	transition: background var(--duration) var(--ease-out), color var(--duration) var(--ease-out);
	margin: 0 3px;
}

.blog-pagination .page-numbers:hover,
.blog-pagination .page-numbers.current {
	background: var(--color-primary);
	color: #ffffff;
	border-color: var(--color-primary);
}

.blog-empty {
	padding: var(--space-2xl) 0;
	text-align: center;
	color: var(--color-text-light);
}

/* --- Single post --- */

.single-post__hero {
	background:
		radial-gradient(ellipse 50% 40% at 15% 0%, rgba(20, 42, 79, 0.04) 0%, transparent 70%),
		var(--color-bg);
	padding: var(--space-2xl) 0 var(--space-xl);
	border-bottom: 1px solid var(--color-border);
}

.single-post__hero-inner {
	max-width: 780px;
}

.single-post__kicker {
	display: inline-flex;
	align-items: center;
	gap: 0.4rem;
	padding: 0.35rem 0.85rem;
	background: rgba(228, 181, 75, 0.12);
	color: var(--color-accent);
	border-radius: 999px;
	font-family: var(--font-heading);
	font-weight: 700;
	font-size: 0.72rem;
	text-transform: uppercase;
	letter-spacing: 0.12em;
	text-decoration: none;
	margin-bottom: var(--space-md);
}

.single-post__kicker:hover {
	background: rgba(228, 181, 75, 0.22);
}

.single-post__title {
	font-family: var(--font-heading);
	font-size: clamp(1.9rem, 4.5vw, 3rem);
	font-weight: 800;
	letter-spacing: -0.025em;
	line-height: 1.1;
	color: var(--color-primary);
	margin: 0 0 var(--space-md);
}

.single-post__meta {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 0.5rem;
	font-size: 0.88rem;
	color: var(--color-text-light);
	font-variant-numeric: tabular-nums;
}

.single-post__meta-sep {
	opacity: 0.5;
}

.single-post__thumb {
	margin: 0;
	background: var(--color-bg-alt);
	padding: var(--space-xl) 0;
}

.single-post__thumb img {
	display: block;
	max-width: 100%;
	height: auto;
	border-radius: var(--radius-lg);
	margin: 0 auto;
}

.single-post__content {
	max-width: 780px;
	padding-top: var(--space-2xl);
	padding-bottom: var(--space-3xl);
}

.single-post__prose {
	font-size: 1.05rem;
	line-height: 1.75;
	color: var(--color-text);
}

.single-post__prose p { margin: 0 0 1.2em; }
.single-post__prose p:last-child { margin-bottom: 0; }

.single-post__prose h2 {
	font-family: var(--font-heading);
	font-size: 1.6rem;
	font-weight: 800;
	line-height: 1.2;
	color: var(--color-primary);
	letter-spacing: -0.015em;
	margin: 2em 0 0.6em;
}

.single-post__prose h3 {
	font-family: var(--font-heading);
	font-size: 1.2rem;
	font-weight: 700;
	color: var(--color-primary);
	line-height: 1.3;
	margin: 1.8em 0 0.5em;
}

.single-post__prose ul,
.single-post__prose ol {
	margin: 0 0 1.2em;
	padding-left: 1.4em;
}

.single-post__prose li { margin-bottom: 0.4em; }

.single-post__prose a {
	color: var(--color-accent-hover);
	text-decoration: underline;
	text-underline-offset: 3px;
}

.single-post__prose a:hover {
	color: var(--color-primary);
}

.single-post__prose blockquote {
	border-left: 3px solid var(--color-accent);
	padding: 0.5em 1em;
	margin: 1.5em 0;
	font-style: italic;
	color: var(--color-text-light);
	background: var(--color-bg-alt);
	border-radius: 0 var(--radius-sm) var(--radius-sm) 0;
}

.single-post__prose strong {
	color: var(--color-primary);
	font-weight: 700;
}

.single-post__prose code {
	font-family: ui-monospace, Menlo, Consolas, monospace;
	background: var(--color-bg-alt);
	padding: 0.1em 0.4em;
	border-radius: 3px;
	font-size: 0.92em;
}

.single-post__tags {
	list-style: none;
	margin: var(--space-xl) 0 0;
	padding: var(--space-lg) 0 0;
	border-top: 1px solid var(--color-border);
	display: flex;
	flex-wrap: wrap;
	gap: 0.4rem;
}

.single-post__tags a {
	display: inline-block;
	padding: 0.25rem 0.65rem;
	background: var(--color-bg-alt);
	border-radius: 999px;
	font-size: 0.82rem;
	color: var(--color-text-light);
	text-decoration: none;
	transition: background var(--duration) var(--ease-out), color var(--duration) var(--ease-out);
}

.single-post__tags a:hover {
	background: var(--color-primary);
	color: #ffffff;
}

.single-post__related {
	margin-top: var(--space-2xl);
	padding-top: var(--space-xl);
	border-top: 1px solid var(--color-border);
}

.single-post__related-title {
	font-family: var(--font-heading);
	font-size: 1rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	color: var(--color-primary);
	margin: 0 0 var(--space-md);
}

.single-post__related-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--space-md);
}

@media (min-width: 768px) {
	.single-post__related-grid {
		grid-template-columns: repeat(3, 1fr);
	}
}

.single-post__related-card {
	display: flex;
	flex-direction: column;
	gap: 0.35rem;
	padding: var(--space-md);
	background: var(--color-bg-alt);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-md);
	text-decoration: none;
	transition: border-color var(--duration) var(--ease-out), transform var(--duration) var(--ease-out);
}

.single-post__related-card:hover {
	border-color: var(--color-accent);
	transform: translateY(-2px);
}

.single-post__related-date {
	font-size: 0.78rem;
	color: var(--color-text-light);
	font-variant-numeric: tabular-nums;
}

.single-post__related-h {
	font-family: var(--font-heading);
	font-size: 0.98rem;
	font-weight: 700;
	line-height: 1.3;
	color: var(--color-primary);
}

/* --- Home "Ultime news" section --- */

.home-news {
	padding: var(--space-3xl) 0;
	background: var(--color-bg-alt);
}

.home-news__inner {
	max-width: var(--container-max);
	margin: 0 auto;
	padding: 0 var(--container-padding);
}

.home-news__head {
	display: flex;
	align-items: flex-end;
	justify-content: space-between;
	gap: var(--space-lg);
	margin-bottom: var(--space-xl);
	flex-wrap: wrap;
}

.home-news__head-text {
	max-width: 720px;
}

.home-news__eyebrow {
	font-family: var(--font-heading);
	font-size: 0.72rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.14em;
	color: var(--color-accent);
	margin: 0 0 0.5rem;
}

.home-news__title {
	font-family: var(--font-heading);
	font-size: clamp(1.75rem, 3vw, 2.25rem);
	line-height: 1.15;
	color: var(--color-primary);
	letter-spacing: -0.015em;
	margin: 0 0 0.5rem;
}

.home-news__lede {
	color: var(--color-text-light);
	line-height: 1.55;
	margin: 0;
}

.home-news__view-all {
	display: inline-flex;
	align-items: center;
	gap: 0.4rem;
	padding: 0.6rem 1rem;
	font-size: 0.85rem;
	font-weight: 600;
	color: var(--color-primary);
	background: #ffffff;
	border: 1px solid var(--color-border);
	border-radius: 999px;
	text-decoration: none;
	white-space: nowrap;
	transition: border-color var(--duration) var(--ease-out), color var(--duration) var(--ease-out);
}

.home-news__view-all:hover {
	border-color: var(--color-accent);
	color: var(--color-accent);
}

.home-news__grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--space-lg);
}

@media (min-width: 768px) {
	.home-news__grid {
		grid-template-columns: repeat(3, 1fr);
	}
}

/* ===========================================================
   Home intro SEO content
   =========================================================== */

.home-intro {
	padding: var(--space-2xl) 0;
	background: #ffffff;
	border-bottom: 1px solid var(--color-border);
}

.home-intro__inner {
	max-width: 840px;
	margin: 0 auto;
	padding: 0 var(--container-padding);
}

.home-intro h2 {
	font-family: var(--font-heading);
	font-size: clamp(1.6rem, 3vw, 2.1rem);
	font-weight: 800;
	color: var(--color-primary);
	letter-spacing: -0.015em;
	line-height: 1.2;
	margin: 0 0 var(--space-md);
}

.home-intro h3 {
	font-family: var(--font-heading);
	font-size: 1.15rem;
	font-weight: 700;
	color: var(--color-primary);
	margin: var(--space-xl) 0 var(--space-sm);
}

.home-intro p {
	font-size: 1.02rem;
	line-height: 1.7;
	color: var(--color-text);
	margin: 0 0 var(--space-md);
}

.home-intro ul {
	margin: 0 0 var(--space-md);
	padding-left: 1.4rem;
}

.home-intro ul li {
	line-height: 1.7;
	margin-bottom: 0.35rem;
}

.home-intro strong {
	color: var(--color-primary);
}

.home-intro a {
	color: var(--color-accent-hover);
	text-decoration: underline;
	text-underline-offset: 3px;
}

.home-intro a:hover {
	color: var(--color-primary);
}
