/* ════════════════════════════════════════════════════════════════════════
   Compagnia dei Trustee — foglio di stile condiviso (MPA statico)
   Migrato e potenziato dallo stile editoriale originale.
   Sezioni: FONT · TOKENS · RESET · TYPE · HEADER · SHELLS · HOME · VALORI ·
            SERVIZI · CONTATTI · PAGINE INTERNE · CLIENTELA · FOOTER · COOKIE ·
            MOBILE · MOTION (view-transitions + reduced-motion)
   ════════════════════════════════════════════════════════════════════════ */

/* ═══════════ FONT SELF-HOSTED (woff2 subset) — nessun Google CDN
   Adelon Serial (display): 400 normale/corsivo, 500 normale.
   Inter (testo): 400/500/600. Generati da tools/make-fonts.py. */
@font-face{
  font-family:"Adelon Serial";
  src:url("/fonts/adelon-400.woff2") format("woff2");
  font-weight:400; font-style:normal; font-display:swap;
}
@font-face{
  font-family:"Adelon Serial";
  src:url("/fonts/adelon-400i.woff2") format("woff2");
  font-weight:400; font-style:italic; font-display:swap;
}
@font-face{
  font-family:"Adelon Serial";
  src:url("/fonts/adelon-500.woff2") format("woff2");
  font-weight:500; font-style:normal; font-display:swap;
}
@font-face{
  font-family:"Inter";
  src:url("/fonts/inter-400.woff2") format("woff2");
  font-weight:400; font-style:normal; font-display:swap;
}
@font-face{
  font-family:"Inter";
  src:url("/fonts/inter-500.woff2") format("woff2");
  font-weight:500; font-style:normal; font-display:swap;
}
@font-face{
  font-family:"Inter";
  src:url("/fonts/inter-600.woff2") format("woff2");
  font-weight:600; font-style:normal; font-display:swap;
}

/* ═══════════ TOKENS ═══════════ */
:root{
  --bordeaux:#3B1A25;
  --bordeaux-80:rgba(59,26,37,.8);
  --bordeaux-20:rgba(59,26,37,.2);
  --bordeaux-12:rgba(59,26,37,.12);
  --bordeaux-08:rgba(59,26,37,.08);
  --avorio:#F0E4CE;
  --avorio-soft:#F7EEDB;
  --terracotta:#6E4241;
  --notte:#161C2C;
  --bianco:#FFFFFF;
  --nero:#1A1A1A;
  --nero-60:#5A5A5A;
  --rule:rgba(59,26,37,.18);

  --serif:"Adelon Serial","EB Garamond","Garamond",serif;
  --sans:"Inter","Söhne","Work Sans","Helvetica Neue",Arial,sans-serif;

  --maxw:1280px;
  --gutter:clamp(20px, 4vw, 56px);
  --col-gap:24px;

  color-scheme:light;
}

