/* ---- Font self-hosted (subset latin) — nessuna richiesta a terze parti ---- */
@font-face{font-family:'Hanken Grotesk';font-style:normal;font-weight:400;font-display:swap;src:url('fonts/hanken-grotesk-latin-400-normal.woff2') format('woff2')}
@font-face{font-family:'Hanken Grotesk';font-style:normal;font-weight:500;font-display:swap;src:url('fonts/hanken-grotesk-latin-500-normal.woff2') format('woff2')}
@font-face{font-family:'Hanken Grotesk';font-style:normal;font-weight:600;font-display:swap;src:url('fonts/hanken-grotesk-latin-600-normal.woff2') format('woff2')}
@font-face{font-family:'Hanken Grotesk';font-style:normal;font-weight:700;font-display:swap;src:url('fonts/hanken-grotesk-latin-700-normal.woff2') format('woff2')}
@font-face{font-family:'Hanken Grotesk';font-style:italic;font-weight:400;font-display:swap;src:url('fonts/hanken-grotesk-latin-400-italic.woff2') format('woff2')}
@font-face{font-family:'Spectral';font-style:normal;font-weight:400;font-display:swap;src:url('fonts/spectral-latin-400-normal.woff2') format('woff2')}
@font-face{font-family:'Spectral';font-style:normal;font-weight:500;font-display:swap;src:url('fonts/spectral-latin-500-normal.woff2') format('woff2')}
@font-face{font-family:'Spectral';font-style:normal;font-weight:600;font-display:swap;src:url('fonts/spectral-latin-600-normal.woff2') format('woff2')}
@font-face{font-family:'Spectral';font-style:italic;font-weight:400;font-display:swap;src:url('fonts/spectral-latin-400-italic.woff2') format('woff2')}

/* ============================================================
   avvocatolavoratore.it — foglio di stile condiviso
   Direzione "L'alleato": verde profondo #14332b / verde azione
   #1f8a5b / evidenziatore #ffe15c / bianco caldo #fbfbf8
   Type: Spectral (display) + Hanken Grotesk (testo)
   ============================================================ */

:root{
  --ink:#14332b;            /* verde profondo: titoli, footer, bande scure */
  --ink-2:#3d4a44;
  --body:#333d38;
  --green:#1f8a5b;          /* verde azione */
  --green-ink:#187a4e;      /* link/interattivi: contrasto AA su bianco */
  --slate:#5c7a6b;          /* alias legacy: testo attenuato */
  --hl:#ffe15c;             /* evidenziatore */
  --mist:#f1f4ee;           /* fondo sezioni */
  --mist-deep:#e8ede4;
  --bg:#fbfbf8;             /* bianco caldo */
  --line:#e2e5dd;
  --line-cool:#d5ddd0;
  --serif:'Spectral',Georgia,'Times New Roman',serif;
  --sans:'Hanken Grotesk',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  --wrap:1120px;
  --gutter:clamp(1.25rem,5vw,2.75rem);
}

