/* =============================================================================
   VEIN CLINIC — main.css
   Tema: Vein Clinic Premium
   Organizzazione: tokens → reset → layout → tipografia → componenti → pagine →
                   compatibilita' plugin → accessibilita' → utilita'
   Tutte le regole si appoggiano alle CSS custom properties di theme.json
   (--wp--preset--color--*, --wp--preset--font-family--*, ecc.).
   ============================================================================= */

/* -------------------------------------------------------------------------- *
 * 1. TOKENS — variabili locali sopra a quelle di theme.json
 * -------------------------------------------------------------------------- */
:root {
	--vc-bg: var(--wp--preset--color--neutral-200);
	--vc-bg-alt: var(--wp--preset--color--neutral-100);
	--vc-text: var(--wp--preset--color--neutral-800);
	--vc-text-soft: var(--wp--preset--color--neutral-600);
	--vc-text-inverse: var(--wp--preset--color--neutral-100);
	--vc-primary: var(--wp--preset--color--primary);
	--vc-primary-dark: var(--wp--preset--color--primary-dark);
	--vc-primary-soft: var(--wp--preset--color--primary-soft);
	--vc-accent: var(--wp--preset--color--accent);
	--vc-accent-soft: var(--wp--preset--color--accent-soft);
	--vc-line: var(--wp--preset--color--neutral-400);

	--vc-radius-sm: 6px;
	--vc-radius-md: 12px;
	--vc-radius-lg: 24px;
	--vc-radius-pill: 999px;

	--vc-shadow-sm: 0 1px 2px rgba(15, 32, 30, 0.06), 0 1px 3px rgba(15, 32, 30, 0.04);
	--vc-shadow-md: 0 6px 24px rgba(15, 32, 30, 0.08);
	--vc-shadow-lg: 0 24px 60px rgba(15, 32, 30, 0.18);

	--vc-ease: cubic-bezier(0.22, 1, 0.36, 1);
	--vc-ease-soft: cubic-bezier(0.4, 0, 0.2, 1);
	--vc-dur-fast: 200ms;
	--vc-dur: 360ms;
	--vc-dur-slow: 700ms;

	--vc-container: 1280px;
	--vc-container-narrow: 880px;
	--vc-gutter: clamp(1rem, 4vw, 2rem);
	--vc-section-y: clamp(3rem, 7vw, 6rem);
	--vc-header-h: 84px;
	--vc-topbar-h: 40px;
}

/* -------------------------------------------------------------------------- *
 * 2. RESET / BASE
 * -------------------------------------------------------------------------- */
*, *::before, *::after { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; text-rendering: optimizeLegibility; }
body {
	margin: 0;
	background: var(--vc-bg);
	color: var(--vc-text);
	font-family: var(--wp--preset--font-family--sans);
	font-size: var(--wp--preset--font-size--md);
	line-height: 1.65;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}
img, svg, video { display: block; max-width: 100%; height: auto; }
button { font: inherit; cursor: pointer; }
a { color: var(--vc-primary); text-decoration: none; transition: color var(--vc-dur-fast) var(--vc-ease); }
a:hover, a:focus-visible { color: var(--vc-accent); }
::selection { background: var(--vc-accent); color: var(--vc-text-inverse); }

.screen-reader-text {
	position: absolute !important;
	clip: rect(1px,1px,1px,1px);
	width: 1px; height: 1px; overflow: hidden;
	word-wrap: normal !important;
}
.skip-link {
	position: absolute; top: -100px; left: 0; padding: 12px 18px;
	background: var(--vc-primary); color: var(--vc-text-inverse);
	z-index: 9999; border-radius: 0 0 var(--vc-radius-sm) 0;
	transition: top var(--vc-dur-fast) var(--vc-ease);
}
.skip-link:focus { top: 0; }

/* -------------------------------------------------------------------------- *
 * 3. LAYOUT
 * -------------------------------------------------------------------------- */
.container {
	width: 100%;
	max-width: var(--vc-container);
	margin-inline: auto;
	padding-inline: var(--vc-gutter);
}
.container--narrow { max-width: var(--vc-container-narrow); }
.container--wide   { max-width: 1440px; }
.section { padding-block: var(--vc-section-y); }
.section__head { margin-bottom: 2.5rem; }
.section__head--center { text-align: center; }
.section__overline {
	font-family: var(--wp--preset--font-family--sans);
	font-size: var(--wp--preset--font-size--xs);
	text-transform: uppercase;
	letter-spacing: 0.16em;
	color: var(--vc-accent);
	margin: 0 0 0.75rem;
	font-weight: 600;
}
.section__title {
	font-family: var(--wp--preset--font-family--serif);
	font-size: var(--wp--preset--font-size--3xl);
	color: var(--vc-primary-dark);
	margin: 0 0 0.5rem;
	letter-spacing: -0.015em;
	line-height: 1.15;
}
.section__lead {
	font-size: var(--wp--preset--font-size--lg);
	color: var(--vc-text-soft);
	max-width: 60ch;
	margin: 0;
}
.section__head--center .section__lead { margin-inline: auto; }
.section__cta { margin-top: 3rem; text-align: center; }
.anchor-offset { display: block; height: var(--vc-header-h); margin-top: calc(-1 * var(--vc-header-h)); pointer-events: none; }

/* -------------------------------------------------------------------------- *
 * 4. TIPOGRAFIA
 * -------------------------------------------------------------------------- */
h1, h2, h3, h4 { color: var(--vc-primary-dark); }
h1 { font-family: var(--wp--preset--font-family--serif); font-weight: 500; }
h2 { font-family: var(--wp--preset--font-family--serif); font-weight: 500; }
h3 { font-family: var(--wp--preset--font-family--serif); font-weight: 500; }
h4 { font-weight: 500; }
.rich-text p { margin-block: 0 1.25em; }
.rich-text ul, .rich-text ol { padding-left: 1.25em; }
.rich-text strong { color: var(--vc-primary-dark); }
.rich-text em { font-family: var(--wp--preset--font-family--serif); font-style: italic; }

/* -------------------------------------------------------------------------- *
 * 5. BUTTON
 * -------------------------------------------------------------------------- */