/* ═══════════ RESET + BASE ═══════════ */
*,*::before,*::after{ box-sizing:border-box; }
html,body{ margin:0; padding:0; }
body{
  font-family:var(--sans);
  font-size:16px;
  line-height:1.65;
  color:var(--nero);
  background:var(--bianco);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
button{ font:inherit; cursor:pointer; }
/* Focus sempre visibile (accessibilità). Bordeaux su chiaro, avorio su scuro. */
a:focus-visible, button:focus-visible{ outline:2px solid var(--bordeaux); outline-offset:3px; }
.site-footer a:focus-visible, .contact-ed a:focus-visible{ outline-color:var(--avorio); }
::selection{ background:var(--bordeaux); color:var(--avorio); }

/* Solo per screen reader / SEO: presente nel DOM ma invisibile */
.visually-hidden{
  position:absolute !important; width:1px; height:1px; padding:0; margin:-1px;
  overflow:hidden; clip:rect(0 0 0 0); clip-path:inset(50%); white-space:nowrap; border:0;
}
/* l'<h1> della home avvolge il logo senza alterare il layout della griglia */
.hero-h1{ display:contents; }

/* Skip link (accessibilità: salta al contenuto) */
.skip-link{
  position:absolute; left:-9999px; top:0; z-index:200;
  background:var(--bordeaux); color:var(--avorio);
  padding:12px 20px; font-size:13px; letter-spacing:.04em;
}
.skip-link:focus{ left:12px; top:12px; outline:2px solid var(--avorio); outline-offset:2px; }

/* ═══════════ TYPE ═══════════ */
h1,h2,h3,h4{
  font-family:var(--serif);
  color:var(--bordeaux);
  margin:0;
  line-height:1.05;
  font-weight:400;
  letter-spacing:-.005em;
  text-wrap:balance;
}
h1{ font-size:clamp(40px, 8vw, 120px); }            /* min ridotto per mobile */
h2{ font-size:clamp(30px, 4.5vw, 64px); }
h3{ font-size:clamp(22px, 2.4vw, 32px); font-weight:500; }
h4{ font-size:clamp(18px, 1.6vw, 22px); font-weight:500; }
.italic{ font-style:italic; color:var(--terracotta); font-weight:400; }
p{ margin:0 0 1em; max-width:64ch; }
.lede{
  font-family:var(--serif); font-weight:500;
  font-size:clamp(22px, 2.2vw, 30px);
  line-height:1.35; color:var(--bordeaux); max-width:42ch;
}

/* Marcatori editoriali inline */
.eyebrow{
  font-family:var(--sans);
  font-size:11px; letter-spacing:.24em; text-transform:uppercase;
  font-weight:500; color:var(--bordeaux);
}
.eyebrow-row{
  display:flex; align-items:center; gap:18px;
  padding-top:14px; border-top:1px solid var(--bordeaux);
  margin-bottom:28px;
  color:var(--bordeaux);
  font-family:var(--sans);
  font-size:11px; letter-spacing:.24em; text-transform:uppercase;
  font-weight:500;
}
.eyebrow-row .sec-no{ font-family:var(--serif); font-style:italic; font-weight:400; font-size:14px; letter-spacing:0; opacity:.8; }

.caption{
  font-size:11px; letter-spacing:.18em; text-transform:uppercase;
  color:var(--nero-60); font-family:var(--sans); font-weight:500;
}

.wrap{ max-width:var(--maxw); margin:0 auto; padding:0 var(--gutter); }
.grid12{ display:grid; grid-template-columns:repeat(12,1fr); gap:var(--col-gap); }
hr.hairline{ border:0; height:1px; background:var(--rule); margin:0; }

/* ═══════════ HEADER (logo centrato + nav divisa, bordeaux) ═══════════ */
.site-header{
  position:sticky; top:0; z-index:50;
  background:var(--bordeaux);
  color:var(--avorio);
  border-bottom:1px solid rgba(240,228,206,.15);
}
.site-header .bar{
  max-width:var(--maxw); margin:0 auto;
  padding:18px var(--gutter);
  display:grid;
  grid-template-columns: 1fr auto 1fr;
  align-items:center;
  gap:32px;
}
.nav-left, .nav-right{
  display:flex; gap:clamp(20px, 2.4vw, 34px);
  font-size:11px; letter-spacing:.24em; text-transform:uppercase;
  font-weight:500;
}
.nav-right{ justify-content:flex-end; }
.site-header nav a{
  color:var(--avorio); opacity:.75; position:relative; padding:6px 0;
  transition:opacity .15s ease;
  cursor:pointer;
}
.site-header nav a:hover{ opacity:1; }
.site-header nav a.active,
.site-header nav a[aria-current="page"]{ opacity:1; }
.site-header nav a.active::after,
.site-header nav a[aria-current="page"]::after{
  content:''; position:absolute; left:0; right:0; bottom:-2px;
  height:1px; background:var(--avorio);
}
.site-header nav a:focus-visible{
  outline:2px solid var(--avorio); outline-offset:6px; opacity:1;
}

/* CTA "Contatti": micro-bottone outline avorio (sobrio) nell'header desktop */
.site-header .nav-right a[href="/contatti"]{
  opacity:1; padding:7px 16px;
  border:1px solid rgba(240,228,206,.45); border-radius:2px;
  transition:background .2s ease, color .2s ease, border-color .2s ease;
}
.site-header .nav-right a[href="/contatti"]:hover{
  background:var(--avorio); color:var(--bordeaux); border-color:var(--avorio); opacity:1;
}
.site-header .nav-right a[href="/contatti"].active,
.site-header .nav-right a[href="/contatti"][aria-current="page"]{
  background:var(--avorio); color:var(--bordeaux); border-color:var(--avorio);
}
/* il bottone non porta la sottolineatura "pagina corrente" degli altri link */
.site-header .nav-right a[href="/contatti"].active::after,
.site-header .nav-right a[href="/contatti"][aria-current="page"]::after{ display:none; }

.brand-center{
  display:flex; align-items:center; gap:14px;
  justify-self:center;
  cursor:pointer;
}
.brand-center img{ height:42px; width:auto; flex:none; }
.brand-center .brand-logo{ height:42px; width:auto; display:block; }
.brand-center .name{
  font-family:var(--serif);
  font-size:18px; letter-spacing:.14em; line-height:1;
  color:var(--avorio); text-transform:uppercase;
  padding-top:2px;
}
.brand-center .name small{
  display:block;
  font-family:var(--sans);
  font-size:9px; letter-spacing:.36em;
  opacity:.55; margin-top:5px; font-weight:500;
}

.menu-toggle{
  display:none;
  background:transparent; border:0; color:var(--avorio);
  width:44px; height:44px; align-items:center; justify-content:center;
}
.menu-toggle svg{ width:22px; height:22px; }

/* ═══════════ SHELLS EDITORIALI ═══════════ */
main{ min-height:70vh; }

section{ padding:clamp(72px, 9vw, 132px) 0; position:relative; }
section.tight{ padding:clamp(48px, 6vw, 88px) 0; }
section.first{ padding-top:clamp(56px, 7vw, 96px); }
section.section-flush-top{ padding-top:0; }   /* ex stile inline nel body */

/* placeholder dello scaffolding (rimosso quando arrivano i contenuti reali) */
.placeholder-build{ padding:clamp(72px,9vw,132px) 0; }

/* ═══════════ HOME — Hero editoriale ═══════════ */
.hero-ed{
  padding:clamp(72px, 10vw, 140px) 0 clamp(72px, 9vw, 120px);
  position:relative;
  /* clip e non hidden: overflow:hidden crea uno scroll container e la
     ViewTimeline del parallax (animation-timeline: view()) si aggancerebbe
     a QUESTO box (che non scrolla mai) invece che alla pagina → timeline
     degenere ferma a 0.5. clip clippa uguale senza essere scroller.
     La riga hidden prima è il fallback per browser senza clip. */
  overflow:hidden; overflow:clip;
  background:var(--bianco);
}
.hero-ed .grid12{ row-gap:0; }
.hero-ed .meta-foot{ grid-column:1 / 4;
  padding-top:20px; border-top:1px solid var(--rule);
  display:flex; flex-direction:column; gap:28px;
}
.hero-ed .meta-foot strong{
  display:block; color:var(--bordeaux); font-weight:500;
  font-size:11px; letter-spacing:.22em; text-transform:uppercase;
  margin-bottom:10px;
}
.hero-ed .meta-foot .mf-val{
  display:block; color:var(--nero-60); font-weight:400;
  font-size:14px; letter-spacing:.01em; line-height:1.7;
  text-transform:none;
}
.hero-ed .meta-foot a.mf-val{
  width:max-content; color:var(--bordeaux); text-decoration:none;
  border-bottom:1px solid var(--rule); padding-bottom:1px;
  transition:color .2s ease, border-color .2s ease;
}
.hero-ed .meta-foot a.mf-val:hover{ color:var(--terracotta); border-color:var(--terracotta); }
.hero-ed .photo{ grid-column:4 / 8;
  aspect-ratio:3/4;
  overflow:hidden; overflow:clip;   /* clip: vedi nota su .hero-ed */
}
.hero-ed .photo img{
  width:100%; height:100%; object-fit:cover;
  filter:grayscale(100%) contrast(.95) brightness(.95);
}
.hero-ed .pull{ grid-column:9 / 13; padding-top:8px; }
.hero-ed .pull .lede{ margin:0 0 24px; }
.hero-ed .pull p{ font-size:15px; line-height:1.7; color:var(--nero); max-width:42ch; }
.hero-ed .pull .read{
  margin-top:32px;
  display:inline-flex; gap:12px; align-items:center;
  font-size:11px; letter-spacing:.22em; text-transform:uppercase;
  font-weight:500; color:var(--bordeaux);
  border-bottom:1px solid var(--bordeaux); padding-bottom:4px;
}

/* link "Leggi di più" riusabile (era inline nell'HTML originale) */
.read{
  display:inline-flex; gap:12px; align-items:center;
  font-size:11px; letter-spacing:.22em; text-transform:uppercase;
  font-weight:500; color:var(--bordeaux);
  border-bottom:1px solid var(--bordeaux); padding-bottom:4px;
  transition:color .15s ease, border-color .15s ease;
}
.read:hover, .hero-ed .pull .read:hover{ color:var(--terracotta); border-color:var(--terracotta); }

/* ═══════════ HOME — excerpt Società ═══════════ */
.ed-section .grid12{ row-gap:0; }
.ed-section h2{ grid-column:1 / 8; margin-bottom:48px; max-width:14ch; }
.ed-section .body{ grid-column:8 / 13; }
.ed-section .body p{ font-size:16px; line-height:1.7; }
.ed-section .body p + p{ margin-top:1em; }
.ed-section .body p:first-child{
  font-family:var(--serif); font-size:21px; font-weight:500;
  color:var(--bordeaux); line-height:1.4; max-width:38ch;
}
@media (max-width:900px){
  .ed-section h2{ grid-column:1 / -1; margin-bottom:24px; }
  .ed-section .body{ grid-column:1 / -1; }
}

/* ═══════════ VALORI — 4 blocchi con numeri romani ═══════════ */
.values-ed{ background:var(--avorio-soft); }
.values-ed .head{ margin-bottom:64px; }
.values-ed .head .eyebrow-row{ grid-column:1 / 5; }
.values-ed .head h2{ grid-column:5 / 13; max-width:20ch; }
.value-block{
  display:grid; grid-template-columns:120px 1fr; gap:48px;
  padding:48px 0; border-top:1px solid var(--bordeaux-20);
  align-items:start;
}
.value-block:last-child{ border-bottom:1px solid var(--bordeaux-20); }
.value-block .roman{
  font-family:var(--serif); font-size:clamp(60px, 6.2vw, 92px);
  color:var(--bordeaux); line-height:.9; font-weight:400; letter-spacing:.02em;
}
.value-block .desc{ display:grid; grid-template-columns:1fr 1.4fr; gap:48px; }
.value-block .desc h3{
  font-size:clamp(22px, 2.2vw, 30px);
  color:var(--bordeaux); font-weight:500;
}
.value-block .desc p{ font-size:15px; line-height:1.7; color:var(--nero); margin:0; max-width:54ch; }
@media (max-width:820px){
  .value-block{ grid-template-columns:1fr; gap:18px; }
  .value-block .desc{ grid-template-columns:1fr; gap:14px; }
}

/* ═══════════ SERVIZI — 3 card editoriali ═══════════ */
.services-ed{ background:var(--bianco); }
.services-ed .head .eyebrow-row{ grid-column:1 / 5; }
.services-ed .head h2{ grid-column:5 / 13; max-width:18ch; margin-bottom:64px; }
.services-ed .cards{ display:grid; grid-template-columns:repeat(3, 1fr); gap:32px; }
.svc-card{
  border-top:1px solid var(--bordeaux);
  padding:32px 0 0;
  display:flex; flex-direction:column;
  min-height:340px;
}
.svc-card .num{
  font-family:var(--serif); font-size:64px; color:var(--bordeaux);
  font-weight:400; line-height:.9; margin-bottom:32px;
}
.svc-card h3{
  font-family:var(--serif); font-size:30px; color:var(--bordeaux);
  font-weight:500; line-height:1.1; margin-bottom:18px; max-width:14ch;
  transition:color .2s ease;
}
.svc-card h3 .italic{ font-style:italic; font-weight:400; color:var(--terracotta); }
.svc-card p{
  font-size:15px; line-height:1.65; color:var(--nero);
  margin:0 0 28px; flex:1; max-width:36ch;
}
.svc-card .arr{
  align-self:flex-start;
  font-size:11px; letter-spacing:.22em; text-transform:uppercase;
  color:var(--bordeaux); font-weight:500;
  border-bottom:1px solid var(--bordeaux); padding-bottom:4px;
  display:inline-flex; gap:12px; align-items:center;
  transition:color .15s, border-color .15s, transform .2s ease;
}
.svc-card .arr:hover{ color:var(--terracotta); border-color:var(--terracotta); }
/* hover sull'intera card: titolo verso terracotta, il link "Leggi di più" avanza */
.svc-card:hover h3{ color:var(--terracotta); }
.svc-card:hover .arr{ color:var(--terracotta); border-color:var(--terracotta); transform:translateX(4px); }
@media (max-width:820px){
  .services-ed .cards{ grid-template-columns:1fr; gap:48px; }
  .services-ed .head h2{ grid-column:1 / -1; }
  .services-ed .head .eyebrow-row{ grid-column:1 / -1; }
}

/* ═══════════ STRISCIA CONTATTI (fondo home) ═══════════ */
.contact-ed{ background:var(--bordeaux); color:var(--avorio); position:relative; overflow:hidden; overflow:clip; }   /* clip: vedi nota su .hero-ed */
.contact-ed::before{
  content:''; position:absolute; right:-180px; bottom:-200px; width:580px; height:580px;
  background:url('/assets/logo-mark-avorio.png') center/contain no-repeat;
  opacity:.06; pointer-events:none;
  /* --cdt-drift: mossa dal fallback JS del parallax (Firefox/Safari);
     dove il parallax CSS è supportato, l'animation la sovrascrive */
  transform:translateY(var(--cdt-drift, 0px));
}
.contact-ed .grid12{ position:relative; z-index:1; row-gap:0; align-items:start; }
.contact-ed .head{ grid-column:1 / 6; }
.contact-ed .eyebrow-row{
  border-top-color:rgba(240,228,206,.5); color:var(--avorio);
}
.contact-ed h2{ color:var(--avorio); max-width:14ch; }
.contact-ed .head h2 .italic{ color:var(--avorio); opacity:.85; }
.contact-ed .col{
  font-family:var(--sans); font-size:13px; line-height:1.85; padding-top:8px;
}
.contact-ed .col strong{
  display:block; font-size:10px; letter-spacing:.24em; text-transform:uppercase;
  opacity:.55; font-weight:500; margin-bottom:10px;
}
.contact-ed .col p{ margin:0 0 22px; font-family:var(--serif); font-size:21px; font-weight:400; color:var(--avorio); line-height:1.35; max-width:none; }
.contact-ed .col a{ overflow-wrap:anywhere; }   /* email va a capo solo se serve */
.contact-ed .col a:hover{ text-decoration:underline; text-underline-offset:5px; }
.contact-ed .col-2{ grid-column:7 / 10; }
.contact-ed .col-3{ grid-column:10 / 13; }
@media (max-width:820px){
  .contact-ed .head, .contact-ed .col-2, .contact-ed .col-3{ grid-column:1 / -1; margin-bottom:32px; }
}

/* ═══════════ TESTATE PAGINE INTERNE ═══════════ */
.page-head-ed{ padding:clamp(80px, 10vw, 140px) 0 clamp(48px, 6vw, 80px); }
/* link di ritorno "Tutti i servizi" sopra la testata dei dettagli servizio */
.svc-back{
  grid-column:1 / -1; justify-self:start; margin-bottom:24px;
  font-family:var(--sans); font-size:11px; letter-spacing:.18em; text-transform:uppercase;
  font-weight:500; color:var(--bordeaux); opacity:.75;
  display:inline-flex; align-items:center; gap:8px;
  transition:opacity .15s ease, color .15s ease;
}
.svc-back:hover{ opacity:1; color:var(--terracotta); }
.page-head-ed .meta{ grid-column:1 / 4;
  padding-top:14px; border-top:1px solid var(--bordeaux);
  font-size:11px; letter-spacing:.22em; text-transform:uppercase;
  color:var(--bordeaux); font-weight:500; line-height:1.85;
}
.page-head-ed .meta em{ font-family:var(--serif); font-style:italic; font-weight:400; font-size:14px; letter-spacing:0; opacity:.85; }
.page-head-ed h1{ grid-column:4 / 13;
  font-size:clamp(38px, 7.5vw, 124px); font-weight:400; line-height:.96; letter-spacing:-.015em;
}
.page-head-ed h1 .italic{ font-style:italic; color:var(--terracotta); }
.page-head-ed .lede{ grid-column:5 / 12; margin-top:48px; }

/* ═══════════ DETTAGLIO SERVIZIO — layout split ═══════════ */
.svc-detail{ background:var(--bianco); }
.svc-detail .grid12{ row-gap:64px; }
.svc-detail .syn{ grid-column:1 / 5; position:sticky; top:120px; align-self:start; }
.svc-detail .syn .eyebrow-row{ font-size:10px; }
.svc-detail .syn .pull{
  font-family:var(--serif); font-size:24px; line-height:1.35; color:var(--bordeaux);
  font-weight:500; margin:0 0 32px; max-width:24ch;
}
/* testo introduttivo del servizio (ex stile inline nel body) */
.svc-intro{
  font-size:15px; line-height:1.7; color:var(--nero); margin:0 0 32px; max-width:34ch;
}
.svc-detail .syn .placeholder-box{
  background:var(--avorio); border:1px solid var(--bordeaux-20);
  padding:24px; font-size:13px; line-height:1.65; color:var(--nero-60); max-width:32ch;
}
.svc-detail .syn .placeholder-box strong{
  display:block; font-family:var(--sans); font-weight:600;
  color:var(--bordeaux); letter-spacing:.18em; text-transform:uppercase;
  font-size:10px; margin-bottom:8px;
}
.svc-detail .acts{ grid-column:6 / 13; }
.svc-detail .acts h2{ margin-bottom:48px; max-width:18ch; font-size:clamp(30px, 3.4vw, 48px); }
.svc-detail .acts ol{ list-style:none; padding:0; margin:0; }
.svc-detail .acts li{
  display:grid; grid-template-columns:80px 1fr; gap:24px;
  padding:28px 0; border-top:1px solid var(--rule);
  align-items:start;
}
.svc-detail .acts li:last-child{ border-bottom:1px solid var(--rule); }
.svc-detail .acts li .idx{
  font-family:var(--serif); font-size:32px; color:var(--bordeaux);
  line-height:.9; font-weight:400; letter-spacing:.02em;
}
.svc-detail .acts li .txt{ font-size:17px; line-height:1.6; color:var(--nero); }
@media (max-width:820px){
  .svc-detail .syn{ grid-column:1 / -1; position:static; }
  .svc-detail .acts{ grid-column:1 / -1; }
  .svc-detail .acts li{ grid-template-columns:48px 1fr; }
}

/* nav servizio (successivo/altro) */
.svc-nav{
  display:grid; grid-template-columns:1fr 1fr; gap:1px;
  background:var(--rule);
  border-top:1px solid var(--rule); border-bottom:1px solid var(--rule);
}
.svc-nav a{
  background:var(--bianco); padding:clamp(36px, 4vw, 56px) clamp(24px, 3vw, 40px);
  display:flex; flex-direction:column; gap:14px;
  transition:background .2s ease;
  min-height:160px;
}
.svc-nav a:hover{ background:var(--avorio-soft); }
.svc-nav h3{ transition:color .2s ease; }
.svc-nav a:hover h3{ color:var(--terracotta); }
.svc-nav .lbl{
  font-size:10px; letter-spacing:.24em; text-transform:uppercase;
  color:var(--bordeaux); opacity:.7; font-weight:500;
}
.svc-nav h3{ font-size:clamp(24px, 2.5vw, 32px); max-width:18ch; }
@media (max-width:640px){ .svc-nav{ grid-template-columns:1fr; } }

/* ═══════════ INDICE SERVIZI — righe ═══════════ */
.svc-rows{ display:flex; flex-direction:column; }
.svc-row{
  display:grid; grid-template-columns: 120px 1fr 60px;
  gap:clamp(24px, 3vw, 48px);
  padding:clamp(40px, 4.5vw, 64px) 0;
  border-top:1px solid var(--rule);
  align-items:start;
  transition:padding .2s ease, background .2s ease;
  cursor:pointer;
}
.svc-row:last-child{ border-bottom:1px solid var(--rule); }
.svc-row:hover{ background:var(--avorio-soft); padding-left:16px; padding-right:16px; }
.svc-row .n{
  font-family:var(--serif); font-size:clamp(56px, 5.5vw, 80px);
  color:var(--bordeaux); line-height:.9; font-weight:400; letter-spacing:.01em;
}
.svc-row h2{ font-size:clamp(28px, 3vw, 40px); margin-bottom:20px; max-width:20ch; }
.svc-row h2 .italic{ font-style:italic; color:var(--terracotta); font-weight:400; }
.svc-row ul{
  list-style:none; padding:0; margin:0; max-width:60ch;
  font-size:15px; line-height:1.7; color:var(--nero);
}
.svc-row li{ padding:7px 0 7px 32px; position:relative; }
.svc-row li::before{
  content:''; position:absolute; left:2px; top:.95em;
  width:7px; height:7px; background:var(--bordeaux);
  transform:translateY(-50%) rotate(45deg);
}
.svc-row .arr{
  align-self:center; justify-self:end;
  font-size:24px; color:var(--bordeaux); font-family:var(--serif); font-weight:400;
  transition:transform .2s ease, color .2s ease;
}
/* hover sulla riga servizio: la freccia avanza e vira a terracotta
   (4px, coerente con .svc-card .arr e a distanza di sicurezza dal bordo) */
.svc-row:hover .arr{ transform:translateX(4px); color:var(--terracotta); }
@media (max-width:640px){
  .svc-row{ grid-template-columns:1fr; gap:14px; }
  .svc-row .arr{ display:none; }
}

/* ═══════════ CLIENTELA — griglia 2x2 ═══════════ */
.audience-ed{
  display:grid; grid-template-columns:1fr 1fr; gap:0;
  border-top:1px solid var(--bordeaux);
  border-left:1px solid var(--rule);
}
.aud-cell{
  padding:clamp(40px, 4.5vw, 64px);
  border-right:1px solid var(--rule);
  border-bottom:1px solid var(--rule);
  display:flex; flex-direction:column; gap:18px;
  min-height:260px;
}
.aud-cell .n{
  font-family:var(--serif); font-size:14px; letter-spacing:.3em;
  color:var(--bordeaux); font-weight:500;
}
.aud-cell h3{ font-size:clamp(24px, 2.4vw, 32px); max-width:18ch; margin:8px 0; }
.aud-cell h3 .italic{ font-style:italic; color:var(--terracotta); font-weight:400; }
.aud-cell p{ font-size:15px; color:var(--nero); margin:0; max-width:40ch; }
@media (max-width:720px){ .audience-ed{ grid-template-columns:1fr; } }

/* ═══════════ SOCIETÀ — griglia team (placeholder onesto) ═══════════ */
.team-ed{ background:var(--avorio-soft); }
.team-ed .head .eyebrow-row{ grid-column:1 / 5; }
.team-ed .head h2{ grid-column:5 / 11; max-width:18ch; margin-bottom:48px; }
.team-ed .head .intro{ grid-column:5 / 11; font-size:17px; line-height:1.7; color:var(--nero); max-width:48ch; margin-bottom:64px; }
.team-grid{ display:grid; grid-template-columns:repeat(4, 1fr); gap:24px; }
.team-card{ display:flex; flex-direction:column; }
.team-card .portrait{
  aspect-ratio:4/5; background:var(--avorio);
  border:1px solid var(--rule);
  display:flex; align-items:center; justify-content:center;
  color:var(--bordeaux-80); margin-bottom:18px;
}
.team-card .portrait svg{ width:48px; height:48px; opacity:.4; }
.team-card .role{
  font-size:10px; letter-spacing:.24em; text-transform:uppercase;
  color:var(--bordeaux); opacity:.7; font-weight:500; margin-bottom:6px;
}
.team-card h3{ font-size:22px; margin:0 0 6px; }
.team-card p{ font-size:13px; color:var(--nero-60); margin:0; line-height:1.55; max-width:none; }
@media (max-width:820px){ .team-grid{ grid-template-columns:1fr 1fr; } }
@media (max-width:480px){ .team-grid{ grid-template-columns:1fr; } }

.placeholder-box{
  background:var(--avorio); border:1px dashed var(--bordeaux-20);
  padding:24px; font-size:13px; color:var(--nero-60); line-height:1.65;
  margin-top:48px; max-width:60ch;
}
.placeholder-box strong{
  display:block; font-family:var(--sans); font-weight:600;
  color:var(--bordeaux); letter-spacing:.18em; text-transform:uppercase;
  font-size:10px; margin-bottom:8px;
}
.placeholder-box.legal-note{ margin-top:0; margin-bottom:48px; }   /* ex stile inline (privacy) */

/* ═══════════ CONTATTI ═══════════ */
.contact-page{ padding-top:0; }
.contact-form-title{ font-size:clamp(28px,3vw,40px); max-width:18ch; }   /* ex stile inline */
.eyebrow-row.compact{ margin-bottom:14px; }   /* ex stile inline (intestazione modulo) */
.contact-page .grid12{ row-gap:48px; align-items:start; }
.contact-info{ grid-column:1 / 6; }
.contact-info dl{ margin:0; }
.contact-info dt{
  font-size:10px; letter-spacing:.24em; text-transform:uppercase;
  color:var(--bordeaux); font-weight:500; margin-bottom:8px;
}
.contact-info dd{
  margin:0 0 32px;
  font-family:var(--serif); font-size:clamp(22px, 2vw, 28px);
  font-weight:400; color:var(--bordeaux); line-height:1.3;
  overflow-wrap:anywhere;
}
.contact-info dd.body{
  font-family:var(--sans); font-size:15px; color:var(--nero); line-height:1.6; font-weight:400;
}

.contact-card{
  grid-column:7 / 13;
  background:var(--avorio); padding:clamp(40px, 5vw, 64px);
  aspect-ratio:4/3; position:relative; overflow:hidden;
  display:flex; flex-direction:column; justify-content:center; gap:28px;
}
.contact-card::after{
  content:''; position:absolute; right:-100px; bottom:-100px;
  width:380px; height:380px;
  background:url('/assets/logo-mark-bordeaux.png') center/contain no-repeat;
  opacity:.07; pointer-events:none;
}
.contact-card .pull{
  font-family:var(--serif); font-size:clamp(28px, 2.6vw, 38px); line-height:1.2;
  color:var(--bordeaux); margin:0; font-weight:500; position:relative;
}
.contact-card .pull .italic{ font-style:italic; color:var(--terracotta); }
.contact-card .rule{ width:48px; height:1px; background:var(--bordeaux); opacity:.4; position:relative; }
.contact-card .note{ font-size:15px; line-height:1.6; color:var(--nero); max-width:38ch; margin:0; position:relative; }

@media (max-width:820px){
  .contact-info, .contact-card{ grid-column:1 / -1; }
  .contact-card{ aspect-ratio:auto; min-height:280px; }
}

/* form */
form.contact-form{ display:grid; gap:24px; max-width:760px; margin:0; }
form.contact-form .form-head{ margin-bottom:8px; }
form.contact-form .row2{ display:grid; grid-template-columns:1fr 1fr; gap:24px; }
form.contact-form label{
  display:block; font-size:10px; letter-spacing:.24em; text-transform:uppercase;
  color:var(--bordeaux); font-weight:500; margin-bottom:10px;
}
form.contact-form input, form.contact-form textarea{
  width:100%; padding:14px 0;
  border:0; border-bottom:1px solid var(--bordeaux-20);
  background:transparent; font:inherit; color:var(--nero); font-size:16px;
  transition:border-color .15s ease;
}
form.contact-form input:focus, form.contact-form textarea:focus{
  outline:none; border-bottom-color:var(--bordeaux);
}
form.contact-form textarea{ min-height:120px; resize:vertical; }
/* honeypot anti-spam (nascosto agli umani, visibile ai bot) */
.hp-field{ position:absolute; left:-9999px; width:1px; height:1px; overflow:hidden; }
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:14px;
  padding:16px 36px; min-height:44px;
  background:var(--bordeaux); color:var(--avorio);
  font-size:11px; letter-spacing:.24em; text-transform:uppercase; font-weight:500;
  border:1px solid var(--bordeaux);
  cursor:pointer;
  transition:background .15s ease, color .15s ease;
  align-self:flex-start;
  justify-self:start;
  font-family:var(--sans);
}
.btn:hover{ background:transparent; color:var(--bordeaux); }
.btn:focus-visible{ outline:2px solid var(--bordeaux); outline-offset:4px; }

