/* ============================================================
   tuttuu — base.css : sistema condiviso pagine contenuto
   (Chi siamo, Blog, articoli). Stesso marchio della home.
   ============================================================ */
:root{
  --ink:#14110F; --ink-2:#1d1a17; --paper:#F2EFEA; --paper-2:#e9e4dc; --white:#fff;
  --muted:#6B655F; --line:rgba(20,17,15,.12); --line-d:rgba(255,255,255,.16);
  --red:#E30A2D;
  --grad:linear-gradient(100deg,#E30A2D 0%,#FF2E48 42%,#FF7A3D 100%);
  --line-grad:linear-gradient(90deg,#E30A2D 0%,#FF2E48 35%,#FF7A3D 70%,#FFB03A 100%);
  --r:999px; --maxw:1180px; --measure:68ch;
  --ease:cubic-bezier(.16,1,.3,1);
}
*{box-sizing:border-box;margin:0;padding:0}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth;scroll-padding-top:132px}
body{font-family:"Inter Tight",system-ui,sans-serif;background:var(--paper);color:var(--ink);line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 clamp(20px,4vw,48px);width:100%}
.mono{font-family:"JetBrains Mono",monospace;text-transform:uppercase;letter-spacing:.2em;font-size:12px;font-weight:500}
.grad-text{background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.lbl{color:var(--red)}
.skip{position:absolute;left:-999px}.skip:focus{left:12px;top:12px;z-index:200;background:#fff;padding:10px 16px;border-radius:8px}

/* buttons */
.btn{display:inline-flex;align-items:center;gap:.6em;font-weight:600;font-size:16px;padding:14px 28px;border-radius:var(--r);transition:transform .4s var(--ease),box-shadow .4s var(--ease),background .4s,color .4s;cursor:pointer;border:0}
.btn .arr{transition:transform .4s var(--ease)}.btn:hover .arr{transform:translateX(5px)}
.btn-grad{background:var(--grad);color:#fff;box-shadow:0 10px 30px -10px rgba(227,10,45,.6)}
.btn-grad:hover{transform:translateY(-2px);box-shadow:0 16px 40px -10px rgba(227,10,45,.75)}
.btn-ghost{border:1.5px solid var(--ink);color:var(--ink)}
.btn-ghost:hover{background:var(--ink);color:var(--paper)}
.btn-ghost-d{border:1.5px solid rgba(255,255,255,.4);color:#fff}
.btn-ghost-d:hover{background:#fff;color:var(--ink)}

/* header (pagine contenuto: barra solida chiara) */
.site-head{position:sticky;top:0;z-index:60;background:rgba(242,239,234,.85);backdrop-filter:blur(14px);border-bottom:1px solid var(--line)}
.site-nav{display:flex;align-items:center;justify-content:space-between;height:72px}
.logo{font-weight:800;font-size:23px;letter-spacing:-.04em;color:var(--ink)}
.logo b{color:var(--red)}
.nav-links{display:flex;gap:30px;align-items:center}
.nav-links a{font-size:15px;font-weight:500;color:var(--ink);position:relative}
.nav-links a[aria-current="page"]{color:var(--red)}
.nav-links a:not(.btn)::after{content:"";position:absolute;left:0;bottom:-5px;width:0;height:2px;background:var(--line-grad);transition:width .3s var(--ease)}
.nav-links a:not(.btn):hover::after{width:100%}
.nav-cta{padding:10px 20px;font-size:14px;color:#fff}
.burger{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:8px}
.burger span{width:24px;height:2px;background:var(--ink);transition:.3s}

/* page hero band */
.phead{background:var(--ink);color:#fff;position:relative;overflow:hidden;padding:clamp(96px,14vh,150px) 0 clamp(56px,8vh,90px)}
.phead::before{content:"";position:absolute;inset:0;background:
   radial-gradient(45% 60% at 12% 20%,rgba(227,10,45,.4),transparent 62%),
   radial-gradient(45% 70% at 90% 90%,rgba(255,122,61,.32),transparent 60%);z-index:0}
.phead::after{content:"";position:absolute;right:-7%;top:50%;transform:translateY(-50%);width:min(48vw,560px);height:min(48vw,560px);border-radius:50%;z-index:0;pointer-events:none;background:radial-gradient(circle at 42% 40%,rgba(255,122,61,.2),rgba(227,10,45,.11) 48%,transparent 72%)}
@media(max-width:760px){.phead::after{display:none}}
.phead .wrap{position:relative;z-index:1}
.crumb{color:rgba(255,255,255,.6);font-size:13px;margin-bottom:20px;display:flex;gap:8px;align-items:center}
.crumb a:hover{color:#fff}.crumb span{opacity:.5}
.phead h1{font-weight:800;letter-spacing:-.035em;line-height:1;font-size:clamp(40px,7vw,92px);margin:14px 0 0}
.phead .lede{margin-top:22px;max-width:60ch;font-size:clamp(17px,2vw,21px);color:rgba(255,255,255,.82)}

/* generic section */
.sec{padding:clamp(64px,9vw,120px) 0}
.sec--paper2{background:var(--paper-2)}
.sec-head{margin-bottom:clamp(34px,5vw,56px)}
.sec-head h2{font-weight:800;letter-spacing:-.03em;line-height:1.04;font-size:clamp(28px,4.4vw,52px);max-width:20ch;margin-top:12px}
.sec-head p{color:var(--muted);max-width:52ch;margin-top:14px;font-size:17px}

/* answer-first AEO block */
.tldr{background:#fff;border:1px solid var(--line);border-left:4px solid var(--red);border-radius:14px;padding:22px 26px;margin:0 0 34px;max-width:var(--measure)}
.tldr .k{color:var(--red);font-weight:700;display:block;margin-bottom:6px}
.tldr p{font-size:17px;color:var(--ink)}

/* prose (articoli) */
.prose{max-width:var(--measure);font-size:18px;color:#2b2723}
.prose>*+*{margin-top:1.15em}
.prose h2{font-size:clamp(24px,3.2vw,34px);font-weight:800;letter-spacing:-.02em;margin-top:1.8em;line-height:1.15}
.prose h3{font-size:21px;font-weight:700;margin-top:1.5em}
.prose p,.prose li{line-height:1.7}
.prose ul,.prose ol{padding-left:1.3em}.prose li+li{margin-top:.4em}
.prose a{color:var(--red);text-decoration:underline;text-underline-offset:3px}
.prose strong{font-weight:700}
.prose blockquote{border-left:3px solid var(--red);padding-left:18px;color:var(--muted);font-style:italic}

/* FAQ (AEO) */
.faq{max-width:var(--measure)}
.faq details{border-bottom:1px solid var(--line);padding:18px 0}
.faq summary{font-weight:700;font-size:18px;cursor:pointer;list-style:none;display:flex;justify-content:space-between;gap:16px;align-items:center}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";color:var(--red);font-weight:700;font-size:24px;transition:transform .3s}
.faq details[open] summary::after{transform:rotate(45deg)}
.faq details p{margin-top:12px;color:var(--muted);font-size:16.5px;line-height:1.7}

/* founder cards */
.people{display:grid;grid-template-columns:repeat(2,1fr);gap:22px}
.person{background:#fff;border:1px solid var(--line);border-radius:20px;padding:30px;transition:transform .4s var(--ease),box-shadow .4s var(--ease)}
.person:hover{transform:translateY(-4px);box-shadow:0 24px 50px -26px rgba(20,17,15,.4)}
.person .ava{width:64px;height:64px;border-radius:50%;background:var(--grad);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:22px;letter-spacing:-.02em;margin-bottom:20px}
.person h3{font-size:23px;font-weight:800;letter-spacing:-.02em}
.person .role{color:var(--red);font-weight:600;font-size:14px;margin:4px 0 14px}
.person p{color:var(--muted);font-size:16px;line-height:1.65}

/* value pills / principi */
.principi{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.principio{padding-top:22px;border-top:2px solid var(--ink)}
.principio .n{font-family:"JetBrains Mono",monospace;font-size:13px;color:var(--red)}
.principio h3{font-size:21px;font-weight:700;margin:10px 0 8px;letter-spacing:-.01em}
.principio p{color:var(--muted);font-size:15.5px}

/* CTA band */
.cta-band{position:relative;background:var(--ink);color:#fff;overflow:hidden;text-align:center}
.cta-band::before{content:"";position:absolute;inset:0;background:
   radial-gradient(45% 70% at 18% 45%,rgba(227,10,45,.55),transparent 60%),
   radial-gradient(45% 80% at 85% 60%,rgba(255,122,61,.45),transparent 60%)}
.cta-band .wrap{position:relative;z-index:1;padding:clamp(64px,9vw,110px) 0}
.cta-band h2{font-weight:800;letter-spacing:-.03em;line-height:1.02;font-size:clamp(32px,5.5vw,72px);margin-bottom:22px}
.cta-band p{color:rgba(255,255,255,.78);font-size:18px;max-width:46ch;margin:0 auto 32px}

/* footer (uguale alla home) */
.site-foot{background:#0c0a09;color:#fff;padding:70px 0 36px;border-top:1px solid var(--line-d)}
.foot-top{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:40px;padding-bottom:48px;border-bottom:1px solid var(--line-d)}
.foot-brand .logo{color:#fff;font-size:28px;display:inline-block;margin-bottom:14px}
.foot-brand p{color:rgba(255,255,255,.6);max-width:30ch}
.foot-col h4{font-family:"JetBrains Mono",monospace;text-transform:uppercase;letter-spacing:.16em;font-size:11px;color:rgba(255,255,255,.5);margin-bottom:16px}
.foot-col a{display:block;color:rgba(255,255,255,.82);margin-bottom:10px;font-size:15px;width:fit-content;transition:color .3s}
.foot-col a:hover{color:#fff}
.foot-bot{display:flex;justify-content:space-between;align-items:center;padding-top:24px;color:rgba(255,255,255,.45);font-family:"JetBrains Mono",monospace;font-size:12px;flex-wrap:wrap;gap:10px}

/* reveal on scroll */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
.reveal.in{opacity:1;transform:none}
[data-d="1"]{transition-delay:.08s}[data-d="2"]{transition-delay:.16s}[data-d="3"]{transition-delay:.24s}

/* ---- article enhancements ---- */
.art-meta{display:flex;flex-wrap:wrap;gap:14px;align-items:center;margin-top:20px;color:rgba(255,255,255,.72);font-family:"JetBrains Mono",monospace;font-size:12px;letter-spacing:.06em;text-transform:uppercase}
.art-meta i{width:4px;height:4px;border-radius:50%;background:rgba(255,255,255,.4);font-style:normal;display:inline-block}
.prose{font-size:18.5px;line-height:1.78;color:#2b2723}
.prose>p:first-of-type{font-size:22px;line-height:1.5;color:#1a1714;font-weight:500}
.prose h2{position:relative;padding-top:20px}
.prose h2::before{content:"";position:absolute;left:0;top:0;width:46px;height:4px;border-radius:4px;background:var(--line-grad)}
.prose blockquote{font-size:24px;line-height:1.35;font-weight:600;font-style:normal;color:var(--ink);border:0;border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:24px 0;margin:1.6em 0}
.prose ul li::marker{color:var(--red)}
.prose img{border-radius:16px;margin:1.4em 0}

/* ---- lead form + post-cta (sotto articoli/servizi) ---- */
.post-cta{position:relative;background:var(--ink);color:#fff;overflow:hidden}
.post-cta::before{content:"";position:absolute;inset:0;background:radial-gradient(40% 80% at 12% 30%,rgba(227,10,45,.42),transparent 60%),radial-gradient(40% 80% at 90% 80%,rgba(255,122,61,.34),transparent 60%)}
.post-cta .wrap{position:relative;z-index:1;padding:clamp(56px,8vw,96px) 0}
.post-cta-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(30px,5vw,64px);align-items:center}
.post-cta-copy h2{font-weight:800;letter-spacing:-.03em;line-height:1.04;font-size:clamp(28px,3.8vw,46px);margin:10px 0 16px}
.post-cta-copy p{color:rgba(255,255,255,.78);font-size:17px;max-width:42ch}
.post-cta-list{list-style:none;display:flex;flex-wrap:wrap;gap:10px 20px;margin-top:20px}
.post-cta-list li{font-size:14px;color:rgba(255,255,255,.85);display:flex;align-items:center;gap:8px}
.post-cta-list li::before{content:"✓";color:#FF7A3D;font-weight:700}
.lead-form{display:grid;gap:14px}
.lead-form .row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.lead-form label{font-size:12px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:rgba(255,255,255,.6);display:block;margin-bottom:6px}
.lead-form input,.lead-form textarea{width:100%;padding:13px 15px;border-radius:12px;border:1px solid rgba(255,255,255,.2);background:rgba(255,255,255,.06);color:#fff;font:inherit;font-size:15px;transition:border-color .25s,background .25s}
.lead-form input::placeholder,.lead-form textarea::placeholder{color:rgba(255,255,255,.42)}
.lead-form input:focus,.lead-form textarea:focus{outline:none;border-color:var(--red);background:rgba(255,255,255,.1)}
.lead-form textarea{min-height:110px;resize:vertical}
.lead-form button{margin-top:4px;justify-self:start}
.form-note{font-size:14px;min-height:1.2em;color:rgba(255,255,255,.75)}
.form-note.ok{color:#86efac}
@media(max-width:780px){.post-cta-grid{grid-template-columns:1fr}.lead-form .row{grid-template-columns:1fr}}

/* ---- related ---- */
.related{border-top:1px solid var(--line);padding-top:34px;margin-top:46px;max-width:var(--measure)}
.related h3{font-family:"JetBrains Mono",monospace;text-transform:uppercase;letter-spacing:.16em;font-size:12px;color:var(--muted);margin-bottom:18px}
.related-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.related-grid a{background:#fff;border:1px solid var(--line);border-radius:14px;padding:18px;font-weight:600;font-size:15px;line-height:1.3;transition:transform .35s var(--ease),box-shadow .35s}
.related-grid a:hover{transform:translateY(-4px);box-shadow:0 20px 40px -24px rgba(20,17,15,.4)}
@media(max-width:760px){.related-grid{grid-template-columns:1fr}}

/* ---- service pages ---- */
.svc-list{display:grid;grid-template-columns:1fr 1fr;gap:14px 26px;max-width:var(--measure);margin-top:8px}
.svc-list .item{display:flex;gap:12px;align-items:flex-start;font-size:16.5px;color:#2b2723}
.svc-list .item::before{content:"";flex:none;width:22px;height:22px;margin-top:1px;border-radius:6px;background:var(--line-grad);-webkit-mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='%23000' d='M9 16.2l-3.5-3.5L4 14.2l5 5L20 8.2 18.6 6.8z'/%3E%3C/svg%3E") center/16px no-repeat;mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='%23000' d='M9 16.2l-3.5-3.5L4 14.2l5 5L20 8.2 18.6 6.8z'/%3E%3C/svg%3E") center/16px no-repeat}
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.svc-card{display:flex;flex-direction:column;background:#fff;border:1px solid var(--line);border-radius:18px;padding:26px;transition:transform .4s var(--ease),box-shadow .4s var(--ease),border-color .4s}
.svc-card:hover{transform:translateY(-5px);border-color:transparent;box-shadow:0 26px 50px -26px rgba(227,10,45,.4)}
.svc-card .n{font-family:"JetBrains Mono",monospace;font-size:12px;color:var(--red);margin-bottom:12px}
.svc-card h3{font-size:20px;font-weight:700;letter-spacing:-.02em;margin-bottom:8px;line-height:1.16}
.svc-card p{color:var(--muted);font-size:15px;flex:1}
.svc-card .more{margin-top:16px;font-weight:600;font-size:15px;color:var(--ink)}
@media(max-width:980px){.svc-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:640px){.svc-list{grid-template-columns:1fr}.svc-grid{grid-template-columns:1fr}}
/* "Altri servizi" leggero (pill, dopo il form) */
.altri-strip{padding:clamp(38px,5.5vw,60px) 0;background:var(--paper-2);border-top:1px solid var(--line)}
.altri-strip .lbl{display:block;margin-bottom:16px}
.svc-pills{display:flex;flex-wrap:wrap;gap:12px}
.svc-pill{display:inline-flex;align-items:center;gap:8px;background:#fff;border:1px solid var(--line);border-radius:999px;padding:11px 20px;font-weight:600;font-size:15px;color:var(--ink);transition:transform .35s var(--ease),border-color .35s,box-shadow .35s}
.svc-pill:hover{transform:translateY(-2px);border-color:transparent;box-shadow:0 14px 30px -16px rgba(227,10,45,.5)}
.svc-pill .ar{color:var(--red);transition:transform .35s var(--ease)}
.svc-pill:hover .ar{transform:translateX(4px)}

/* ---- esperienza di lettura (reader.js) ---- */
.read-bar{position:fixed;top:0;left:0;right:0;height:3px;z-index:140;pointer-events:none}
.read-bar i{display:block;height:100%;background:var(--line-grad);transform:scaleX(0);transform-origin:left;transition:transform .1s linear}
.phead-wm{position:absolute;right:-2%;bottom:-14%;z-index:0;pointer-events:none;font-weight:800;letter-spacing:-.04em;font-size:clamp(90px,22vw,280px);line-height:1;color:#fff;opacity:.05;white-space:nowrap;text-transform:lowercase}
@media(max-width:760px){.phead-wm{font-size:120px;bottom:-8%;opacity:.06}}
.art-meta2{display:flex;gap:12px;align-items:center;flex-wrap:wrap;margin-top:24px}
.art-meta2 .m-time{font-family:"JetBrains Mono",monospace;font-size:12px;letter-spacing:.08em;text-transform:uppercase;color:rgba(255,255,255,.66)}
.m-listen{display:inline-flex;align-items:center;justify-content:center;gap:8px;min-width:178px;font:600 14px/1 "Inter Tight",system-ui,sans-serif;color:#fff;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.4);border-radius:999px;padding:11px 20px;cursor:pointer;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);transition:background .3s,border-color .3s}
.m-listen:hover{background:rgba(255,255,255,.2)}
.m-listen.on{background:var(--red);border-color:transparent}
/* indice: striscia appiccicata in alto */
.toc{position:sticky;top:62px;z-index:30;display:flex;align-items:center;gap:14px;font-size:18.5px;background:rgba(242,239,234,.92);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-bottom:1px solid var(--line);padding:11px 2px;margin:0 0 40px;max-width:var(--measure);overflow:hidden}
.toc-scroll{position:relative;flex:1 1 auto;min-width:0;overflow-x:auto;white-space:nowrap;scrollbar-width:none;scroll-behavior:smooth;-webkit-mask-image:linear-gradient(90deg,transparent 0,#000 20px,#000 calc(100% - 52px),transparent 100%);mask-image:linear-gradient(90deg,transparent 0,#000 20px,#000 calc(100% - 52px),transparent 100%)}
.toc-scroll::-webkit-scrollbar{display:none}
.toc-t{font-family:"JetBrains Mono",monospace;text-transform:uppercase;letter-spacing:.14em;font-size:10px;color:var(--muted);flex:none;margin-right:4px}
.toc ul{list-style:none;display:flex;gap:20px;padding:0;margin:0;flex:none}
.toc li{flex:none}
.toc-sp{flex:none;width:64px;height:1px;pointer-events:none}
.toc-spl{flex:none;width:22px;height:1px;pointer-events:none}
.toc a{display:inline-block;font-size:13.5px;color:var(--muted);padding:5px 0;border-bottom:2px solid transparent;transition:color .25s,border-color .25s;white-space:nowrap}
.toc a:hover{color:var(--ink)}
.toc a.on{color:var(--ink);border-color:var(--red);font-weight:600}
/* elementi per spezzare il testo (pronti per l'uso nel corpo) */
.prose .pullquote{font-size:clamp(22px,3vw,30px);font-weight:700;line-height:1.25;letter-spacing:-.02em;color:var(--ink);border:0;border-top:2px solid var(--ink);border-bottom:2px solid var(--ink);padding:26px 0;margin:1.8em 0}
.prose .pullquote .grad{background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.remember{background:#fff;border:1px solid var(--line);border-left:4px solid #FF7A3D;border-radius:14px;padding:22px 26px;margin:1.8em 0}
.remember .rk{display:block;font-family:"JetBrains Mono",monospace;text-transform:uppercase;letter-spacing:.14em;font-size:11px;color:#FF7A3D;margin-bottom:10px}
.remember ul{margin:0;padding-left:1.2em}
.stat-row{display:flex;flex-wrap:wrap;gap:18px 40px;margin:1.6em 0}
.stat{display:flex;flex-direction:column;gap:2px}
.stat b{font-size:clamp(34px,5vw,52px);font-weight:800;letter-spacing:-.03em;background:var(--line-grad);-webkit-background-clip:text;background-clip:text;color:transparent;line-height:1}
.stat span{font-size:14px;color:var(--muted)}

/* responsive */
@media(max-width:900px){
  .people{grid-template-columns:1fr}
  .principi{grid-template-columns:1fr;gap:26px}
  .foot-top{grid-template-columns:1fr 1fr;gap:32px}
}
@media(max-width:720px){
  .nav-links{position:fixed;inset:72px 0 auto 0;flex-direction:column;gap:0;background:var(--paper);padding:8px 0;transform:translateY(-130%);transition:transform .45s var(--ease);border-bottom:1px solid var(--line)}
  .nav-links.open{transform:translateY(0)}
  .nav-links a{width:100%;padding:15px 24px}
  .nav-links a:not(.btn)::after{display:none}
  .nav-links .btn{margin:10px 24px;justify-content:center}
  .burger{display:flex}
}
/* ===== Lavori (casi studio) ===== */
.lav-cases{display:flex;flex-direction:column;gap:clamp(34px,6vw,76px);margin-top:8px}
.lav-case{position:relative;display:grid;grid-template-columns:1.04fr .96fr;gap:clamp(22px,4vw,56px);align-items:center;background:linear-gradient(120deg,#FBE7D6 0%,#F6EFE7 50%,#FCEFE6 100%);border:1px solid var(--line);border-radius:26px;padding:clamp(22px,3.2vw,44px);overflow:hidden}
.lav-case.v2{background:linear-gradient(120deg,#E8E5F4 0%,#F4F0EA 52%,#FBE9E6 100%)}
.lav-case.v3{background:linear-gradient(120deg,#FDE6B6 0%,#F8EEE6 46%,#FCE0EB 100%)}
.lav-case.alt .lav-media{order:2}
.lav-media{position:relative;border-radius:16px;overflow:hidden;aspect-ratio:4/3;background:#14110F;box-shadow:0 30px 60px -28px rgba(20,17,15,.55)}
.lav-media video,.lav-media>img{width:100%;height:100%;object-fit:cover;display:block}
.lav-media video{animation:kbz 20s ease-in-out infinite alternate}
@keyframes kbz{from{transform:scale(1.03)}to{transform:scale(1.12)}}
.lav-media.brand{display:grid;place-items:center}
.lav-media.brand::before{content:"";position:absolute;inset:0;background:radial-gradient(130% 130% at 28% 18%,rgba(227,10,45,.42),transparent 58%),linear-gradient(135deg,#1c1916,#14110F 70%)}
.lav-media .bn{position:relative;z-index:1;font-weight:800;letter-spacing:-.02em;color:#fff;text-align:center;padding:0 20px;font-size:clamp(28px,3.6vw,46px);line-height:1.04}
.lav-media .bn .grad{background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.lav-media .bn small{display:block;margin-top:10px;font-family:"JetBrains Mono",monospace;font-size:11px;letter-spacing:.18em;text-transform:uppercase;font-weight:500;color:rgba(255,255,255,.62)}
.lav-kick{display:inline-block;padding:6px 13px;border-radius:var(--r);background:#fff;border:1px solid var(--line);font-family:"JetBrains Mono",monospace;font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink);margin-bottom:15px}
.lav-name{font-weight:800;letter-spacing:-.03em;line-height:1.02;font-size:clamp(30px,4.2vw,52px);margin-bottom:14px}
.lav-name .grad{background:var(--line-grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.lav-case .lav-body p{font-size:clamp(15.5px,1.5vw,17.5px);color:#5a544e;line-height:1.62}
.lav-tags{display:flex;flex-wrap:wrap;gap:8px;margin-top:18px}
.lav-tag{font-family:"JetBrains Mono",monospace;font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink);background:rgba(255,255,255,.7);border:1px solid var(--line);padding:6px 11px;border-radius:var(--r)}
.lav-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(286px,1fr));gap:18px;margin-top:30px}
.lav-card{background:#fff;border:1px solid var(--line);border-radius:18px;padding:24px 24px 22px;display:flex;flex-direction:column}
.lav-card .s{font-family:"JetBrains Mono",monospace;font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--red);margin-bottom:10px}
.lav-card h3{font-size:23px;font-weight:800;letter-spacing:-.02em;margin-bottom:8px}
.lav-card p{font-size:15px;color:var(--muted);line-height:1.55;margin-bottom:16px}
.lav-card .lav-tags{margin-top:auto}
.lav-more{display:inline-block;margin-top:16px;font-family:"JetBrains Mono",monospace;font-size:11px;letter-spacing:.1em;text-transform:uppercase;font-weight:600;color:var(--ink);border-bottom:2px solid var(--red);padding-bottom:3px;transition:color .25s}
a.lav-card{cursor:pointer;text-decoration:none;transition:transform .3s var(--ease),box-shadow .3s var(--ease),border-color .3s}
a.lav-card:hover{transform:translateY(-3px);box-shadow:0 22px 46px -24px rgba(20,17,15,.45);border-color:rgba(227,10,45,.4)}
a.lav-card:hover .lav-more,.lav-case .lav-more:hover{color:var(--red)}
.lav-roster{margin-top:30px;border-top:1px solid var(--line);padding-top:24px;max-width:var(--measure)}
.lav-roster h4{font-family:"JetBrains Mono",monospace;font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin-bottom:12px}
.lav-roster p{font-size:16.5px;color:var(--ink);line-height:1.75}
@media(max-width:760px){.lav-case,.lav-case.alt{grid-template-columns:1fr}.lav-case .lav-media{order:0}.lav-media{aspect-ratio:16/10}}

@media(prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important;scroll-behavior:auto!important}
  .reveal{opacity:1;transform:none}
  html{scroll-behavior:auto}
}

/* ===== Fondo scuro con macchie di colore in tutto il sito (richiesta utente 2026-06-09) ===== */
body{background:#14110F;color:#fff}
/* Sfondo "lava": due blob di colore che derivano lenti come liquido, fissi dietro a tutto (desktop + mobile) */
body::before,body::after{content:"";position:fixed;z-index:-2;border-radius:50%;pointer-events:none;filter:blur(54px);will-change:transform}
body::before{left:-14%;top:-20%;width:76vw;height:80vh;background:radial-gradient(circle,rgba(227,10,45,.6),rgba(227,10,45,.2) 40%,transparent 68%);animation:ttuLavaA 26s ease-in-out infinite alternate}
body::after{right:-14%;bottom:-20%;width:80vw;height:84vh;background:radial-gradient(circle,rgba(255,122,61,.5),rgba(255,122,61,.16) 40%,transparent 68%);animation:ttuLavaB 33s ease-in-out infinite alternate}
@keyframes ttuLavaA{0%{transform:translate(0,0) scale(1)}50%{transform:translate(14vw,18vh) scale(1.2)}100%{transform:translate(6vw,8vh) scale(1.1)}}
@keyframes ttuLavaB{0%{transform:translate(0,0) scale(1.12)}50%{transform:translate(-13vw,-16vh) scale(1.24)}100%{transform:translate(-5vw,-6vh) scale(1.14)}}
@media(prefers-reduced-motion:reduce){body::before,body::after{animation:none}}
.site-head{background:rgba(20,17,15,.74);border-bottom-color:var(--line-d)}
.logo{color:#fff}.nav-links a{color:#fff}.burger span{background:#fff}
.nav-links a[aria-current="page"]{color:var(--red)}
@media(max-width:720px){.nav-links{background:#14110F}}
.sec--paper2,.altri-strip{background:transparent;border-color:var(--line-d)}
.sec-head h2{color:#fff}.sec-head p{color:rgba(255,255,255,.72)}
.tldr{background:rgba(255,255,255,.05);border-color:var(--line-d)}.tldr p{color:#fff}
.prose{color:rgba(255,255,255,.84)}
.prose>p:first-of-type{color:#fff}
.prose h2,.prose h3,.prose strong{color:#fff}
.prose blockquote{color:rgba(255,255,255,.82);border-color:var(--line-d)}
.prose .pullquote{color:#fff;border-color:var(--line-d)}
.remember{background:rgba(255,255,255,.05);border-color:var(--line-d)}.remember ul{color:rgba(255,255,255,.84)}
.faq details{border-color:var(--line-d)}.faq summary{color:#fff}.faq details p{color:rgba(255,255,255,.74)}
.person{background:rgba(255,255,255,.05);border-color:var(--line-d)}.person h3{color:#fff}.person p{color:rgba(255,255,255,.74)}
.principio{border-color:var(--line-d)}.principio h3{color:#fff}.principio p{color:rgba(255,255,255,.74)}
.related-grid a{background:rgba(255,255,255,.05);border-color:var(--line-d);color:#fff}
.svc-list .item{color:rgba(255,255,255,.84)}
.svc-card{background:rgba(255,255,255,.05);border-color:var(--line-d)}.svc-card h3{color:#fff}.svc-card p{color:rgba(255,255,255,.72)}.svc-card .more{color:#fff}
.svc-pill{background:rgba(255,255,255,.06);border-color:var(--line-d);color:#fff}
.toc{background:rgba(20,17,15,.85);border-color:var(--line-d)}
.toc a:hover{color:#fff}.toc a.on{color:#fff}
.btn-ghost{border-color:#fff;color:#fff}.btn-ghost:hover{background:#fff;color:var(--ink)}
.lav-case{background:linear-gradient(120deg,#241a1e,#171311 62%);border-color:var(--line-d)}
.lav-case .lav-body p{color:rgba(255,255,255,.76)}
.lav-kick{background:rgba(255,255,255,.08);border-color:var(--line-d);color:#fff}
.lav-name{color:#fff}
.lav-card{background:rgba(255,255,255,.05);border-color:var(--line-d)}.lav-card h3{color:#fff}.lav-card p{color:rgba(255,255,255,.7)}
.lav-tag{color:#fff;background:rgba(255,255,255,.08);border-color:var(--line-d)}
.lav-more{color:#fff}
.lav-roster{border-color:var(--line-d)}.lav-roster h4{color:rgba(255,255,255,.6)}.lav-roster p{color:rgba(255,255,255,.82)}