.btn {
	display: inline-flex;
	align-items: center;
	gap: 0.55rem;
	padding: 0.95rem 1.85rem;
	border: 1px solid var(--vc-primary);
	border-radius: var(--vc-radius-pill);
	background: var(--vc-primary);
	color: var(--vc-text-inverse);
	font-size: var(--wp--preset--font-size--sm);
	font-weight: 500;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	cursor: pointer;
	transition: background var(--vc-dur-fast) var(--vc-ease),
	            color var(--vc-dur-fast) var(--vc-ease),
	            border-color var(--vc-dur-fast) var(--vc-ease),
	            transform var(--vc-dur-fast) var(--vc-ease);
}
.btn:hover, .btn:focus-visible {
	background: var(--vc-primary-dark);
	border-color: var(--vc-primary-dark);
	color: var(--vc-accent-soft);
	transform: translateY(-1px);
}
.btn--accent { background: var(--vc-accent); border-color: var(--vc-accent); color: var(--vc-primary-dark); }
.btn--accent:hover, .btn--accent:focus-visible {
	background: var(--vc-primary-dark); border-color: var(--vc-primary-dark); color: var(--vc-accent-soft);
}
.btn--ghost {
	background: transparent;
	color: var(--vc-primary-dark);
	border-color: var(--vc-primary-dark);
}
.btn--ghost:hover, .btn--ghost:focus-visible {
	background: var(--vc-primary-dark); color: var(--vc-accent-soft);
}
.btn--lg { padding: 1.05rem 2.1rem; font-size: var(--wp--preset--font-size--sm); }
.btn--sm { padding: 0.55rem 1.1rem; font-size: 0.78rem; }
.btn .ph { font-size: 1.1em; }

/* -------------------------------------------------------------------------- *
 * 6. HEADER / TOPBAR / NAV
 * -------------------------------------------------------------------------- */
.site-header {
	position: sticky; top: 0; z-index: 1000;
	background: rgba(255,255,255,0.96);
	backdrop-filter: saturate(140%) blur(10px);
	-webkit-backdrop-filter: saturate(140%) blur(10px);
	box-shadow: 0 1px 0 rgba(15,32,30,0.06);
	transition: background var(--vc-dur) var(--vc-ease), box-shadow var(--vc-dur) var(--vc-ease);
}
.site-header.is-scrolled { box-shadow: var(--vc-shadow-md); }
.site-topbar {
	background: var(--vc-primary-dark);
	color: var(--vc-accent-soft);
	font-size: 0.85rem;
	height: var(--vc-topbar-h);
	display: flex; align-items: center;
}
.site-topbar a { color: inherit; }
.site-topbar a:hover, .site-topbar a:focus-visible { color: var(--vc-accent); }
.site-topbar__inner { display: flex; align-items: center; justify-content: space-between; gap: 1rem; }
.site-topbar__contacts {
	list-style: none; margin: 0; padding: 0;
	display: flex; gap: 1.25rem; align-items: center; flex-wrap: wrap;
}
.site-topbar__contacts li { display: inline-flex; align-items: center; gap: 0.4rem; }
.site-topbar__right { display: flex; align-items: center; gap: 1rem; }

.site-nav-bar { height: var(--vc-header-h); display: flex; align-items: center; }
.site-nav-bar__inner { display: flex; align-items: center; justify-content: space-between; gap: 2rem; width: 100%; }
.site-branding__link { display: inline-flex; align-items: center; gap: 0.6rem; color: var(--vc-primary-dark); }
.site-branding__name {
	font-family: var(--wp--preset--font-family--serif);
	font-size: 1.5rem; font-weight: 500; letter-spacing: 0.01em;
}
.site-branding__tagline { color: var(--vc-text-soft); font-size: 0.78rem; }
.site-branding__logo { max-height: 56px; width: auto; }

.site-nav { display: flex; align-items: center; }
.menu, .menu--primary {
	list-style: none; margin: 0; padding: 0;
	display: flex; align-items: center; gap: 1.75rem;
}
.menu-item { position: relative; }
.menu-link {
	display: inline-flex; align-items: center; gap: 0.35rem;
	color: var(--vc-primary-dark); padding: 0.5rem 0;
	font-size: 0.95rem; font-weight: 500; letter-spacing: 0.02em;
	position: relative;
}
.menu-link::after {
	content: ''; position: absolute; left: 0; right: 0; bottom: -2px;
	height: 1px; background: var(--vc-accent);
	transform: scaleX(0); transform-origin: left center;
	transition: transform var(--vc-dur) var(--vc-ease);
}
.menu-link:hover::after, .menu-link:focus-visible::after,
.menu-item.is-current > .menu-link::after { transform: scaleX(1); }
.menu-link__caret { transition: transform var(--vc-dur-fast) var(--vc-ease); }
.menu-item.is-open > .menu-link .menu-link__caret { transform: rotate(180deg); }

.submenu {
	position: absolute; top: 100%; left: 0; min-width: 240px;
	background: var(--vc-bg-alt);
	box-shadow: var(--vc-shadow-md);
	list-style: none; margin: 0; padding: 0.5rem 0;
	border-radius: var(--vc-radius-md);
	opacity: 0; transform: translateY(8px); pointer-events: none;
	transition: opacity var(--vc-dur) var(--vc-ease), transform var(--vc-dur) var(--vc-ease);
}
.menu-item.has-submenu:hover > .submenu,
.menu-item.has-submenu:focus-within > .submenu,
.menu-item.is-open > .submenu {
	opacity: 1; transform: translateY(0); pointer-events: auto;
}
.submenu .menu-link { padding: 0.55rem 1.25rem; }

.submenu-toggle {
	background: transparent; border: 0; color: inherit;
	padding: 0.35rem 0.5rem; border-radius: var(--vc-radius-sm);
}
.submenu-toggle:focus-visible { outline: 2px solid var(--vc-accent); outline-offset: 2px; }

/* MEGA-MENU (Sirohotels-like): pannello pieno con 2 riquadri */
.menu-item.has-megamenu { position: static; }
.megamenu {
	position: absolute; left: 0; right: 0; top: 100%;
	background: var(--vc-bg-alt);
	box-shadow: var(--vc-shadow-lg);
	opacity: 0; transform: translateY(8px); pointer-events: none;
	transition: opacity var(--vc-dur) var(--vc-ease), transform var(--vc-dur) var(--vc-ease);
	z-index: 50;
}
.menu-item.has-megamenu:hover > .megamenu,
.menu-item.has-megamenu:focus-within > .megamenu,
.menu-item.has-megamenu.is-open > .megamenu {
	opacity: 1; transform: translateY(0); pointer-events: auto;
}
.megamenu__inner { padding-block: 2.25rem; }
.megamenu__grid {
	list-style: none; margin: 0; padding: 0;
	display: grid; grid-template-columns: 1fr 1fr; gap: 1.5rem;
}
.megamenu__card { list-style: none; }
.megamenu__link {
	display: grid; grid-template-columns: 220px 1fr; gap: 1.5rem;
	align-items: center;
	padding: 1rem;
	border-radius: var(--vc-radius-md);
	background: transparent; color: var(--vc-primary-dark);
	transition: background var(--vc-dur) var(--vc-ease);
}
.megamenu__link:hover, .megamenu__link:focus-visible {
	background: var(--vc-bg);
	color: var(--vc-primary-dark);
}
.megamenu__media {
	overflow: hidden; border-radius: var(--vc-radius-md);
	background: var(--vc-bg);
	aspect-ratio: 4/3;
}
.megamenu__media img { width: 100%; height: 100%; object-fit: cover; transition: transform var(--vc-dur-slow) var(--vc-ease); }
.megamenu__link:hover .megamenu__media img { transform: scale(1.04); }
.megamenu__media--placeholder {
	display: grid; place-items: center; color: var(--vc-text-soft);
	font-size: 0.8rem; letter-spacing: 0.06em; text-transform: uppercase;
}
.megamenu__title {
	margin: 0 0 0.35rem; font-family: var(--wp--preset--font-family--serif);
	font-size: 1.5rem; font-weight: 500;
}
.megamenu__desc { margin: 0 0 0.5rem; color: var(--vc-text-soft); font-size: 0.95rem; }
.megamenu__cta { color: var(--vc-accent); font-size: 0.8rem; letter-spacing: 0.14em; text-transform: uppercase; font-weight: 600; }