/* contatto diretto sotto il modulo: email in chiaro + bottone "Copia" */
.form-direct{
  display:flex; align-items:center; flex-wrap:wrap; gap:8px 14px;
  font-size:14px; color:var(--nero-60); margin:0;
}
.form-direct a{ color:var(--bordeaux); text-decoration:underline; text-underline-offset:3px; }
.copy-btn{
  font-family:var(--sans); font-size:10px; letter-spacing:.16em; text-transform:uppercase;
  font-weight:500; color:var(--bordeaux);
  background:transparent; border:1px solid var(--bordeaux-20); border-radius:2px;
  padding:6px 12px; min-height:32px; cursor:pointer;
  transition:background .15s ease, color .15s ease, border-color .15s ease;
}
.copy-btn:hover{ background:var(--bordeaux); color:var(--avorio); border-color:var(--bordeaux); }
.copy-btn:focus-visible{ outline:2px solid var(--bordeaux); outline-offset:3px; }
.copy-btn.copied{ background:var(--bordeaux); color:var(--avorio); border-color:var(--bordeaux); }
.copy-btn.copy-failed{ color:var(--terracotta); border-color:var(--terracotta); background:transparent; }
form.contact-form .disclaimer{
  font-size:12px; color:var(--nero-60); line-height:1.6; max-width:62ch;
}
form.contact-form .disclaimer a{
  color:var(--bordeaux); text-decoration:underline; text-underline-offset:3px;
}
form.contact-form .field-error{
  display:block; margin-top:8px;
  font-size:12px; letter-spacing:.01em; line-height:1.45;
  color:var(--terracotta); font-family:var(--sans); font-weight:500;
}
form.contact-form input[aria-invalid="true"],
form.contact-form textarea[aria-invalid="true"]{ border-bottom-color:var(--terracotta); }
.form-status{ font-size:14px; line-height:1.6; color:var(--bordeaux); font-weight:500; }
.btn:disabled{ opacity:.6; cursor:default; }
@media (max-width:640px){
  form.contact-form .row2{ grid-template-columns:1fr; }
  form.contact-form .btn{ width:100%; }   /* target touch pieno su mobile */
}

