:root{
  --navy:#0C2448;
  --navy-800:#102A52;
  --navy-700:#16335f;
  --teal:#0C909C;
  --teal-deep:#0a7d88;
  --teal-bright:#19B9C6;
  --mint:#54B484;
  --mint-bright:#74D6A0;
  --slate:#60606C;
  --platinum:#F3F6FB;
  --platinum-2:#E8EEF6;
  --ink:#0C2448;
  --ink-soft:#46526E;
  --line:#DCE4F0;
  --white:#ffffff;
  --r:18px;
  --maxw:1180px;
  --shadow:0 24px 60px -28px rgba(12,36,72,.30);
  --shadow-sm:0 10px 30px -18px rgba(12,36,72,.35);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:"Spline Sans",-apple-system,sans-serif;
  color:var(--ink);
  background:var(--white);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
h1,h2,h3,h4{font-family:"Bricolage Grotesque",sans-serif;line-height:1.04;font-weight:700;letter-spacing:-.02em;color:var(--navy)}
a{color:inherit;text-decoration:none}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px}
.mono{font-family:"JetBrains Mono",monospace;font-size:.74rem;letter-spacing:.14em;text-transform:uppercase;font-weight:500}

/* ---------- buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:.55em;font-family:"Spline Sans";font-weight:600;font-size:.98rem;
  padding:.82em 1.5em;border-radius:999px;border:1.5px solid transparent;cursor:pointer;transition:.25s ease;white-space:nowrap}
.btn-primary,.btn--primary{background:var(--navy);color:#fff}
.btn-primary:hover,.btn--primary:hover{background:var(--teal);transform:translateY(-2px);box-shadow:0 14px 30px -12px rgba(12,144,156,.6)}
.btn-ghost,.btn--ghost{background:transparent;color:var(--navy);border-color:var(--line)}
.btn-ghost:hover,.btn--ghost:hover{border-color:var(--teal);color:var(--teal)}
.btn-light{background:#fff;color:var(--navy)}
.btn-light:hover{background:var(--mint-bright);transform:translateY(-2px)}
.btn-outline-light{background:transparent;color:#fff;border-color:rgba(255,255,255,.3)}
.btn-outline-light:hover{border-color:var(--teal-bright);color:var(--teal-bright)}
.btn .arr{transition:transform .25s}
.btn:hover .arr{transform:translateX(3px)}

/* ---------- header ---------- */
header{position:sticky;top:0;z-index:100;background:rgba(255,255,255,.82);backdrop-filter:blur(14px);
  border-bottom:1px solid transparent;transition:.3s}
header.scrolled{border-bottom-color:var(--line);box-shadow:0 6px 24px -20px rgba(12,36,72,.5)}
.nav{display:flex;align-items:center;justify-content:space-between;height:96px}
.brand img{height:66px;display:block}
.nav-links{display:flex;align-items:center;gap:28px}
.nav-links a{font-size:.95rem;font-weight:500;color:var(--ink-soft);transition:.2s;position:relative}
.nav-links a:hover{color:var(--navy)}
.nav-links a::after{content:"";position:absolute;left:0;bottom:-6px;width:0;height:2px;background:var(--teal);transition:.25s}
.nav-links a:hover::after{width:100%}
.nav-cta{display:flex;align-items:center;gap:14px}
.menu-btn{display:none;background:none;border:none;cursor:pointer;flex-direction:column;gap:5px;padding:8px}
.menu-btn span{width:24px;height:2px;background:var(--navy);border-radius:2px;transition:.3s}