/* Lang switcher (Polylang) */
.lang-switcher ul { list-style: none; margin: 0; padding: 0; display: flex; gap: 0.5rem; }
.lang-switcher a { text-transform: uppercase; font-size: 0.78rem; letter-spacing: 0.12em; opacity: 0.85; }
.lang-switcher .current-lang a { opacity: 1; color: var(--vc-accent); }

/* Toggle mobile */
.nav-toggle {
	display: none; background: transparent; border: 0;
	width: 44px; height: 44px; border-radius: var(--vc-radius-sm);
	position: relative; color: var(--vc-primary-dark);
}
.nav-toggle__bars,
.nav-toggle__bars::before,
.nav-toggle__bars::after {
	content: ''; position: absolute; left: 22%; right: 22%; height: 2px;
	background: currentColor; transition: transform var(--vc-dur) var(--vc-ease), top var(--vc-dur) var(--vc-ease), opacity var(--vc-dur-fast) var(--vc-ease);
}
.nav-toggle__bars { top: 50%; }
.nav-toggle__bars::before { top: -7px; }
.nav-toggle__bars::after  { top:  7px; }
.nav-toggle[aria-expanded="true"] .nav-toggle__bars { background: transparent; }
.nav-toggle[aria-expanded="true"] .nav-toggle__bars::before { top: 0; transform: rotate(45deg); }
.nav-toggle[aria-expanded="true"] .nav-toggle__bars::after  { top: 0; transform: rotate(-45deg); }

/* -------------------------------------------------------------------------- *
 * 7. HERO
 * -------------------------------------------------------------------------- */
.hero {
	position: relative; overflow: hidden;
	min-height: clamp(520px, 80vh, 760px);
	color: var(--vc-text-inverse);
	display: grid; place-items: end start;
}
.hero--align-center { place-items: end center; text-align: center; }
.hero__media { position: absolute; inset: 0; z-index: 1; }
.hero__image, .hero__video { width: 100%; height: 100%; object-fit: cover; }
.hero__placeholder {
	width: 100%; height: 100%;
	background:
		linear-gradient(140deg, #2a4441 0%, #1c3532 50%, #102624 100%);
	display: grid; place-items: center; color: var(--vc-accent-soft);
	font-size: 0.85rem; letter-spacing: 0.16em; text-transform: uppercase;
	padding: 2rem; text-align: center;
}
.hero__overlay {
	position: absolute; inset: 0;
	background: linear-gradient(180deg, rgba(15,32,30,0.15) 0%, rgba(15,32,30,0.85) 100%);
}
.hero__inner {
	position: relative; z-index: 2;
	padding-block: clamp(4rem, 9vw, 7rem);
	max-width: 760px;
}
.hero--align-center .hero__inner { margin-inline: auto; }
.hero__overline { color: var(--vc-accent); font-size: 0.85rem; letter-spacing: 0.18em; text-transform: uppercase; font-weight: 600; margin: 0 0 1rem; }
.hero__title {
	margin: 0 0 1.25rem;
	font-family: var(--wp--preset--font-family--serif);
	font-size: clamp(2.5rem, 5.5vw, 4.5rem);
	font-weight: 500; line-height: 1.05; letter-spacing: -0.02em;
	color: var(--vc-text-inverse);
}
.hero__title em { font-style: italic; color: var(--vc-accent-soft); }
.hero__lead {
	margin: 0 0 2rem; color: rgba(255,255,255,0.86);
	font-size: var(--wp--preset--font-size--lg);
	max-width: 56ch;
}
.hero--align-center .hero__lead { margin-inline: auto; }
.hero__actions { display: flex; gap: 0.75rem; flex-wrap: wrap; }
.hero--align-center .hero__actions { justify-content: center; }
.hero__scroll {
	position: absolute; left: 50%; bottom: 1.5rem; transform: translateX(-50%);
	width: 44px; height: 44px; border-radius: 50%;
	background: rgba(255,255,255,0.12); color: var(--vc-text-inverse);
	display: grid; place-items: center;
	animation: vc-bob 2.2s var(--vc-ease) infinite;
	z-index: 3;
}
@keyframes vc-bob { 0%,100% { transform: translate(-50%,0); } 50% { transform: translate(-50%,6px); } }

/* -------------------------------------------------------------------------- *
 * 8. PAGE HERO (versione "simple")
 * -------------------------------------------------------------------------- */
.page-hero {
	padding-block: clamp(4rem, 8vw, 6.5rem);
	background:
		radial-gradient(120% 100% at 100% 0%, rgba(184,153,104,0.10) 0%, transparent 60%),
		linear-gradient(180deg, var(--vc-bg) 0%, var(--vc-bg-alt) 100%);
	border-bottom: 1px solid var(--vc-line);
	text-align: center;
}
.page-hero--simple { text-align: left; }
.page-hero__overline {
	color: var(--vc-accent); font-size: 0.85rem; letter-spacing: 0.18em;
	text-transform: uppercase; font-weight: 600; margin: 0 0 0.75rem;
}
.page-hero__title {
	font-family: var(--wp--preset--font-family--serif);
	font-size: clamp(2.25rem, 5vw, 3.5rem); margin: 0 0 1rem;
	letter-spacing: -0.015em; line-height: 1.1;
}
.page-hero__lead { color: var(--vc-text-soft); max-width: 64ch; margin-inline: auto; }
.page-hero--simple .page-hero__lead { margin: 0; }
.page-hero__icon { font-size: 3rem; color: var(--vc-accent); margin-bottom: 1rem; }

/* -------------------------------------------------------------------------- *
 * 9. CARDS / GRID
 * -------------------------------------------------------------------------- */
.card-grid {
	display: grid; gap: 1.5rem;
	grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
}
.card-grid--3       { grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); }
.card-grid--specs   { grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); }
.card-grid--doctors { grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); }
.card-grid--doctors-sm { grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); }
.card-grid__item.is-hidden { display: none; }