/* ═══════════ PRIVACY ═══════════ */
.privacy-body{ max-width:780px; margin:0 auto; }
.privacy-body p{ font-size:16px; line-height:1.75; }
.privacy-body h3{ margin-top:48px; margin-bottom:16px; }
.privacy-updated{ margin-bottom:32px; }   /* ex stile inline (data ultimo aggiornamento) */

/* ═══════════ FAQ (domande frequenti) ═══════════ */
.faq-ed{ background:var(--avorio-soft); }
.faq-ed .head{ margin-bottom:40px; }
.faq-ed .head .eyebrow-row{ grid-column:1 / 5; }
.faq-ed .head h2{ grid-column:5 / 13; max-width:18ch; }
.faq-list{ border-top:1px solid var(--bordeaux-20); }
.faq-item{ border-bottom:1px solid var(--bordeaux-20); interpolate-size:allow-keywords; }
.faq-item summary{
  list-style:none; cursor:pointer; position:relative;
  padding:26px 44px 26px 0;
  font-family:var(--serif); font-size:clamp(19px, 2vw, 24px);
  color:var(--bordeaux); font-weight:500; line-height:1.3;
}
.faq-item summary::-webkit-details-marker{ display:none; }
/* marcatore "+" che ruota a "×" all'apertura (transform → animabile, a differenza
   del cambio di glifo +/–; il reset reduced-motion ne azzera la durata) */
