/* ============================================================
   Jerkunica — design tokens + base + componenti
   Niente dipendenze esterne. Mobile-first. DOM pulito.
   ============================================================ */
:root{
  --ink:#0A0A0B;
  --ink-2:#3a3a3c;
  --ink-3:#6a6a6e;
  --bg:#ffffff;
  --bg-2:#FAFAF9;
  --line:rgba(0,0,0,.14);
  --line-2:rgba(0,0,0,.08);
  --curtain:#0A0A0B;
  --maxw:1180px;
  --pad:28px;
  --radius:12px;
  --font:-apple-system,BlinkMacSystemFont,"Inter","Segoe UI",Roboto,sans-serif;
  --drawer-w:300px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;overflow-x:clip;background:#000}
body{margin:0;font-family:var(--font);color:var(--ink);background:#000;line-height:1.6;-webkit-font-smoothing:antialiased}
img{max-width:100%;height:auto;display:block}
a{color:inherit}
h1,h2,h3{font-weight:600;letter-spacing:-.025em;line-height:1.08;margin:0}
/* <b>/<strong> nei titoli (editing legacy): niente extra-grassetto, ereditano il peso del titolo */
h1 b,h2 b,h3 b,h4 b,h5 b,h6 b,
h1 strong,h2 strong,h3 strong,h4 strong,h5 strong,h6 strong{font-weight:inherit}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 var(--pad)}
/* Nessuno scroll orizzontale dal contenuto (full-bleed, caroselli, embed, parole lunghe).
   Sta sotto l'header sticky, quindi non lo tocca. */
#main{overflow-x:clip}

/* ---------- Header (bloccato, gestito in PHP) ---------- */
.site-header{position:sticky;top:0;z-index:100;background:rgba(255,255,255,.82);
  backdrop-filter:saturate(180%) blur(14px);-webkit-backdrop-filter:saturate(180%) blur(14px);
  border-bottom:1px solid var(--line-2)}
.site-header .bar{display:flex;align-items:center;justify-content:space-between;gap:20px;height:64px}
.site-header .brand{font-size:19px;font-weight:600;letter-spacing:.04em;text-decoration:none;color:var(--ink)}
.site-nav{display:flex;align-items:center;gap:4px}
.site-nav a{font-size:14px;color:var(--ink-2);text-decoration:none;padding:8px 12px;border-radius:8px;transition:background .15s,color .15s}
.site-nav a:hover{color:var(--ink);background:var(--bg-2)}
.site-nav .cta{background:var(--ink);color:#fff;font-weight:500}
.site-nav .cta:hover{background:var(--ink);opacity:.88}
/* Hamburger: due linee, nero (niente blu di default iOS) */
.nav-toggle{display:none;flex-direction:column;justify-content:center;gap:6px;width:42px;height:38px;padding:0;background:none;border:0;cursor:pointer;-webkit-tap-highlight-color:transparent;-webkit-appearance:none;appearance:none}
.nav-toggle .bar{display:block;width:24px;height:2px;background:var(--ink);border-radius:2px;transition:transform .28s cubic-bezier(.4,0,.2,1)}
body.nav-open .nav-toggle .bar:first-child{transform:translateY(4px) rotate(45deg)}
body.nav-open .nav-toggle .bar:last-child{transform:translateY(-4px) rotate(-45deg)}

/* Drawer laterale che spinge il layout + overlay (mobile) */
.site-shell{background:var(--bg);min-height:100vh;transition:transform .32s cubic-bezier(.4,0,.2,1)}
.nav-drawer,.nav-overlay{display:none}
.nav-drawer{position:fixed;top:0;right:0;bottom:0;width:var(--drawer-w);max-width:84vw;background:#fff;border-left:1px solid var(--line-2);transform:translateX(100%);transition:transform .32s cubic-bezier(.4,0,.2,1);z-index:300;flex-direction:column;padding:80px 0 24px;overflow-y:auto;box-shadow:-24px 0 60px -30px rgba(0,0,0,.45)}
.nav-overlay{position:fixed;inset:0;background:rgba(10,10,11,.3);opacity:0;visibility:hidden;transition:opacity .32s,visibility .32s;z-index:250}
.nav-drawer a{display:block;padding:14px 26px;font-size:16px;color:var(--ink-2);text-decoration:none;transition:background .15s,color .15s}
.nav-drawer a:hover,.nav-drawer a:focus{background:var(--bg-2);color:var(--ink)}
.nav-drawer .cta{margin:16px 24px 0;text-align:center;background:var(--ink);color:#fff;border-radius:9px;padding:14px;font-weight:500}
@media(max-width:880px){
  .site-nav{display:none}
  .nav-toggle{display:flex}
  .nav-drawer,.nav-overlay{display:flex}
  body.nav-open .site-shell{transform:translateX(calc(-1 * var(--drawer-w)))}
  body.nav-open .nav-drawer{transform:translateX(0)}
  body.nav-open .nav-overlay{opacity:1;visibility:visible}
}

/* ---------- Hero ---------- */
.hero{background:var(--ink);color:#fff;padding:84px 0 72px}
@media(min-width:782px){.hero{padding:18vh 0 72px}}
/* Prefazione: fascia nera a tutta larghezza */
.prefazione{background:#000;color:#fff;padding:10vh 0}
.prefazione p{font-size:clamp(18px,2.1vw,22px);line-height:1.62;font-weight:300;color:#fff;max-width:64ch;margin:0 0 1em}
.prefazione p:last-child{margin-bottom:0}
.prefazione strong,.prefazione b{font-weight:600;color:#fff}
.prefazione a{color:#fff;text-decoration:underline;text-underline-offset:2px}
.prefazione h2,.prefazione h3{color:#fff;margin:0 0 .4em}
.prefazione small{font-size:13px;color:rgba(255,255,255,.6)}
.hero--image{position:relative;background-size:cover;background-position:center;background-repeat:no-repeat}
.hero-overlay{position:absolute;inset:0;z-index:0}
.hero--image > .wrap{position:relative;z-index:1}
body.has-transparent-header .hero--image{padding-top:30vh}
.hero .eyebrow{font-size:13px;color:rgba(255,255,255,.55);margin:0 0 22px;font-weight:400}
.hero h1{font-size:clamp(30px,5vw,56px);max-width:18ch;letter-spacing:-.03em;color:#fff}
.hero .sub{margin:22px 0 0;max-width:54ch;font-size:clamp(15px,2vw,18px);font-weight:300;color:rgba(255,255,255,.78)}
.hero .trust{display:flex;flex-wrap:wrap;margin:34px 0 0;border-top:1px solid rgba(255,255,255,.16);border-bottom:1px solid rgba(255,255,255,.16)}
.hero .trust .t{padding:18px 28px 18px 0;margin-right:28px;border-right:1px solid rgba(255,255,255,.16);font-size:13px;font-weight:300;color:rgba(255,255,255,.7)}
.hero .trust .t:last-child{border-right:0;margin-right:0}
.hero .trust .t b{display:block;color:#fff;font-size:15px;font-weight:500;margin-bottom:4px}
.hero .cta-row{display:flex;flex-wrap:wrap;gap:12px;margin:32px 0 0}
.btn{display:inline-block;padding:14px 26px;border-radius:10px;font-size:15px;font-weight:500;text-decoration:none;border:1px solid transparent;transition:opacity .15s,background .15s}
.btn-primary{background:#fff;color:var(--ink)}
.btn-primary:hover{opacity:.88}
.btn-ghost{background:transparent;color:#fff;border-color:rgba(255,255,255,.32)}
.btn-ghost:hover{background:rgba(255,255,255,.08)}
@media(max-width:560px){
  .hero{padding:56px 0 48px}
  .hero .trust .t{border-right:0;margin-right:0;padding:14px 0;width:100%;border-bottom:1px solid rgba(255,255,255,.12)}
  .hero .trust .t:last-child{border-bottom:0}
  .btn{flex:1;text-align:center}
}

/* ---------- Footer (bloccato) ---------- */
.site-footer{background:var(--bg-2);border-top:1px solid var(--line-2);padding:48px 0;font-size:13px;color:var(--ink-3)}
.site-footer a{color:var(--ink-2);text-decoration:none}
.site-footer a:hover{color:var(--ink)}
.site-footer .cols{display:flex;flex-wrap:wrap;gap:40px;justify-content:space-between}

/* ---------- Sezioni generiche ---------- */
.section{padding:64px 0}
.section > .wrap > h2{font-size:clamp(24px,3.4vw,38px);letter-spacing:-.025em;max-width:22ch}
.section .lead{max-width:64ch;color:var(--ink-2);font-weight:300;font-size:16px;margin:14px 0 0}

/* ---------- Doppia entrata ---------- */
.dual{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-top:30px}
.entry-card{border:1px solid var(--line);border-radius:var(--radius);padding:24px}
.entry-card.dark{background:var(--ink);border-color:var(--ink);color:#fff}
.entry-card .k{font-size:12px;color:var(--ink-3);font-weight:500;margin:0 0 6px}
.entry-card.dark .k{color:rgba(255,255,255,.7)}
.entry-card h3{font-size:20px;margin:0 0 16px}
.entry-card.dark h3{color:#fff}
.pills{display:flex;flex-wrap:wrap;gap:8px}
.pill{display:inline-block;padding:8px 14px;border:1px solid var(--line);border-radius:8px;font-size:13px;color:var(--ink-2);text-decoration:none;transition:background .15s,color .15s}
.pill:hover{background:var(--bg-2)}
.pill.hot{background:var(--ink);color:#fff;border-color:var(--ink);font-weight:500}
.entry-card.dark .pill{border-color:rgba(255,255,255,.28);color:rgba(255,255,255,.85)}
.entry-card.dark .pill.hot{background:#fff;color:var(--ink);border-color:#fff}
.entry-card.dark .pill:hover{background:rgba(255,255,255,.1)}
@media(max-width:760px){.dual{grid-template-columns:1fr}}

/* ---------- Tool "Quanto vale il mio danno" ---------- */
.tool{padding:64px 0;background:var(--bg-2)}
.tool .k{font-size:12px;color:var(--ink-3);font-weight:500;margin:0 0 6px}
.tool-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:28px;margin-top:28px;max-width:720px}
.tool-bar{display:flex;gap:10px;list-style:none;margin:0 0 24px;padding:0;font-size:12px;color:var(--ink-3)}
.tool-bar li{flex:1;padding:0 0 9px;border-bottom:2px solid var(--line-2);transition:border-color .2s,color .2s}
.tool-bar li.is-active{color:var(--ink);border-bottom-color:var(--ink)}
.tool-step .q{font-size:18px;font-weight:600;margin:0 0 16px;color:var(--ink);letter-spacing:-.01em}
.opts{display:flex;flex-wrap:wrap;gap:10px}
.opt{padding:12px 18px;border:1px solid var(--line);border-radius:10px;background:#fff;font-size:14px;color:var(--ink-2);cursor:pointer;font-family:inherit;transition:border-color .15s,background .15s,color .15s}
.opt:hover{border-color:var(--ink);color:var(--ink)}
.opt.is-selected{background:var(--ink);color:#fff;border-color:var(--ink)}
.tool-result .result-band{font-size:clamp(20px,3vw,24px);font-weight:600;letter-spacing:-.02em;margin:0 0 10px;color:var(--ink)}
.tool-result .result-note{font-size:15px;font-weight:300;color:var(--ink-2);margin:0 0 22px;max-width:60ch;line-height:1.55}
.tool .btn-primary{background:var(--ink);color:#fff}
.tool .btn-primary:hover{opacity:.9}
.tool-restart{background:none;border:0;color:var(--ink-3);font-size:13px;cursor:pointer;text-decoration:underline;font-family:inherit;padding:8px 0;margin-left:4px}
.tool-restart:hover{color:var(--ink)}
.tool-disclaimer{font-size:11.5px;color:var(--ink-3);font-weight:300;margin:18px 0 0;line-height:1.5;max-width:64ch}

/* ---------- Articolo (aspetto centrale) ---------- */
.article-head{padding:52px 0 30px;border-bottom:1px solid var(--line-2)}
.article-head .eyebrow{font-size:12px;font-weight:500;letter-spacing:.02em;color:var(--ink-3);margin:0 0 14px;text-decoration:none;display:inline-block}
.article-head .eyebrow:hover{color:var(--ink)}
.article-head h1{font-size:clamp(28px,4vw,44px);letter-spacing:-.03em;max-width:20ch;margin:0}
.article-head .meta{margin:18px 0 0;font-size:13px;color:var(--ink-3);font-weight:300}
.article-grid{display:grid;grid-template-columns:minmax(0,1fr) 300px;gap:52px;padding:44px 0 0}
.article--full .article-grid{grid-template-columns:1fr}
.article--full .article-body{max-width:none}
.article-body{font-size:17px;line-height:1.78;color:var(--ink-2);max-width:70ch;font-weight:400}
.article-body > *{margin:0}
.article-body h2{font-size:clamp(22px,2.6vw,30px);color:var(--ink);letter-spacing:-.02em;margin:.3em 0 .3em;line-height:1.15}
.article-body h3{font-size:20px;color:var(--ink);margin:1.5em 0 .4em}
.article-body a{color:var(--ink);text-decoration:underline;text-underline-offset:2px;text-decoration-thickness:1px}
.article-body ul,.article-body ol{padding-left:1.3em}
.article-body li{margin:.4em 0}
.article-body img{border-radius:10px;margin:1.6em 0}
.article-body blockquote{border-left:2px solid var(--ink);padding-left:20px;margin:1.6em 0;color:var(--ink);font-weight:300}
.article-aside{position:relative}
.aside-box{position:sticky;top:84px;background:var(--ink);color:#fff;border-radius:var(--radius);padding:24px}
.aside-box .k{font-size:12px;color:rgba(255,255,255,.6);font-weight:500;margin:0 0 8px}
.aside-box h3{font-size:19px;color:#fff;margin:0 0 12px;letter-spacing:-.01em}
.aside-box p{font-size:13px;font-weight:300;color:rgba(255,255,255,.75);margin:0 0 18px;line-height:1.5}
.aside-box .btn{display:block;text-align:center;background:#fff;color:var(--ink)}
.aside-box .btn:hover{opacity:.9}
@media(max-width:900px){
  .article-grid{grid-template-columns:1fr;gap:0}
  .aside-box{position:static;margin:0 0 32px}
}

/* ---------- Trust (metriche) ---------- */
.metrics{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-top:28px}
.metric{border:1px solid var(--line);border-radius:var(--radius);padding:22px}
.metric .k{font-size:12px;color:var(--ink-3);font-weight:500;margin:0 0 10px}
.metric .v{font-size:26px;font-weight:600;letter-spacing:-.02em;color:var(--ink);margin:0 0 6px;line-height:1}
.metric .d{font-size:13px;font-weight:300;color:var(--ink-3);margin:0}
@media(max-width:760px){.metrics{grid-template-columns:1fr 1fr}}

/* ---------- card generica testo ---------- */
.entry-card .card-text{font-size:14.5px;font-weight:300;color:var(--ink-2);line-height:1.6;margin:0}

/* ---------- Risorse (dinamiche) ---------- */
.res-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:28px}
.res-card{display:flex;flex-direction:column;gap:10px;border:1px solid var(--line);border-radius:var(--radius);padding:22px;text-decoration:none;transition:border-color .15s}
.res-card:hover{border-color:var(--ink)}
.res-cat{font-size:11.5px;font-weight:500;color:var(--ink-3)}
.res-title{font-size:16px;font-weight:600;color:var(--ink);letter-spacing:-.01em;line-height:1.28}
@media(max-width:760px){.res-grid{grid-template-columns:1fr}}

/* ---------- CTA finale ---------- */
.cta-finale{background:var(--ink);color:#fff;padding:72px 0}
.cta-finale h2{font-size:clamp(24px,3.4vw,38px);color:#fff;max-width:24ch;letter-spacing:-.025em}
.cta-finale .sub{margin:16px 0 0;font-size:16px;font-weight:300;color:rgba(255,255,255,.78);max-width:54ch}
.cta-finale .cta-row{display:flex;flex-wrap:wrap;gap:12px;margin-top:28px}

/* ---------- Archivi / listati ---------- */
.archive-head{padding:52px 0 30px;border-bottom:1px solid var(--line-2)}
.archive-head h1{font-size:clamp(28px,4vw,44px);letter-spacing:-.03em;max-width:24ch}
.archive-head .meta{margin:14px 0 0;font-size:13px;color:var(--ink-3);font-weight:300}
.archive-body{padding:40px 0 64px}
.post-list{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.post-card{display:flex;flex-direction:column;gap:9px;border:1px solid var(--line);border-radius:var(--radius);padding:22px;text-decoration:none;transition:border-color .15s}
.post-card:hover{border-color:var(--ink)}
.post-card-title{font-size:16px;font-weight:600;color:var(--ink);letter-spacing:-.01em;line-height:1.28}
.post-card-ex{font-size:13px;font-weight:300;color:var(--ink-2);line-height:1.5}
.post-card-date{font-size:11.5px;color:var(--ink-3);font-weight:300;margin-top:auto}
@media(max-width:760px){.post-list{grid-template-columns:1fr}}
.pagination{margin-top:36px}
.pagination .nav-links{display:flex;flex-wrap:wrap;gap:8px;align-items:center}
.pagination .page-numbers{display:inline-flex;min-width:38px;height:38px;align-items:center;justify-content:center;padding:0 12px;border:1px solid var(--line);border-radius:8px;text-decoration:none;color:var(--ink-2);font-size:14px}
.pagination .page-numbers.current{background:var(--ink);color:#fff;border-color:var(--ink)}
.pagination .page-numbers:hover{border-color:var(--ink);color:var(--ink)}
.pagination .page-numbers.current:hover{color:#fff}
/* Infinite load: nasconde la paginazione quando l'enhancement è attivo */
.post-feed.is-infinite .pagination{display:none}
.post-feed-sentinel{height:1px}
.post-feed-status{min-height:24px;display:flex;justify-content:center;align-items:center;color:var(--ink-3);font-size:22px;letter-spacing:.2em;margin-top:18px}
.post-feed-status.is-loading{animation:jerk-pulse 1.1s ease-in-out infinite}
@keyframes jerk-pulse{0%,100%{opacity:.3}50%{opacity:1}}
@media(prefers-reduced-motion:no-preference){
  .post-card.is-appending{animation:jerk-card-in .55s cubic-bezier(.2,.6,.2,1)}
}
@keyframes jerk-card-in{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:none}}

.res-ex{font-size:13px;line-height:1.45;color:var(--ink-2)}
/* Niente sottolineatura quando il blocco è dentro il contenuto (.article-body a). */
.risorse-sec .res-card,.risorse-sec .res-all{text-decoration:none}

/* Banda colorata a tutta larghezza (opzionale). */
.risorse-sec--bg{margin-left:calc(50% - 50vw);margin-right:calc(50% - 50vw)}

/* ---------- Risorse: carosello (1 o 2 righe) ---------- */
/* padding verticale: lascia spazio al lift/ombra dell'hover, altrimenti l'overflow-x lo taglia. */
.res-grid.res-track{display:grid;grid-auto-flow:column;grid-template-rows:1fr;grid-auto-columns:calc((100% - 28px) / 3);grid-template-columns:none;overflow-x:auto;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;scrollbar-width:thin;margin-top:22px;padding:6px 1px 16px}
.res-grid.res-track--rows2{grid-template-rows:1fr 1fr}
.res-grid.res-track .res-card{scroll-snap-align:start}
.res-grid.res-track::-webkit-scrollbar{height:6px}
.res-grid.res-track::-webkit-scrollbar-thumb{background:var(--line-2,#e3e3e3);border-radius:4px}
@media(max-width:760px){.res-grid.res-track{grid-auto-columns:82%}}

/* ---------- Risorse: footer (frecce + link "vedi tutti") ---------- */
.res-foot{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-top:22px}
.res-foot--invert{flex-direction:row-reverse}
.res-nav{display:inline-flex;gap:8px;flex:0 0 auto}
.res-arrow{width:40px;height:40px;display:inline-flex;align-items:center;justify-content:center;border:1px solid var(--line);border-radius:50%;background:#fff;color:var(--ink);cursor:pointer;padding:0;transition:border-color .15s,opacity .15s}
.res-arrow:hover{border-color:var(--ink)}
.res-arrow:disabled{opacity:.32;cursor:default}
.res-all{font-size:14px;font-weight:500;color:var(--ink);text-decoration:none;transition:opacity .15s}
.res-all:hover{opacity:.6}

/* ---------- Rifiniture small-screen ---------- */
@media(max-width:560px){
  .metrics{grid-template-columns:1fr 1fr;gap:10px}
  .archive-head{padding:36px 0 22px}
  .article-head{padding:36px 0 22px}
  .section{padding:48px 0}
}

/* ============ Più carattere: micro-interazioni + reveal ============ */
.btn{transition:transform .16s ease,opacity .15s,background .15s}
.btn:hover{transform:translateY(-1px)}
.btn:active{transform:translateY(0)}
.entry-card,.res-card,.post-card,.metric{transition:border-color .15s,transform .18s ease,box-shadow .22s ease}
.res-card:hover,.post-card:hover{transform:translateY(-3px);box-shadow:0 14px 34px -20px rgba(0,0,0,.28)}
.metric:hover{transform:translateY(-2px)}
.pill{transition:background .15s,color .15s,border-color .15s,transform .15s}
.pill:hover{transform:translateY(-1px)}
.opt{transition:border-color .15s,background .15s,color .15s,transform .12s}
.opt:active{transform:scale(.98)}

/* Accento sull'eyebrow dell'hero */
.hero .eyebrow{display:inline-flex;align-items:center;gap:9px}
.hero .eyebrow::before{content:"";width:6px;height:6px;border-radius:50%;background:#fff;opacity:.55}

/* Reveal allo scroll (solo se l'utente non ha ridotto le animazioni) */
@media(prefers-reduced-motion:no-preference){
  .reveal-ready main>section:not(:first-child),.reveal-ready main>article:not(:first-child){opacity:0;transform:translateY(20px)}
  .reveal-ready main>section.in,.reveal-ready main>article.in{opacity:1;transform:none;transition:opacity .7s cubic-bezier(.2,.6,.2,1),transform .7s cubic-bezier(.2,.6,.2,1)}
}

/* Menu: lista orizzontale (desktop) / verticale (drawer), senza bullet */
.site-nav .menu{display:flex;align-items:center;gap:4px;margin:0;padding:0;list-style:none}
.site-nav .menu li{list-style:none;margin:0}
.site-nav a{white-space:nowrap}
.nav-drawer .menu{list-style:none;margin:0;padding:0}
.nav-drawer .menu li{list-style:none;margin:0}

/* Logo */
.brand{display:inline-flex;align-items:center}
.brand-logo{height:26px;width:auto;display:block;color:#33302d}
.logo-mobile{display:none}
@media(max-width:880px){
  .brand:has(.logo-mobile) .logo-desktop{display:none}
  .brand .logo-mobile{display:block}
}
@media(max-width:560px){.brand-logo{height:22px}}
.footer-logo-wrap{flex-basis:100%}
.footer-logo{height:32px;width:auto;display:block;color:#33302d}

/* ---------- Hero con immagine (pagine interne) ---------- */
.page-hero{position:relative;background-size:cover;background-position:center;color:#fff;padding:96px 0 64px}
.page-hero-overlay{position:absolute;inset:0;z-index:0}
.page-hero .wrap{position:relative;z-index:1}
.page-hero .eyebrow{color:rgba(255,255,255,.75);margin:0 0 14px}
.page-hero h1{color:#fff;font-size:clamp(28px,4vw,46px);letter-spacing:-.03em;max-width:20ch;margin:0}
body.has-transparent-header .page-hero{padding-top:30vh}
/* Header trasparente senza immagine: spazio per non coprire il titolo */
body.has-transparent-header .article-head,
body.has-transparent-header .archive-head{padding-top:120px}

/* ---------- Header trasparente (overlay) ---------- */
body.has-transparent-header .site-header{position:fixed;top:0;left:0;right:0;background:transparent;border-bottom-color:transparent;-webkit-backdrop-filter:none;backdrop-filter:none}
body.has-transparent-header .brand-logo{color:#fff}
body.has-transparent-header .site-nav a{color:rgba(255,255,255,.9)}
body.has-transparent-header .site-nav a:hover{color:#fff;background:rgba(255,255,255,.14)}
body.has-transparent-header .site-nav .cta{background:#fff;color:var(--ink)}
body.has-transparent-header .nav-toggle .bar{background:#fff}
/* Solidifica allo scroll */
body.has-transparent-header.is-scrolled .site-header{background:rgba(255,255,255,.9);-webkit-backdrop-filter:saturate(180%) blur(14px);backdrop-filter:saturate(180%) blur(14px);border-bottom-color:var(--line-2)}
body.has-transparent-header.is-scrolled .brand-logo{color:#33302d}
body.has-transparent-header.is-scrolled .site-nav a{color:var(--ink-2)}
body.has-transparent-header.is-scrolled .site-nav a:hover{color:var(--ink);background:var(--bg-2)}
body.has-transparent-header.is-scrolled .site-nav .cta{background:var(--ink);color:#fff}
body.has-transparent-header.is-scrolled .nav-toggle .bar{background:var(--ink)}
/* Header trasparente su sfondo CHIARO: logo/menu scuri (auto o forzato) */
body.has-transparent-header.th-dark .brand-logo{color:#33302d}
body.has-transparent-header.th-dark .site-nav a{color:var(--ink-2)}
body.has-transparent-header.th-dark .site-nav a:hover{color:var(--ink);background:rgba(0,0,0,.06)}
body.has-transparent-header.th-dark .site-nav .cta{background:var(--ink);color:#fff}
body.has-transparent-header.th-dark .nav-toggle .bar{background:var(--ink)}
/* Logo caricato come <img> (SVG/PNG): non eredita currentColor → ricoloro con filtri */
body.has-transparent-header img.brand-logo{filter:brightness(0) invert(1)}
body.has-transparent-header.th-dark img.brand-logo,
body.has-transparent-header.is-scrolled img.brand-logo{filter:none}

/* ---------- Widget "Servizio urgenze" ---------- */
.help-widget{position:fixed;right:22px;bottom:22px;z-index:400;font-family:var(--font)}
.help-launcher{display:inline-flex;align-items:center;gap:10px;background:var(--ink);color:#fff;border:0;border-radius:999px;padding:13px 20px;font-size:14px;font-weight:500;cursor:pointer;font-family:inherit;box-shadow:0 16px 40px -12px rgba(0,0,0,.5);transition:transform .15s,opacity .15s}
.help-launcher:hover{transform:translateY(-2px)}
.help-launcher-ic{display:inline-flex;align-items:center}
.help-panel{position:absolute;right:0;bottom:64px;width:360px;max-width:calc(100vw - 32px);background:#fff;border:1px solid var(--line-2);border-radius:16px;overflow:hidden;box-shadow:0 30px 70px -22px rgba(0,0,0,.5);transform-origin:bottom right}
/* Reveal a "maschera": tenda dall'angolo in basso a destra (launcher) verso l'alto a sinistra. */
@media(prefers-reduced-motion:no-preference){
  .help-panel{clip-path:circle(0% at 100% 108%);opacity:0;transform:translateY(6px);transition:clip-path .6s cubic-bezier(.22,.7,.2,1),opacity .4s ease,transform .6s cubic-bezier(.22,.7,.2,1);will-change:clip-path,opacity,transform}
  .help-widget.is-open .help-panel{clip-path:circle(220% at 100% 108%);opacity:1;transform:none}
}
.help-head{display:flex;align-items:center;justify-content:space-between;gap:12px;background:#fff;color:var(--ink);padding:14px 20px;border-bottom:.5px solid #EAEAEA}
.help-kicker{margin:0;font-size:11.5px;font-weight:600;color:var(--ink);display:inline-flex;align-items:center;gap:8px}
.help-kicker::before{content:"";width:8px;height:8px;border-radius:50%;background:#19b15a;box-shadow:0 0 0 0 rgba(25,177,90,.5);animation:jerk-blink 1.3s ease-in-out infinite}
@keyframes jerk-blink{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.8)}}
@media(prefers-reduced-motion:reduce){.help-kicker::before{animation:none}}
.help-title{margin:0;padding:16px 20px 0;font-size:18px;font-weight:600;letter-spacing:-.01em;color:var(--ink)}
.help-close{background:none;border:0;color:var(--ink-3);font-size:24px;line-height:1;cursor:pointer;padding:0}
.help-close:hover{color:var(--ink)}
.help-intro{margin:0;padding:0 20px 4px;font-size:13.5px;line-height:1.5;color:var(--ink-2);background:#fff}
.help-body{padding:14px 18px 18px;max-height:min(70vh,560px);overflow-y:auto}
.tool-reassure{margin:0 0 18px;padding:2px 0 16px;border-bottom:.5px solid #EAEAEA;font-size:12.5px;color:var(--ink-3);font-weight:500}
.tool-back{background:none;border:0;color:var(--ink-3);font-size:13px;cursor:pointer;font-family:inherit;padding:10px 0 0;text-decoration:underline;text-underline-offset:2px}
.tool-back:hover{color:var(--ink)}
.tool-result-foot{display:flex;gap:18px;align-items:center;margin-top:14px}
.tool-result-foot .tool-back{padding:0}
/* Dallo step 2: nascondi titolo, intro e reassure (restano solo nel primo step) */
.help-widget.flow-started .help-title,
.help-widget.flow-started .help-intro,
.help-widget.flow-started .tool-reassure{display:none}
/* Form lead nel risultato */
.urg-form{display:flex;flex-direction:column;gap:10px;margin-top:8px}
.urg-row{display:flex;gap:10px}
.urg-row input{flex:1;min-width:0}
.urg-form input,.urg-form textarea{width:100%;padding:11px 13px;border:1px solid var(--line);border-radius:9px;font-family:inherit;font-size:14px;background:#fff;color:var(--ink)}
.urg-form input:focus,.urg-form textarea:focus{outline:none;border-color:var(--ink)}
.urg-form textarea{resize:vertical;min-height:52px}
.urg-submit{margin-top:4px;width:100%;text-align:center;background:var(--ink);color:#fff;border:0;cursor:pointer}
.urg-submit:hover{opacity:.92}
.urg-msg{font-size:12.5px;margin:2px 0 0;color:var(--ink-3);min-height:1em}
.urg-msg.is-error{color:#a32d2d}
.urg-ok{font-size:15px;font-weight:500;color:var(--ink);margin:0;padding:10px 0}

/* ---------- Card (stile Apple) ---------- */
.jcard{position:relative;border-radius:22px;overflow:hidden;background:var(--bg-2);border:1px solid var(--line)}
.jcard-body{padding:32px}
.jcard-icon{width:48px;height:48px;object-fit:contain;display:block;margin:0 0 16px}
.jcard-eyebrow{font-size:12px;font-weight:500;color:var(--ink-3);margin:0 0 8px}
.jcard-title{margin:0 0 10px;letter-spacing:-.02em}
.jcard-text{margin:0 0 20px;color:var(--ink-2);font-weight:300;line-height:1.6}
.jcard-text:last-child{margin-bottom:0}
.jcard-media img{display:block;width:100%;height:auto}
.jcard-btn{display:inline-block}
.jcard-btn--dark{background:var(--ink);color:#fff}
.jcard-btn--dark:hover{opacity:.9}
.jcard-btn--light{background:#fff;color:var(--ink);border:1px solid var(--line)}
.jcard-btn--light:hover{background:var(--bg-2)}
/* immagine sotto */
.jcard--below .jcard-media{margin-top:8px}
/* immagine a destra */
.jcard--right{display:grid;grid-template-columns:1fr 1fr;align-items:stretch}
.jcard--right .jcard-body{align-self:center}
.jcard--right .jcard-media{height:100%}
.jcard--right .jcard-media img{height:100%;object-fit:cover}
@media(max-width:680px){.jcard--right{grid-template-columns:1fr}}
/* immagine di sfondo */
.jcard--bg{min-height:400px;background-size:cover;background-position:center;display:flex;align-items:flex-end;color:#fff}
.jcard--bg .jcard-overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(10,10,11,0) 35%,rgba(10,10,11,.78))}
.jcard--bg .jcard-body{position:relative;z-index:1;padding:36px}
.jcard--bg .jcard-eyebrow{color:rgba(255,255,255,.7)}
.jcard--bg .jcard-title{color:#fff}
.jcard--bg .jcard-text{color:rgba(255,255,255,.85)}
.help-body .tool-card{border:0;padding:0;margin:0;max-width:none;background:transparent}
.help-body .tool-bar{margin:0 0 16px}
.help-body .tool-step .q{font-size:15px;margin:0 0 12px}
.help-body .opts{gap:8px}
.help-body .opt{padding:9px 13px;font-size:13px}
.help-body .result-band{font-size:19px}
.help-body .result-note{font-size:13.5px}
.help-body .tool-disclaimer{margin-top:14px}
@media(max-width:560px){
  .help-widget{right:14px;bottom:14px}
  .help-launcher-label{display:none}
  .help-launcher{padding:14px;border-radius:50%}
  .help-panel{bottom:70px}
}

/* ---------- Editor: rendi selezionabili i blocchi ServerSideRender ----------
   L'anteprima dinamica contiene link/bottoni che intercettano il click e
   impediscono di selezionare il blocco. Nell'editor la rendiamo non
   interattiva: il click seleziona il blocco, i controlli restano nel pannello. */
.block-editor-server-side-render{pointer-events:none}
.block-editor-server-side-render a,
.block-editor-server-side-render button{cursor:default}

/* ---------- Transizioni di pagina (PJAX): tendina a tutto schermo ---------- */
/* Solo transform (compositore) → fluida anche su mobile. Copre tutto, header incluso. */
.pjax-curtain{position:fixed;inset:0;z-index:9990;background:var(--curtain);pointer-events:none;transform:translateY(100%);will-change:transform}
@media(prefers-reduced-motion:no-preference){
  .pjax-curtain.is-in{transform:translateY(0);transition:transform .48s cubic-bezier(.7,0,.3,1)}
  .pjax-curtain.is-out{transform:translateY(-100%);transition:transform .48s cubic-bezier(.7,0,.3,1)}
}
html.pjax-animating{overflow:hidden}
.pjax-bar{position:fixed;top:0;left:0;height:2px;width:0;background:var(--ink);z-index:9999;opacity:0;transition:width .35s cubic-bezier(.2,.6,.2,1),opacity .25s ease;pointer-events:none}
.pjax-bar.is-active{opacity:1}
body.pjax-loading{cursor:progress}
body.has-transparent-header .pjax-bar{background:#fff;mix-blend-mode:difference}
@media(prefers-reduced-motion:reduce){.pjax-bar{display:none}}

/* ---------- Sezione / Riga (blocco container full-bleed) ---------- */
.jrow{position:relative;margin-left:calc(50% - 50vw);margin-right:calc(50% - 50vw);background-size:cover;background-position:center;background-repeat:no-repeat}
.jrow-overlay{position:absolute;inset:0;z-index:0}
.jrow-inner{position:relative;z-index:1}
.jrow--w-boxed .jrow-inner{max-width:var(--maxw);margin:0 auto;padding-left:var(--pad);padding-right:var(--pad)}
.jrow--w-full .jrow-inner{padding-left:var(--pad);padding-right:var(--pad)}
.jrow--pad-none .jrow-inner{padding-top:0;padding-bottom:0}
.jrow--pad-s .jrow-inner{padding-top:48px;padding-bottom:48px}
.jrow--pad-m .jrow-inner{padding-top:80px;padding-bottom:80px}
.jrow--pad-l .jrow-inner{padding-top:120px;padding-bottom:120px}
/* schema testo */
.jrow--dark{color:var(--ink)}
.jrow--light{color:#fff}
.jrow--light h1,.jrow--light h2,.jrow--light h3,.jrow--light h4,.jrow--light h5,.jrow--light h6,
.jrow--light p,.jrow--light li,.jrow--light blockquote,.jrow--light figcaption{color:#fff}
.jrow--light a{color:#fff}
/* bottoni: default coerenti con lo schema, sovrascrivibili (specificità 0 con :where) */
.jrow--dark :where(.wp-block-button__link,.btn,.jcard-btn){background:var(--ink);color:#fff}
.jrow--light :where(.wp-block-button__link,.btn,.jcard-btn){background:#fff;color:var(--ink)}
@media(max-width:760px){
  .jrow--pad-l .jrow-inner{padding-top:72px;padding-bottom:72px}
  .jrow--pad-m .jrow-inner{padding-top:56px;padding-bottom:56px}
  .jrow--pad-s .jrow-inner{padding-top:36px;padding-bottom:36px}
}

/* ============================================================
   Dark mode — attivata da html.jerk-dark (toggle + pianificazione)
   ============================================================ */
html.jerk-dark{
  --ink:#ededf0;
  --ink-2:#b6b6bd;
  --ink-3:#8a8a92;
  --bg:#0e0e11;
  --bg-2:#17171c;
  --line:rgba(255,255,255,.16);
  --line-2:rgba(255,255,255,.09);
  --curtain:#000;
}
/* Superfici chiare -> scure */
html.jerk-dark body:not(.has-transparent-header) .site-header{background-color:rgba(16,16,20,.82)}
html.jerk-dark body.has-transparent-header.is-scrolled .site-header{background-color:rgba(16,16,20,.9)}
html.jerk-dark .nav-drawer,
html.jerk-dark .tool-card,
html.jerk-dark .opt,
html.jerk-dark .res-arrow,
html.jerk-dark .help-panel,
html.jerk-dark .help-head,
html.jerk-dark .help-intro,
html.jerk-dark .urg-form input,
html.jerk-dark .urg-form textarea{background-color:var(--bg-2)}
html.jerk-dark .help-head,
html.jerk-dark .tool-reassure{border-bottom-color:var(--line-2)}
/* Superfici scure "per natura": ribadisci lo sfondo scuro (var(--ink) ora è chiaro) */
html.jerk-dark .hero,
html.jerk-dark .cta-finale,
html.jerk-dark .aside-box,
html.jerk-dark .entry-card.dark{background-color:#0b0b0d}
html.jerk-dark .entry-card.dark{border-color:var(--line-2)}
/* Bottoni/elementi già neri: restano scuri (NON invertiti), testo bianco. */
html.jerk-dark .site-nav .cta,
html.jerk-dark .nav-drawer .cta,
html.jerk-dark .help-launcher,
html.jerk-dark .urg-submit,
html.jerk-dark .jcard-btn--dark,
html.jerk-dark .opt.is-selected,
html.jerk-dark .pill.hot,
html.jerk-dark .tool .btn-primary,
html.jerk-dark .pagination .page-numbers.current,
html.jerk-dark .jrow--dark :where(.wp-block-button__link,.btn,.jcard-btn){background-color:#23232b;color:#fff;border-color:#23232b}
html.jerk-dark .site-nav .cta:hover{background-color:#2c2c35;opacity:1}
/* Bottoni a fondo bianco: mantieni bianco, testo scuro */
html.jerk-dark .btn-primary,
html.jerk-dark .aside-box .btn,
html.jerk-dark .jcard-btn--light,
html.jerk-dark .entry-card.dark .pill.hot,
html.jerk-dark .jrow--light :where(.wp-block-button__link,.btn,.jcard-btn){color:#0e0e11}
/* Logo: bianco in dark mode */
html.jerk-dark img.brand-logo{filter:brightness(0) invert(1)!important}

/* Toggle tema (icone outline minimali) */
.bar-actions{display:flex;align-items:center;gap:6px}
.theme-toggle{display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;border:0;background:none;color:var(--ink);cursor:pointer;border-radius:8px;padding:0;transition:background .15s,color .15s}
.theme-toggle:hover{background:var(--bg-2)}
.theme-toggle svg{width:19px;height:19px;display:block;fill:none;stroke:currentColor;stroke-width:1.6;stroke-linecap:round;stroke-linejoin:round}
.theme-toggle .icon-sun{display:none}
html.jerk-dark .theme-toggle .icon-moon{display:none}
html.jerk-dark .theme-toggle .icon-sun{display:block}
body.has-transparent-header .theme-toggle{color:#fff}
body.has-transparent-header.is-scrolled .theme-toggle,
body.has-transparent-header.th-dark .theme-toggle{color:var(--ink)}