/* Card post (blog) */
.card { background: var(--vc-bg-alt); border-radius: var(--vc-radius-md); overflow: hidden; box-shadow: var(--vc-shadow-sm); transition: transform var(--vc-dur) var(--vc-ease), box-shadow var(--vc-dur) var(--vc-ease); }
.card:hover { transform: translateY(-3px); box-shadow: var(--vc-shadow-md); }
.card__media img { width: 100%; aspect-ratio: 4/3; object-fit: cover; transition: transform var(--vc-dur-slow) var(--vc-ease); }
.card:hover .card__media img { transform: scale(1.04); }
.card__body { padding: 1.5rem; }
.card__meta { color: var(--vc-text-soft); font-size: 0.85rem; letter-spacing: 0.08em; text-transform: uppercase; margin: 0 0 0.5rem; }
.card__title { font-size: var(--wp--preset--font-size--xl); margin: 0 0 0.5rem; }
.card__title a { color: inherit; }
.card__excerpt { color: var(--vc-text-soft); margin: 0 0 1rem; }
.card__link { color: var(--vc-accent); font-weight: 600; font-size: 0.85rem; letter-spacing: 0.1em; text-transform: uppercase; display: inline-flex; gap: 0.4rem; align-items: center; }

/* Spec card */
.spec-card { background: var(--vc-bg-alt); border-radius: var(--vc-radius-md); border: 1px solid transparent; transition: transform var(--vc-dur) var(--vc-ease), border-color var(--vc-dur) var(--vc-ease), box-shadow var(--vc-dur) var(--vc-ease); }
.spec-card__link { display: block; padding: 2rem 1.75rem; color: var(--vc-primary-dark); }
.spec-card:hover { transform: translateY(-3px); border-color: var(--vc-accent); box-shadow: var(--vc-shadow-md); }
.spec-card__icon { font-size: 2.25rem; color: var(--vc-accent); margin-bottom: 1rem; }
.spec-card__title { font-family: var(--wp--preset--font-family--serif); font-size: 1.5rem; margin: 0 0 0.4rem; }
.spec-card__payoff { color: var(--vc-text-soft); font-size: 0.9rem; margin: 0 0 0.75rem; }
.spec-card__desc { color: var(--vc-text-soft); margin: 0 0 1rem; }
.spec-card__more { color: var(--vc-accent); font-weight: 600; font-size: 0.78rem; letter-spacing: 0.14em; text-transform: uppercase; display: inline-flex; gap: 0.35rem; align-items: center; }

/* Doctor card */
.doctor-card { position: relative; border-radius: var(--vc-radius-md); overflow: hidden; background: var(--vc-bg-alt); box-shadow: var(--vc-shadow-sm); transition: transform var(--vc-dur) var(--vc-ease), box-shadow var(--vc-dur) var(--vc-ease); }
.doctor-card:hover { transform: translateY(-3px); box-shadow: var(--vc-shadow-md); }
.doctor-card__link { color: inherit; display: block; }
.doctor-card__media { position: relative; overflow: hidden; aspect-ratio: 5/6; background: var(--vc-bg); }
.doctor-card__image { width: 100%; height: 100%; object-fit: cover; transition: transform var(--vc-dur-slow) var(--vc-ease), filter var(--vc-dur) var(--vc-ease); }
.doctor-card:hover .doctor-card__image { transform: scale(1.04); filter: brightness(0.85); }
.doctor-card__placeholder { width: 100%; height: 100%; display: grid; place-items: center; color: var(--vc-text-soft); font-size: 4rem; background: linear-gradient(180deg, var(--vc-bg) 0%, var(--vc-line) 100%); }
.doctor-card__overlay {
	position: absolute; inset: auto 0 0 0;
	padding: 1.25rem;
	background: linear-gradient(180deg, transparent 0%, rgba(15,32,30,0.92) 100%);
	color: var(--vc-text-inverse);
	transform: translateY(10%); opacity: 0;
	transition: transform var(--vc-dur) var(--vc-ease), opacity var(--vc-dur) var(--vc-ease);
}
.doctor-card:hover .doctor-card__overlay, .doctor-card:focus-within .doctor-card__overlay { transform: translateY(0); opacity: 1; }
.doctor-card__bio { font-size: 0.9rem; margin: 0 0 0.5rem; color: rgba(255,255,255,0.92); }
.doctor-card__more { font-size: 0.78rem; letter-spacing: 0.14em; text-transform: uppercase; color: var(--vc-accent); font-weight: 600; }
.doctor-card__body { padding: 1.25rem 1.5rem 1.75rem; }
.doctor-card__honorific { color: var(--vc-text-soft); font-size: 0.78rem; letter-spacing: 0.14em; text-transform: uppercase; margin: 0 0 0.35rem; }
.doctor-card__name { font-family: var(--wp--preset--font-family--serif); font-size: 1.4rem; margin: 0 0 0.25rem; }
.doctor-card__role { color: var(--vc-accent); margin: 0 0 0.75rem; font-size: 0.95rem; }
.doctor-card__tags { list-style: none; margin: 0; padding: 0; display: flex; gap: 0.5rem; flex-wrap: wrap; }
.doctor-card__tags li { font-size: 0.74rem; padding: 0.35rem 0.7rem; border: 1px solid var(--vc-line); border-radius: var(--vc-radius-pill); color: var(--vc-text-soft); }

/* Doctor single hero */
.doctor-hero { background: var(--vc-bg-alt); border-bottom: 1px solid var(--vc-line); padding-block: clamp(2.5rem, 6vw, 5rem); }
.doctor-hero__inner { display: grid; grid-template-columns: minmax(0, 360px) 1fr; gap: clamp(2rem, 5vw, 4rem); align-items: center; }
.doctor-hero__media { border-radius: var(--vc-radius-lg); overflow: hidden; box-shadow: var(--vc-shadow-md); }
.doctor-hero__placeholder { background: var(--vc-bg); aspect-ratio: 5/6; display: grid; place-items: center; color: var(--vc-text-soft); font-size: 6rem; }
.doctor-hero__honorific { color: var(--vc-text-soft); letter-spacing: 0.14em; text-transform: uppercase; font-size: 0.85rem; margin: 0 0 0.5rem; }
.doctor-hero__name { font-family: var(--wp--preset--font-family--serif); font-size: clamp(2rem, 4.5vw, 3.25rem); margin: 0 0 0.5rem; }
.doctor-hero__role { color: var(--vc-accent); font-size: 1.1rem; margin: 0 0 1rem; }
.doctor-hero__tags { list-style: none; margin: 0 0 1.25rem; padding: 0; display: flex; gap: 0.5rem; flex-wrap: wrap; }
.doctor-hero__tags a { display: inline-block; padding: 0.4rem 0.85rem; border: 1px solid var(--vc-line); border-radius: var(--vc-radius-pill); color: var(--vc-text-soft); font-size: 0.8rem; }
.doctor-hero__tags a:hover { border-color: var(--vc-accent); color: var(--vc-accent); }
.doctor-hero__lead { font-size: var(--wp--preset--font-size--lg); color: var(--vc-text-soft); max-width: 60ch; }
.doctor-hero__cta { display: flex; gap: 0.75rem; flex-wrap: wrap; margin-top: 1.5rem; }

