/* =========================================================
   LUXURY AUTO — main.css
   Clone strutturale di realeya.com (tema scuro)
   Token estratti dal kit Elementor del sito originale
   ========================================================= */

:root {
	/* Colori */
	--c-cream:    #FAF0E6;
	--c-dark:     #2b2a28;  /* sezioni scure */
	--c-darker:   #211f1d;  /* footer */
	--c-ink:      #333333;  /* testo su chiaro */
	--c-grey:     #b9b4ad;  /* testo secondario su scuro */
	--c-sage:     #80968D;
	--c-gold:     #D2B690;
	--c-white:    #FFFFFF;
	--c-hairline: rgba(255, 255, 255, .14);

	/* Tipografia */
	--font-serif: 'Lora', Georgia, 'Times New Roman', serif;
	--font-sans:  'Roboto', -apple-system, BlinkMacSystemFont, 'Segoe UI', Helvetica, Arial, sans-serif;
	--font-nav:   'Manrope', -apple-system, BlinkMacSystemFont, 'Segoe UI', Helvetica, Arial, sans-serif;

	/* Layout */
	--container:  1920px;   /* full-width come realeya (sezioni a 1920) */
	--gutter:     clamp(20px, 4vw, 72px);
	--header-h:   90px;
	--overlay-split: clamp(380px, 38vw, 660px); /* larghezza pannello voci del menu */
	--ease:       cubic-bezier(.22, .61, .36, 1);
}

/* ---------- Reset ---------- */
*, *::before, *::after { box-sizing: border-box; }
html {
	-webkit-text-size-adjust: 100%;
	scroll-behavior: smooth;
}
/* rete di sicurezza: nessuna fascia/scroll orizzontale su mobile (non rompe sticky/smooth) */
body { overflow-x: clip; }
body {
	margin: 0;
	font-family: var(--font-sans);
	font-size: 16px;
	line-height: 1.7;
	color: var(--c-white);
	background: var(--c-dark);
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}
img, video { max-width: 100%; height: auto; display: block; }
a { color: inherit; text-decoration: none; transition: color .3s var(--ease); }
button { font-family: inherit; cursor: pointer; }
ul { list-style: none; margin: 0; padding: 0; }
h1, h2, h3, h4 { font-family: var(--font-serif); font-weight: 400; line-height: 1.14; margin: 0 0 .5em; }
p { margin: 0 0 1.3em; }