.faq-item summary::after{
  content:'+'; position:absolute; right:4px; top:50%;
  transform:translateY(-50%) rotate(0deg);
  font-family:var(--serif); font-size:30px; color:var(--bordeaux); line-height:1;
}
.faq-item[open] summary::after{ transform:translateY(-50%) rotate(45deg); }
.faq-item summary:focus-visible{ outline:2px solid var(--bordeaux); outline-offset:3px; }
/* Animazioni FAQ (solo con motion abilitato; coerente con le altre animazioni):
   - marcatore "+" che ruota a "×" all'apertura;
   - apertura morbida del pannello via ::details-content (block-size 0→auto grazie a
     interpolate-size). Dove ::details-content non è supportato (Firefox/Safari) la
     regola è ignorata in toto → il <details> apre/chiude in modo nativo istantaneo. */
@media (prefers-reduced-motion: no-preference){
  .faq-item summary::after{ transition:transform .3s ease; }
  .faq-item::details-content{
    block-size:0; overflow:clip;
    transition:block-size .35s ease, content-visibility .35s allow-discrete;
  }
  .faq-item[open]::details-content{ block-size:auto; }
}
.faq-a{ padding:0 0 28px; font-size:15px; line-height:1.7; color:var(--nero); max-width:64ch; }
.faq-a a{ color:var(--bordeaux); text-decoration:underline; text-underline-offset:3px; }
.faq-a a:hover{ color:var(--terracotta); }
@media (max-width:900px){
  .faq-ed .head .eyebrow-row, .faq-ed .head h2{ grid-column:1 / -1; }
}