/* ---------- hero ---------- */
.hero{position:relative;padding:88px 0 96px;overflow:hidden}
.hero-bg{position:absolute;inset:0;z-index:-1;background:
  radial-gradient(900px 520px at 82% -10%,rgba(12,144,156,.16),transparent 60%),
  radial-gradient(700px 500px at 8% 110%,rgba(84,180,132,.13),transparent 60%),
  linear-gradient(180deg,#fff 0%,var(--platinum) 100%)}
.grid-lines{position:absolute;inset:0;z-index:-1;opacity:.5;
  background-image:linear-gradient(var(--line) 1px,transparent 1px),linear-gradient(90deg,var(--line) 1px,transparent 1px);
  background-size:44px 44px;
  -webkit-mask-image:radial-gradient(700px 600px at 70% 30%,#000,transparent 75%);
  mask-image:radial-gradient(700px 600px at 70% 30%,#000,transparent 75%)}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:54px;align-items:center}
.eyebrow{display:inline-flex;align-items:center;gap:9px;color:var(--teal-deep);background:rgba(12,144,156,.09);
  border:1px solid rgba(12,144,156,.22);padding:.5em 1em;border-radius:999px;margin-bottom:26px}
.eyebrow .dot{width:7px;height:7px;border-radius:50%;background:var(--teal);box-shadow:0 0 0 4px rgba(12,144,156,.18);animation:pulse 2.4s infinite}
@keyframes pulse{0%,100%{box-shadow:0 0 0 4px rgba(12,144,156,.18)}50%{box-shadow:0 0 0 8px rgba(12,144,156,.05)}}
.hero h1{font-size:clamp(2.5rem,5.4vw,4.1rem);font-weight:800}
.hero h1 .hl{color:var(--teal-deep);position:relative;white-space:nowrap}
.hero__sub,.hero p.lead{font-size:1.18rem;color:var(--ink-soft);margin:26px 0 34px;max-width:560px}
.hero-actions,.hero__actions{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:34px}
.trust-row{display:flex;gap:26px;flex-wrap:wrap}
.trust-item{display:flex;align-items:flex-start;gap:11px;max-width:240px}
.trust-item .ck{flex:none;width:26px;height:26px;border-radius:8px;background:rgba(84,180,132,.16);
  display:grid;place-items:center;color:var(--mint);margin-top:2px}
.trust-item b{display:block;font-family:"Bricolage Grotesque";font-weight:700;font-size:.96rem;color:var(--navy)}
.trust-item span{font-size:.85rem;color:var(--ink-soft);line-height:1.4}

/* hero panel */
.hero-panel{position:relative;background:var(--navy);border-radius:26px;padding:30px;color:#fff;box-shadow:var(--shadow);overflow:hidden}
.hero-panel::before{content:"";position:absolute;top:-40%;right:-30%;width:340px;height:340px;border-radius:50%;
  background:radial-gradient(circle,rgba(25,185,198,.35),transparent 70%);filter:blur(8px)}
.panel-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:22px;position:relative}
.panel-head .mono{color:var(--teal-bright)}
.panel-head .live{display:flex;align-items:center;gap:7px;font-size:.78rem;color:#9fb4d6}
.panel-head .live i{width:7px;height:7px;border-radius:50%;background:var(--mint-bright);animation:pulse 2s infinite}
.gauge{display:flex;align-items:center;gap:22px;margin-bottom:24px;position:relative}
.ring{--p:78;width:118px;height:118px;border-radius:50%;flex:none;display:grid;place-items:center;
  background:conic-gradient(var(--teal-bright) calc(var(--p)*1%),rgba(255,255,255,.08) 0)}
.ring::after{content:"";position:absolute;width:90px;height:90px;border-radius:50%;background:var(--navy)}
.ring b{position:relative;z-index:1;font-family:"Bricolage Grotesque";font-size:1.7rem;font-weight:800}
.ring b small{font-size:.85rem;opacity:.7}
.gauge-txt b{font-family:"Bricolage Grotesque";font-size:1.05rem;display:block}
.gauge-txt span{font-size:.85rem;color:#9fb4d6}
.bars{display:flex;flex-direction:column;gap:13px;position:relative}
.bar-row{display:flex;align-items:center;gap:12px;font-size:.84rem}
.bar-row .lbl{width:96px;color:#c3d0e6;flex:none}
.bar-track{flex:1;height:8px;border-radius:99px;background:rgba(255,255,255,.09);overflow:hidden}
.bar-fill{height:100%;border-radius:99px;width:0;transition:width 1.3s cubic-bezier(.2,.8,.2,1)}
.bar-row .val{width:38px;text-align:right;font-family:"JetBrains Mono";color:#fff;font-size:.78rem}

/* ---------- section primitives ---------- */
section{padding:96px 0}
.section .wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px}
.sec-tag{display:inline-flex;align-items:center;gap:9px;color:var(--teal-deep);margin-bottom:18px}
.sec-tag::before{content:"";width:26px;height:1.5px;background:var(--teal)}
.sec-head{max-width:680px;margin-bottom:54px}
.sec-head.center{margin-left:auto;margin-right:auto;text-align:center}
.sec-head.center .sec-tag{justify-content:center}
h2.sec-title{font-size:clamp(1.9rem,3.6vw,2.85rem);font-weight:800}
.sec-head p{color:var(--ink-soft);font-size:1.12rem;margin-top:18px}
.section h2{font-size:clamp(1.9rem,3.6vw,2.85rem);font-weight:800;max-width:760px}
.section>.wrap>p{color:var(--ink-soft);font-size:1.08rem;margin-top:18px;max-width:760px}

/* problem table */
.problem{background:var(--platinum)}
.prob-table{background:#fff;border-radius:var(--r);border:1px solid var(--line);overflow:hidden;box-shadow:var(--shadow-sm);margin-top:18px}
.prob-row{display:grid;grid-template-columns:1fr 1fr 1.1fr;gap:0;border-bottom:1px solid var(--line)}
.prob-row:last-child{border-bottom:none}
.prob-row.head{background:var(--navy);color:#fff}
.prob-row.head>div{padding:18px 24px;font-family:"Bricolage Grotesque";font-weight:700;font-size:.92rem}
.prob-row.head .ans{color:var(--teal-bright)}
.prob-row>div{padding:20px 24px;font-size:.95rem}
.prob-row:not(.head)>div:not(:last-child){color:var(--ink-soft)}
.prob-row .ans{border-left:3px solid var(--mint);font-weight:600;color:var(--navy);background:rgba(84,180,132,.05)}
.prob-row:not(.head):hover{background:rgba(12,144,156,.03)}

/* ---------- chain (DARK centerpiece) ---------- */
.chain{background:var(--navy);color:#fff;position:relative;overflow:hidden}
.chain::before{content:"";position:absolute;inset:0;opacity:.4;
  background:radial-gradient(800px 400px at 15% 0%,rgba(12,144,156,.3),transparent 60%),
  radial-gradient(700px 500px at 90% 100%,rgba(84,180,132,.22),transparent 60%)}
.chain .wrap{position:relative}
.chain .sec-tag{color:var(--teal-bright)}
.chain .sec-tag::before{background:var(--teal-bright)}
.chain h2,.chain h2.sec-title{color:#fff}
.chain>.wrap>p,.chain .sec-head p{color:#aebbd6}
.chain-flow{display:grid;grid-template-columns:repeat(4,1fr);gap:0;align-items:stretch;margin-top:28px;position:relative}
.node{position:relative;padding:30px 24px;border-radius:18px;background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.08);margin:0 9px;transition:.3s}
.node:hover{background:rgba(25,185,198,.08);border-color:rgba(25,185,198,.4);transform:translateY(-5px)}
.node .step{font-family:"JetBrains Mono";font-size:.72rem;color:var(--teal-bright);letter-spacing:.1em;margin-bottom:14px}
.node .ico{width:48px;height:48px;border-radius:12px;display:grid;place-items:center;margin-bottom:16px;
  background:rgba(25,185,198,.14);color:var(--teal-bright)}
.node:nth-child(4) .ico{background:rgba(116,214,160,.16);color:var(--mint-bright)}
.node h4{color:#fff;font-size:1.18rem;margin-bottom:8px}
.node p{font-size:.88rem;color:#9fb0cf;line-height:1.5}
.connector{position:absolute;top:50%;left:0;right:0;height:2px;z-index:0;
  background:linear-gradient(90deg,transparent 6%,rgba(255,255,255,.12) 6%,rgba(255,255,255,.12) 94%,transparent 94%)}
.pulse-dot{position:absolute;top:50%;left:0;width:10px;height:10px;border-radius:50%;margin-top:-4px;
  background:var(--teal-bright);box-shadow:0 0 14px 3px rgba(25,185,198,.7);animation:travel 4.5s linear infinite}
@keyframes travel{0%{left:8%;opacity:0}8%{opacity:1}92%{opacity:1}100%{left:92%;opacity:0}}
.chain-note{margin-top:40px;text-align:center;max-width:640px;margin-left:auto;margin-right:auto;color:#aebbd6;font-size:1.02rem}
.chain-note b{color:var(--mint-bright)}

/* ---------- benefits ---------- */
.benefits-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(248px,1fr));gap:20px;margin-top:18px}
.bcard{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:30px;transition:.3s;position:relative;overflow:hidden}
.bcard::after{content:"";position:absolute;top:0;left:0;width:100%;height:3px;background:var(--teal);transform:scaleX(0);transform-origin:left;transition:.35s}
.bcard:hover{transform:translateY(-6px);box-shadow:var(--shadow);border-color:transparent}
.bcard:hover::after{transform:scaleX(1)}
.bcard .ico{width:50px;height:50px;border-radius:13px;display:grid;place-items:center;margin-bottom:20px;
  background:linear-gradient(135deg,rgba(12,144,156,.12),rgba(84,180,132,.12));color:var(--teal-deep);font-family:"Bricolage Grotesque";font-weight:800}
.bcard h3{font-size:1.24rem;margin-bottom:10px}
.bcard p{color:var(--ink-soft);font-size:.96rem}

/* ---------- security (dark) ---------- */
.security{background:var(--navy);color:#fff;position:relative;overflow:hidden}
.security::before{content:"";position:absolute;inset:0;opacity:.5;background:radial-gradient(700px 400px at 85% 10%,rgba(84,180,132,.18),transparent 60%)}
.security .wrap{position:relative}
.security .sec-tag{color:var(--mint-bright)}
.security .sec-tag::before{background:var(--mint-bright)}
.security h2,.security h2.sec-title{color:#fff}
.security>.wrap>p,.security .sec-head p{color:#aebbd6}
.sec-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:18px;margin-top:18px}
.scard{padding:26px;border-radius:16px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.09);transition:.3s}
.scard:hover{border-color:rgba(116,214,160,.4);background:rgba(116,214,160,.06)}
.scard .ico{width:44px;height:44px;border-radius:12px;background:rgba(116,214,160,.14);color:var(--mint-bright);display:grid;place-items:center;margin-bottom:16px;font-family:"Bricolage Grotesque";font-weight:800}
.scard h4{color:#fff;font-size:1.1rem;margin-bottom:8px}
.scard p{font-size:.88rem;color:#9fb0cf}

/* ---------- CTA ---------- */
.cta{background:linear-gradient(135deg,var(--navy) 0%,#0a3a52 100%);color:#fff;text-align:center;position:relative;overflow:hidden}
.cta::before{content:"";position:absolute;top:-50%;left:50%;transform:translateX(-50%);width:700px;height:700px;border-radius:50%;
  background:radial-gradient(circle,rgba(25,185,198,.18),transparent 65%)}
.cta .wrap{position:relative}
.cta h2{color:#fff;font-size:clamp(2rem,4.4vw,3.2rem);font-weight:800;max-width:740px;margin:0 auto 18px}
.cta p{color:#bcc9e0;font-size:1.15rem;max-width:520px;margin:0 auto 34px}
.cta-actions{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}

/* ---------- FAQ ---------- */
.faq{background:var(--platinum)}
.faq__list{max-width:820px;margin:18px auto 0;display:flex;flex-direction:column;gap:12px}
.faq details{background:#fff;border:1px solid var(--line);border-radius:14px;padding:0;overflow:hidden;transition:.25s}
.faq details[open]{border-color:var(--teal);box-shadow:var(--shadow-sm)}
.faq summary{list-style:none;cursor:pointer;padding:20px 24px;font-family:"Bricolage Grotesque";font-weight:700;
  font-size:1.05rem;color:var(--navy);display:flex;align-items:center;justify-content:space-between;gap:16px}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";font-size:1.4rem;color:var(--teal);font-family:"Spline Sans";line-height:1;transition:.25s}
.faq details[open] summary::after{transform:rotate(45deg)}
.faq details p{padding:0 24px 22px;color:var(--ink-soft);font-size:.98rem;margin:0}

/* ---------- footer ---------- */
footer{background:#08182f;color:#9fb0cf;padding:62px 0 34px}
.foot-top{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:36px;padding-bottom:40px;border-bottom:1px solid rgba(255,255,255,.08)}
footer .brand img{height:42px;margin-bottom:18px}
.foot-about{font-size:.92rem;max-width:300px;line-height:1.6}
.foot-col h5{font-family:"Bricolage Grotesque";color:#fff;font-size:.95rem;margin-bottom:16px}
.foot-col a{display:block;font-size:.9rem;margin-bottom:10px;transition:.2s}
.foot-col a:hover{color:var(--teal-bright)}
.foot-bottom{display:flex;justify-content:space-between;align-items:center;padding-top:26px;font-size:.84rem;flex-wrap:wrap;gap:14px}
.foot-bottom .tag{font-style:italic;color:#7488a8}

/* ---------- reveal ---------- */
.reveal{opacity:0;transform:translateY(26px);transition:.7s cubic-bezier(.2,.8,.2,1)}
.reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.08s}.reveal.d2{transition-delay:.16s}.reveal.d3{transition-delay:.24s}.reveal.d4{transition-delay:.32s}

/* ---------- accessibility ---------- */
:focus-visible{outline:3px solid var(--teal-bright);outline-offset:2px;border-radius:4px}

/* ---------- responsive ---------- */
@media(max-width:960px){
  .nav-links,.nav-cta .btn-ghost,.nav-cta .btn--ghost{display:none}
  .menu-btn{display:flex}
  .nav{height:78px}
  .brand img{height:52px}
  .hero-grid{grid-template-columns:1fr;gap:40px}
  .hero-panel{max-width:480px}
  .norm-grid{grid-template-columns:1fr}
  .chain-flow{grid-template-columns:1fr 1fr}
  .connector,.pulse-dot{display:none}
  .node{margin:0}
  .foot-top{grid-template-columns:1fr 1fr}
}
@media(max-width:640px){
  section{padding:64px 0}
  .hero{padding:54px 0 64px}
  .prob-row,.prob-row.head{grid-template-columns:1fr}
  .prob-row .ans{border-left:none;border-top:3px solid var(--mint)}
  .prob-row.head{display:none}
  .chain-flow{grid-template-columns:1fr}
  .foot-top{grid-template-columns:1fr}
  .trust-row{flex-direction:column;gap:14px}
}
/* mobile menu */
.mobile-menu{position:fixed;inset:78px 0 auto 0;background:#fff;border-bottom:1px solid var(--line);
  padding:18px 28px 26px;display:none;flex-direction:column;gap:4px;z-index:99;box-shadow:var(--shadow)}
.mobile-menu.open{display:flex}
.mobile-menu a{padding:13px 0;font-weight:500;border-bottom:1px solid var(--line)}
.mobile-menu .btn{margin-top:14px;justify-content:center}

/* ---------- error pages ---------- */
.section--narrow{padding:120px 0 140px}
.section--narrow>.wrap{max-width:640px}
.error-page .eyebrow{margin-bottom:24px}
.error-page h1{font-size:clamp(2rem,4.5vw,3.2rem);font-weight:800;margin-bottom:20px}
.error-page>p:not(:last-child){color:var(--ink-soft);font-size:1.1rem;margin-bottom:32px}
.error-page>p:last-child{display:flex;gap:14px;flex-wrap:wrap;margin-top:36px}
.error-page .btn:not(.btn--primary){background:transparent;color:var(--navy);border:1.5px solid var(--line)}
.error-page .btn:not(.btn--primary):hover{border-color:var(--teal);color:var(--teal)}

/* ---------- gallery ---------- */
.gallery{display:grid;grid-template-columns:2fr 1fr;gap:12px}
.gallery__main{margin:0;border:1px solid var(--line);border-radius:14px;overflow:hidden;background:var(--platinum)}
.gallery__main img{display:block;width:100%;height:auto}
.gallery__main figcaption{padding:10px 14px;font-size:.85rem;color:var(--ink-soft)}
.gallery__thumbs{display:grid;grid-auto-rows:1fr;gap:12px}
.gallery__thumbs .gallery__zoom{height:100%}
.gallery__thumbs img{width:100%;height:100%;object-fit:cover;border:1px solid var(--line);border-radius:10px}
.gallery__zoom{display:block;width:100%;height:100%;padding:0;border:0;background:none;cursor:zoom-in}
.gallery__zoom:focus-visible{outline:3px solid var(--teal-bright);outline-offset:2px}
.gallery__empty{grid-column:1/-1;min-height:200px;border:1.5px dashed var(--line);border-radius:14px;
  display:grid;place-items:center;color:var(--slate);
  background:linear-gradient(135deg,var(--platinum),var(--platinum-2))}

/* ---------- lightbox ---------- */
.lightbox[hidden]{display:none}
.lightbox{position:fixed;inset:0;z-index:300;display:grid;place-items:center;padding:32px}
.lightbox__backdrop{position:absolute;inset:0;background:rgba(12,36,72,.85)}
.lightbox__img{position:relative;max-width:92vw;max-height:88vh;border-radius:12px;box-shadow:var(--shadow)}
.lightbox__close{position:absolute;top:18px;right:24px;z-index:1;background:none;border:0;
  color:#fff;font-size:2.6rem;line-height:1;cursor:pointer}

/* ---------- feature drawer ---------- */
.feature-drawer[hidden]{display:none}
.feature-drawer{position:fixed;inset:0;z-index:200}
.feature-drawer__backdrop{position:absolute;inset:0;background:rgba(12,36,72,.45)}
.feature-drawer__panel{position:absolute;top:0;right:0;height:100%;width:min(440px,92vw);
  background:#fff;box-shadow:-30px 0 60px -30px rgba(12,36,72,.5);padding:28px;overflow-y:auto}
.feature-drawer__head{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px}
.feature-drawer__close{background:none;border:0;font-size:2rem;line-height:1;color:var(--ink-soft);cursor:pointer}
.feature-drawer__list{list-style:none;display:flex;flex-direction:column;gap:12px}
.feature-drawer__list li{display:flex;gap:10px;align-items:flex-start;font-size:.95rem;color:var(--ink-soft)}
.feature-drawer__list li::before{content:"›";color:var(--teal);font-weight:700;flex:none}

/* ---------- relation graph ---------- */
.relation-graph{margin:0;width:100%;border:1px solid var(--line);border-radius:16px;
  background:#fff;padding:10px;box-shadow:var(--shadow-sm)}
.relation-graph img{display:block;width:100%;height:auto;border-radius:8px}

/* ---------- macro cards + bande (funzionalita) ---------- */
.band{margin-top:48px}
.band__title{font-family:"JetBrains Mono";text-transform:uppercase;letter-spacing:.12em;
  font-size:.8rem;color:var(--teal-deep);margin-bottom:18px}
.macro-card{display:grid;grid-template-columns:1fr 1.15fr;gap:28px;align-items:center;
  border:1px solid var(--line);border-radius:18px;padding:26px;margin-bottom:18px;background:#fff}
.macro-card:nth-child(even){grid-template-columns:1.15fr 1fr}
.macro-card:nth-child(even) .macro-card__text{order:2}
.macro-card__eyebrow{font-family:"JetBrains Mono";font-size:.72rem;letter-spacing:.1em;
  text-transform:uppercase;color:var(--teal-deep)}
.macro-card h3{font-size:1.4rem;margin:8px 0 10px}
.macro-card p{color:var(--ink-soft);font-size:1rem;margin-bottom:16px}
.macro-card .ai-badge{display:inline-block;margin-left:8px;font-family:"JetBrains Mono";font-size:.66rem;
  letter-spacing:.08em;padding:2px 8px;border-radius:999px;background:rgba(25,185,198,.12);
  color:var(--teal-deep);border:1px solid rgba(25,185,198,.3)}
.macro-see{display:inline-flex;align-items:center;gap:7px;background:var(--navy);color:#fff;
  border:0;border-radius:999px;padding:9px 17px;font-family:"Spline Sans";font-weight:600;
  font-size:.9rem;cursor:pointer}
.macro-see:hover{background:var(--teal)}
.macro-micro{margin-top:14px}
.macro-micro:not(:target){position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0 0 0 0);visibility:hidden}

/* ---------- contact form ---------- */
.contatti-grid{display:grid;grid-template-columns:1.4fr .9fr;gap:26px;align-items:start}
.contact-form{background:#fff;border:1px solid var(--line);border-radius:18px;padding:28px;box-shadow:var(--shadow-sm)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:14px}
.form-row--full{grid-template-columns:1fr}
.form-row label{display:block;font-family:"Spline Sans";font-weight:600;font-size:.85rem;color:var(--navy);margin-bottom:6px}
.contact-form input,.contact-form textarea{width:100%;border:1.5px solid var(--line);border-radius:11px;
  padding:11px 13px;font-family:"Spline Sans";font-size:.98rem;color:var(--ink);background:#fcfdff}
.contact-form textarea{resize:vertical;min-height:110px}
.contact-form input:focus,.contact-form textarea:focus{outline:none;border-color:var(--teal);
  box-shadow:0 0 0 3px rgba(12,144,156,.12);background:#fff}
.form-row--submit{grid-template-columns:1fr;margin-top:6px}
.contatti-side{display:flex;flex-direction:column;gap:16px}
.contatti-rassicurazioni{background:var(--platinum);border:1px solid var(--line);border-radius:16px;padding:22px}
.contatto-diretto{background:var(--navy);border-radius:16px;padding:22px;color:#fff}
.contatto-diretto .sec-tag{color:var(--teal-bright)}
.contatto-email{display:inline-block;color:var(--teal-bright);font-family:"Bricolage Grotesque";
  font-weight:700;font-size:1.2rem;margin-top:8px}
.contatto-note{color:#9fb0cf;font-size:.86rem;margin-top:10px}

@media(max-width:860px){
  .macro-card,.macro-card:nth-child(even){grid-template-columns:1fr}
  .macro-card:nth-child(even) .macro-card__text{order:0}
  .contatti-grid{grid-template-columns:1fr}
  .form-row{grid-template-columns:1fr}
  .gallery{grid-template-columns:1fr}
}

/* ---------- home: pilastri + anteprima prodotto ---------- */
.pillars-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.preview-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.preview-grid img{width:100%;border:1px solid var(--line);border-radius:12px}
.preview-empty{min-height:140px;border:1.5px dashed var(--line);border-radius:12px;
  display:grid;place-items:center;color:var(--slate);
  background:linear-gradient(135deg,var(--platinum),var(--platinum-2))}
.section--alt{background:var(--platinum)}
@media(max-width:860px){
  .preview-grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:760px){
  .pillars-grid{grid-template-columns:1fr}
}
@media(max-width:540px){
  .preview-grid{grid-template-columns:1fr}
}

/* ---------- pagine normativa / consulenti ---------- */

/* hero--norma: variante hero per le landing normativa.
   La base .hero funziona già; questa classe consente piccoli override futuri
   senza toccare il default. Attualmente allinea il panel alla sommità su desktop. */
.hero--norma .hero-panel{align-self:start}

/* chain-mini — mini-catena verticale dentro .hero-panel (fondo navy scuro) */
.chain-mini{display:flex;flex-direction:column;gap:0;position:relative}
.chain-step{
  display:flex;align-items:center;gap:12px;
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.1);
  border-radius:10px;padding:10px 14px;
  color:#c3d0e6;font-size:.9rem;
  position:relative;z-index:1
}
.step-num{
  font-family:"JetBrains Mono",monospace;font-size:.7rem;letter-spacing:.1em;
  color:var(--teal-bright);flex:none;min-width:24px;font-weight:600
}
.chain-step--active{
  border-color:rgba(25,185,198,.55);
  background:rgba(25,185,198,.12);
  color:#fff
}
.chain-step--active .step-num{color:var(--teal-bright)}
.chain-step--done{
  border-color:rgba(84,180,132,.45);
  background:rgba(84,180,132,.12);
  color:var(--mint-bright)
}
.chain-step--done .step-num{color:var(--mint-bright)}
.chain-arrow{
  text-align:center;color:rgba(255,255,255,.25);
  font-size:.9rem;padding:2px 0;line-height:1;
  pointer-events:none;user-select:none
}

/* panel-note — nota piccola a piè di un hero-panel scuro */
.panel-note{
  margin-top:14px;color:#aebbd6;
  font-size:.75rem;line-height:1.4
}

/* incident-states — sequenza badge stato incidente (su sezione .security o altra scura) */
.incident-states{
  display:flex;align-items:center;gap:14px;flex-wrap:wrap;
  margin-top:28px
}
.incident-states .arr{color:rgba(255,255,255,.3);font-size:1.1rem}
.state-badge{
  display:inline-flex;align-items:center;
  padding:.5em 1.1em;border-radius:999px;
  font-family:"JetBrains Mono",monospace;font-size:.74rem;letter-spacing:.08em;text-transform:uppercase;
  font-weight:600;border:1.5px solid transparent
}
.state-badge--open{
  background:rgba(96,96,108,.18);
  border-color:rgba(96,96,108,.35);
  color:#c3d0e6
}
.state-badge--progress{
  background:rgba(25,185,198,.18);
  border-color:rgba(25,185,198,.4);
  color:var(--teal-bright)
}
.state-badge--done{
  background:rgba(84,180,132,.18);
  border-color:rgba(84,180,132,.4);
  color:var(--mint-bright)
}

/* cards-grid / card / card--benefit
   Griglia responsive di card benefit (sezioni chiare) */
.cards-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(260px,1fr));
  gap:18px;margin-top:18px
}
.card{
  background:#fff;border:1px solid var(--line);border-radius:var(--r);
  padding:26px;transition:.3s;position:relative;overflow:hidden
}
.card:hover{transform:translateY(-5px);box-shadow:var(--shadow);border-color:transparent}
.card--benefit{
  display:flex;align-items:flex-start;gap:14px
}
.card--benefit .ck{
  flex:none;width:28px;height:28px;border-radius:8px;
  background:rgba(84,180,132,.14);
  display:grid;place-items:center;
  color:var(--mint);font-size:1rem;margin-top:3px
}
.card--benefit h3{font-size:1.08rem;margin-bottom:6px;color:var(--navy)}
.card--benefit p{color:var(--ink-soft);font-size:.92rem;line-height:1.5}

/* feature-grid / feature-item — lista di feature con checkmark (sezioni chiare) */
.feature-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(240px,1fr));
  gap:12px;margin-top:18px
}
.feature-item{
  display:flex;align-items:flex-start;gap:11px;
  background:var(--platinum);border:1px solid var(--line);
  border-radius:12px;padding:14px 16px;font-size:.94rem;color:var(--ink)
}
.feature-item .ck{
  flex:none;width:24px;height:24px;border-radius:7px;
  background:rgba(84,180,132,.16);
  display:grid;place-items:center;
  color:var(--mint);margin-top:1px;font-size:.9rem
}

/* lifecycle-row / lc-step — sequenza step lifecycle (es. audit ISO)
   Su sezione .chain (navy scuro) */
.lifecycle-row{
  display:flex;align-items:center;gap:12px;flex-wrap:wrap;
  margin-top:28px
}
.lifecycle-row .arr{color:rgba(255,255,255,.3);font-size:1.1rem}
.lc-step{
  display:inline-flex;align-items:center;
  padding:.55em 1.2em;border-radius:10px;
  background:rgba(255,255,255,.06);
  border:1.5px solid rgba(255,255,255,.1);
  color:#c3d0e6
}
.lc-step--active{
  border-color:rgba(25,185,198,.55);
  background:rgba(25,185,198,.14);
  color:#fff
}
.lc-step--done{
  border-color:rgba(84,180,132,.45);
  background:rgba(84,180,132,.12);
  color:var(--mint-bright)
}

/* badge pills colorati (usati nei panel scuri e nelle tenant-row) */
.badge{
  display:inline-flex;align-items:center;
  padding:.3em .8em;border-radius:999px;
  font-family:"JetBrains Mono",monospace;font-size:.7rem;letter-spacing:.06em;font-weight:600;
  line-height:1.3;white-space:nowrap
}
.badge--teal{background:rgba(12,144,156,.18);color:var(--teal-bright)}
.badge--navy{background:rgba(255,255,255,.12);color:#c3d0e6;border:1px solid rgba(255,255,255,.18)}
.badge--mint{background:rgba(84,180,132,.18);color:var(--mint-bright)}

/* tenant-list / tenant-row / tenant-dot — lista clienti/tenant nel panel hero */
.tenant-list{display:flex;flex-direction:column;gap:10px;margin-top:4px}
.tenant-row{
  display:flex;align-items:center;gap:10px;
  background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.09);
  border-radius:10px;padding:9px 12px;font-size:.88rem;color:#c3d0e6
}
.tenant-row>span:nth-child(2){flex:1}
.tenant-dot{
  flex:none;width:10px;height:10px;border-radius:50%
}
.tenant-dot--a{background:var(--teal-bright);box-shadow:0 0 0 3px rgba(25,185,198,.25)}
.tenant-dot--b{background:var(--mint-bright);box-shadow:0 0 0 3px rgba(116,214,160,.25)}
.tenant-dot--c{background:#9fb4d6;box-shadow:0 0 0 3px rgba(159,180,214,.2)}

/* treat-list / treat-row / treat-code — lista trattamenti nel panel hero GDPR */
.treat-list{display:flex;flex-direction:column;gap:8px;margin-top:4px}
.treat-row{
  display:flex;align-items:center;gap:10px;
  background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.08);
  border-radius:10px;padding:9px 12px;font-size:.85rem;color:#c3d0e6;flex-wrap:wrap
}
.treat-row>span:nth-child(2){flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.treat-code{
  font-family:"JetBrains Mono",monospace;font-size:.68rem;letter-spacing:.06em;
  background:rgba(255,255,255,.1);color:var(--teal-bright);
  border-radius:6px;padding:2px 7px;white-space:nowrap
}

/* responsive: su mobile le lifecycle-row e incident-states si impilano ordinatamente */
@media(max-width:640px){
  .lifecycle-row,.incident-states{gap:8px}
  .lifecycle-row .arr,.incident-states .arr{transform:rotate(90deg)}
  .treat-row>span:nth-child(2){white-space:normal}
}

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