.meta-grid { display: grid; gap: 1.5rem; grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); }
.meta-grid__item { background: var(--vc-bg-alt); padding: 1.5rem; border-radius: var(--vc-radius-md); border: 1px solid var(--vc-line); }
.meta-grid__item h3 { display: inline-flex; gap: 0.5rem; align-items: center; font-family: var(--wp--preset--font-family--sans); font-size: 1rem; text-transform: uppercase; letter-spacing: 0.1em; color: var(--vc-accent); margin: 0 0 0.75rem; }
.meta-grid__item p, .meta-grid__item div { color: var(--vc-text-soft); margin: 0; }

/* Benefit grid */
.benefits-grid { display: grid; gap: 1.5rem; grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); }
.benefit-card { background: var(--vc-bg-alt); padding: 2rem 1.75rem; border-radius: var(--vc-radius-md); border: 1px solid var(--vc-line); transition: transform var(--vc-dur) var(--vc-ease), border-color var(--vc-dur) var(--vc-ease); }
.benefit-card:hover { transform: translateY(-3px); border-color: var(--vc-accent); }
.benefit-card__icon { font-size: 2rem; color: var(--vc-accent); margin-bottom: 0.75rem; }
.benefit-card__title { font-family: var(--wp--preset--font-family--serif); font-size: 1.3rem; margin: 0 0 0.5rem; }
.benefit-card__text { color: var(--vc-text-soft); margin: 0; }

/* Hub cards (Cura & Servizi) */
.hub-grid { display: grid; gap: 1.5rem; grid-template-columns: repeat(2, 1fr); }
@media (max-width: 800px) { .hub-grid { grid-template-columns: 1fr; } }
.hub-card { position: relative; border-radius: var(--vc-radius-lg); overflow: hidden; background: var(--vc-primary-dark); color: var(--vc-text-inverse); min-height: 460px; box-shadow: var(--vc-shadow-md); transition: transform var(--vc-dur) var(--vc-ease), box-shadow var(--vc-dur) var(--vc-ease); }
.hub-card:hover { transform: translateY(-4px); box-shadow: var(--vc-shadow-lg); }
.hub-card__link { display: block; height: 100%; color: inherit; }
.hub-card__media { position: absolute; inset: 0; }
.hub-card__image { width: 100%; height: 100%; object-fit: cover; transition: transform var(--vc-dur-slow) var(--vc-ease); }
.hub-card:hover .hub-card__image { transform: scale(1.04); }
.hub-card__placeholder { width: 100%; height: 100%; background: linear-gradient(140deg, var(--vc-primary-soft) 0%, var(--vc-primary-dark) 100%); display: grid; place-items: center; color: rgba(255,255,255,0.5); font-size: 0.85rem; letter-spacing: 0.16em; text-transform: uppercase; padding: 2rem; text-align: center; }
.hub-card__overlay { position: absolute; inset: 0; background: linear-gradient(180deg, rgba(15,32,30,0.20) 0%, rgba(15,32,30,0.85) 80%); }
.hub-card__body { position: relative; padding: clamp(2rem, 4vw, 3rem); display: flex; flex-direction: column; justify-content: flex-end; min-height: 460px; }
.hub-card__overline { color: var(--vc-accent); font-size: 0.8rem; letter-spacing: 0.18em; text-transform: uppercase; margin: 0 0 0.5rem; }
.hub-card__title { font-family: var(--wp--preset--font-family--serif); font-size: clamp(1.75rem, 3vw, 2.5rem); color: var(--vc-text-inverse); margin: 0 0 0.5rem; }
.hub-card__desc { color: rgba(255,255,255,0.82); margin: 0 0 1.25rem; max-width: 48ch; }
.hub-card__cta { display: inline-flex; align-items: center; gap: 0.5rem; color: var(--vc-accent); font-size: 0.78rem; letter-spacing: 0.14em; text-transform: uppercase; font-weight: 600; }
.hub-card__cta .ph { transition: transform var(--vc-dur-fast) var(--vc-ease); }
.hub-card:hover .hub-card__cta .ph { transform: translateX(4px); }

/* Pillars / Values */
.pillars { display: grid; gap: 1.5rem; grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); }
.pillar { padding: 2rem 1.75rem; background: var(--vc-bg-alt); border-radius: var(--vc-radius-md); border: 1px solid var(--vc-line); text-align: center; }
.pillar__icon { font-size: 2.25rem; color: var(--vc-accent); margin-bottom: 0.75rem; }
.pillar__title { font-family: var(--wp--preset--font-family--serif); font-size: 1.4rem; margin: 0 0 0.5rem; }
.pillar__text { color: var(--vc-text-soft); margin: 0; }

.values-grid { display: grid; gap: 1.5rem; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); }
.value-card { padding: 1.75rem; background: var(--vc-bg-alt); border-radius: var(--vc-radius-md); border: 1px solid var(--vc-line); }
.value-card .ph { font-size: 1.75rem; color: var(--vc-accent); margin-bottom: 0.5rem; display: inline-block; }
.value-card h3 { font-family: var(--wp--preset--font-family--serif); font-size: 1.25rem; margin: 0 0 0.5rem; }
.value-card p { margin: 0; color: var(--vc-text-soft); }

/* KPI */
.kpi-grid { margin-top: 2.5rem; display: grid; gap: 1.5rem; grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); }
.kpi { padding: 1.5rem; border: 1px solid var(--vc-line); border-radius: var(--vc-radius-md); background: var(--vc-bg-alt); text-align: center; }
.kpi__num { display: block; font-family: var(--wp--preset--font-family--serif); font-size: 2.5rem; color: var(--vc-accent); line-height: 1; margin-bottom: 0.5rem; }
.kpi__lab { color: var(--vc-text-soft); font-size: 0.85rem; letter-spacing: 0.12em; text-transform: uppercase; }