/* ═══════════ FOOTER ═══════════ */
footer.site-footer{
  background:var(--bordeaux); color:var(--avorio);
  padding:clamp(72px, 7vw, 100px) 0 32px;
  position:relative;
  overflow:hidden; overflow:clip;   /* clip: vedi nota su .hero-ed */
}
footer.site-footer::before{
  content:''; position:absolute; left:-120px; top:-120px;
  width:400px; height:400px;
  background:url('/assets/logo-mark-avorio.png') center/contain no-repeat;
  opacity:.05; pointer-events:none;
  transform:translateY(var(--cdt-drift, 0px));   /* vedi .contact-ed::before */
}
footer.site-footer .grid12{ row-gap:48px; padding-bottom:48px; border-bottom:1px solid rgba(240,228,206,.18); position:relative; z-index:1; }
footer.site-footer .brand-col{ grid-column:1 / 5; display:flex; flex-direction:column; gap:24px; }
.footer-wordmark{
  display:grid; grid-template-columns:48px 1fr; gap:14px 16px;
  align-items:center;
}
.footer-wordmark img{ width:48px; height:48px; grid-row:1 / 3; }
.footer-wordmark .fw-name{
  font-family:var(--serif); font-size:18px; line-height:1; color:var(--avorio);
  letter-spacing:.14em; text-transform:uppercase;
}
.footer-wordmark .fw-sub{
  font-family:var(--sans); font-size:10px; letter-spacing:.28em; text-transform:uppercase;
  opacity:.6; color:var(--avorio); font-weight:500;
}
footer.site-footer address{
  font-style:normal; font-family:var(--serif); font-size:18px;
  line-height:1.55; max-width:28ch;
}
footer.site-footer .col{ grid-column:span 3; }
footer.site-footer h4{
  font-family:var(--sans); font-size:10px; letter-spacing:.24em; text-transform:uppercase;
  font-weight:500; color:var(--avorio); opacity:.55;
  margin:0 0 22px;
}
footer.site-footer ul{ list-style:none; margin:0; padding:0; }
footer.site-footer li{ margin-bottom:10px; font-size:13px; opacity:.9; }
footer.site-footer li.footer-note{ margin-top:14px; opacity:.7; }   /* ex stile inline */
footer.site-footer li a{ overflow-wrap:anywhere; }
footer.site-footer li a:hover{ text-decoration:underline; text-underline-offset:4px; }
footer.site-footer .coda{
  padding-top:24px; display:flex; justify-content:space-between; gap:14px 32px; flex-wrap:wrap; align-items:baseline;
  font-size:11px; letter-spacing:.14em; text-transform:uppercase; opacity:.65;
  position:relative; z-index:1;
}
footer.site-footer .coda .legal{
  text-transform:none; letter-spacing:.01em; line-height:1.6;
  font-size:11px; max-width:78ch; opacity:.85; flex:1 1 460px;
}
footer.site-footer .coda .legal a{ text-decoration:none; }
footer.site-footer .coda .legal-links{ display:flex; gap:20px; flex:0 0 auto; }
footer.site-footer .coda .legal-links a:hover{ text-decoration:underline; text-underline-offset:4px; }
@media (max-width:820px){
  footer.site-footer .brand-col, footer.site-footer .col{ grid-column:1 / -1; }
}