*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{
  margin:0;background:var(--bg);color:var(--body);
  font-family:var(--sans);font-size:17px;line-height:1.65;
  font-weight:400;-webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{max-width:100%;display:block}
a{color:var(--green-ink);text-decoration:none}
a:hover{text-decoration:underline;text-underline-offset:3px}
::selection{background:var(--ink);color:#fff}
mark{background:linear-gradient(transparent 55%,var(--hl) 55%);color:inherit}
a:focus-visible,button:focus-visible,summary:focus-visible{outline:2px solid var(--green);outline-offset:2px;border-radius:2px}
[id]{scroll-margin-top:96px}
image-slot{display:block;width:100%}

.wrap{max-width:var(--wrap);margin-inline:auto;padding-inline:var(--gutter)}

/* ---------- Tipografia ---------- */
h1,h2,h3{font-family:var(--serif);color:var(--ink);font-weight:500;
  letter-spacing:-.01em;line-height:1.14;margin:0}
.eyebrow{font-family:var(--sans);font-size:.72rem;font-weight:700;
  letter-spacing:.18em;text-transform:uppercase;color:var(--green);margin:0 0 1.1rem;
  display:flex;align-items:center;gap:.7rem}
.eyebrow::before{content:"";width:22px;height:3px;background:var(--hl);flex:none}
p{margin:0 0 1.05rem}
.lede{font-size:1.18rem;line-height:1.6;color:var(--ink-2);max-width:44ch;text-wrap:pretty}

/* ---------- Icone ---------- */
.ic{flex:none}

/* ---------- Header ---------- */
.masthead{border-bottom:1px solid var(--line);background:var(--bg);
  position:sticky;top:0;z-index:40;transition:box-shadow .25s}
.masthead.scrolled{box-shadow:0 10px 30px rgba(20,51,43,.08)}
.masthead .wrap{display:flex;align-items:center;justify-content:space-between;
  min-height:74px;gap:1rem}
.brand{font-family:var(--serif);font-size:1.3rem;color:var(--ink);
  font-weight:600;letter-spacing:-.01em;white-space:nowrap}
.brand:hover{text-decoration:none}
.brand .dot{color:var(--green)}
.nav{display:flex;align-items:center;gap:clamp(1rem,2.5vw,2rem)}
.nav a{font-size:.93rem;color:var(--ink-2);font-weight:500}
.nav a:hover{color:var(--ink);text-decoration:none}
.nav a[aria-current="page"]:not(.btn){color:var(--ink);box-shadow:inset 0 -2px 0 var(--hl);padding-bottom:.2rem}
.nav a.btn{margin-left:.4rem;color:#fff}
.nav a.btn:hover{color:#fff}
.nav-tel{display:inline-flex;align-items:center;gap:.45rem;white-space:nowrap}
.nav-tel .ic{color:var(--green)}
.nav-toggle{display:none;background:none;border:0;padding:.4rem;cursor:pointer;color:var(--ink)}
.nav-toggle svg{display:block}

/* ---------- Bottoni ---------- */
.btn{display:inline-flex;align-items:center;gap:.55rem;
  font-family:var(--sans);font-size:.95rem;font-weight:700;
  padding:.72rem 1.35rem;border-radius:6px;border:1px solid var(--ink);
  background:var(--ink);color:#fff;cursor:pointer;transition:background .15s,border-color .15s}
.btn:hover{background:#0e261f;border-color:#0e261f;text-decoration:none}
.btn .ic{transition:transform .18s}
.btn:hover .ic{transform:translateX(3px)}
.btn-accent{background:var(--green);border-color:var(--green)}
.btn-accent:hover{background:#187a4e;border-color:#187a4e}
.btn-ghost{background:transparent;color:var(--ink);border-color:var(--line-cool)}
.btn-ghost:hover{background:var(--mist);border-color:var(--green);color:var(--ink)}
.btn-light{background:#fff;color:var(--ink);border-color:#fff}
.btn-light:hover{background:var(--hl);border-color:var(--hl)}
.btn-ghost-dark{background:transparent;color:var(--ink);border-color:var(--line-cool)}
.btn-ghost-dark:hover{background:var(--mist);border-color:var(--green);color:var(--ink)}

/* ---------- Foto ---------- */
.photo-frame{position:relative;z-index:1;margin:0;background:transparent;border:0;padding:0}
.photo-frame image-slot,.photo-frame img{border-radius:12px;overflow:hidden;margin-inline:auto}
.photo-frame figcaption{display:flex;justify-content:space-between;gap:1rem;
  padding:.8rem .2rem .3rem;font-size:.7rem;font-weight:700;
  letter-spacing:.14em;text-transform:uppercase;color:var(--green)}

/* ---------- Hero ---------- */
.hero-dark{position:relative;overflow:hidden;
  background:linear-gradient(180deg,#f4f6f0 0%,var(--bg) 100%)}
.hero-dark .wrap{position:relative;z-index:1}
.hero{padding:clamp(3.2rem,8vw,5.8rem) 0 clamp(3rem,7vw,5rem)}
.hero-grid{display:grid;grid-template-columns:1.08fr .92fr;gap:clamp(2.5rem,7vw,5.5rem);align-items:center}
.hero h1{font-size:clamp(2.1rem,4.6vw,3.35rem);font-weight:500;margin-bottom:1.4rem;text-wrap:balance}
.hero .lede{margin-bottom:2rem;font-size:1.2rem}
.hero-actions{display:flex;flex-wrap:wrap;gap:.85rem;align-items:center}
.hero-note{font-size:.86rem;color:var(--ink-2);margin:1.6rem 0 0;padding-left:1rem;
  border-left:3px solid var(--hl)}
.hero-media{position:relative;padding:0}
.hero-ghost{position:absolute;right:-2rem;bottom:-6rem;font-family:var(--serif);
  font-size:clamp(14rem,26vw,22rem);line-height:1;color:rgba(20,51,43,.04);
  pointer-events:none;user-select:none;z-index:0}

/* ---------- Banda "situazioni ricorrenti" ---------- */
.sit-band{border-bottom:1px solid var(--line);background:var(--bg)}
.sit-row{display:flex;flex-wrap:wrap;align-items:center;gap:.6rem;padding-block:1.05rem}
.sit-label{font-size:.7rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;
  color:var(--green);margin-right:.9rem}
.chip{display:inline-flex;align-items:center;gap:.5rem;padding:.46rem .95rem;
  border:1.5px solid transparent;border-radius:999px;font-size:.87rem;font-weight:600;
  color:var(--ink);background:#fff;transition:filter .15s,border-color .15s}
.chip .ic{color:var(--ink)}
.chip:hover{filter:brightness(.95);text-decoration:none}
/* tinte pastello dal collage, stessa mappa dei box "Le tue tutele" */
.sit-row .chip:nth-of-type(1){background:#f8e9ab}
.sit-row .chip:nth-of-type(2){background:#e7def2}
.sit-row .chip:nth-of-type(3){background:#e3edf3}
.sit-row .chip:nth-of-type(4){background:#d3dff0}
.sit-row .chip:nth-of-type(5){background:#f8e9d8}
.sit-row .chip:nth-of-type(6){background:#d9edf7}

/* ---------- Sezioni ---------- */
.section{padding:clamp(3.2rem,7vw,5.5rem) 0}
.section-mist{background:var(--mist);border-block:1px solid var(--line-cool)}
.section-ink{background:var(--ink);color:#d3ddd6}
.section-head{max-width:60ch;margin-bottom:clamp(2rem,4vw,3rem)}
.section-head h2{font-size:clamp(1.7rem,3.4vw,2.35rem);margin-bottom:.9rem;text-wrap:balance}
.section-head p{color:var(--ink-2)}
.section-ink .section-head h2{color:#fff}
.section-ink .eyebrow{color:#8fc4a8}
.more-link{display:inline-flex;align-items:center;gap:.5rem;font-weight:700;
  font-size:.95rem;color:var(--green-ink);margin-top:2.2rem}
.more-link .ic{transition:transform .18s}
.more-link:hover .ic{transform:translateX(3px)}

/* ---------- Ornamento tipografico ---------- */
.ghost{position:absolute;right:-1.5rem;top:50%;transform:translateY(-46%);
  font-family:var(--serif);font-size:clamp(11rem,22vw,17rem);line-height:1;
  color:rgba(20,51,43,.045);pointer-events:none;user-select:none;z-index:0}
.section-ink .ghost{color:rgba(255,255,255,.05)}

/* ---------- "Le tue tutele" — indice a domande ---------- */
.tutele{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}
.tutela{background:#fff;padding:clamp(1.5rem,2.5vw,2rem);display:flex;
  flex-direction:column;gap:.55rem;border-radius:12px;transition:filter .15s,transform .15s}
a.tutela:hover{filter:brightness(.965);text-decoration:none}
.tutela .icon{width:42px;height:42px;display:grid;place-items:center;
  color:var(--ink);background:rgba(255,255,255,.72);border:0;
  border-radius:8px;margin-bottom:.5rem}
/* palette presa dai fondi del collage in hero */
.tutele .tutela:nth-child(1){background:#f5d95f}
.tutele .tutela:nth-child(2){background:#d8c9e6}
.tutele .tutela:nth-child(3){background:#d9e8ee}
.tutele .tutela:nth-child(4){background:#9fb9e0}
.tutele .tutela:nth-child(5){background:#f3ddc5}
.tutele .tutela:nth-child(6){background:#bfe0ef}
.tutela .q{font-family:var(--serif);font-size:1.18rem;color:var(--ink);line-height:1.3}
.tutela .a{font-size:.9rem;font-weight:700;letter-spacing:.02em;color:var(--ink);
  text-transform:uppercase;display:flex;align-items:center;gap:.4rem;margin-top:.2rem}
.tutela .a::after{content:"→";font-weight:400;display:inline-block;transition:transform .18s}
a.tutela:hover .a::after{transform:translateX(4px)}
.tutela p{font-size:.96rem;color:var(--ink-2);margin:0}

/* ---------- Come funziona — sequenza ---------- */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(1.2rem,2.5vw,2rem)}
.step{position:relative;padding-top:1.15rem;border-top:3px solid var(--ink)}
.step-head{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:.85rem}
.step-head .ic{color:var(--green-ink)}
.step .num{font-family:var(--serif);font-size:1.55rem;font-weight:500;color:var(--green);line-height:1}
.step h3{font-size:1.18rem;margin-bottom:.55rem}
.step p{font-size:.96rem;color:var(--ink-2);margin:0}

/* ---------- Lo studio / assicurazione della qualità ---------- */
.assure{display:grid;grid-template-columns:minmax(240px,320px) 1fr;
  gap:clamp(2.2rem,5.5vw,4.5rem);align-items:start}
.who{padding:0}
.who-name{font-family:var(--serif);font-size:1.18rem;color:var(--ink);margin:1.2rem 0 .1rem}
.who-role{font-size:.86rem;color:var(--ink-2);margin:0}
.assure-body h2{font-size:clamp(1.7rem,3.4vw,2.35rem);margin-bottom:1rem}
.assure-lede{color:var(--ink-2);max-width:52ch;margin-bottom:1.7rem}
.assure-list{list-style:none;margin:0;padding:0}
.assure-list li{padding:1.05rem 0;border-top:1px solid var(--line-cool);display:grid;
  grid-template-columns:minmax(200px,auto) 1fr;gap:1rem;align-items:baseline}
.assure-list li:first-child{border-top:0;padding-top:0}
.assure-list b{font-family:var(--serif);font-weight:500;color:var(--ink);font-size:1.05rem}
.assure-list span{font-size:.96rem;color:var(--ink-2)}

/* ---------- Banda contatto ---------- */
.cta-band{padding:clamp(3.2rem,7vw,5rem) 0;position:relative;overflow:hidden}
.cta-band .inner{display:grid;grid-template-columns:1.2fr .8fr;gap:2.5rem;align-items:center;
  position:relative;z-index:1}
.cta-band h2{font-size:clamp(1.8rem,3.6vw,2.5rem);color:#fff;margin-bottom:.7rem}
.cta-band p{color:#a9bfb1;margin:0;max-width:42ch}
.cta-actions{display:flex;flex-direction:column;gap:.9rem;align-items:flex-start}
.cta-direct{font-size:.92rem;color:#a9bfb1;line-height:1.8}
.cta-direct a{color:#fff;font-weight:700}

/* ---------- Contenuto lungo (pagine interne) ---------- */
.page-hero{padding:clamp(2.8rem,6vw,4.5rem) 0 clamp(1.5rem,3vw,2.5rem);
  border-bottom:1px solid var(--line);position:relative;overflow:hidden;
  background:linear-gradient(176deg,#f4f6f0 0%,var(--bg) 70%)}
.page-hero .wrap{position:relative;z-index:1}
.page-hero h1{font-size:clamp(2rem,4.2vw,3rem);font-weight:500;max-width:20ch;margin-bottom:1rem}
.topic-mark{position:absolute;right:calc(var(--gutter)*.6);bottom:-34px;z-index:0;
  color:var(--green);opacity:.12;pointer-events:none}
.breadcrumb{font-size:.82rem;color:var(--green-ink);margin-bottom:1.4rem}
.breadcrumb a{color:var(--green-ink)}
.prose{max-width:68ch}
.prose h2{font-size:clamp(1.4rem,2.8vw,1.85rem);margin:2.6rem 0 1rem}
.prose h3{font-size:1.2rem;margin:2rem 0 .7rem}
.prose ul{padding-left:1.1rem;margin:0 0 1.2rem}
.prose li{margin-bottom:.5rem}
.prose .callout{background:var(--mist);border-left:3px solid var(--green);
  padding:1.3rem 1.5rem;margin:2rem 0;border-radius:6px}
.prose .callout p:last-child{margin-bottom:0}
.prose .callout strong{color:var(--ink)}
.layout{display:grid;grid-template-columns:1fr 300px;gap:clamp(2rem,5vw,4rem);
  padding:clamp(2.5rem,5vw,4rem) 0}
.aside-card{background:var(--mist);border:1px solid var(--line-cool);border-radius:8px;
  padding:1.6rem;position:sticky;top:98px}
.aside-card h3{font-family:var(--sans);font-size:.72rem;font-weight:700;letter-spacing:.14em;
  text-transform:uppercase;color:var(--green);margin-bottom:.9rem}
.aside-card p{font-size:.94rem;color:var(--ink-2)}
.aside-card .btn{width:100%;justify-content:center;margin-top:.6rem}
.aside-stack{position:sticky;top:98px;display:flex;flex-direction:column;gap:1.4rem}
.aside-stack .aside-card{position:static}

/* ---------- Timeline dei termini ---------- */
.timeline{list-style:none;margin:2.2rem 0 2.4rem;padding:0;
  display:grid;grid-template-columns:repeat(3,1fr);position:relative}
.timeline::before{content:"";position:absolute;top:6px;left:7px;right:7px;height:2px;
  background:var(--line-cool)}
.tl{position:relative;padding:1.5rem 1.4rem 0 0;margin:0}
.tl::before{content:"";position:absolute;top:0;left:0;width:14px;height:14px;
  border-radius:50%;background:var(--hl);border:2px solid var(--ink)}
.tl-kicker{font-size:.68rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;
  color:var(--green-ink);margin:0 0 .35rem}
@media(min-width:641px){.tl-kicker{min-height:2.35em}}
.tl h3{font-size:1.08rem;margin:0 0 .35rem}
.tl p{font-size:.88rem;color:var(--ink-2);margin:0}

/* ---------- Griglia documenti / checklist ---------- */
.doc-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.doc{border-radius:12px;padding:1.3rem;display:flex;flex-direction:column;gap:.65rem}
.doc-grid .doc:nth-child(1){background:#f5d95f}
.doc-grid .doc:nth-child(2){background:#d8c9e6}
.doc-grid .doc:nth-child(3){background:#d9e8ee}
.doc-grid .doc:nth-child(4){background:#f3ddc5}
.doc .ic{width:42px;height:42px;padding:10px;background:rgba(255,255,255,.72);
  border-radius:8px;color:var(--ink)}
.doc b{font-family:var(--serif);font-weight:500;color:var(--ink);font-size:1.02rem}
.doc span{font-size:.87rem;color:var(--ink-2)}
.doc-note{font-size:.88rem;color:var(--green-ink);margin:1.1rem 0 0}
.check-list{list-style:none;padding:0;margin:0 0 1.2rem}
.check-list li{display:flex;gap:.85rem;align-items:flex-start;padding:.7rem 0;
  border-top:1px solid var(--line);margin:0}
.check-list li:first-child{border-top:0}
.check-list .ic{margin-top:.2rem;color:var(--green)}
.deadline-note{display:flex;gap:.6rem;align-items:center;font-family:var(--serif);
  color:var(--ink);font-size:1.02rem;padding:.7rem .9rem;background:#fff;
  border:1px solid var(--line-cool);border-left:3px solid var(--hl);border-radius:8px;margin:0 0 1rem}
.deadline-note .ic{color:var(--green-ink)}

/* ---------- FAQ ---------- */
.faq{border-top:1px solid var(--line)}
.faq details{border-bottom:1px solid var(--line);padding:.4rem 0}
.faq summary{font-family:var(--serif);font-size:1.12rem;color:var(--ink);
  padding:1.05rem 2rem 1.05rem 0;cursor:pointer;list-style:none;position:relative;
  transition:color .15s}
.faq summary:hover{color:var(--green-ink)}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";position:absolute;right:.2rem;top:1rem;color:var(--green);
  font-size:1.3rem;font-family:var(--sans)}
.faq details[open] summary::after{content:"–"}
.faq details p{color:var(--ink-2);font-size:.98rem;padding:0 0 1.1rem}

/* ---------- Form ---------- */
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.1rem}
.field{display:flex;flex-direction:column;gap:.4rem;margin-bottom:1.1rem}
.field.full{grid-column:1/-1}
.field label,.chipset legend{font-size:.85rem;font-weight:700;color:var(--ink)}
.field input,.field textarea,.field select{font-family:var(--sans);font-size:1rem;
  padding:.72rem .85rem;border:1px solid var(--line-cool);border-radius:6px;background:#fff;color:var(--body)}
.field input:focus,.field textarea:focus,.field select:focus{outline:2px solid var(--green);
  outline-offset:1px;border-color:var(--green)}
.field textarea{resize:vertical;min-height:130px}
.chipset{border:0;padding:0;margin:0}
.chipset legend{padding:0;margin-bottom:.55rem}
.chip-group{display:flex;flex-wrap:wrap;gap:.55rem}
.chip-opt{position:relative}
.chip-opt input{position:absolute;inset:0;opacity:0;pointer-events:none}
.chip-opt span{display:inline-flex;align-items:center;padding:.5rem 1rem;
  border:1.5px solid var(--line-cool);border-radius:999px;font-size:.9rem;font-weight:600;
  color:var(--ink);cursor:pointer;background:#fff;
  transition:background .15s,border-color .15s,color .15s}
.chip-opt span:hover{border-color:var(--green)}
.chip-opt input:checked+span{background:var(--ink);border-color:var(--ink);color:#fff}
.chip-opt input:focus-visible+span{outline:2px solid var(--green);outline-offset:2px}
.consent{display:flex;gap:.6rem;align-items:flex-start;font-size:.85rem;color:var(--ink-2);margin:.4rem 0 1.3rem}
.consent input{margin-top:.25rem;accent-color:var(--green)}
.consent a{color:var(--green-ink)}
.form-note{font-size:.82rem;color:var(--green-ink);margin-top:1rem}

/* ---------- Contatti diretti (aside) ---------- */
.contact-line{display:flex;gap:.8rem;padding:.85rem 0;border-top:1px solid var(--line-cool);
  font-size:.94rem;color:var(--ink-2)}
.contact-line:first-of-type{border-top:0;padding-top:0}
.contact-line .ic{color:var(--green-ink);margin-top:.2rem}
.contact-line b{display:block;color:var(--ink);font-size:.8rem;font-weight:700;
  letter-spacing:.06em;text-transform:uppercase;margin-bottom:.1rem}
.mini-steps{list-style:none;margin:0;padding:0;counter-reset:ms}
.mini-steps li{counter-increment:ms;display:flex;gap:.75rem;padding:.5rem 0;
  font-size:.92rem;color:var(--ink-2);align-items:baseline}
.mini-steps li::before{content:counter(ms,decimal-leading-zero);font-family:var(--serif);
  color:var(--green);font-weight:600;font-size:.95rem;flex:none}

/* ---------- Footer ---------- */
.foot{background:var(--ink);color:#9db3a6;padding:clamp(2.8rem,5vw,3.6rem) 0 2rem;font-size:.9rem}
.foot-top{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:2rem;
  padding-bottom:2.2rem;border-bottom:1px solid #24453a}
.foot .brand{color:#fff;font-size:1.2rem;margin-bottom:.8rem;display:inline-block}
.foot .brand span{color:#8fc4a8!important}
.foot h4{font-family:var(--sans);font-size:.72rem;font-weight:700;letter-spacing:.14em;
  text-transform:uppercase;color:#6f8d7d;margin:0 0 .9rem}
.foot ul{list-style:none;margin:0;padding:0}
.foot li{margin-bottom:.5rem}
.foot a{color:#c6d6cc}
.foot a:hover{color:#fff}
.foot-contact{display:flex;flex-direction:column;gap:.5rem;margin-top:1.1rem}
.foot-contact a,.foot-contact span{display:inline-flex;gap:.55rem;align-items:center;color:#c6d6cc}
.foot-contact .ic{color:#6f8d7d}
.foot-legal{padding-top:1.6rem;font-size:.8rem;color:#6f8d7d;line-height:1.7}
.foot-legal p{margin:0 0 .4rem;max-width:78ch}

/* ---------- Utility ---------- */
.reveal{opacity:0;transform:translateY(14px);transition:opacity .6s ease,transform .6s ease}
.reveal.in{opacity:1;transform:none}

/* ---------- Responsive ---------- */
@media(max-width:1080px){
  .nav-tel span{display:none}
}
@media(max-width:860px){
  .nav a:not(.btn){display:none}
  .nav .btn{display:none}
  .nav.open a:not(.btn){display:flex;align-items:center;gap:.5rem}
  .nav-toggle{display:inline-flex}
  .nav{position:relative}
  .nav.open{position:absolute;top:74px;right:0;left:0;background:#fff;flex-direction:column;
    align-items:stretch;gap:0;padding:.5rem var(--gutter) 1.2rem;border-bottom:1px solid var(--line);
    box-shadow:0 12px 24px rgba(20,51,43,.08)}
  .nav.open a{padding:.75rem 0;border-top:1px solid var(--line)}
  .nav.open a[aria-current="page"]:not(.btn){box-shadow:none}
  .nav.open .nav-tel span{display:inline}
  .nav.open .btn{display:inline-flex;justify-content:center;margin:.9rem 0 0}
  .hero-grid{grid-template-columns:1fr;gap:3rem}
  .hero-media{max-width:440px}
  .tutele{grid-template-columns:1fr}
  .steps{grid-template-columns:1fr 1fr}
  .assure{grid-template-columns:1fr;gap:2.2rem}
  .who{max-width:320px}
  .cta-band .inner{grid-template-columns:1fr;gap:1.8rem}
  .layout{grid-template-columns:1fr}
  .aside-card{position:static}
  .aside-stack{position:static}
  .form-grid{grid-template-columns:1fr}
  .doc-grid{grid-template-columns:1fr 1fr}
  .foot-top{grid-template-columns:1fr 1fr}
  .topic-mark{display:none}
}
@media(max-width:640px){
  .timeline{grid-template-columns:1fr;gap:1.5rem}
  .timeline::before{top:7px;bottom:7px;left:6px;right:auto;width:2px;height:auto}
  .tl{padding:0 0 0 2.1rem}
  .tl::before{top:3px}
}
@media(max-width:480px){
  body{font-size:16px}
  .steps{grid-template-columns:1fr}
  .doc-grid{grid-template-columns:1fr}
  .foot-top{grid-template-columns:1fr}
  .assure-list li{grid-template-columns:1fr;gap:.15rem}
}
@media print{
  .reveal{opacity:1!important;transform:none!important}
}
@media(prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;transition:none}
  *{scroll-behavior:auto!important}
}