/* Quote */
.quote-mark { font-family: var(--wp--preset--font-family--serif); font-style: italic; font-size: clamp(1.5rem, 3vw, 2.25rem); color: var(--vc-primary-dark); line-height: 1.35; max-width: 60ch; margin: 0 auto 1rem; text-align: center; }
.quote-mark__att { text-align: center; color: var(--vc-text-soft); letter-spacing: 0.1em; text-transform: uppercase; font-size: 0.85rem; margin: 0; }

/* Package cards (Prestazioni e Servizi) */
.package-grid { display: grid; gap: 1.5rem; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); }
.package-card { background: var(--vc-bg-alt); border-radius: var(--vc-radius-md); overflow: hidden; border: 1px solid var(--vc-line); display: flex; flex-direction: column; transition: transform var(--vc-dur) var(--vc-ease), border-color var(--vc-dur) var(--vc-ease); }
.package-card:hover { transform: translateY(-3px); border-color: var(--vc-accent); }
.package-card__media { aspect-ratio: 16/10; overflow: hidden; }
.package-card__media img { width: 100%; height: 100%; object-fit: cover; }
.package-card__body { padding: 1.75rem; display: flex; flex-direction: column; flex: 1; }
.package-card__icon { font-size: 2rem; color: var(--vc-accent); margin-bottom: 0.5rem; }
.package-card__title { font-family: var(--wp--preset--font-family--serif); font-size: 1.4rem; margin: 0 0 0.35rem; }
.package-card__payoff { color: var(--vc-text-soft); margin: 0 0 1rem; }
.package-card__list { list-style: none; padding: 0; margin: 0 0 1rem; }
.package-card__list li { display: flex; gap: 0.5rem; align-items: flex-start; padding: 0.35rem 0; color: var(--vc-text); border-bottom: 1px dashed var(--vc-line); }
.package-card__list li:last-child { border-bottom: 0; }
.package-card__list .ph { color: var(--vc-accent); margin-top: 0.25rem; }
.package-card__price { font-family: var(--wp--preset--font-family--serif); font-size: 1.5rem; color: var(--vc-primary-dark); margin: 0 0 1rem; }
.package-card .btn { margin-top: auto; align-self: flex-start; }

/* Prestazioni accessorie list */
.prestazioni-list { display: grid; gap: 0; margin: 0; }
.prestazioni-list__row { display: grid; grid-template-columns: 1fr 2fr; gap: 1.5rem; padding: 1.25rem 0; border-bottom: 1px solid var(--vc-line); align-items: baseline; }
@media (max-width: 640px) { .prestazioni-list__row { grid-template-columns: 1fr; gap: 0.25rem; } }
.prestazioni-list__name { font-family: var(--wp--preset--font-family--serif); font-size: 1.2rem; margin: 0; color: var(--vc-primary-dark); display: inline-flex; gap: 0.5rem; align-items: center; }
.prestazioni-list__name .ph { color: var(--vc-accent); }
.prestazioni-list__desc { margin: 0; color: var(--vc-text-soft); }

/* -------------------------------------------------------------------------- *
 * 10. SLIDERS / MARQUEE
 * -------------------------------------------------------------------------- */