/* ═══════════ COOKIE BANNER ═══════════ */
.cookie-banner{
  position:fixed; left:20px; right:20px; bottom:20px;
  max-width:560px;
  background:var(--bianco);
  border:1px solid var(--bordeaux-20);
  padding:18px 22px;
  display:flex; gap:18px; align-items:center;
  z-index:60;
  font-size:12px; line-height:1.55; color:var(--nero);
  transform:translateY(140%);
  transition:transform .3s ease;
}
.cookie-banner.visible{ transform:none; }
.cookie-banner a{ color:var(--bordeaux); text-decoration:underline; text-underline-offset:3px; }
.cookie-banner button{
  flex:none; padding:10px 22px; min-height:44px;
  display:inline-flex; align-items:center; justify-content:center;
  background:var(--bordeaux); color:var(--avorio); border:0;
  font-size:10px; letter-spacing:.2em; text-transform:uppercase; font-weight:500;
  cursor:pointer;
}
.cookie-banner button:hover{ background:var(--nero); }

/* ═══════════ MOBILE ═══════════ */
@media (max-width:900px){
  .site-header .bar{ grid-template-columns: auto 1fr auto; gap:14px; padding:14px var(--gutter); }
  .nav-left, .nav-right{ display:none; }
  .menu-toggle{ display:flex; }
  .brand-center{ justify-self:start; }
  .brand-center img{ height:30px; width:auto; }
  .brand-center .name{ font-size:14px; letter-spacing:.12em; }
  .brand-center .name small{ display:none; }
  .menu-toggle{ justify-self:end; }

  /* blocca lo scroll della pagina quando il menu è aperto */
  body.menu-open{ overflow:hidden; }

  .site-header.menu-open .mobile-nav{ display:flex; }
  .mobile-nav{
    display:none;
    position:fixed; top:0; left:0; right:0; bottom:0;
    background:var(--bordeaux); z-index:99;
    flex-direction:column; align-items:center; justify-content:center;
    gap:18px; padding:80px 24px;
  }
  .mobile-nav a{
    font-family:var(--serif); font-size:30px; color:var(--avorio);
    letter-spacing:.02em; text-transform:none; opacity:.85;
  }
  .mobile-nav a.active,
  .mobile-nav a[aria-current="page"]{ opacity:1; border-bottom:1px solid var(--avorio); padding-bottom:4px; }
  /* CTA "Contatti" evidenziata anche nel menu mobile (bottone outline) */
  .mobile-nav a[href="/contatti"]{
    opacity:1; border:1px solid rgba(240,228,206,.5); border-radius:3px; padding:10px 30px;
  }
  .mobile-nav a[href="/contatti"].active,
  .mobile-nav a[href="/contatti"][aria-current="page"]{
    background:var(--avorio); color:var(--bordeaux); border-color:var(--avorio); padding-bottom:10px;
  }
  .mobile-close{
    position:absolute; top:18px; right:18px;
    width:44px; height:44px; background:transparent; border:0; color:var(--avorio);
  }
  .mobile-close svg{ width:24px; height:24px; }

  .hero-ed .meta-foot, .hero-ed .photo, .hero-ed .pull{ grid-column:1 / -1; }
  .hero-ed .photo{ max-height:60vh; }
  .page-head-ed h1, .page-head-ed .meta, .page-head-ed .lede{ grid-column:1 / -1; }
  .values-ed .head .eyebrow-row, .values-ed .head h2{ grid-column:1 / -1; }
  .contact-ed .head, .contact-ed .col-2, .contact-ed .col-3{ grid-column:1 / -1; }
  .contact-info, .contact-card{ grid-column:1 / -1; }
  .team-ed .head .eyebrow-row, .team-ed .head h2, .team-ed .head .intro{ grid-column:1 / -1; }
}