/* ---------- Utility ---------- */
.container { width: 100%; max-width: var(--container); margin-inline: auto; padding-inline: var(--gutter); }
.container--narrow { max-width: 820px; }
.screen-reader-text { position: absolute !important; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0; }
.skip-link { position: absolute; left: -999px; top: 0; z-index: 1000; background: #000; color: #fff; padding: 12px 20px; }
.skip-link:focus { left: 12px; top: 12px; }

/* =========================================================
   HEADER
   ========================================================= */
.site-header {
	position: fixed;
	inset: 0 0 auto 0;
	z-index: 200;
	height: var(--header-h);
	display: flex;
	align-items: center;
	background: transparent;
	transition: background .4s var(--ease), height .4s var(--ease), box-shadow .4s var(--ease), opacity .28s var(--ease), visibility .28s var(--ease);
}
.site-header__inner {
	width: 100%;
	max-width: var(--container);
	margin-inline: auto;
	padding-inline: var(--gutter);
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 24px;
}
.site-header__right { display: flex; align-items: center; gap: clamp(18px, 2vw, 34px); }

/* Logo / Wordmark di marca */
.site-logo, .custom-logo-link {
	font-family: var(--font-serif);
	font-size: 26px;
	letter-spacing: .18em;
	text-transform: uppercase;
	color: #fff;
}
.brand { display: inline-flex; align-items: center; gap: 13px; color: #fff; }
.brand__mark { color: var(--c-gold); display: inline-flex; transition: color .3s var(--ease); }
.brand__mark svg { width: 26px; height: 26px; display: block; }
.brand__text { display: flex; flex-direction: column; line-height: 1; }
.brand__name { font-family: var(--font-serif); font-size: 22px; letter-spacing: .3em; text-transform: uppercase; }
.brand__sub { font-family: var(--font-nav); font-size: 9px; font-weight: 600; letter-spacing: .32em; text-transform: uppercase; color: var(--c-gold); margin-top: 6px; padding-left: .3em; }
.brand:hover .brand__mark { color: #e7d0aa; }
.brand--footer .brand__name { font-size: 24px; }
.site-footer__brand .brand { margin-bottom: 18px; }

/* Nav inline (desktop) */
.site-nav .primary-menu { display: flex; align-items: center; gap: clamp(16px, 2vw, 34px); }
.primary-menu > .menu-item { position: relative; }
.primary-menu .menu-link {
	display: inline-flex; align-items: center; gap: 6px;
	font-family: var(--font-nav);
	font-size: 15px; font-weight: 600; letter-spacing: normal;
	text-transform: uppercase;
	color: #fff;
}
.primary-menu > .menu-item:hover > .menu-link,
.primary-menu .current-menu-item > .menu-link { color: var(--c-gold); }
.primary-menu > .menu-item-has-children > .menu-link::after {
	content: ''; width: 6px; height: 6px;
	border-right: 1.5px solid currentColor; border-bottom: 1.5px solid currentColor;
	transform: translateY(-2px) rotate(45deg); transition: transform .3s var(--ease);
}
.primary-menu > .menu-item-has-children:hover > .menu-link::after { transform: translateY(1px) rotate(45deg); }

/* dropdown del nav inline */
.site-nav .sub-menu {
	position: absolute; top: 100%; left: 50%;
	transform: translate(-50%, 12px);
	min-width: 200px; padding: 12px 0;
	background: rgba(20, 19, 17, .92);
	backdrop-filter: blur(14px); -webkit-backdrop-filter: blur(14px);
	box-shadow: 0 24px 60px rgba(0,0,0,.4);
	opacity: 0; visibility: hidden;
	transition: opacity .3s var(--ease), transform .3s var(--ease);
}
.site-nav .menu-item-has-children:hover > .sub-menu { opacity: 1; visibility: visible; transform: translate(-50%, 0); }
.site-nav .sub-menu .menu-link { display: block; padding: 11px 24px; font-size: 15px; font-weight: 500; letter-spacing: normal; }
.site-nav .sub-menu .menu-link:hover { color: var(--c-gold); }
.site-nav .submenu-toggle { display: none; }

/* Lang switcher header: bandiera attiva + dropdown (stile realeya) */
.lang-switch { position: relative; }
.lang-switch__toggle {
	display: inline-flex; align-items: center; gap: 8px;
	background: none; border: 0; color: #fff; padding: 6px 0;
	font-family: var(--font-nav); font-size: 13px; letter-spacing: .06em;
}
.lang-switch__toggle:hover { color: var(--c-gold); }
.lang-flag { display: inline-flex; line-height: 0; }
.lang-flag img { display: block; width: 20px; height: auto; border-radius: 2px; }
.lang-switch__caret {
	width: 6px; height: 6px;
	border-right: 1.5px solid currentColor; border-bottom: 1.5px solid currentColor;
	transform: translateY(-2px) rotate(45deg); transition: transform .3s var(--ease);
}
.lang-switch.is-open .lang-switch__caret { transform: translateY(1px) rotate(225deg); }

.lang-switch__menu {
	position: absolute; top: calc(100% + 8px); right: 0;
	min-width: 168px; padding: 8px 0;
	background: rgba(20, 19, 17, .96);
	backdrop-filter: blur(14px); -webkit-backdrop-filter: blur(14px);
	box-shadow: 0 24px 60px rgba(0, 0, 0, .45);
	opacity: 0; visibility: hidden; transform: translateY(8px);
	transition: opacity .25s var(--ease), transform .25s var(--ease), visibility .25s;
	z-index: 20;
}
.lang-switch:hover .lang-switch__menu,
.lang-switch.is-open .lang-switch__menu { opacity: 1; visibility: visible; transform: translateY(0); }
.lang-switch__menu li a {
	display: flex; align-items: center; gap: 11px;
	padding: 9px 18px; color: rgba(255, 255, 255, .7);
	font-family: var(--font-nav); font-size: 13px; letter-spacing: .04em;
}
.lang-switch__menu li a:hover { color: var(--c-gold); }
.lang-switch__menu .is-active a { color: #fff; }

/* Hamburger — SEMPRE visibile (desktop + mobile) */
.menu-toggle {
	background: none; border: 0; width: 34px; height: 24px; padding: 0; color: #fff; position: relative;
	/* isola il pulsante su un layer proprio: niente sfarfallamento sopra il backdrop-filter durante lo scroll */
	transform: translateZ(0);
	-webkit-backface-visibility: hidden; backface-visibility: hidden;
}
.menu-toggle__bars { display: block; width: 28px; height: 16px; position: relative; margin: 0 auto; }
.menu-toggle__bars span { position: absolute; left: 0; width: 100%; height: 2px; background: currentColor; transition: transform .3s var(--ease), opacity .3s var(--ease), width .3s var(--ease); -webkit-backface-visibility: hidden; backface-visibility: hidden; }
.menu-toggle__bars span:nth-child(1) { top: 0; }
.menu-toggle__bars span:nth-child(2) { top: 50%; transform: translateY(-50%); width: 70%; }
.menu-toggle__bars span:nth-child(3) { bottom: 0; }
.menu-toggle:hover { color: var(--c-gold); }
.menu-toggle:hover .menu-toggle__bars span:nth-child(2) { width: 100%; }

/* Sfondo solido: header scrollato (ovunque) e pagine interne (sempre) */
.site-header.is-scrolled,
body:not(.has-transparent-header) .site-header {
	background: rgba(33, 31, 29, .96);
	backdrop-filter: blur(10px); -webkit-backdrop-filter: blur(10px);
	box-shadow: 0 1px 0 var(--c-hairline);
}
/* Riduzione altezza SOLO da scrollati, identica su TUTTE le pagine (home + interne) */
.site-header.is-scrolled { height: 72px; }
/* Spazio sotto l'header fisso nelle pagine interne (= altezza header a riposo) */
body:not(.has-transparent-header) .site-content { padding-top: var(--header-h); }

/* =========================================================
   OVERLAY MENU ("il menu che si apre")
   ========================================================= */
/* Layout a due pannelli: VOCI a sinistra, SLIDESHOW a destra, X tonda sulla divisione */
.overlay-menu {
	position: fixed; inset: 0; z-index: 190; overflow: hidden;
	background: #1a1917;                       /* fondo unico: niente "buco" durante il movimento */
	opacity: 0; visibility: hidden;
	transition: opacity .35s var(--ease), visibility .35s var(--ease);
}
body.menu-open .overlay-menu { opacity: 1; visibility: visible; }
body.menu-open { overflow: hidden; }

/* All'apertura l'header (logo + voci + bandiera) sparisce subito (rapido, non resta sopra il menu) */
body.menu-open .site-header { opacity: 0; visibility: hidden; pointer-events: none; transition: opacity .2s var(--ease), visibility .2s var(--ease); }

/* Stage: i DUE pannelli si muovono come UN UNICO blocco (fadeInDown, come realeya) */
.overlay-menu__stage {
	height: 100%;
	display: grid;
	grid-template-columns: var(--overlay-split) 1fr;
	opacity: 0; transform: translateY(-48px);
	transition: opacity .55s var(--ease), transform .7s var(--ease);
	will-change: transform, opacity;
}
body.menu-open .overlay-menu__stage { opacity: 1; transform: none; }

/* Chiusura: prosegue verso il BASSO (stessa direzione d'entrata) + dissolvenza */
body.menu-closing { overflow: hidden; }
body.menu-closing .overlay-menu { opacity: 0; visibility: visible; transition: opacity .55s var(--ease); }
body.menu-closing .overlay-menu__stage { opacity: 0; transform: translateY(48px); }
body.menu-closing .site-header { opacity: 0; visibility: hidden; pointer-events: none; }

/* --- Pannello voci (sinistra) --- */
.overlay-menu__panel {
	background: #1a1917;
	display: flex; flex-direction: column; justify-content: center;
	padding: 120px clamp(40px, 5vw, 92px) 60px;
	position: relative; z-index: 2;
}

.overlay-nav { display: flex; flex-direction: column; }
.overlay-nav .menu-item { position: relative; border-bottom: 1px solid rgba(255,255,255,.08); }
.overlay-nav .menu-link {
	display: flex; align-items: center; justify-content: space-between;
	font-family: var(--font-nav);
	font-size: 15px; font-weight: 600;
	letter-spacing: normal; text-transform: uppercase; color: #fff;
	padding: clamp(15px, 1.9vw, 24px) 0;
	transition: color .3s var(--ease), padding-left .3s var(--ease);
}
.overlay-nav > .menu-item:hover > .menu-link { color: var(--c-gold); padding-left: 10px; }
.overlay-nav .submenu-toggle { background: none; border: 0; color: var(--c-gold); width: 40px; height: 40px; position: relative; flex: 0 0 auto; }
.overlay-nav .submenu-toggle__icon::before,
.overlay-nav .submenu-toggle__icon::after { content: ''; position: absolute; top: 50%; left: 50%; width: 12px; height: 1.5px; background: currentColor; transform: translate(-50%,-50%); transition: transform .3s var(--ease); }
.overlay-nav .submenu-toggle__icon::after { transform: translate(-50%,-50%) rotate(90deg); }
.overlay-nav .menu-item-has-children.is-open .submenu-toggle__icon::after { transform: translate(-50%,-50%) rotate(0); }
.overlay-nav .sub-menu { max-height: 0; overflow: hidden; transition: max-height .4s var(--ease); }
.overlay-nav .menu-item-has-children.is-open > .sub-menu { max-height: 220px; padding-bottom: 6px; }
.overlay-nav .sub-menu .menu-link { font-size: 14px; font-weight: 500; letter-spacing: normal; color: var(--c-grey); padding: 8px 0 8px 14px; }
.overlay-nav .sub-menu .menu-link:hover { color: var(--c-gold); }

.overlay-menu__lang { display: flex; flex-direction: column; gap: 14px; margin-top: 42px; }
.overlay-menu__lang a { display: inline-flex; align-items: center; gap: 11px; color: rgba(255,255,255,.5); font-family: var(--font-nav); font-size: 14px; letter-spacing: .04em; }
.overlay-menu__lang .lang-flag img { width: 22px; height: auto; border-radius: 2px; }
.overlay-menu__lang .is-active a, .overlay-menu__lang a:hover { color: #fff; }

/* --- Pannello immagini (destra) — slideshow --- */
.overlay-menu__media { position: relative; overflow: hidden; background: #0f0e0d; }
.overlay-slide {
	position: absolute; inset: 0;
	background-size: cover; background-position: center;
	opacity: 0; transform: scale(1);
	transition: opacity 2s var(--ease), transform 2s var(--ease);
}
/* Ken Burns: zoom "in" lento (come realeya) + dissolvenza 2s */
.overlay-slide.is-active {
	opacity: 1; transform: scale(1.12);
	transition: opacity 2s var(--ease), transform 7s ease-out;
}
.overlay-slide[data-placeholder]:nth-child(1) { background-image: linear-gradient(140deg, #4a463f 0%, #29251f 100%); }
.overlay-slide[data-placeholder]:nth-child(2) { background-image: linear-gradient(140deg, #3a4640 0%, #1f2622 100%); }
.overlay-slide[data-placeholder]:nth-child(3) { background-image: linear-gradient(140deg, #4a3f3a 0%, #261f1c 100%); }
.overlay-menu__media::after {
	content: ''; position: absolute; inset: 0; pointer-events: none;
	background: linear-gradient(90deg, rgba(26,25,23,.5) 0%, rgba(26,25,23,0) 22%);
}

/* --- X tonda sulla linea di divisione --- */
.overlay-close {
	position: absolute; top: 50%; left: var(--overlay-split);
	transform: translate(-50%, -50%);
	z-index: 5;
	width: 58px; height: 58px; border-radius: 50%;
	border: 1px solid rgba(255,255,255,.5);
	background: rgba(20,19,17,.55);
	backdrop-filter: blur(6px); -webkit-backdrop-filter: blur(6px);
	display: grid; place-items: center;
	opacity: 0; transition: opacity .4s var(--ease) .25s, background .3s var(--ease), border-color .3s var(--ease);
}
body.menu-open .overlay-close { opacity: 1; }
.overlay-close:hover { background: var(--c-gold); border-color: var(--c-gold); }
.overlay-close__x { position: relative; width: 20px; height: 20px; display: block; }
.overlay-close__x::before, .overlay-close__x::after { content: ''; position: absolute; top: 50%; left: 50%; width: 18px; height: 1.5px; background: #fff; transition: background .3s var(--ease); }
.overlay-close__x::before { transform: translate(-50%,-50%) rotate(45deg); }
.overlay-close__x::after { transform: translate(-50%,-50%) rotate(-45deg); }
.overlay-close:hover .overlay-close__x::before,
.overlay-close:hover .overlay-close__x::after { background: #1a1917; }

/* Overlay su mobile: voci a tutta larghezza, immagini nascoste, X in alto a destra */
@media (max-width: 860px) {
	/* Menu mobile: banda immagine in alto (slideshow continua) + voci sotto */
	.overlay-menu__stage { grid-template-columns: 1fr; grid-template-rows: 42vh 1fr; }
	.overlay-menu__media { display: block; order: -1; }
	.overlay-menu__panel { padding: 46px clamp(24px, 7vw, 48px); justify-content: center; }
	.overlay-close {
		top: 18px; left: auto; right: 18px;
		transform: none; width: 46px; height: 46px;
	}
}

/* =========================================================
   HERO (banner immagine/video, senza testo)
   ========================================================= */
.hero { position: relative; width: 100%; height: 100vh; height: 100svh; overflow: hidden; background: #1c1a18; }
/* Mobile: hero come banner contenuto (i contenuti iniziano subito sotto, stile realeya) */
@media (max-width: 768px) {
	.hero { height: 58svh; min-height: 360px; }
}
.hero__media { position: absolute; inset: 0; }
.hero__media video, .hero__video { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }
/* overlay leggero per uniformare il video e dare profondità (come realeya) */
.hero__overlay {
	position: absolute; inset: 0; z-index: 1; pointer-events: none;
	background: linear-gradient(180deg, rgba(0,0,0,.28) 0%, rgba(0,0,0,.05) 30%, rgba(0,0,0,.10) 70%, rgba(0,0,0,.35) 100%);
}

/* =========================================================
   SEZIONE INTRO (scura, due colonne)
   ========================================================= */
.intro { background: var(--c-dark); padding-block: clamp(60px, 8vw, 120px); }
.intro__grid { display: grid; grid-template-columns: 1.05fr .95fr; gap: clamp(40px, 6vw, 96px); align-items: center; }

.intro__head { margin-bottom: 44px; }
.intro__brand { font-size: clamp(46px, 6vw, 74px); letter-spacing: .04em; margin: 0; }
.intro__tagline { font-family: var(--font-serif); font-size: clamp(20px, 2.4vw, 28px); color: rgba(255,255,255,.92); margin: 4px 0 0; }

.intro__block { margin-bottom: 34px; max-width: 560px; }
.intro__heading { font-size: clamp(19px, 2.1vw, 24px); color: #fff; margin-bottom: .5em; }
.intro__block p { color: var(--c-grey); font-size: 15.5px; line-height: 1.85; margin: 0; }

.intro__actions { display: flex; flex-direction: column; align-items: flex-start; gap: 14px; margin-top: 44px; }

.intro__media {
	align-self: stretch;
	min-height: 520px;
	background: linear-gradient(150deg, #3b3833 0%, #211f1c 100%);
	position: relative;
}
.intro__media[data-placeholder]::after {
	content: 'IMMAGINE';
	position: absolute; inset: 0; display: flex; align-items: center; justify-content: center;
	font-family: var(--font-nav); font-size: 12px; letter-spacing: .3em; color: rgba(255,255,255,.3);
}

/* Bottoni intro (scuri, bordati, con icona) */
.lux-btn {
	display: inline-flex; align-items: center; gap: 12px;
	font-family: var(--font-nav); font-size: 14px; font-weight: 500; letter-spacing: .06em;
	color: #fff;
	padding: 14px 26px;
	border: 1px solid rgba(255,255,255,.28);
	background: rgba(255,255,255,.02);
	min-width: 230px;
	transition: border-color .35s var(--ease), background .35s var(--ease), color .35s var(--ease);
}
.lux-btn__icon { color: var(--c-gold); font-size: 15px; }
.lux-btn:hover { border-color: var(--c-gold); background: rgba(210,182,144,.08); color: var(--c-gold); }
.lux-btn:hover .lux-btn__icon { color: var(--c-gold); }

/* =========================================================
   PAGINE / BLOG
   ========================================================= */
.main { padding-block: clamp(48px, 7vw, 110px); background: var(--c-dark); }
.page-head { text-align: center; margin-bottom: clamp(32px, 5vw, 64px); }
.page-head__title { font-size: clamp(30px, 4vw, 48px); }
.entry-content { font-size: 17px; color: var(--c-grey); }
.entry-content a { color: var(--c-gold); text-decoration: underline; text-underline-offset: 3px; }
.post-list { display: grid; gap: 48px; }
.post-card__title { font-size: 26px; margin: .4em 0; }
.post-card__title a:hover { color: var(--c-gold); }
.post-card__link { font-size: 12px; letter-spacing: .2em; text-transform: uppercase; color: var(--c-gold); }

/* =========================================================
   FOOTER
   ========================================================= */
.site-footer { background: var(--c-darker); color: var(--c-grey); padding-top: clamp(56px, 7vw, 90px); }
.site-footer__inner {
	max-width: var(--container); margin-inline: auto; padding-inline: var(--gutter);
	display: grid; grid-template-columns: 1.4fr repeat(4, 1fr) auto; gap: clamp(24px, 3vw, 48px);
	padding-bottom: 56px;
}
.site-footer__logo { font-family: var(--font-serif); font-size: 24px; letter-spacing: .14em; text-transform: uppercase; color: #fff; display: inline-block; margin-bottom: 18px; }
.site-footer__address { font-size: 14px; line-height: 1.9; }
.footer-col__title, .site-footer__heading { color: #fff; font-family: var(--font-nav); font-size: 13px; letter-spacing: .12em; text-transform: uppercase; margin: 0 0 16px; font-weight: 600; }
.footer-menu { display: grid; gap: 12px; }
.footer-menu a { font-size: 14px; }
.footer-menu a:hover { color: var(--c-gold); }
.site-footer__newsletter { min-width: 240px; }
.newsletter-form { display: flex; border-bottom: 1px solid rgba(255,255,255,.3); margin-bottom: 14px; }
.newsletter-form input { flex: 1; background: none; border: 0; color: #fff; padding: 10px 0; font-size: 14px; }
.newsletter-form input::placeholder { color: rgba(255,255,255,.45); }
.newsletter-form input:focus { outline: none; }
.newsletter-form button { background: none; border: 0; color: var(--c-gold); font-size: 18px; padding: 0 6px; }
.newsletter-privacy { display: flex; align-items: flex-start; gap: 9px; font-size: 12px; line-height: 1.5; margin-bottom: 22px; }
.social-links { display: flex; gap: 16px; font-size: 13px; }
.social-links a:hover { color: var(--c-gold); }
.site-footer__bottom { border-top: 1px solid rgba(255,255,255,.1); text-align: center; padding: 24px var(--gutter); font-size: 12px; letter-spacing: .05em; }
.site-footer__bottom p { margin: 0; }
.site-footer__demo { margin-top: 8px; font-size: 11px; color: rgba(255,255,255,.62); letter-spacing: .04em; }
.site-footer__demo strong { font-weight: 600; color: rgba(255,255,255,.85); }

/* =========================================================
   RESPONSIVE
   ========================================================= */
@media (max-width: 1024px) {
	/* nav inline nascosta: resta solo il burger (che apre l'overlay) */
	.site-nav { display: none; }
	.intro__grid { grid-template-columns: 1fr; }
	.intro__media { min-height: 360px; order: -1; }
	.site-footer__inner { grid-template-columns: 1fr 1fr 1fr; }
	.overlay-menu__inner { grid-template-columns: 1fr; gap: 40px; align-items: start; }
	.overlay-menu__aside { align-self: start; }
}

@media (max-width: 600px) {
	:root { --header-h: 70px; }
	.site-footer__inner { grid-template-columns: 1fr 1fr; }
	.lux-btn { min-width: 100%; }
	.overlay-menu__inner { padding-top: 100px; }
}

@media (prefers-reduced-motion: reduce) {
	* { animation: none !important; transition-duration: .01ms !important; }
	html { scroll-behavior: auto; }
}

/* =========================================================
   PAGINE INTERNE / STRUTTURA (additivo — non tocca home/hero)
   ========================================================= */

/* Placeholder riquadri */
.ph { position: relative; width: 100%; height: 100%; min-height: 220px; background: linear-gradient(150deg, #3b3833 0%, #211f1c 100%); display: grid; place-items: center; overflow: hidden; }
.ph span { font-family: var(--font-nav); font-size: 11px; letter-spacing: .28em; text-transform: uppercase; color: rgba(255,255,255,.32); }
.ph--tall { min-height: 460px; }
.ph--portrait { aspect-ratio: 3/4; min-height: 0; }
.ph--wide { aspect-ratio: 16/7; min-height: 0; }
.ph--thumb { aspect-ratio: 4/3; min-height: 0; }
.ph--map { min-height: 420px; }

/* Media reale (immagine dal pool) dentro la cornice .ph */
.ph--img { background: #14130f; }
.ph--img img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; transform: scale(1.001); transition: transform 1.2s cubic-bezier(.16,.84,.34,1); }
.ph--img .ph__sheen { position: absolute; inset: 0; pointer-events: none; background: linear-gradient(180deg, rgba(20,19,15,0) 55%, rgba(20,19,15,.42) 100%); }
.ph--img::after { content: ""; position: absolute; inset: 0; border: 1px solid rgba(210,182,144,.16); pointer-events: none; }
.split__media .ph--img:hover img,
.info-card--link:hover .ph--img img,
.vcard:hover .ph--img img,
.jcard:hover .ph--img img { transform: scale(1.06); }

/* Titoli sezione */
.section { padding-block: clamp(56px, 7vw, 110px); background: var(--c-dark); }
.section--alt { background: #232220; }
.section-title { font-family: var(--font-serif); font-size: clamp(24px, 3vw, 36px); color: #fff; margin: 0 0 36px; }
.section-title--center { text-align: center; }
.note { color: rgba(255,255,255,.4); font-size: 13px; text-align: center; margin-top: 16px; }

/* Page hero (pagine interne) */
.page-hero { background: #232220; padding: clamp(80px, 11vw, 150px) 0 clamp(40px, 5vw, 70px); text-align: center; border-bottom: 1px solid var(--c-hairline); }
.page-hero__eyebrow { font-family: var(--font-nav); font-size: 12px; letter-spacing: .3em; text-transform: uppercase; color: var(--c-gold); margin: 0 0 18px; }
.page-hero__title { font-family: var(--font-serif); font-size: clamp(34px, 5vw, 60px); color: #fff; margin: 0; }
.page-hero__subtitle { color: var(--c-grey); font-size: clamp(15px, 1.6vw, 18px); max-width: 640px; margin: 18px auto 0; }
.page-hero--article { text-align: center; }
.article__byline { color: var(--c-grey); font-size: 14px; margin-top: 12px; }

/* Page hero cinematografico (immagine + velo + parallax) */
.page-hero--image { position: relative; overflow: hidden; background: #14130f; border-bottom: none; min-height: clamp(380px, 56vh, 620px); display: flex; align-items: flex-end; padding: clamp(80px, 12vw, 160px) 0 clamp(48px, 6vw, 84px); }
.page-hero--image .container { position: relative; z-index: 2; }
.page-hero__bg { position: absolute; inset: -14% 0; z-index: 0; will-change: transform; }
.page-hero__bg img { width: 100%; height: 100%; object-fit: cover; display: block; filter: saturate(1.02) contrast(1.02); }
.page-hero__veil { position: absolute; inset: 0; z-index: 1; background:
	linear-gradient(180deg, rgba(20,19,15,.55) 0%, rgba(20,19,15,.18) 32%, rgba(20,19,15,.62) 78%, rgba(20,19,15,.94) 100%),
	radial-gradient(120% 90% at 50% 0%, rgba(0,0,0,.35), transparent 60%); }
.page-hero--image .page-hero__title { text-shadow: 0 2px 40px rgba(0,0,0,.5); }
.page-hero--image .page-hero__subtitle { color: #e9e3d8; }

/* Bottone solido */
.lux-btn--solid { background: var(--c-gold); border-color: var(--c-gold); color: #1a1917; }
.lux-btn--solid:hover { background: #e3cba6; border-color: #e3cba6; color: #1a1917; }

/* Badge */
.badge { display: inline-block; font-family: var(--font-nav); font-size: 11px; letter-spacing: .16em; text-transform: uppercase; color: var(--c-gold); border: 1px solid rgba(210,182,144,.5); padding: 5px 12px; }
.badge--soft { color: var(--c-grey); border-color: var(--c-hairline); }

/* Split testo/immagine */
.split { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(32px, 5vw, 80px); align-items: center; }
.split__media .ph { min-height: 460px; }

/* Cards generiche */
.cards-3 { display: grid; grid-template-columns: repeat(3, 1fr); gap: clamp(20px, 2.6vw, 36px); }
.cards-4 { display: grid; grid-template-columns: repeat(4, 1fr); gap: clamp(20px, 2.4vw, 32px); }
.info-card { background: #2b2a28; border: 1px solid var(--c-hairline); padding: 34px 30px; }
.section--alt .info-card { background: var(--c-dark); }
.info-card h3 { font-family: var(--font-serif); font-size: 22px; color: #fff; margin: 0 0 12px; }
.info-card p { color: var(--c-grey); font-size: 15px; margin: 0; }
.info-card--link { display: block; position: relative; text-decoration: none; transition: border-color .3s var(--ease), transform .3s var(--ease); }
.info-card--link .info-card__media { margin: -34px -30px 24px; }
.info-card--link .ph { min-height: 200px; }
.info-card--link:hover { border-color: var(--c-gold); transform: translateY(-4px); }
.info-card__arrow { color: var(--c-gold); font-size: 20px; display: inline-block; margin-top: 16px; }

/* Team */
.team-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: clamp(20px, 2.4vw, 32px); }
.team-member { margin: 0; }
.team-member figcaption { padding-top: 16px; }
.team-member__name { display: block; font-family: var(--font-serif); font-size: 19px; color: #fff; }
.team-member__role { display: block; font-family: var(--font-nav); font-size: 12px; letter-spacing: .12em; text-transform: uppercase; color: var(--c-gold); margin-top: 4px; }

/* Steps */
.steps { display: grid; grid-template-columns: repeat(4, 1fr); gap: clamp(20px, 2.6vw, 40px); }
.step__num { font-family: var(--font-serif); font-size: 34px; color: var(--c-gold); display: block; margin-bottom: 14px; }
.step h3 { font-family: var(--font-serif); font-size: 20px; color: #fff; margin: 0 0 8px; }
.step p { color: var(--c-grey); font-size: 14px; margin: 0; }

/* Form */
.lux-form { display: grid; gap: 22px; }
.lux-form__row { display: grid; grid-template-columns: 1fr 1fr; gap: 22px; }
.lux-form label { display: grid; gap: 8px; font-family: var(--font-nav); font-size: 12px; letter-spacing: .12em; text-transform: uppercase; color: var(--c-grey); }
.lux-form input, .lux-form textarea, .lux-form select { background: #1c1b19; border: 1px solid var(--c-hairline); color: #fff; padding: 13px 16px; font-family: var(--font-sans); font-size: 15px; }
.lux-form input:focus, .lux-form textarea:focus, .lux-form select:focus { outline: none; border-color: var(--c-gold); }
.lux-form__step { border: 0; padding: 0; margin: 0; }
.lux-form__step legend { font-family: var(--font-nav); font-size: 12px; letter-spacing: .16em; text-transform: uppercase; color: var(--c-gold); margin-bottom: 16px; }
.lux-form__check { flex-direction: row; align-items: center; grid-auto-flow: column; justify-content: start; gap: 10px; text-transform: none; letter-spacing: .02em; }
.simulator__result { display: flex; justify-content: space-between; align-items: baseline; border-top: 1px solid var(--c-hairline); padding-top: 18px; }
.simulator__label { font-family: var(--font-nav); font-size: 12px; letter-spacing: .14em; text-transform: uppercase; color: var(--c-grey); }
.simulator__value { font-family: var(--font-serif); font-size: 26px; color: var(--c-gold); }

/* Filtri collection */
.filters { margin-bottom: 48px; }
.filters__row { display: flex; flex-wrap: wrap; gap: 16px; align-items: end; }
.filters__field { display: grid; gap: 7px; font-family: var(--font-nav); font-size: 11px; letter-spacing: .12em; text-transform: uppercase; color: var(--c-grey); flex: 1 1 150px; }
.filters select { background: #1c1b19; border: 1px solid var(--c-hairline); color: #fff; padding: 12px 14px; font-size: 14px; }
.filters.is-auto button[type="submit"] { display: none; }
.filters__reset { align-self: end; display: none; }
.filters.is-filtered .filters__reset { display: inline-block; }
.fleet-results { transition: opacity .25s ease; }
.fleet-results.is-loading { opacity: .4; pointer-events: none; }
.fleet-empty { grid-column: 1 / -1; text-align: center; padding: 56px 20px; color: var(--c-grey); font-size: 17px; }
.fleet-empty a { color: var(--c-gold); text-decoration: underline; text-underline-offset: 3px; margin-left: 6px; }

/* Griglia veicoli */
.vehicle-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: clamp(22px, 2.6vw, 40px); }
.vcard { background: #2b2a28; border: 1px solid var(--c-hairline); transition: border-color .3s var(--ease), transform .3s var(--ease); }
.vcard:hover { border-color: var(--c-gold); transform: translateY(-4px); }
.vcard__media { position: relative; display: block; aspect-ratio: 3/2; overflow: hidden; }
.vcard__media img { width: 100%; height: 100%; object-fit: cover; transition: transform .6s var(--ease); }
.vcard:hover .vcard__media img { transform: scale(1.05); }
.vcard__badge { position: absolute; top: 14px; left: 14px; background: rgba(20,19,17,.7); color: var(--c-gold); font-family: var(--font-nav); font-size: 10px; letter-spacing: .14em; text-transform: uppercase; padding: 5px 10px; }
.vcard__body { padding: 24px 24px 28px; }
.vcard__title { font-family: var(--font-serif); font-size: 21px; margin: 0 0 12px; }
.vcard__title a { color: #fff; }
.vcard__title a:hover { color: var(--c-gold); }
.vcard__meta { display: flex; gap: 18px; color: var(--c-grey); font-size: 13px; margin: 0 0 14px; }
.vcard__price { font-family: var(--font-nav); font-size: 14px; letter-spacing: .04em; color: var(--c-gold); margin: 0 0 16px; }
.vcard__link { font-family: var(--font-nav); font-size: 12px; letter-spacing: .16em; text-transform: uppercase; color: #fff; }
.vcard__link:hover { color: var(--c-gold); }

/* Scheda veicolo */
.vehicle-gallery { display: grid; grid-template-columns: 1fr; gap: 12px; padding: 0 0 clamp(30px,4vw,56px); }
.vehicle-gallery__main img, .vehicle-gallery__main .ph { width: 100%; }
.vehicle-gallery__thumbs { display: grid; grid-template-columns: repeat(4, 1fr); gap: 12px; max-width: var(--container); margin: 0 auto; padding-inline: var(--gutter); }
.vehicle-detail { display: grid; grid-template-columns: 1fr 360px; gap: clamp(32px, 4vw, 64px); padding-block: clamp(20px, 3vw, 40px) clamp(56px,7vw,100px); }
.vehicle-detail__title { font-family: var(--font-serif); font-size: clamp(28px, 3.4vw, 44px); color: #fff; margin: 14px 0 10px; }
.vehicle-detail__price { font-family: var(--font-nav); font-size: 18px; letter-spacing: .04em; color: var(--c-gold); }
.specs { margin: 40px 0; }
.specs__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1px; background: var(--c-hairline); border: 1px solid var(--c-hairline); }
.specs__grid li { background: var(--c-dark); padding: 18px 20px; display: flex; flex-direction: column; gap: 6px; }
.specs__label { font-family: var(--font-nav); font-size: 11px; letter-spacing: .12em; text-transform: uppercase; color: var(--c-grey); }
.specs__value { color: #fff; font-size: 16px; }
.cta-card { position: sticky; top: 96px; background: #2b2a28; border: 1px solid var(--c-hairline); padding: 30px; display: grid; gap: 16px; }
.cta-card__price { font-family: var(--font-serif); font-size: 24px; color: var(--c-gold); margin: 0; }
.cta-card .lux-btn { justify-content: center; min-width: 0; }
.cta-card__contact { color: var(--c-grey); font-size: 14px; display: grid; gap: 6px; margin: 4px 0 0; }

/* Contatti */
.contact { display: grid; grid-template-columns: 1fr 1.2fr; gap: clamp(32px, 5vw, 80px); }
.contact__list, .contact__hours { display: grid; gap: 12px; margin: 0 0 30px; }
.contact__list li, .contact__hours li { color: #fff; font-size: 15px; display: flex; gap: 12px; }
.contact__list span, .contact__hours span { color: var(--c-grey); min-width: 110px; font-family: var(--font-nav); font-size: 12px; letter-spacing: .1em; text-transform: uppercase; }
.contact__subtitle { font-family: var(--font-serif); font-size: 20px; color: #fff; margin: 0 0 16px; }
.contact-map .ph { min-height: 440px; }

/* Journal */
.journal-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: clamp(24px, 3vw, 44px); }
.jcard__media { display: block; aspect-ratio: 3/2; overflow: hidden; }
.jcard__media img { width: 100%; height: 100%; object-fit: cover; transition: transform .6s var(--ease); }
.jcard:hover .jcard__media img { transform: scale(1.04); }
.jcard__body { padding-top: 20px; }
.jcard__date { font-family: var(--font-nav); font-size: 11px; letter-spacing: .14em; text-transform: uppercase; color: var(--c-gold); }
.jcard__title { font-family: var(--font-serif); font-size: 22px; margin: 10px 0; }
.jcard__title a { color: #fff; }
.jcard__title a:hover { color: var(--c-gold); }
.jcard__excerpt { color: var(--c-grey); font-size: 14px; margin: 0; }
.article__media { max-width: 1100px; margin: 0 auto clamp(30px,4vw,56px); text-align: center; }
.article__media img { display: inline-block; max-width: 100%; width: auto; height: auto; max-height: 78vh; }
.article__body { font-size: 17px; }

/* FAQ */
.faq__item { border-bottom: 1px solid var(--c-hairline); }
.faq__q { width: 100%; background: none; border: 0; color: #fff; display: flex; justify-content: space-between; align-items: center; gap: 20px; padding: 24px 0; text-align: left; font-family: var(--font-serif); font-size: clamp(17px,1.8vw,21px); cursor: pointer; }
.faq__icon { position: relative; width: 16px; height: 16px; flex: 0 0 auto; }
.faq__icon::before, .faq__icon::after { content: ''; position: absolute; top: 50%; left: 50%; width: 14px; height: 1.5px; background: var(--c-gold); transform: translate(-50%,-50%); transition: transform .3s var(--ease); }
.faq__icon::after { transform: translate(-50%,-50%) rotate(90deg); }
.faq__item.is-open .faq__icon::after { transform: translate(-50%,-50%) rotate(0); }
.faq__a { max-height: 0; overflow: hidden; transition: max-height .35s var(--ease); }
.faq__item.is-open .faq__a { max-height: 240px; }
.faq__a p { color: var(--c-grey); padding: 0 0 24px; margin: 0; }

/* CTA finale */
.section--cta { background: #232220; text-align: center; }
.cta__title { font-family: var(--font-serif); font-size: clamp(26px, 3.4vw, 40px); color: #fff; margin: 0 0 14px; }
.cta__text { color: var(--c-grey); max-width: 560px; margin: 0 auto 30px; }
.cta__actions { display: flex; gap: 16px; justify-content: center; flex-wrap: wrap; }

/* Paginazione */
.pagination, .nav-links { display: flex; gap: 10px; justify-content: center; margin-top: 50px; flex-wrap: wrap; }
.page-numbers { font-family: var(--font-nav); font-size: 13px; letter-spacing: .08em; color: var(--c-grey); border: 1px solid var(--c-hairline); padding: 10px 15px; }
.page-numbers.current, .page-numbers:hover { color: #1a1917; background: var(--c-gold); border-color: var(--c-gold); }
.legal p { color: var(--c-grey); line-height: 1.75; margin: 0 0 1.1em; }
.legal h2 { font-family: var(--font-nav); font-size: 14px; letter-spacing: .12em; text-transform: uppercase; color: #1a1917; margin: 2em 0 .6em; }
.legal__note { border-left: 2px solid var(--c-gold); padding: 14px 18px; background: rgba(0,0,0,.02); font-size: 14px; margin-bottom: 2.2em !important; }

/* Responsive pagine interne */
@media (max-width: 1024px) {
	.cards-4, .team-grid, .steps { grid-template-columns: repeat(2, 1fr); }
	.cards-3, .cards-3--linked, .vehicle-grid, .journal-grid { grid-template-columns: repeat(2, 1fr); }
	.vehicle-detail { grid-template-columns: 1fr; }
	.cta-card { position: static; }
	.split, .contact { grid-template-columns: 1fr; }
	.specs__grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 640px) {
	.cards-3, .cards-3--linked, .cards-4, .vehicle-grid, .journal-grid, .team-grid, .steps { grid-template-columns: 1fr; }
	.lux-form__row { grid-template-columns: 1fr; }
	.filters__row { flex-direction: column; align-items: stretch; }
	.specs__grid { grid-template-columns: 1fr; }
	.vehicle-gallery__thumbs { grid-template-columns: repeat(2, 1fr); }
}

/* Lista tariffe (scheda veicolo · noleggio) */
.cta-card__label { font-family: var(--font-nav); font-size: 11px; letter-spacing: .16em; text-transform: uppercase; color: var(--c-grey); margin: 0; }
.rate-list { display: grid; gap: 10px; margin: 0 0 4px; }
.rate-list li { display: flex; justify-content: space-between; align-items: baseline; border-bottom: 1px solid var(--c-hairline); padding-bottom: 10px; font-size: 14px; color: #fff; }
.rate-list span { color: var(--c-grey); }
.rate-list em { font-style: normal; color: var(--c-gold); font-family: var(--font-nav); font-size: 12px; letter-spacing: .04em; }

/* =========================================================
   HOMEPAGE — SEZIONI 2→7 (Aurea Drive) — design coerente col live
   ========================================================= */
:root { --ease2: cubic-bezier(.16, 1, .3, 1); }

.container--mid { max-width: 920px; margin-inline: auto; }

/* Elementi condivisi */
.overline { font-family: var(--font-nav); font-size: 12px; font-weight: 600; letter-spacing: .36em; text-transform: uppercase; color: var(--c-gold); margin: 0 0 22px; }
.overline--center { text-align: center; }
.display-title { font-family: var(--font-serif); font-style: italic; font-weight: 400; color: #fff; line-height: 1.08; margin: 0; }
.badge-mono { font-family: var(--font-nav); font-size: 10px; font-weight: 600; letter-spacing: .26em; text-transform: uppercase; color: var(--c-gold); }
.link-underline { display: inline-flex; align-items: center; gap: 8px; font-family: var(--font-nav); font-size: 13px; letter-spacing: .12em; text-transform: uppercase; color: var(--c-gold); position: relative; padding-bottom: 4px; }
.link-underline::after { content: ''; position: absolute; left: 0; bottom: 0; width: 100%; height: 1px; background: currentColor; transform: scaleX(0); transform-origin: left; transition: transform .5s var(--ease2); }
.link-underline:hover::after, a:hover > .link-underline::after, .fleet-card:hover .link-underline::after { transform: scaleX(1); }
.btn-ghost { display: inline-block; font-family: var(--font-nav); font-size: 12px; letter-spacing: .25em; text-transform: uppercase; color: var(--c-gold); border: 1px solid var(--c-gold); border-radius: 2px; padding: 16px 40px; transition: background .4s var(--ease2), color .4s var(--ease2); }
.btn-ghost:hover { background: var(--c-gold); color: #14130f; }

/* Reveal on scroll: contenuti VISIBILI di default; le animazioni si attivano solo
   se il JS aggiunge .reveal-ready (fail-safe: senza JS nulla resta nascosto). */
@media (prefers-reduced-motion: no-preference) {
	.reveal-ready [data-reveal] { opacity: 0; transform: translateY(26px); transition: opacity .9s var(--ease2), transform .9s var(--ease2); }
	.reveal-ready [data-reveal="left"] { transform: translateX(-40px); }
	.reveal-ready [data-reveal="right"] { transform: translateX(40px); }
	.reveal-ready [data-reveal].is-in { opacity: 1; transform: none; }
	.reveal-ready [data-reveal][data-d="1"] { transition-delay: .12s; }
	.reveal-ready [data-reveal][data-d="2"] { transition-delay: .27s; }
	.reveal-ready [data-reveal][data-d="3"] { transition-delay: .42s; }
	[data-parallax] { will-change: transform; }
}

/* --- SEZIONE 2 · MANIFESTO --- */
.manifesto { background: #211f1d; padding-block: clamp(72px, 10vw, 128px); text-align: center; border-top: 1px solid rgba(210, 182, 144, .1); }
.manifesto__quote { font-family: var(--font-serif); font-style: italic; font-weight: 300; font-size: clamp(26px, 3.6vw, 48px); line-height: 1.3; color: var(--c-white); margin: 0 auto; max-width: 18ch; }
.manifesto__rule { display: block; width: 60px; height: 1px; background: var(--c-gold); margin: 44px auto 56px; }
.pillars { display: flex; justify-content: center; gap: 0; flex-wrap: wrap; }
.pillars__item { flex: 1 1 0; min-width: 200px; padding: 6px 36px; display: flex; flex-direction: column; align-items: center; gap: 14px; }
.pillars__item + .pillars__item { border-left: 1px solid rgba(210, 182, 144, .2); }
.pillars__icon svg { width: 24px; height: 24px; color: var(--c-gold); display: block; }
.pillars__label { font-family: var(--font-nav); font-size: 12px; font-weight: 600; letter-spacing: .22em; text-transform: uppercase; color: #d8d3cc; }
.pillars__desc { font-family: var(--font-nav); font-size: 14px; line-height: 1.6; color: var(--c-grey); max-width: 24ch; }

/* --- SEZIONE 3 · FLEET PREVIEW --- */
.fleet { background: #1a1917; padding-block: clamp(70px, 9vw, 130px); border-top: 1px solid rgba(210, 182, 144, .08); }
.fleet__head { margin-bottom: clamp(40px, 5vw, 70px); }
.fleet__head .display-title { font-size: clamp(44px, 6.5vw, 72px); }
.fleet__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: clamp(14px, 1.6vw, 22px); }
.fleet-card { position: relative; overflow: hidden; min-height: clamp(320px, 38vw, 520px); display: flex; align-items: flex-end; border-radius: 2px; }
.fleet-card--lg { grid-column: span 2; }
.fleet-card--sm { grid-column: span 1; }
.fleet-card__media { position: absolute; inset: 0; }
.fleet-card__media img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }
.fleet-card[data-veh] .fleet-card__media { background: linear-gradient(150deg, #4a4843 0%, #232120 100%); }
.fleet-card[data-veh="b"] .fleet-card__media { background: linear-gradient(150deg, #59473a 0%, #211c19 100%); }
.fleet-card[data-veh="c"] .fleet-card__media { background: linear-gradient(150deg, #54514b 0%, #2a2824 100%); }
.fleet-card[data-veh="d"] .fleet-card__media { background: linear-gradient(150deg, #3b3a38 0%, #181715 100%); }
.fleet-card__overlay { position: absolute; inset: 0; background: rgba(10, 10, 10, .4); transition: background .5s var(--ease2); }
.fleet-card:hover .fleet-card__overlay { background: rgba(10, 10, 10, .65); }
.fleet-card__content { position: relative; z-index: 2; padding: clamp(24px, 3vw, 40px); display: flex; flex-direction: column; align-items: flex-start; gap: 12px; transform: translateY(18px); transition: transform .5s var(--ease2); }
.fleet-card:hover .fleet-card__content { transform: translateY(0); }
.fleet-card__name { font-family: var(--font-serif); font-style: italic; font-size: clamp(22px, 2.4vw, 28px); color: #fff; line-height: 1.1; }
.fleet__cta { text-align: right; margin-top: clamp(28px, 3vw, 44px); }

/* --- SEZIONE 4 · EXPERIENCES STRIP --- */
.exp-strip { background: #1a1917; border-top: 1px solid rgba(210, 182, 144, .15); border-bottom: 1px solid rgba(210, 182, 144, .15); padding-block: 64px; }
.exp-strip__grid { display: grid; grid-template-columns: repeat(4, 1fr); }
.exp-strip__item { padding: 6px clamp(20px, 2.4vw, 40px); }
.exp-strip__item + .exp-strip__item { border-left: 1px solid rgba(210, 182, 144, .1); }
.exp-strip__icon svg { width: 22px; height: 22px; color: var(--c-gold); display: block; margin-bottom: 18px; }
.exp-strip__item h3 { font-family: var(--font-nav); font-size: 13.5px; font-weight: 600; letter-spacing: .18em; text-transform: uppercase; color: #fff; margin: 0 0 11px; }
.exp-strip__item p { font-family: var(--font-nav); font-size: 13.5px; line-height: 1.65; color: var(--c-grey); margin: 0; }

/* --- SEZIONE 5 · ABOUT TEASER --- */
.about { background: #211f1d; padding-block: clamp(70px, 9vw, 130px); }
.about__grid { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(40px, 6vw, 96px); align-items: center; }
.about__title { font-size: clamp(34px, 4.4vw, 52px); margin: 0 0 28px; }
.about__body { font-family: var(--font-nav); font-size: 15px; line-height: 1.8; color: var(--c-grey); max-width: 440px; margin: 0 0 32px; }
.about__media { position: relative; aspect-ratio: 4 / 5; overflow: hidden; border-radius: 2px; }
.about__img { position: absolute; top: -6%; left: 0; width: 100%; height: 112%; background: linear-gradient(160deg, #3a3833 0%, #181715 100%); will-change: transform; }
.about__img img { width: 100%; height: 100%; object-fit: cover; display: block; }

/* --- SEZIONE 6 · TESTIMONIALS --- */
.testi { background: #161412; padding-block: clamp(58px, 7vw, 96px); border-top: 1px solid rgba(210, 182, 144, .08); }
.testi__slider { position: relative; margin-top: 18px; }
.testi__track { position: relative; min-height: 240px; }
.testi__slide { position: absolute; inset: 0; text-align: center; padding: 0 clamp(20px, 6vw, 70px); opacity: 0; visibility: hidden; transition: opacity .6s var(--ease2); }
.testi__slide.is-active { opacity: 1; visibility: visible; position: relative; }
.testi__slide::before { content: '\201C'; position: absolute; top: -40px; left: 50%; transform: translateX(-50%); font-family: var(--font-serif); font-size: 120px; line-height: 1; color: rgba(210, 182, 144, .08); pointer-events: none; }
.testi__quote { font-family: var(--font-serif); font-style: italic; font-size: clamp(22px, 2.6vw, 28px); line-height: 1.55; color: var(--c-white); margin: 0 0 24px; position: relative; }
.testi__stars { display: flex; justify-content: center; gap: 5px; margin-bottom: 16px; }
.testi__stars .star { width: 14px; height: 14px; color: var(--c-gold); }
.testi__attr { font-family: var(--font-nav); font-size: 13px; letter-spacing: .04em; color: var(--c-grey); }
.testi__nav { position: absolute; top: 50%; transform: translateY(-50%); background: none; border: 0; color: var(--c-gold); width: 44px; height: 44px; display: grid; place-items: center; opacity: .6; transition: opacity .3s var(--ease2); }
.testi__nav:hover { opacity: 1; }
.testi__nav svg { width: 24px; height: 24px; }
.testi__nav--prev { left: -10px; }
.testi__nav--next { right: -10px; }
.testi__dots { display: flex; justify-content: center; gap: 10px; margin-top: 34px; }
.testi__dot { width: 7px; height: 7px; border-radius: 50%; border: 1px solid var(--c-gold); background: none; padding: 0; opacity: .4; transition: opacity .3s var(--ease2), background .3s var(--ease2); }
.testi__dot.is-active { opacity: 1; background: var(--c-gold); }

/* --- SEZIONE 7 · FINAL CTA --- */
.final-cta { position: relative; min-height: 64vh; display: flex; align-items: center; justify-content: center; text-align: center; overflow: hidden; border-top: 1px solid rgba(210, 182, 144, .1); }
.final-cta__bg { position: absolute; inset: -10% 0; background: linear-gradient(160deg, #2a2723 0%, #100f0d 100%); will-change: transform; }
.final-cta__bg img { width: 100%; height: 100%; object-fit: cover; display: block; }
.final-cta__overlay { position: absolute; inset: 0; background: linear-gradient(to bottom, rgba(10,10,10,.5), rgba(10,10,10,.85)); }
.final-cta__content { position: relative; z-index: 2; }
.final-cta__title { font-size: clamp(34px, 5.4vw, 64px); max-width: 16ch; margin: 0 auto; }
.final-cta__sub { font-family: var(--font-nav); font-size: 14px; color: var(--c-grey); margin: 16px 0 0; }
.final-cta .btn-ghost { margin-top: 40px; }

/* Responsive sezioni home */
@media (max-width: 900px) {
	.fleet__grid { grid-template-columns: 1fr; }
	.fleet-card--lg, .fleet-card--sm { grid-column: span 1; }
	.exp-strip__grid { grid-template-columns: 1fr 1fr; }
	.exp-strip__item:nth-child(3), .exp-strip__item:nth-child(4) { border-top: 1px solid rgba(210,182,144,.1); }
	.exp-strip__item:nth-child(odd) { border-left: 0; }
	.about__grid { grid-template-columns: 1fr; }
	.about__media { order: -1; }
	.pillars__item { flex-basis: 100%; }
	.pillars__item + .pillars__item { border-left: 0; border-top: 1px solid rgba(210,182,144,.18); padding-top: 26px; margin-top: 26px; }
}
@media (max-width: 560px) {
	.exp-strip__grid { grid-template-columns: 1fr; }
	.exp-strip__item + .exp-strip__item { border-left: 0; border-top: 1px solid rgba(210,182,144,.1); margin-top: 4px; padding-top: 26px; }
	.testi__nav--prev { left: -16px; }
	.testi__nav--next { right: -16px; }
}

/* =========================================================
   RIFINITURE LUXURY (wordmark già sopra) — grana, grading, indici, titoli
   ========================================================= */

/* Grana/texture globale fissa (molto sottile) */
.grain {
	position: fixed; inset: 0; z-index: 300; pointer-events: none;
	opacity: .045; mix-blend-mode: overlay;
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
	background-size: 180px 180px;
}
@media (prefers-reduced-motion: reduce) { .grain { display: none; } }

/* Color-grade unificato: stesse foto = stessa "campagna" */
.hero__video,
.fleet-card__media img,
.about__img img,
.overlay-slide { filter: saturate(.9) contrast(1.04) brightness(.97); }

/* Tinta calda d'unione sopra le foto delle sezioni */
.fleet-card__media::after,
.about__media::after {
	content: ''; position: absolute; inset: 0; pointer-events: none; z-index: 1;
	background: linear-gradient(180deg, rgba(210,182,144,.07) 0%, rgba(18,14,9,.22) 100%);
	mix-blend-mode: multiply;
}

/* Indici editoriali sulle card flotta (01—04) */
.fleet-card__index {
	position: absolute; top: clamp(16px, 2vw, 26px); left: clamp(20px, 2.4vw, 32px);
	z-index: 3; font-family: var(--font-nav); font-size: 12px; font-weight: 600;
	letter-spacing: .2em; color: var(--c-gold);
}
.fleet-card__index::before { content: ''; display: inline-block; width: 22px; height: 1px; background: currentColor; vertical-align: middle; margin-right: 9px; opacity: .7; }

/* Titoli più monumentali */
.fleet__head .display-title { font-size: clamp(48px, 7vw, 84px); letter-spacing: -.012em; }
.about__title { font-size: clamp(36px, 4.8vw, 58px); letter-spacing: -.01em; }
.final-cta__title { font-size: clamp(36px, 5.8vw, 70px); letter-spacing: -.01em; }
.manifesto__quote { font-size: clamp(27px, 3.8vw, 50px); }

/* =========================================================
   SIGNATURE: cursore custom · magnetic CTA · intro loader · focus
   ========================================================= */

/* Cursore custom (solo desktop fine pointer; native nascosto via .has-cursor) */
.has-cursor, .has-cursor a, .has-cursor button, .has-cursor label,
.has-cursor summary, .has-cursor .fleet-card, .has-cursor [data-magnetic] { cursor: none; }
.cursor {
	position: fixed; top: 0; left: 0; width: 30px; height: 30px;
	border: 1px solid var(--c-gold); border-radius: 50%;
	pointer-events: none; z-index: 9998; will-change: transform;
	transition: width .3s var(--ease2), height .3s var(--ease2), background .3s var(--ease2), opacity .3s var(--ease2);
}
.cursor.is-hover { width: 52px; height: 52px; background: rgba(210, 182, 144, .1); }
.cursor.is-down  { width: 22px; height: 22px; background: rgba(210, 182, 144, .2); }

/* Magnetic CTA */
[data-magnetic] { transition: transform .35s var(--ease2), background .4s var(--ease2), color .4s var(--ease2); }

/* Intro loader */
.loader {
	position: fixed; inset: 0; z-index: 9999; background: #14130f;
	display: grid; place-items: center;
	transition: opacity .8s var(--ease2), visibility .8s var(--ease2);
}
.loader.is-done { opacity: 0; visibility: hidden; }
.loader__brand {
	font-family: var(--font-serif); font-size: clamp(42px, 9vw, 96px);
	letter-spacing: .34em; padding-left: .34em; color: #fff;
	opacity: 0; transform: translateY(12px);
	animation: loaderIn 1.1s var(--ease2) .15s forwards;
}
@keyframes loaderIn { to { opacity: 1; transform: none; } }
html.is-loading, html.is-loading body { overflow: hidden; }

/* Focus states accessibili (keyboard nav — checklist punto 08) */
a:focus-visible, button:focus-visible, input:focus-visible, select:focus-visible,
textarea:focus-visible, .fleet-card:focus-visible, [tabindex]:focus-visible {
	outline: 2px solid var(--c-gold); outline-offset: 3px;
}

/* Fail-safe: senza JS il loader si nasconde comunque (mai pagina bloccata) */
@keyframes loaderAuto { to { opacity: 0; visibility: hidden; } }
.loader { animation: loaderAuto 1s var(--ease2) 2.6s forwards; }

/* =========================================================
   SCROLL CUE + TOUCH TARGETS + MOBILE DESIGN PASS (checklist #07/#02)
   ========================================================= */

/* Hero scroll indicator (additivo, non tocca il video) */
.hero__scroll { position: absolute; left: 50%; bottom: 30px; transform: translateX(-50%); z-index: 3; width: 1px; height: 56px; overflow: hidden; }
.hero__scroll-line { display: block; width: 100%; height: 100%; background: linear-gradient(var(--c-gold), rgba(210,182,144,0)); animation: scrollCue 2.2s var(--ease2) infinite; }
@keyframes scrollCue { 0% { transform: translateY(-100%); } 100% { transform: translateY(100%); } }
@media (prefers-reduced-motion: reduce) { .hero__scroll-line { animation: none; } }

/* Touch targets ≥44px (sempre) */
.menu-toggle { width: 44px; height: 44px; display: inline-flex; align-items: center; justify-content: center; }
.testi__dot { position: relative; }
.testi__dot::after { content: ''; position: absolute; inset: -15px; } /* area tap 44 */

/* ---- MOBILE DESIGN PASS ---- */
@media (max-width: 768px) {
	/* Leggibilità: testo di lettura ≥16px */
	.about__body { font-size: 16px; }
	.exp-strip__item p { font-size: 14px; }
	.pillars__desc { font-size: 14px; max-width: 28ch; }

	/* Titoli bilanciati per il telefono (non solo "rimpiccioliti") */
	.fleet__head .display-title { font-size: clamp(40px, 12vw, 56px); }
	.manifesto__quote { font-size: clamp(25px, 6.6vw, 34px); max-width: 16ch; }

	/* Flotta: card a piena presenza (portrait), non letterbox */
	.fleet-card { min-height: 0; aspect-ratio: 4 / 5; }
	.fleet-card__name { font-size: 25px; }
	.fleet-card__content { padding: 24px; gap: 10px; }
	.fleet__cta { text-align: left; }

	/* Ritmo verticale più contenuto su mobile */
	.manifesto, .fleet, .about, .testi { padding-block: clamp(56px, 13vw, 84px); }

	/* Experiences: divisori orizzontali puliti (non bordi a sinistra) */
	.exp-strip__grid { grid-template-columns: 1fr; }
	.exp-strip__item { padding: 26px 0; }
	.exp-strip__item + .exp-strip__item { border-left: 0; border-top: 1px solid rgba(210, 182, 144, .12); }

	/* Touch comodo */
	.testi__nav { width: 48px; height: 48px; }
	.lang-switch__menu li a { padding: 13px 18px; }
	.lang-switch__toggle { padding: 10px 0; }
}

@media (max-width: 480px) {
	:root { --gutter: clamp(18px, 6vw, 28px); }
	.fleet__head .display-title { font-size: clamp(34px, 11vw, 46px); }
	.brand__sub { font-size: 8px; letter-spacing: .26em; }
}

/* Fix overflow titoli su mobile (niente scroll orizzontale) */
.display-title { overflow-wrap: break-word; }
@media (max-width: 480px) {
	.fleet__head .display-title { font-size: clamp(30px, 8.6vw, 40px); }
	.about__title { font-size: clamp(30px, 8vw, 40px); }
}
@media (max-width: 480px) { .fleet__head .display-title { font-size: clamp(28px, 7.4vw, 36px); } }

/* Fix larghezza minima 500px su mobile (footer newsletter + pillars min-width) */
@media (max-width: 768px) {
	.site-footer__newsletter { min-width: 0; }
	.pillars__item { min-width: 0; }
}
@media (max-width: 560px) {
	.site-footer__inner { grid-template-columns: 1fr; }
}