.marquee { background: var(--vc-bg-alt); padding-block: clamp(2.5rem, 5vw, 4rem); }
.marquee__title { text-align: center; color: var(--vc-text-soft); font-size: 0.85rem; letter-spacing: 0.16em; text-transform: uppercase; font-weight: 600; margin: 0 0 1.5rem; }
.marquee__viewport { overflow: hidden; mask-image: linear-gradient(90deg, transparent, #000 10%, #000 90%, transparent); }
.marquee__track {
	list-style: none; padding: 0; margin: 0;
	display: flex; align-items: center; gap: 4rem; width: max-content;
	animation: vc-marquee 40s linear infinite;
}
.marquee__item { display: inline-flex; align-items: center; height: 60px; }
.marquee__logo { max-height: 50px; width: auto; filter: grayscale(100%); opacity: 0.7; transition: opacity var(--vc-dur) var(--vc-ease), filter var(--vc-dur) var(--vc-ease); }
.marquee__item:hover .marquee__logo { opacity: 1; filter: grayscale(0%); }
@keyframes vc-marquee { from { transform: translateX(0); } to { transform: translateX(-50%); } }
@media (prefers-reduced-motion: reduce) { .marquee__track { animation: none; } }

/* IG slider */
.ig-slider { background: var(--vc-bg-alt); }
.ig-slider__head { display: flex; justify-content: space-between; align-items: end; gap: 1rem; margin-bottom: 1.5rem; flex-wrap: wrap; }
.ig-slider__viewport { overflow: hidden; position: relative; }
.ig-slider__track { list-style: none; padding: 0 var(--vc-gutter); margin: 0; display: flex; gap: 1rem; overflow-x: auto; scroll-snap-type: x mandatory; scroll-behavior: smooth; }
.ig-slider__track::-webkit-scrollbar { display: none; }
.ig-slider__item { flex: 0 0 calc((100% / 4) - 0.75rem); scroll-snap-align: start; }
@media (max-width: 1024px) { .ig-slider__item { flex-basis: calc((100% / 3) - 0.75rem); } }
@media (max-width: 640px)  { .ig-slider__item { flex-basis: calc((100% / 2) - 0.5rem); } }
.ig-slider__link { display: block; position: relative; border-radius: var(--vc-radius-md); overflow: hidden; aspect-ratio: 1; }
.ig-slider__image { width: 100%; height: 100%; object-fit: cover; transition: transform var(--vc-dur-slow) var(--vc-ease); }
.ig-slider__link:hover .ig-slider__image { transform: scale(1.06); }
.ig-slider__overlay { position: absolute; inset: 0; display: grid; place-items: center; color: var(--vc-text-inverse); font-size: 2rem; background: rgba(15,32,30,0); transition: background var(--vc-dur) var(--vc-ease); }
.ig-slider__link:hover .ig-slider__overlay { background: rgba(15,32,30,0.4); }
.ig-slider__controls { display: flex; gap: 0.5rem; justify-content: flex-end; margin-top: 1rem; }
.ig-slider__btn { width: 44px; height: 44px; border-radius: 50%; background: var(--vc-bg); border: 1px solid var(--vc-line); display: grid; place-items: center; color: var(--vc-primary-dark); transition: background var(--vc-dur) var(--vc-ease), color var(--vc-dur) var(--vc-ease); }
.ig-slider__btn:hover, .ig-slider__btn:focus-visible { background: var(--vc-primary-dark); color: var(--vc-accent-soft); }

/* -------------------------------------------------------------------------- *
 * 11. FILTERS (specialita / medici)
 * -------------------------------------------------------------------------- */
.filters { padding-block: 1rem; background: var(--vc-bg); border-bottom: 1px solid var(--vc-line); }
.filters--sticky { position: sticky; top: calc(var(--vc-header-h) + var(--vc-topbar-h)); z-index: 50; background: rgba(250, 247, 242, 0.96); backdrop-filter: blur(6px); }
.filters__list { list-style: none; padding: 0; margin: 0; display: flex; gap: 0.5rem; flex-wrap: wrap; }
.filters__item { background: transparent; border: 1px solid var(--vc-line); padding: 0.55rem 1.1rem; border-radius: var(--vc-radius-pill); color: var(--vc-text); font-size: 0.85rem; letter-spacing: 0.04em; cursor: pointer; transition: all var(--vc-dur-fast) var(--vc-ease); }
.filters__item:hover { border-color: var(--vc-accent); color: var(--vc-accent); }
.filters__item.is-active { background: var(--vc-primary-dark); border-color: var(--vc-primary-dark); color: var(--vc-accent-soft); }

/* -------------------------------------------------------------------------- *
 * 12. CONTATTI
 * -------------------------------------------------------------------------- */
.contact-grid { display: grid; gap: 1rem; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); }
.contact-card { background: var(--vc-bg-alt); border: 1px solid var(--vc-line); border-radius: var(--vc-radius-md); padding: 1.75rem; }
.contact-card .ph { font-size: 1.5rem; color: var(--vc-accent); margin-bottom: 0.5rem; }
.contact-card h3 { font-family: var(--wp--preset--font-family--serif); font-size: 1.2rem; margin: 0 0 0.5rem; }
.contact-card address, .contact-card p { font-style: normal; color: var(--vc-text-soft); margin: 0 0 0.5rem; }
.contact-card__link { display: inline-flex; gap: 0.4rem; align-items: center; color: var(--vc-accent); font-size: 0.85rem; font-weight: 600; letter-spacing: 0.1em; text-transform: uppercase; }
.contact-card__hours p { margin: 0 0 0.25rem; }

.form-wrap { background: var(--vc-bg-alt); padding: clamp(1.5rem, 4vw, 2.5rem); border-radius: var(--vc-radius-md); border: 1px solid var(--vc-line); box-shadow: var(--vc-shadow-sm); }
.map-wrap iframe { width: 100%; height: 480px; border: 0; border-radius: 0; display: block; }

/* -------------------------------------------------------------------------- *
 * 13. CTA BAND
 * -------------------------------------------------------------------------- */
.cta-band { background: var(--vc-primary-dark); color: var(--vc-text-inverse); position: relative; overflow: hidden; }
.cta-band::after { content: ''; position: absolute; right: -100px; top: -100px; width: 360px; height: 360px; background: radial-gradient(circle, rgba(184,153,104,0.22) 0%, transparent 70%); pointer-events: none; }
.cta-band__inner { display: grid; grid-template-columns: 1.4fr 1fr; gap: 2rem; align-items: center; position: relative; z-index: 1; }
@media (max-width: 800px) { .cta-band__inner { grid-template-columns: 1fr; } }
.cta-band__title { font-family: var(--wp--preset--font-family--serif); font-size: clamp(1.75rem, 3.5vw, 2.5rem); color: var(--vc-text-inverse); margin: 0 0 0.75rem; }
.cta-band__lead { color: rgba(255,255,255,0.82); margin: 0; max-width: 50ch; }
.cta-band__actions { display: flex; gap: 0.75rem; flex-wrap: wrap; justify-content: flex-end; }
@media (max-width: 800px) { .cta-band__actions { justify-content: flex-start; } }

/* -------------------------------------------------------------------------- *
 * 14. FOOTER
 * -------------------------------------------------------------------------- */
.site-footer { background: var(--vc-primary-dark); color: rgba(255,255,255,0.86); padding-block: 3.5rem 1.5rem; }
.site-footer a { color: inherit; }
.site-footer a:hover, .site-footer a:focus-visible { color: var(--vc-accent); }
.site-footer__top { display: grid; gap: 2rem; grid-template-columns: 1.4fr repeat(3, 1fr); padding-bottom: 2.5rem; border-bottom: 1px solid rgba(255,255,255,0.08); }
@media (max-width: 900px) { .site-footer__top { grid-template-columns: 1fr 1fr; } }
@media (max-width: 600px) { .site-footer__top { grid-template-columns: 1fr; } }
.site-footer__name, .site-footer__logo { color: var(--vc-text-inverse); font-family: var(--wp--preset--font-family--serif); font-size: 1.4rem; margin: 0 0 0.5rem; }
.site-footer__claim { font-style: italic; max-width: 30ch; color: rgba(255,255,255,0.7); }
.site-footer__title { color: var(--vc-accent); font-size: 0.8rem; letter-spacing: 0.16em; text-transform: uppercase; margin: 0 0 1rem; font-weight: 600; }
.site-footer__contacts, .site-footer__menu, .site-footer__legal, .site-footer__social { list-style: none; padding: 0; margin: 0; }
.site-footer__contacts li { padding: 0.25rem 0; display: flex; gap: 0.5rem; align-items: center; }
.site-footer__menu li, .site-footer__legal li { padding: 0.25rem 0; }
.site-footer__address { font-style: normal; color: rgba(255,255,255,0.7); }
.site-footer__hours { color: rgba(255,255,255,0.7); margin-top: 0.5rem; font-size: 0.9rem; }
.site-footer__bottom { display: flex; justify-content: space-between; gap: 1rem; flex-wrap: wrap; align-items: center; padding-top: 1.5rem; font-size: 0.85rem; color: rgba(255,255,255,0.6); }
.site-footer__legal { display: flex; gap: 1rem; flex-wrap: wrap; }
.site-footer__social { display: flex; gap: 0.5rem; }
.site-footer__social a { width: 36px; height: 36px; border-radius: 50%; background: rgba(255,255,255,0.06); display: grid; place-items: center; transition: background var(--vc-dur) var(--vc-ease); }
.site-footer__social a:hover { background: var(--vc-accent); color: var(--vc-primary-dark); }

/* -------------------------------------------------------------------------- *
 * 15. 404 / search / empty
 * -------------------------------------------------------------------------- */
.section--404 { text-align: center; padding-block: clamp(4rem, 10vw, 8rem); }
.not-found__code { font-family: var(--wp--preset--font-family--serif); font-size: clamp(5rem, 14vw, 9rem); color: var(--vc-accent); line-height: 1; margin: 0; }
.not-found__title { font-family: var(--wp--preset--font-family--serif); font-size: clamp(1.75rem, 4vw, 2.5rem); margin: 0.5rem 0; }
.not-found__lead { color: var(--vc-text-soft); max-width: 50ch; margin: 0 auto 2rem; }
.not-found__actions { display: flex; gap: 0.75rem; justify-content: center; flex-wrap: wrap; margin-bottom: 2rem; }
.search-form { display: inline-flex; gap: 0; background: var(--vc-bg-alt); border: 1px solid var(--vc-line); border-radius: var(--vc-radius-pill); overflow: hidden; }
.search-form__input { border: 0; padding: 0.85rem 1.25rem; background: transparent; min-width: 240px; font: inherit; color: var(--vc-text); }
.search-form__input:focus { outline: none; }
.search-form__submit { padding: 0 1.25rem; background: var(--vc-primary-dark); color: var(--vc-accent-soft); border: 0; border-radius: 0 var(--vc-radius-pill) var(--vc-radius-pill) 0; }
.empty-state { text-align: center; padding: 2rem; border: 1px dashed var(--vc-line); border-radius: var(--vc-radius-md); color: var(--vc-text-soft); }
.empty-state--soft { background: var(--vc-bg-alt); border-style: solid; }

/* -------------------------------------------------------------------------- *
 * 16. PLUGIN COMPATIBILITY
 * -------------------------------------------------------------------------- */
/* Fluent Forms — stile minimal coerente */
.has-fluent-forms .ff-default input[type="text"],
.has-fluent-forms .ff-default input[type="email"],
.has-fluent-forms .ff-default input[type="tel"],
.has-fluent-forms .ff-default textarea,
.has-fluent-forms .ff-default select {
	border: 1px solid var(--vc-line) !important;
	border-radius: var(--vc-radius-sm) !important;
	padding: 0.85rem 1rem !important;
	background: var(--vc-bg-alt) !important;
	font: inherit !important;
	color: var(--vc-text) !important;
	width: 100% !important;
	transition: border-color var(--vc-dur-fast) var(--vc-ease);
}
.has-fluent-forms .ff-default input:focus,
.has-fluent-forms .ff-default textarea:focus {
	border-color: var(--vc-accent) !important; outline: none;
	box-shadow: 0 0 0 3px rgba(184,153,104,0.15);
}
.has-fluent-forms .ff-default button.ff-btn-submit {
	background: var(--vc-primary-dark) !important; color: var(--vc-accent-soft) !important;
	border-radius: var(--vc-radius-pill) !important;
	padding: 0.95rem 2rem !important; letter-spacing: 0.08em; text-transform: uppercase;
	border: 0; font-weight: 500;
}
.has-fluent-forms .ff-default label { font-size: 0.9rem !important; font-weight: 500 !important; color: var(--vc-text); }

/* Amelia — wrapper neutro */
.veinclinic-amelia { background: var(--vc-bg-alt); border-radius: var(--vc-radius-md); padding: clamp(1rem, 2vw, 1.5rem); border: 1px solid var(--vc-line); }

/* Rank Math breadcrumbs (se mostrati) */
.rank-math-breadcrumb { font-size: 0.85rem; color: var(--vc-text-soft); letter-spacing: 0.04em; }
.rank-math-breadcrumb a { color: var(--vc-text-soft); }
.rank-math-breadcrumb a:hover { color: var(--vc-accent); }

/* -------------------------------------------------------------------------- *
 * 17. ACCESSIBILITA' / FOCUS
 * -------------------------------------------------------------------------- */
:focus-visible {
	outline: 2px solid var(--vc-accent);
	outline-offset: 3px;
	border-radius: var(--vc-radius-sm);
}
@media (prefers-reduced-motion: reduce) {
	*, *::before, *::after { animation-duration: 0ms !important; transition-duration: 0ms !important; scroll-behavior: auto !important; }
}

/* -------------------------------------------------------------------------- *
 * 18. ANIMAZIONI (data-reveal)
 * -------------------------------------------------------------------------- */
[data-reveal] { opacity: 0; transform: translate3d(0, 16px, 0); transition: opacity var(--vc-dur) var(--vc-ease), transform var(--vc-dur) var(--vc-ease); }
[data-reveal="down"] { transform: translate3d(0, -16px, 0); }
[data-reveal="left"] { transform: translate3d(16px, 0, 0); }
[data-reveal="right"] { transform: translate3d(-16px, 0, 0); }
[data-reveal].is-revealed { opacity: 1; transform: translate3d(0, 0, 0); }
@media (prefers-reduced-motion: reduce) { [data-reveal] { opacity: 1; transform: none; } }

/* -------------------------------------------------------------------------- *
 * 19. MOBILE NAV / RESPONSIVE
 * -------------------------------------------------------------------------- */
@media (max-width: 960px) {
	.nav-toggle { display: inline-grid; place-items: center; }
	.menu--primary {
		position: fixed; inset: var(--vc-header-h) 0 0 0;
		display: flex; flex-direction: column; align-items: stretch; gap: 0;
		background: var(--vc-bg-alt);
		padding: 1rem;
		transform: translateX(100%); opacity: 0;
		transition: transform var(--vc-dur) var(--vc-ease), opacity var(--vc-dur) var(--vc-ease);
		overflow-y: auto;
	}
	.site-nav.is-open .menu--primary { transform: translateX(0); opacity: 1; }
	.menu--primary > .menu-item { border-bottom: 1px solid var(--vc-line); }
	.menu--primary > .menu-item > .menu-link { padding: 1rem 0; font-size: 1.1rem; justify-content: space-between; width: 100%; }
	.menu-link::after { display: none; }
	.submenu, .megamenu { position: static; opacity: 1; transform: none; pointer-events: auto; box-shadow: none; background: transparent; padding: 0 0 0.5rem; max-height: 0; overflow: hidden; transition: max-height var(--vc-dur) var(--vc-ease); }
	.menu-item.is-open > .submenu, .menu-item.is-open > .megamenu { max-height: 1200px; }
	.megamenu__inner { padding-block: 0.5rem; }
	.megamenu__grid { grid-template-columns: 1fr; gap: 0.75rem; }
	.megamenu__link { grid-template-columns: 80px 1fr; gap: 1rem; padding: 0.75rem; background: var(--vc-bg); border-radius: var(--vc-radius-md); }
	.megamenu__media { aspect-ratio: 1; }
	.megamenu__title { font-size: 1.1rem; }
	.megamenu__desc { font-size: 0.85rem; }
	.doctor-hero__inner { grid-template-columns: 1fr; }
	.hide-on-mobile { display: none !important; }
}

@media (max-width: 600px) {
	.site-topbar__contacts { gap: 0.75rem; }
	.site-topbar__contacts li:not(:first-child):not(:nth-child(2)) { display: none; }
}