@media (min-width:901px){
  .menu-toggle, .mobile-nav, .mobile-close{ display:none !important; }
}

/* ═══════════ MOTION — transizioni di pagina + rispetto reduced-motion ═══════════ */
/* NB: niente `scroll-behavior:smooth` globale su <html>. Penalizzava gli scroll
   incrementali (inerzia del trackpad, tasti Freccia/PagSu-Giù/Home/Fine,
   trascinamento della scrollbar, scroll programmatici): ogni delta ravvicinato
   ridefiniva il bersaglio dell'animazione dalla posizione "in ritardo",
   annullando i precedenti → lo scroll sembrava bloccarsi/gommoso (~84% di corsa
   persa nei test Playwright). Le ancore (skip-link → #main) saltano istantanee,
   che è anche il comportamento atteso per l'accessibilità. */
/* Cross-document View Transitions: transizioni morbide tra pagine reali,
   CSS puro e progressive (ignorato dai browser che non le supportano). */
@view-transition{ navigation: auto; }

/* Rifinitura: l'header (identico fra pagine) resta FERMO invece di sfumare
   — niente "lampeggio" della barra in alto; il contenuto principale entra con un
   fade + slide sobrio. Solo con motion abilitato; i browser senza View
   Transitions ignorano queste regole e navigano in modo normale (come oggi). */
@media (prefers-reduced-motion: no-preference){
  .site-header{ view-transition-name: cdt-header; }
  main{ view-transition-name: cdt-main; }
  ::view-transition-old(cdt-main){ animation: cdt-vt-out .2s ease both; }
  ::view-transition-new(cdt-main){ animation: cdt-vt-in .28s cubic-bezier(.22,.61,.36,1) both; }
  @keyframes cdt-vt-out{ to  { opacity:0; transform:translateY(-8px); } }
  @keyframes cdt-vt-in { from{ opacity:0; transform:translateY(8px);  } }
}

@media (prefers-reduced-motion: reduce){
  ::view-transition-group(*),
  ::view-transition-old(*),
  ::view-transition-new(*){ animation:none !important; }
  *,*::before,*::after{
    animation-duration:.001ms !important; animation-iteration-count:1 !important;
    transition-duration:.001ms !important; scroll-behavior:auto !important;
  }
}

/* ═══════════ PARALLAX — scroll-driven, CSS nativo (progressive enhancement)
   Attivo SOLO dove supportato (@supports animation-timeline) e SOLO se l'utente
   non ha chiesto meno movimento. Degrada a zero effetto altrove. Nessun JS,
   gira fuori dal main thread → nessun costo su mobile. */
@media (prefers-reduced-motion: no-preference){
  @supports (animation-timeline: view()){
    /* foto hero: lieve deriva verticale; lo scale evita bordi vuoti */
    .hero-ed .photo img{
      animation: cdt-parallax-rise linear both;
      animation-timeline: view();
      animation-range: entry 0% exit 100%;
      will-change: transform;
    }
    @keyframes cdt-parallax-rise{
      from{ transform: translateY(-6%) scale(1.12); }
      to  { transform: translateY(6%)  scale(1.12); }
    }
    /* watermark del marchio: deriva lenta e sobria */
    .contact-ed::before,
    footer.site-footer::before{
      animation: cdt-parallax-drift linear both;
      animation-timeline: view();
      animation-range: entry 0% exit 100%;
    }
    @keyframes cdt-parallax-drift{
      from{ transform: translateY(7%); }
      to  { transform: translateY(-7%); }
    }
  }
}

/* ═══════════ REVEAL — comparsa morbida allo scroll (progressive enhancement)
   Lo stato nascosto esiste SOLO se il JS è attivo (html.anim, vedi main.js) e
   l'utente non ha chiesto meno movimento: senza JS, con reduced-motion o su
   crawler il contenuto è sempre visibile. --rd = ritardo di sfalsamento. */
@media (prefers-reduced-motion: no-preference){
  html.anim .reveal{
    opacity:0; transform:translateY(20px);
    transition:opacity .7s ease, transform .7s cubic-bezier(.22,.61,.36,1);
    transition-delay:var(--rd, 0ms);
  }
  html.anim .reveal.in-view{ opacity:1; transform:none; }
}
