/* =========================================================================
   SIDEBLOOM · Design System
   Mood: editorial · geometric · brutalist-elegant
   Font: Montserrat (only) · Angoli: netti, no border-radius
   Palette: dal Brand Book pp.11-13 (blu, navy, grigio, bianco, nero)
   ========================================================================= */
:root{
  --blue:#0e72b9;          /* primary - blu intenso (Brand Elements bg) */
  --blue-bright:#1494e6;   /* lighter accent */
  --navy:#0f2440;          /* dark navy - "side" del logo */
  --navy-soft:#1f3a5f;
  --ink:#101012;
  --paper:#ebebec;         /* soft gray bg */
  --paper-2:#dddddd;
  --gray:#8d8d8d;
  --line:#cfcfd0;
  --line-dark:rgba(255,255,255,.14);
  --white:#fff;
  --ff:"Montserrat",system-ui,-apple-system,Segoe UI,sans-serif;
  --maxw:1400px;
  --pad:clamp(20px,4vw,64px);
}
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
body{margin:0;font-family:var(--ff);color:var(--ink);background:var(--paper);font-weight:400;line-height:1.55;overflow-x:hidden}
img,video{max-width:100%;display:block;height:auto}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer;border:0;background:none;color:inherit}
::selection{background:var(--blue);color:#fff}

/* ============ UTILITIES ============ */
.container{max-width:var(--maxw);margin:0 auto;padding-left:var(--pad);padding-right:var(--pad)}
.eyebrow{font-family:var(--ff);font-weight:600;font-size:12px;letter-spacing:.22em;text-transform:uppercase;color:var(--blue);display:inline-flex;align-items:center;gap:14px}
.eyebrow::before{content:"";width:28px;height:2px;background:currentColor}
.eyebrow.on-dark{color:#9ed5f5}

h1,h2,h3,h4,h5{font-family:var(--ff);margin:0;font-weight:300;letter-spacing:-.02em;line-height:1.04}
h1{font-size:clamp(48px,7vw,108px);font-weight:300}
h1 b,h1 strong{font-weight:700;color:var(--blue)}
h2{font-size:clamp(36px,5vw,72px);font-weight:300}
h2 b,h2 strong{font-weight:700;color:var(--blue)}
h3{font-size:clamp(24px,2.4vw,34px);font-weight:600;letter-spacing:-.01em}
h4{font-size:18px;font-weight:600;letter-spacing:0}
p{margin:0 0 16px}

/* ============ HEADER ============ */
.site-header{position:fixed;top:0;left:0;right:0;z-index:60;padding:18px 0;transition:background .35s,padding .35s,border-color .35s;border-bottom:1px solid transparent}
.site-header.is-scrolled,.site-header.is-solid{background:rgba(235,235,236,.96);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);padding:12px 0;border-bottom-color:var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;gap:24px}
.brand{display:flex;align-items:center;gap:10px}
.brand img{height:36px;width:auto;transition:filter .3s}
.site-header:not(.is-scrolled):not(.is-solid) .brand img{filter:brightness(0) invert(1)}
.nav-links{display:flex;gap:30px;align-items:center}
.nav-links a{font-size:13px;font-weight:600;letter-spacing:.04em;color:var(--ink);text-transform:uppercase;position:relative;transition:color .2s}
.nav-links a.active{color:var(--blue)}
.site-header:not(.is-scrolled):not(.is-solid) .nav-links a{color:#fff}
.site-header:not(.is-scrolled):not(.is-solid) .nav-links a.active{color:#9ed5f5}
.nav-links a::after{content:"";position:absolute;left:0;bottom:-6px;width:0;height:2px;background:currentColor;transition:width .25s}
.nav-links a:hover::after,.nav-links a.active::after{width:100%}
.cta-btn{display:inline-flex;align-items:center;gap:10px;background:var(--blue);color:#fff!important;padding:13px 22px;font-weight:700;font-size:13px;letter-spacing:.06em;text-transform:uppercase;transition:background .2s,transform .2s}
.cta-btn:hover{background:var(--navy);transform:translate(2px,-2px);box-shadow:-4px 4px 0 0 var(--ink)}
.cta-btn.invert{background:#fff;color:var(--blue)!important}
.cta-btn.invert:hover{background:var(--navy);color:#fff!important;box-shadow:-4px 4px 0 0 #fff}
.cta-btn .arr{transition:transform .2s}
.cta-btn:hover .arr{transform:translateX(3px)}
.burger{display:none;width:42px;height:42px;align-items:center;justify-content:center;border:1px solid var(--line)}
.burger span,.burger span::before,.burger span::after{width:18px;height:2px;background:currentColor;display:block;position:relative}
.burger span::before,.burger span::after{content:"";position:absolute;left:0;right:0}
.burger span::before{top:-6px}.burger span::after{top:6px}
.site-header:not(.is-scrolled):not(.is-solid) .burger{color:#fff;border-color:rgba(255,255,255,.4)}

/* ============ HERO ============ */
.hero{position:relative;min-height:100vh;color:#fff;background:var(--blue);overflow:hidden;display:flex;align-items:center;padding-top:120px;padding-bottom:80px}
.hero::before{content:"";position:absolute;inset:0;background:
  linear-gradient(135deg,rgba(15,36,64,.55) 0%,rgba(14,114,185,.25) 60%,rgba(15,36,64,.7) 100%);
  z-index:1}
.hero-pattern{position:absolute;inset:0;z-index:0;opacity:.35}
.hero-pattern svg{width:100%;height:100%}
.hero-grid{position:relative;z-index:2;width:100%;display:grid;grid-template-columns:1.3fr .9fr;gap:60px;align-items:center}
.hero-left h1{color:#fff;margin-bottom:30px;max-width:14ch}
.hero-left .lead{font-size:clamp(17px,1.5vw,20px);max-width:50ch;color:rgba(255,255,255,.85);font-weight:400;margin-bottom:36px;line-height:1.55}
.hero-actions{display:flex;flex-wrap:wrap;gap:14px}
.btn-outline{display:inline-flex;align-items:center;gap:10px;padding:13px 22px;border:2px solid #fff;color:#fff!important;font-weight:700;font-size:13px;letter-spacing:.06em;text-transform:uppercase;transition:background .2s,color .2s,transform .2s}
.btn-outline:hover{background:#fff;color:var(--blue)!important;transform:translate(2px,-2px);box-shadow:-4px 4px 0 0 rgba(255,255,255,.4)}

.hero-video-wrap{position:relative;aspect-ratio:9/16;max-width:380px;justify-self:end;background:var(--navy);overflow:hidden;box-shadow:-20px 20px 0 0 rgba(15,36,64,.6)}
.hero-video-wrap video{width:100%;height:100%;object-fit:cover;display:block}
.hero-video-wrap .vid-label{position:absolute;top:18px;left:18px;background:var(--blue);color:#fff;padding:6px 12px;font-size:10px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;z-index:2}
.hero-video-wrap .vid-label::before{content:"";display:inline-block;width:7px;height:7px;background:#fff;margin-right:6px;vertical-align:1px;animation:blink 1.4s infinite}
@keyframes blink{0%,60%{opacity:1}30%,90%{opacity:.3}}

.hero-eyebrow{font-family:var(--ff);font-weight:700;font-size:11px;letter-spacing:.28em;text-transform:uppercase;color:#fff;display:flex;align-items:center;gap:14px;margin-bottom:28px;opacity:.85}
.hero-eyebrow::before{content:"";width:36px;height:2px;background:#fff}

.hero-scroll{position:absolute;left:var(--pad);bottom:26px;font-size:10px;letter-spacing:.22em;text-transform:uppercase;font-weight:700;color:#fff;display:flex;align-items:center;gap:10px;z-index:3;opacity:.75}
.hero-scroll .l{display:block;width:2px;height:36px;background:#fff;animation:sline 2s infinite}
@keyframes sline{0%,100%{transform:scaleY(1);opacity:1}50%{transform:scaleY(.3) translateY(15px);opacity:.3}}

/* ============ PAGE HEAD (subpages) ============ */
.page-head{padding:160px 0 60px;background:var(--paper);position:relative;overflow:hidden}
.page-head .container{position:relative;z-index:2}
.page-head .crumbs{font-size:12px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--gray);margin-bottom:24px}
.page-head .crumbs a{color:var(--gray)}
.page-head .crumbs a:hover{color:var(--blue)}
.page-head .crumbs span{color:var(--ink)}
.page-head h1{margin:0 0 20px;max-width:18ch}
.page-head .lead{font-size:clamp(17px,1.5vw,20px);max-width:60ch;color:var(--gray);font-weight:400}
.page-head::after{content:"";position:absolute;right:-100px;top:-100px;width:400px;height:400px;background:var(--blue);transform:rotate(45deg);opacity:.08;z-index:1}

/* ============ SECTIONS ============ */
section{padding:clamp(80px,9vw,140px) 0;position:relative}
.section-head{margin-bottom:60px;display:flex;gap:60px;flex-wrap:wrap;align-items:flex-end}
.section-head .left{flex:1;min-width:280px}
.section-head .right{flex:1;min-width:280px;max-width:480px;color:var(--gray);font-size:16px;line-height:1.65}
.section-head h2{margin:18px 0 0}

/* ============ MANIFESTO / INTRO ============ */

.manifesto::before{content:"sidebloom";position:absolute;left:-2vw;bottom:-3vw;font-size:24vw;font-weight:800;color:var(--paper-2);line-height:.8;letter-spacing:-.04em;pointer-events:none;user-select:none}
.manifesto .container{position:relative;z-index:1}
.manifesto-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:start}
.manifesto-text h2{margin-bottom:30px}
.manifesto-text p{font-size:17px;color:#2a2a30;max-width:50ch;margin-bottom:16px}
.stats-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:30px;margin-top:48px;padding-top:30px;border-top:2px solid var(--ink)}
.stat .num{font-size:54px;font-weight:200;line-height:1;color:var(--blue);letter-spacing:-.02em;display:block}
.stat .lbl{font-size:12px;color:var(--gray);margin-top:8px;font-weight:600;letter-spacing:.06em;text-transform:uppercase}
.tag-list{display:flex;flex-wrap:wrap;gap:8px;margin-top:24px}
.tag{font-size:11px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;border:1.5px solid var(--ink);padding:8px 14px;color:var(--ink)}

/* ============ DECORATIVE BLOCKS ============ */
.diamond-deco{position:relative;aspect-ratio:1;background:var(--blue);overflow:hidden}
.diamond-deco::before,.diamond-deco::after{content:"";position:absolute;background:#fff;opacity:.08}
.diamond-deco::before{width:80%;height:80%;top:10%;left:-30%;transform:rotate(45deg)}
.diamond-deco::after{width:60%;height:60%;bottom:-20%;right:10%;transform:rotate(45deg);opacity:.06}

/* ============ SERVICES ============ */
.services{background:var(--ink);color:#fff}
.services .section-head .right{color:rgba(255,255,255,.6)}
.services h2{color:#fff}
.services-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:1px;background:rgba(255,255,255,.08)}
.service-card{grid-column:span 6;background:var(--ink);padding:44px 36px;position:relative;transition:background .35s,transform .25s}
.service-card:nth-child(3),.service-card:nth-child(4),.service-card:nth-child(5){grid-column:span 4}
.service-card:hover{background:rgba(14,114,185,.16)}
.service-card .num{font-size:11px;letter-spacing:.2em;color:var(--blue-bright);font-weight:700;text-transform:uppercase}
.service-card h3{margin:16px 0 16px;color:#fff;font-weight:600;font-size:24px}
.service-card p{color:rgba(255,255,255,.7);font-size:15px;line-height:1.6;margin-bottom:20px}
.service-card .skills{display:flex;flex-wrap:wrap;gap:6px}
.service-card .skills span{font-size:10.5px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;padding:5px 10px;background:rgba(255,255,255,.08);color:rgba(255,255,255,.85)}
.service-card .arrow{position:absolute;top:36px;right:36px;color:var(--blue-bright);opacity:0;transition:opacity .3s,transform .3s}
.service-card:hover .arrow{opacity:1;transform:translate(2px,-2px)}

/* ============ MARQUEE ============ */
.marquee{overflow:hidden;position:relative;padding:24px 0}
.marquee::before,.marquee::after{content:"";position:absolute;top:0;bottom:0;width:120px;z-index:2;pointer-events:none}
.marquee::before{left:0;background:linear-gradient(90deg,var(--paper),transparent)}
.marquee::after{right:0;background:linear-gradient(-90deg,var(--paper),transparent)}
.marquee.dark::before{background:linear-gradient(90deg,var(--ink),transparent)}
.marquee.dark::after{background:linear-gradient(-90deg,var(--ink),transparent)}
.marquee-track{display:flex;gap:60px;animation:scroll 55s linear infinite;width:max-content;align-items:center}
.marquee-track:hover{animation-play-state:paused}
.marquee-track .item{font-size:clamp(22px,2.6vw,38px);font-weight:300;color:var(--ink);opacity:.7;white-space:nowrap;letter-spacing:-.01em;transition:opacity .3s,color .3s}
.marquee-track .item b{font-weight:700;color:var(--blue)}
.marquee-track .item:hover{opacity:1;color:var(--blue)}
.marquee-track .star{flex-shrink:0;width:18px;height:18px;background:var(--blue);clip-path:polygon(50% 0,61% 35%,98% 35%,68% 57%,79% 91%,50% 70%,21% 91%,32% 57%,2% 35%,39% 35%)}
.marquee.dark .marquee-track .item{color:#fff;opacity:.5}
.marquee.dark .marquee-track .item:hover{opacity:1;color:#9ed5f5}
@keyframes scroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}


.press-section h3{text-align:center;font-weight:300;font-size:clamp(22px,2.6vw,32px);color:var(--ink);margin-bottom:40px}
.press-section h3 b{font-weight:700;color:var(--blue)}


.clients-section h3{text-align:center;font-weight:300;font-size:clamp(22px,2.6vw,32px);color:#fff;margin-bottom:40px}
.clients-section h3 b{font-weight:700;color:#9ed5f5}

/* ============ LOGO MARQUEE (immagini) ============ */
.logo-marquee{overflow:hidden;position:relative;padding:20px 0}
.logo-marquee::before,.logo-marquee::after{content:"";position:absolute;top:0;bottom:0;width:120px;z-index:2;pointer-events:none}
.logo-marquee::before{left:0}.logo-marquee::after{right:0}
.logo-marquee.on-paper::before{background:linear-gradient(90deg,var(--paper),transparent)}
.logo-marquee.on-paper::after{background:linear-gradient(-90deg,var(--paper),transparent)}
.logo-marquee.on-dark::before{background:linear-gradient(90deg,var(--ink),transparent)}
.logo-marquee.on-dark::after{background:linear-gradient(-90deg,var(--ink),transparent)}
.logo-marquee-track{display:flex;gap:60px;animation:scroll 65s linear infinite;width:max-content;align-items:center}
.logo-marquee-track:hover{animation-play-state:paused}
.logo-marquee-track .logo-item{flex-shrink:0;height:80px;width:auto;display:flex;align-items:center;justify-content:center;padding:0 10px}
.logo-marquee-track .logo-item img{max-height:80px;max-width:160px;width:auto;height:auto;object-fit:contain;filter:grayscale(100%);opacity:.65;transition:filter .3s,opacity .3s,transform .3s;background:transparent}
.logo-marquee-track .logo-item:hover img{filter:grayscale(0%);opacity:1;transform:scale(1.08)}
.logo-marquee.on-dark .logo-marquee-track .logo-item img{filter:brightness(0) invert(1) grayscale(100%);opacity:.5}
.logo-marquee.on-dark .logo-marquee-track .logo-item:hover img{filter:brightness(0) invert(1);opacity:1}

/* Press / wordmark stilizzati */
.press-wordmark{flex-shrink:0;font-family:var(--ff);white-space:nowrap;opacity:.6;transition:opacity .3s,color .3s;color:var(--ink)}
.press-wordmark:hover{opacity:1;color:var(--blue)}
.press-wordmark.forbes{font-family:Georgia,"Times New Roman",serif;font-weight:700;font-size:32px;letter-spacing:-.02em}
.press-wordmark.sole{font-weight:700;font-size:24px;letter-spacing:.01em}
.press-wordmark.sole em{font-style:italic;color:var(--blue);font-weight:600}
.press-wordmark.ansa{font-weight:800;font-size:30px;letter-spacing:.04em;color:#c5363b}
.press-wordmark.nazione{font-family:Georgia,serif;font-weight:700;font-size:26px;font-style:italic}
.press-wordmark.tirreno{font-weight:300;font-size:28px;letter-spacing:-.01em;text-transform:lowercase}
.press-wordmark.tirreno b{font-weight:800}
.press-wordmark.qn{font-weight:900;font-size:36px;letter-spacing:-.04em}
.press-wordmark.pisatoday{font-weight:300;font-size:24px}
.press-wordmark.pisatoday b{font-weight:800;color:var(--blue)}
.press-wordmark.canale50{font-weight:800;font-size:28px}
.press-wordmark.canale50 em{font-style:normal;color:var(--blue)}
.press-wordmark.mkey{font-weight:600;font-size:24px;letter-spacing:.1em;text-transform:uppercase}
.press-wordmark.gonews{font-weight:300;font-size:24px}
.press-wordmark.gonews b{font-weight:800;color:var(--blue)}

/* ============ VIDEO REELS (autoplay muted loop) ============ */
.reel-card.video-reel{position:relative;aspect-ratio:9/16;background:var(--navy);overflow:hidden;cursor:pointer;transition:transform .35s,box-shadow .35s;display:block}
.reel-card.video-reel:hover{transform:translate(4px,-4px);box-shadow:-8px 8px 0 0 var(--blue)}
.reel-card.video-reel video{width:100%;height:100%;object-fit:cover;display:block}
.reel-card.video-reel::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 50%,rgba(0,0,0,.65) 100%);pointer-events:none;z-index:1}
.reel-card.video-reel .meta{position:absolute;bottom:0;left:0;right:0;padding:20px;color:#fff;z-index:2}
.reel-card.video-reel .tag{position:absolute;top:18px;left:18px;background:var(--blue);color:#fff;padding:5px 10px;font-size:10px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;z-index:2;display:inline-flex;align-items:center;gap:5px}
.reel-card.video-reel .tag::before{content:"";width:7px;height:7px;background:#fff;animation:blink 1.4s infinite}
.reel-card.video-reel .meta .t{font-size:15px;font-weight:600;line-height:1.3;margin-bottom:4px}
.reel-card.video-reel .meta .a{font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.8);display:inline-flex;align-items:center;gap:6px}
.reel-card.video-reel .meta .a::after{content:"→";transition:transform .25s}
.reel-card.video-reel:hover .meta .a::after{transform:translateX(4px)}
.reel-card.video-reel .play-toggle{position:absolute;top:18px;right:18px;width:36px;height:36px;background:rgba(255,255,255,.95);display:flex;align-items:center;justify-content:center;z-index:3;cursor:pointer;color:var(--blue);font-size:11px;border:0}
.reel-card.video-reel .play-toggle:hover{background:var(--blue);color:#fff}

/* Co-branded with Powerside */
.powerside-coop{display:inline-flex;align-items:center;gap:12px;padding:14px 20px;background:#fff;border:1.5px solid var(--line);font-size:13px;font-weight:500;color:var(--gray);margin-top:18px}
.powerside-coop img{height:24px;width:auto;opacity:.85}
.powerside-coop b{color:var(--ink);font-weight:700}

/* ============ REELS GRID ============ */
.reels{background:var(--paper)}
.reels-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:30px;margin-top:50px}
.reel-card{position:relative;aspect-ratio:9/16;background:var(--navy);overflow:hidden;cursor:pointer;transition:transform .35s,box-shadow .35s}
.reel-card:hover{transform:translate(4px,-4px);box-shadow:-8px 8px 0 0 var(--blue)}
.reel-card img{width:100%;height:100%;object-fit:cover;transition:transform .7s}
.reel-card:hover img{transform:scale(1.05)}
.reel-card::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 50%,rgba(0,0,0,.7) 100%)}
.reel-card .meta{position:absolute;bottom:0;left:0;right:0;padding:20px;color:#fff;z-index:2}
.reel-card .play{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:64px;height:64px;background:rgba(255,255,255,.95);display:flex;align-items:center;justify-content:center;z-index:2;transition:transform .3s,background .3s}
.reel-card:hover .play{background:var(--blue);transform:translate(-50%,-50%) scale(1.1)}
.reel-card .play svg{color:var(--blue);transition:color .3s}
.reel-card:hover .play svg{color:#fff}
.reel-card .tag{position:absolute;top:18px;left:18px;background:var(--blue);color:#fff;padding:5px 10px;font-size:10px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;z-index:2}
.reel-card .meta .t{font-size:15px;font-weight:600;line-height:1.3;margin-bottom:4px}
.reel-card .meta .a{font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.75)}

/* ============ CASE LIST GRID ============ */
.cases-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:30px}
.case-tile{grid-column:span 6;position:relative;aspect-ratio:4/3;overflow:hidden;background:var(--navy);display:block;cursor:pointer}
.case-tile.wide{grid-column:span 12;aspect-ratio:16/7}
.case-tile.full{grid-column:span 12;aspect-ratio:16/8}
.case-tile.third{grid-column:span 4;aspect-ratio:4/5}
.case-tile img{width:100%;height:100%;object-fit:cover;transition:transform .8s cubic-bezier(.2,.6,.2,1)}
.case-tile:hover img{transform:scale(1.06)}
.case-tile::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(15,36,64,0) 30%,rgba(15,36,64,.85) 100%);transition:background .35s}
.case-tile:hover::after{background:linear-gradient(180deg,rgba(14,114,185,.15) 30%,rgba(15,36,64,.92) 100%)}
.case-tile .label{position:absolute;left:24px;bottom:24px;right:24px;z-index:2;color:#fff}
.case-tile .label .cat{font-size:11px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:#9ed5f5;margin-bottom:8px;display:block}
.case-tile .label h3{font-size:clamp(22px,2.4vw,32px);font-weight:600;color:#fff;margin:0 0 6px;line-height:1.1}
.case-tile .label .more{margin-top:14px;display:inline-flex;align-items:center;gap:8px;font-size:12px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:#fff}
.case-tile:hover .label .more::after{transform:translateX(6px)}
.case-tile .label .more::after{content:"→";transition:transform .25s}
.case-tile .badge{position:absolute;top:18px;left:18px;background:var(--blue);color:#fff;padding:6px 12px;font-size:10px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;z-index:2}
.case-tile .award-pin{position:absolute;top:18px;right:18px;background:#fff;color:var(--blue);padding:6px 12px;font-size:10px;font-weight:700;letter-spacing:.1em;z-index:2}

/* ============ PROJECT PAGE ============ */
.project-hero{background:var(--paper);padding:140px 0 60px}
.project-hero .crumbs{font-size:12px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--gray);margin-bottom:24px}
.project-hero .crumbs a{color:var(--gray)}
.project-hero .crumbs a:hover{color:var(--blue)}
.project-hero .client-tag{font-size:13px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--blue);margin-bottom:12px;display:inline-block}
.project-hero h1{margin-bottom:24px;max-width:18ch}
.project-hero .summary{font-size:clamp(17px,1.4vw,20px);max-width:60ch;color:var(--gray);font-weight:400}
.project-meta{display:flex;flex-wrap:wrap;gap:0;margin-top:50px;border-top:2px solid var(--ink);border-bottom:2px solid var(--ink)}
.project-meta .item{flex:1 1 200px;padding:20px 24px 20px 0;border-right:1px solid var(--line);min-width:200px}
.project-meta .item:last-child{border-right:0}
.project-meta .item .k{font-size:10.5px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--gray)}
.project-meta .item .v{font-size:18px;font-weight:600;color:var(--ink);margin-top:6px}

.project-cover{padding:0;background:var(--paper)}
.project-cover img{width:100%;max-height:80vh;object-fit:cover;display:block}

.project-body{background:var(--paper);padding:90px 0}
.project-body .container{max-width:980px}
.project-body h2{margin:32px 0 18px}
.project-body p{font-size:17px;line-height:1.7;color:#2a2a30;margin-bottom:16px}
.project-body p.lead{font-size:21px;line-height:1.55;color:var(--ink);font-weight:500;margin:0 0 36px;padding-left:24px;border-left:4px solid var(--blue)}
.project-block{display:grid;grid-template-columns:1fr 1fr;gap:30px;margin:48px 0}
.project-block.single{grid-template-columns:1fr}
.project-block img{width:100%;aspect-ratio:4/3;object-fit:cover}

.project-results{background:var(--blue);color:#fff;padding:80px 0}
.project-results .container{max-width:980px}
.project-results h2{color:#fff;margin-bottom:30px}
.project-results h2 b{color:#fff;font-weight:800}
.results-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:rgba(255,255,255,.15);margin-top:40px}
.result{padding:36px 28px;background:var(--blue)}
.result .v{font-size:48px;font-weight:300;line-height:1;letter-spacing:-.02em}
.result .l{font-size:12px;letter-spacing:.12em;text-transform:uppercase;font-weight:600;color:rgba(255,255,255,.8);margin-top:10px}

.project-awards{background:var(--ink);color:#fff;padding:80px 0}
.project-awards h2{color:#fff;margin-bottom:30px}
.project-awards .container{max-width:980px}
.awards-list{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:rgba(255,255,255,.1);margin-top:30px}
.award-item{padding:30px 26px;background:var(--ink);display:flex;gap:18px;align-items:flex-start}
.award-icon{flex-shrink:0;width:42px;height:42px;background:var(--blue);display:flex;align-items:center;justify-content:center;color:#fff}
.award-item h4{color:#fff;font-size:18px;font-weight:700;margin-bottom:4px}
.award-item p{color:rgba(255,255,255,.65);font-size:14px;margin:0;line-height:1.5}

.project-cta{background:var(--paper);padding:90px 0;text-align:center}
.project-cta h2{margin-bottom:24px;max-width:18ch;margin-left:auto;margin-right:auto}
.project-cta p{font-size:17px;color:var(--gray);max-width:54ch;margin:0 auto 36px}
.project-nav{background:var(--ink);color:#fff;padding:0}
.project-nav-grid{display:grid;grid-template-columns:1fr 1fr;gap:0}
.project-nav a{padding:50px;display:flex;flex-direction:column;gap:8px;border-right:1px solid rgba(255,255,255,.12);transition:background .3s}
.project-nav a:last-child{border-right:0;align-items:flex-end;text-align:right}
.project-nav a:hover{background:var(--blue)}
.project-nav a .lbl{font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--gray);font-weight:600}
.project-nav a .ttl{font-size:24px;font-weight:300;letter-spacing:-.01em;color:#fff}

/* ============ FORM ============ */
.form-section{background:var(--ink);color:#fff;padding:80px 0}
.form-section.light{background:var(--paper);color:var(--ink)}
.form-section .container{max-width:840px}
.form-section h2{color:#fff;margin-bottom:14px}
.form-section.light h2{color:var(--ink)}
.form-section h2 b{color:var(--blue);font-weight:800}
.form-section .sub{font-size:16px;color:rgba(255,255,255,.65);margin-bottom:36px}
.form-section.light .sub{color:var(--gray)}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-top:32px}
.form-grid .full{grid-column:1/-1}
.field{display:flex;flex-direction:column;gap:6px}
.field label{font-size:11px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.7)}
.form-section.light .field label{color:var(--gray)}
.field label .req{color:var(--blue-bright)}
.field input,.field select,.field textarea{font:inherit;font-size:15px;padding:14px 16px;border:1.5px solid rgba(255,255,255,.18);background:rgba(255,255,255,.04);color:#fff;outline:none;transition:border-color .25s,background .25s;border-radius:0;font-family:var(--ff)}
.form-section.light .field input,.form-section.light .field select,.form-section.light .field textarea{background:#fff;color:var(--ink);border-color:var(--line)}
.field input::placeholder,.field textarea::placeholder{color:rgba(255,255,255,.3)}
.form-section.light .field input::placeholder,.form-section.light .field textarea::placeholder{color:#aaa}
.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--blue-bright);background:rgba(255,255,255,.08)}
.form-section.light .field input:focus,.form-section.light .field select:focus,.form-section.light .field textarea:focus{border-color:var(--blue);background:#fff}
.field textarea{min-height:100px;resize:vertical}
.field.has-error input,.field.has-error select,.field.has-error textarea{border-color:#ff6464}
.field .err{font-size:12px;color:#ff8a8a;display:none;font-weight:600}
.field.has-error .err{display:block}
.budget-pills{display:flex;flex-wrap:wrap;gap:8px}
.budget-pills label{display:inline-flex;align-items:center;padding:11px 18px;border:1.5px solid rgba(255,255,255,.18);cursor:pointer;font-size:13px;font-weight:600;letter-spacing:.04em;text-transform:none;color:#fff;transition:border-color .2s,background .2s;position:relative}
.form-section.light .budget-pills label{border-color:var(--line);color:var(--ink)}
.budget-pills label:hover{border-color:var(--blue-bright)}
.budget-pills input{position:absolute;opacity:0;pointer-events:none}
.budget-pills label:has(input:checked){background:var(--blue);border-color:var(--blue);color:#fff}
.privacy-row{display:flex;gap:12px;align-items:flex-start;font-size:13px;color:rgba(255,255,255,.7);line-height:1.5}
.form-section.light .privacy-row{color:var(--gray)}
.privacy-row input{margin-top:4px;width:18px;height:18px;accent-color:var(--blue);flex-shrink:0}
.privacy-row a{color:#9ed5f5;text-decoration:underline}
.form-section.light .privacy-row a{color:var(--blue)}
.submit-row{display:flex;justify-content:space-between;align-items:center;gap:14px;flex-wrap:wrap;margin-top:14px}
.btn-submit{background:var(--blue);color:#fff!important;padding:15px 32px;font-weight:700;font-size:13px;letter-spacing:.08em;text-transform:uppercase;border:0;display:inline-flex;align-items:center;gap:10px;cursor:pointer;transition:background .2s,transform .2s,box-shadow .2s}
.btn-submit:hover{background:#fff;color:var(--blue)!important;transform:translate(2px,-2px);box-shadow:-4px 4px 0 0 var(--blue-bright)}
.form-section.light .btn-submit:hover{background:var(--navy);color:#fff!important;box-shadow:-4px 4px 0 0 var(--blue)}
.form-success{display:none;padding:18px 22px;background:rgba(14,114,185,.16);border-left:3px solid var(--blue-bright);color:#fff;margin-top:14px;font-size:14px;font-weight:500}
.form-section.light .form-success{background:rgba(14,114,185,.1);color:var(--ink)}
.form-success.show{display:block}

/* ============ NEWS GRID ============ */
.news-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:30px}
.news-card{background:#fff;border:1px solid var(--line);display:flex;flex-direction:column;transition:transform .3s,box-shadow .3s,border-color .3s;text-decoration:none;color:inherit}
.news-card:hover{transform:translate(3px,-3px);box-shadow:-6px 6px 0 0 var(--blue);border-color:var(--blue)}
.news-card .img{aspect-ratio:16/10;background:var(--blue);position:relative;overflow:hidden}
.news-card .img.v1{background:linear-gradient(135deg,var(--blue),var(--navy))}
.news-card .img.v2{background:linear-gradient(135deg,var(--navy),var(--blue-bright))}
.news-card .img.v3{background:linear-gradient(135deg,var(--blue-bright),var(--blue))}
.news-card .img::after{content:"";position:absolute;inset:0;background-image:radial-gradient(circle at 30% 30%,rgba(255,255,255,.15),transparent 50%);mix-blend-mode:overlay}
.news-card .body{padding:26px;display:flex;flex-direction:column;gap:12px;flex:1}
.news-card .date{font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--blue);font-weight:700}
.news-card h4{font-size:19px;font-weight:600;line-height:1.3;color:var(--ink);margin:0}
.news-card .more{margin-top:auto;font-size:12px;font-weight:700;color:var(--ink);letter-spacing:.14em;text-transform:uppercase;display:inline-flex;align-items:center;gap:8px}

/* ============ CONTACT OFFICES ============ */
.offices-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:0;margin-top:40px}
.office-card{background:var(--paper);border:1.5px solid var(--ink);padding:36px;display:flex;flex-direction:column;gap:14px;position:relative;transition:background .3s,color .3s}
.office-card:nth-child(2){border-left:0}
.office-card:hover{background:var(--ink);color:#fff}
.office-card .city{font-size:11px;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--blue)}
.office-card h3{font-size:32px;font-weight:300;color:var(--ink);margin:0}
.office-card:hover h3{color:#fff}
.office-card .addr{font-size:15px;color:var(--gray);line-height:1.5}
.office-card:hover .addr{color:rgba(255,255,255,.7)}
.office-card a{font-size:14px;color:var(--ink);font-weight:600;display:block;margin-top:4px;transition:color .2s}
.office-card:hover a{color:#9ed5f5}

/* ============ FOOTER ============ */
footer{background:#0a0a0c;color:rgba(255,255,255,.55);padding:80px 0 32px;font-size:14px}
.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:50px;margin-bottom:60px}
footer h5{color:#fff;font-size:11px;letter-spacing:.2em;text-transform:uppercase;margin:0 0 22px;font-weight:700}
footer a{display:block;padding:6px 0;color:rgba(255,255,255,.55);font-weight:500;transition:color .2s}
footer a:hover{color:#9ed5f5}
.footer-brand img{height:36px;width:auto;margin-bottom:20px}
.footer-brand p{margin:0;line-height:1.6;color:rgba(255,255,255,.5)}
.footer-bot{display:flex;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:14px;padding-top:30px;border-top:1px solid rgba(255,255,255,.1);font-size:12px;letter-spacing:.04em}
.socials{display:flex;gap:8px}
.socials a{width:38px;height:38px;border:1.5px solid rgba(255,255,255,.18);display:flex;align-items:center;justify-content:center;padding:0;transition:border-color .2s,background .2s,color .2s}
.socials a:hover{background:var(--blue);border-color:var(--blue);color:#fff}

/* ============ COOKIE BANNER ============ */
.cookie-banner{position:fixed;left:20px;right:20px;bottom:20px;z-index:90;background:#fff;padding:24px 28px;display:none;border:2px solid var(--ink);box-shadow:-8px 8px 0 0 var(--blue);max-width:540px;margin-left:auto}
.cookie-banner.show{display:block;animation:slideUp .4s ease}
@keyframes slideUp{from{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}
.cookie-banner h4{font-size:18px;font-weight:700;margin:0 0 8px;color:var(--ink)}
.cookie-banner p{font-size:13.5px;line-height:1.55;color:var(--gray);margin:0 0 16px}
.cookie-banner p a{color:var(--blue);text-decoration:underline}
.cookie-actions{display:flex;flex-wrap:wrap;gap:10px}
.cookie-actions button{padding:10px 16px;font-size:12px;font-weight:700;letter-spacing:.08em;text-transform:uppercase}
.cookie-actions .accept{background:var(--blue);color:#fff}
.cookie-actions .accept:hover{background:var(--navy)}
.cookie-actions .reject{background:transparent;color:var(--ink);border:1.5px solid var(--ink)}
.cookie-actions .reject:hover{background:var(--ink);color:#fff}
.cookie-actions .customize{background:transparent;color:var(--blue);text-decoration:underline}

.modal{position:fixed;inset:0;z-index:100;background:rgba(10,10,15,.7);backdrop-filter:blur(8px);display:none;align-items:center;justify-content:center;padding:20px}
.modal.show{display:flex}
.modal-inner{background:#fff;max-width:640px;width:100%;max-height:88vh;overflow-y:auto;padding:40px;position:relative;border:2px solid var(--ink);box-shadow:-12px 12px 0 0 var(--blue)}
.modal-close{position:absolute;top:14px;right:14px;width:38px;height:38px;background:var(--paper);font-size:22px;color:var(--ink)}
.modal-close:hover{background:var(--ink);color:#fff}
.modal h3{font-size:32px;font-weight:300;margin:0 0 10px}
.modal h3 b{color:var(--blue);font-weight:700}
.modal h4{font-size:15px;font-weight:700}
.cookie-row{display:flex;justify-content:space-between;gap:24px;padding:18px 0;border-bottom:1px solid var(--line)}
.cookie-row:last-child{border-bottom:0}
.cookie-row .info p{margin:4px 0 0;font-size:13px;color:var(--gray)}
.toggle-switch{position:relative;width:46px;height:26px;flex-shrink:0}
.toggle-switch input{opacity:0;width:0;height:0;position:absolute}
.toggle-switch .slider{position:absolute;inset:0;background:#d4d4d4;cursor:pointer;transition:background .2s}
.toggle-switch .slider::before{content:"";position:absolute;width:20px;height:20px;background:#fff;top:3px;left:3px;transition:transform .2s}
.toggle-switch input:checked + .slider{background:var(--blue)}
.toggle-switch input:checked + .slider::before{transform:translateX(20px)}
.toggle-switch input:disabled + .slider{opacity:.6;cursor:not-allowed}
.modal-actions{display:flex;gap:10px;margin-top:24px;flex-wrap:wrap}
.modal-actions button{padding:12px 22px;font-size:12px;font-weight:700;letter-spacing:.08em;text-transform:uppercase}
.modal-actions .save{background:var(--blue);color:#fff}
.modal-actions .save:hover{background:var(--navy)}

/* ============ LEGAL PAGES ============ */
.legal-page{max-width:860px;margin:0 auto;padding:140px clamp(20px,4vw,40px) 100px;line-height:1.65}
.legal-page .back-link{display:inline-flex;align-items:center;gap:8px;font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--blue);margin-bottom:40px;font-weight:600}
.legal-page h1{font-size:clamp(36px,5vw,64px);margin-bottom:14px}
.legal-page .subtitle{font-size:17px;color:var(--gray);margin-bottom:48px;max-width:60ch}
.legal-page h2{font-size:28px;font-weight:600;color:var(--blue);margin:42px 0 14px}
.legal-page h3{font-size:18px;font-weight:600;margin:28px 0 10px}
.legal-page p{font-size:15.5px;margin:0 0 14px}
.legal-page ul,.legal-page ol{padding-left:22px;margin-bottom:18px}.legal-page li{margin-bottom:6px}
.legal-page .box{background:#fff;border:1.5px solid var(--ink);padding:24px;margin:20px 0}
.legal-page table{width:100%;border-collapse:collapse;margin:14px 0 22px;font-size:14px}
.legal-page th,.legal-page td{text-align:left;padding:10px 12px;border-bottom:1px solid var(--line);vertical-align:top}
.legal-page th{font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--blue);font-weight:700}
.legal-page .badge{display:inline-block;background:var(--blue);color:#fff;padding:6px 14px;font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase}
.legal-page footer{background:transparent;color:var(--gray);padding:30px 0 0;margin-top:50px;border-top:1px solid var(--line);font-size:13px}
.legal-page footer a{color:var(--blue);display:inline}

/* ============ REVEAL ============ */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .8s ease,transform .8s cubic-bezier(.2,.6,.2,1)}
.reveal.in{opacity:1;transform:translateY(0)}
.reveal-stagger > *{opacity:0;transform:translateY(20px);transition:opacity .6s ease,transform .6s cubic-bezier(.2,.6,.2,1)}
.reveal-stagger.in > *{opacity:1;transform:translateY(0)}
.reveal-stagger.in > *:nth-child(1){transition-delay:0s}
.reveal-stagger.in > *:nth-child(2){transition-delay:.07s}
.reveal-stagger.in > *:nth-child(3){transition-delay:.14s}
.reveal-stagger.in > *:nth-child(4){transition-delay:.21s}
.reveal-stagger.in > *:nth-child(5){transition-delay:.28s}
.reveal-stagger.in > *:nth-child(6){transition-delay:.35s}

/* ============ RESPONSIVE ============ */
@media (max-width:1024px){
  .hero-grid{grid-template-columns:1fr;gap:50px}
  .hero-video-wrap{max-width:280px;margin:0 auto;justify-self:center}
  .manifesto-grid{grid-template-columns:1fr;gap:50px}
  .cases-grid .case-tile,.cases-grid .case-tile.third,.cases-grid .case-tile.wide,.cases-grid .case-tile.full{grid-column:span 12}
  .services-grid .service-card,.services-grid .service-card:nth-child(3),.services-grid .service-card:nth-child(4),.services-grid .service-card:nth-child(5){grid-column:span 12}
  .reels-grid{grid-template-columns:1fr 1fr}
  .reels-grid .reel-card:nth-child(3){grid-column:1/-1;max-width:50%;margin:0 auto}
}
@media (max-width:780px){
  .nav-links{display:none}
  .nav-links.open{display:flex;position:absolute;top:100%;left:0;right:0;flex-direction:column;background:#fff;padding:30px var(--pad);gap:18px;align-items:flex-start;border-top:1px solid var(--line);box-shadow:0 20px 30px -10px rgba(0,0,0,.1)}
  .site-header:not(.is-scrolled):not(.is-solid) .nav-links.open a{color:var(--ink)}
  .burger{display:flex}
  .news-grid{grid-template-columns:1fr}
  .reels-grid{grid-template-columns:1fr;max-width:380px;margin:50px auto 0}
  .reels-grid .reel-card:nth-child(3){max-width:100%;grid-column:auto}
  .offices-grid{grid-template-columns:1fr}
  .office-card:nth-child(2){border-left:1.5px solid var(--ink);border-top:0}
  .form-grid{grid-template-columns:1fr}
  .stats-grid{grid-template-columns:1fr 1fr}
  .results-grid{grid-template-columns:1fr}
  .awards-list{grid-template-columns:1fr}
  .project-block{grid-template-columns:1fr}
  .project-nav-grid{grid-template-columns:1fr}
  .project-nav a{padding:30px;border-right:0;border-bottom:1px solid rgba(255,255,255,.12)}
  .project-nav a:last-child{align-items:flex-start;text-align:left}
  .footer-grid{grid-template-columns:1fr 1fr;gap:30px}
  .section-head{flex-direction:column;align-items:flex-start;gap:24px}
  .project-meta .item{flex:1 1 100%;border-right:0;border-bottom:1px solid var(--line)}
}
@media (max-width:480px){
  .footer-grid{grid-template-columns:1fr}
  .stats-grid{grid-template-columns:1fr}
  h1{font-size:44px}
}

@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}
  .marquee-track{animation:none}
}

/* =========================================================================
   ADDITION: 2-LOGO SWITCH + LOGO POWERSIDE + PRESS/CLIENT GRID + BANDO + VIDEO REELS
   ========================================================================= */

/* Switch logo colorato (su sfondo chiaro) / bianco (su sfondo scuro/hero) */
.brand{position:relative;display:flex;align-items:center}
.brand img{height:36px;width:auto;display:block;transition:opacity .3s}
.brand .logo-white{position:absolute;left:0;top:0;opacity:1}
.brand .logo-color{opacity:0}
.site-header.is-scrolled .brand .logo-color,
.site-header.is-solid .brand .logo-color{opacity:1}
.site-header.is-scrolled .brand .logo-white,
.site-header.is-solid .brand .logo-white{opacity:0}

/* Press logos grid (loghi giornali) */
.press-grid{
  display:grid;
  grid-template-columns:repeat(5,1fr);
  gap:0;
  margin-top:60px;
  border-top:1px solid var(--line);
  border-left:1px solid var(--line);
}
.press-grid .logo-cell{
  border-right:1px solid var(--line);
  border-bottom:1px solid var(--line);
  aspect-ratio:5/3;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:24px;
  background:var(--paper);
  transition:background .25s;
  color:var(--navy);
}
.press-grid .logo-cell:hover{background:#fff;color:var(--blue)}
.press-grid .logo-cell svg{max-width:80%;max-height:50px;height:auto}

/* Client logos grid */
.clients-grid{
  display:grid;
  grid-template-columns:repeat(6,1fr);
  gap:0;
  margin-top:50px;
  border-top:1px solid rgba(255,255,255,.12);
  border-left:1px solid rgba(255,255,255,.12);
}
.clients-grid .logo-cell{
  border-right:1px solid rgba(255,255,255,.12);
  border-bottom:1px solid rgba(255,255,255,.12);
  aspect-ratio:1/1;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:24px;
  background:var(--ink);
  transition:background .25s;
  color:rgba(255,255,255,.85);
}
.clients-grid .logo-cell:hover{background:rgba(14,114,185,.15);color:#fff}
.clients-grid .logo-cell svg{max-width:80%;max-height:55px;height:auto}
.clients-grid /* old dark filter rimosso */
.clients-grid 

/* Reel video con autoplay */
.reels-grid .reel-card{position:relative;aspect-ratio:9/16;background:var(--navy);overflow:hidden;display:block;cursor:pointer;transition:transform .35s,box-shadow .35s;text-decoration:none;color:inherit}
.reels-grid .reel-card:hover{transform:translate(4px,-4px);box-shadow:-8px 8px 0 0 var(--blue)}
.reels-grid .reel-card video{width:100%;height:100%;object-fit:cover;display:block;transition:transform .7s}
.reels-grid .reel-card:hover video{transform:scale(1.03)}
.reels-grid .reel-card::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 50%,rgba(0,0,0,.7) 100%);pointer-events:none}
.reels-grid .reel-card .tag{position:absolute;top:14px;left:14px;background:var(--blue);color:#fff;padding:5px 10px;font-size:10px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;z-index:2}
.reels-grid .reel-card .ig-link{position:absolute;top:14px;right:14px;width:30px;height:30px;background:rgba(255,255,255,.92);display:flex;align-items:center;justify-content:center;z-index:2;transition:background .25s;color:var(--blue)}
.reels-grid .reel-card .ig-link:hover{background:#fff}
.reels-grid .reel-card .meta{position:absolute;bottom:0;left:0;right:0;padding:18px;color:#fff;z-index:2}
.reels-grid .reel-card .meta .t{font-size:14px;font-weight:600;line-height:1.3;margin-bottom:3px}
.reels-grid .reel-card .meta .a{font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.7);font-weight:600}

/* Bando · Finanza Agevolata block */
.bando{
  background:linear-gradient(135deg,var(--blue) 0%,var(--navy) 100%);
  color:#fff;
  position:relative;
  overflow:hidden;
  padding:100px 0;
}
.bando::before{
  content:"50%";
  position:absolute;
  right:-3vw;
  top:-3vw;
  font-size:32vw;
  font-weight:800;
  color:rgba(255,255,255,.06);
  line-height:.8;
  letter-spacing:-.05em;
  pointer-events:none;
  user-select:none;
}
.bando .container{position:relative;z-index:1}
.bando-grid{display:grid;grid-template-columns:1.2fr .8fr;gap:60px;align-items:center}
.bando-left .pill{
  display:inline-block;
  background:#fff;
  color:var(--blue);
  padding:8px 16px;
  font-size:11px;
  font-weight:800;
  letter-spacing:.18em;
  text-transform:uppercase;
  margin-bottom:24px;
}
.bando-left h2{color:#fff;margin-bottom:24px}
.bando-left h2 b{color:#fff;font-weight:800}
.bando-left .sub{font-size:18px;color:rgba(255,255,255,.85);max-width:50ch;margin:0 0 32px;line-height:1.6}
.bando-stats{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:0;
  border-top:1.5px solid rgba(255,255,255,.2);
  border-bottom:1.5px solid rgba(255,255,255,.2);
  margin:30px 0 36px;
}
.bando-stats .s{padding:24px 20px 24px 0;border-right:1px solid rgba(255,255,255,.15)}
.bando-stats .s:last-child{border-right:0}
.bando-stats .s .v{font-size:42px;font-weight:300;line-height:1;letter-spacing:-.02em;color:#fff}
.bando-stats .s .v b{font-weight:800}
.bando-stats .s .l{font-size:11px;letter-spacing:.14em;text-transform:uppercase;font-weight:600;color:rgba(255,255,255,.7);margin-top:8px}
.bando-right{
  background:#fff;
  color:var(--ink);
  padding:36px 30px;
  position:relative;
}
.bando-right h3{font-size:22px;font-weight:700;margin:0 0 8px;color:var(--ink)}
.bando-right .check{font-size:14px;line-height:1.5;display:flex;gap:10px;align-items:flex-start;color:#2a2a30;padding:12px 0;border-bottom:1px solid var(--line)}
.bando-right .check:last-of-type{border-bottom:0}
.bando-right .check::before{content:"✓";color:var(--blue);font-weight:800;flex-shrink:0;width:22px;height:22px;background:rgba(14,114,185,.12);display:flex;align-items:center;justify-content:center;font-size:13px}

/* Sezione "trust strip" sopra hero */
.trust-strip{
  background:var(--paper-2);
  padding:18px 0;
  font-size:12px;
  letter-spacing:.06em;
  color:var(--gray);
}
.trust-strip .container{
  display:flex;
  flex-wrap:wrap;
  gap:30px;
  justify-content:center;
  align-items:center;
  text-align:center;
}
.trust-strip strong{color:var(--blue);font-weight:700}

/* Responsive */
@media (max-width:980px){
  .press-grid{grid-template-columns:repeat(3,1fr)}
  .clients-grid{grid-template-columns:repeat(3,1fr)}
  .bando-grid{grid-template-columns:1fr;gap:40px}
  .bando-stats .s .v{font-size:34px}
}
@media (max-width:580px){
  .press-grid{grid-template-columns:repeat(2,1fr)}
  .clients-grid{grid-template-columns:repeat(2,1fr)}
  .bando-stats{grid-template-columns:1fr;gap:0}
  .bando-stats .s{border-right:0;border-bottom:1px solid rgba(255,255,255,.15)}
}

/* =========================================================================
   v4 · TESTIMONIAL · TEAM · CALCOLATORE
   ========================================================================= */

/* TESTIMONIAL */
.testimonials{background:var(--ink);color:#fff;padding:120px 0;position:relative;overflow:hidden}
.testimonials::before{content:"\201C";position:absolute;left:-3vw;top:-8vw;font-family:Georgia,serif;font-size:50vw;color:rgba(14,114,185,.07);line-height:.8;pointer-events:none;user-select:none;font-weight:700}
.testimonials .container{position:relative;z-index:1}
.testimonials .eyebrow{color:#9ed5f5}.testimonials .eyebrow::before{background:#9ed5f5}
.testimonials h2{color:#fff;margin:18px 0 60px}
.testimonials h2 b{color:#9ed5f5;font-weight:800}
.t-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:30px}
.t-card{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.12);padding:36px 30px;display:flex;flex-direction:column;gap:20px;transition:background .3s,border-color .3s,transform .3s}
.t-card:hover{background:rgba(14,114,185,.08);border-color:rgba(158,213,245,.4);transform:translateY(-3px)}
.t-card .quote-mark{font-family:Georgia,serif;font-size:64px;line-height:.6;color:var(--blue-bright);font-weight:700;height:30px}
.t-card .quote{font-size:17px;line-height:1.6;color:#fff;font-weight:400;flex:1;font-style:italic}
.t-card .author{display:flex;gap:14px;align-items:center;padding-top:18px;border-top:1px solid rgba(255,255,255,.12)}
.t-card .avatar{width:48px;height:48px;flex-shrink:0;background:var(--blue);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:16px;letter-spacing:.04em}
.t-card .author .info .n{font-size:14px;font-weight:700;color:#fff}
.t-card .author .info .r{font-size:12px;color:rgba(255,255,255,.6);margin-top:2px;letter-spacing:.04em}

/* TEAM */
.team{background:var(--paper);padding:120px 0}
.team-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:30px;margin-top:60px}
.team-card{text-align:left;transition:transform .3s}
.team-card:hover{transform:translateY(-4px)}
.team-card .photo{aspect-ratio:3/4;background:var(--blue);position:relative;overflow:hidden;margin-bottom:20px}
.team-card .photo img{width:100%;height:100%;object-fit:cover;filter:grayscale(.4) contrast(1.05);transition:filter .4s}
.team-card:hover .photo img{filter:grayscale(0) contrast(1)}
.team-card .photo .initials{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:64px;font-weight:300;color:rgba(255,255,255,.95);letter-spacing:-.02em}
.team-card .photo::after{content:"";position:absolute;left:0;right:0;bottom:0;height:50%;background:linear-gradient(180deg,transparent,rgba(15,36,64,.3));pointer-events:none}
.team-card .n{font-size:18px;font-weight:700;color:var(--ink);margin:0 0 4px;letter-spacing:-.01em}
.team-card .r{font-size:12px;letter-spacing:.14em;text-transform:uppercase;font-weight:600;color:var(--blue)}
.team-card .bio{font-size:13px;color:var(--gray);margin-top:8px;line-height:1.5}

/* CALCOLATORE */
.calc-section{background:var(--paper);padding:120px 0;position:relative;overflow:hidden}
.calc-section::before{content:"€";position:absolute;right:-3vw;top:-5vw;font-size:30vw;color:var(--paper-2);line-height:.8;pointer-events:none;user-select:none;font-weight:800}
.calc-section .container{position:relative;z-index:1;max-width:880px}
.calc-section h2{margin-bottom:14px}
.calc-section .lead-text{font-size:18px;color:var(--gray);max-width:60ch;margin-bottom:50px}

.calculator{background:#fff;border:2px solid var(--ink);box-shadow:-8px 8px 0 0 var(--blue);padding:0;overflow:hidden}
.calc-progress{display:flex;background:var(--paper-2);border-bottom:2px solid var(--ink)}
.calc-progress .step{flex:1;padding:14px 20px;text-align:center;font-size:11px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--gray);border-right:1px solid var(--line);position:relative}
.calc-progress .step:last-child{border-right:0}
.calc-progress .step.done{color:var(--blue)}
.calc-progress .step.active{background:var(--ink);color:#fff}
.calc-body{padding:48px 40px;min-height:340px}
.calc-step{display:none}
.calc-step.active{display:block}
.calc-step h3{font-size:24px;font-weight:600;margin:0 0 8px}
.calc-step .qsub{font-size:14px;color:var(--gray);margin-bottom:30px}
.calc-options{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}
.calc-options.three{grid-template-columns:repeat(3,1fr)}
.calc-option{padding:18px 20px;border:1.5px solid var(--line);cursor:pointer;display:flex;align-items:center;gap:14px;background:#fff;transition:border-color .2s,background .2s,transform .2s;font-size:14.5px;font-weight:500}
.calc-option:hover{border-color:var(--blue);transform:translate(2px,-2px);box-shadow:-4px 4px 0 0 var(--paper-2)}
.calc-option.selected{border-color:var(--blue);background:rgba(14,114,185,.05);color:var(--blue)}
.calc-option .num{width:32px;height:32px;background:var(--paper-2);color:var(--ink);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:13px;flex-shrink:0}
.calc-option.selected .num{background:var(--blue);color:#fff}
.calc-multi .calc-option{justify-content:flex-start}
.calc-multi .calc-option .check{width:22px;height:22px;border:1.5px solid var(--line);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.calc-multi .calc-option.selected .check{background:var(--blue);border-color:var(--blue);color:#fff}
.calc-nav{padding:24px 40px;border-top:1px solid var(--line);display:flex;justify-content:space-between;align-items:center;background:var(--paper)}
.calc-nav button{padding:12px 24px;font-size:12px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;cursor:pointer;border:1.5px solid var(--ink);background:#fff;color:var(--ink);transition:background .2s,color .2s,transform .2s}
.calc-nav button.primary{background:var(--blue);border-color:var(--blue);color:#fff}
.calc-nav button.primary:hover{background:var(--navy);border-color:var(--navy);transform:translate(2px,-2px);box-shadow:-4px 4px 0 0 var(--ink)}
.calc-nav button:hover:not(:disabled){background:var(--ink);color:#fff;transform:translate(2px,-2px);box-shadow:-4px 4px 0 0 var(--blue)}
.calc-nav button:disabled{opacity:.4;cursor:not-allowed}
.calc-result{display:none;padding:48px 40px;text-align:center;background:var(--blue);color:#fff}
.calc-result.show{display:block}
.calc-result .label{font-size:12px;letter-spacing:.16em;text-transform:uppercase;font-weight:700;color:rgba(255,255,255,.7);margin-bottom:14px}
.calc-result .range{font-size:clamp(36px,5vw,56px);font-weight:300;letter-spacing:-.02em;line-height:1.1;margin-bottom:14px}
.calc-result .range b{font-weight:800}
.calc-result .disclaimer{font-size:13px;color:rgba(255,255,255,.7);max-width:50ch;margin:0 auto 30px;line-height:1.55}
.calc-result .actions{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}
.calc-result .actions a,.calc-result .actions button{display:inline-flex;align-items:center;gap:10px;padding:14px 24px;font-size:13px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;cursor:pointer;transition:transform .2s,box-shadow .2s}
.calc-result .actions .primary{background:#fff;color:var(--blue)}
.calc-result .actions .primary:hover{transform:translate(2px,-2px);box-shadow:-4px 4px 0 0 var(--navy)}
.calc-result .actions .secondary{background:transparent;color:#fff;border:1.5px solid #fff}
.calc-result .actions .secondary:hover{background:#fff;color:var(--blue)}

/* Responsive */
@media (max-width:980px){
  .t-grid{grid-template-columns:1fr}
  .team-grid{grid-template-columns:repeat(3,1fr)}
  .calc-options{grid-template-columns:1fr}
  .calc-options.three{grid-template-columns:1fr}
  .calc-body{padding:36px 24px}
  .calc-nav{padding:18px 24px}
}
@media (max-width:580px){
  .team-grid{grid-template-columns:1fr 1fr;gap:20px}
  .calc-progress .step{padding:10px 8px;font-size:10px;letter-spacing:.08em}
}

/* SB-SINGLE-REEL */
.reels-grid:has(.reel-card:only-child){display:grid;grid-template-columns:minmax(0,420px);justify-content:center}
.reel-card.yt-reel{aspect-ratio:9/16}
@media (max-width:760px){.reels-grid:has(.reel-card:only-child){grid-template-columns:minmax(0,320px)}}

/* SB-HERO-YT */
.hero-video-yt{position:absolute;inset:0;width:100%;height:100%;overflow:hidden;border-radius:inherit}
/* old hero-video-yt 177vh rule rimossa, vedi SB-IFRAME-FIT */
.hero-video-wrap{position:relative;overflow:hidden;aspect-ratio:9/16;max-width:380px;background:#0e2440}
@media (max-width:760px){.hero-video-wrap{max-width:280px}}

/* SB-BROCHURE-STRIPS */
.brochure-strip{padding:60px 0;background:#fff}
.brochure-strip-img{display:block;width:100%;max-width:1200px;height:auto;margin:0 auto}
.clients-section.brochure-strip .brochure-strip-img{max-width:1400px}
@media (max-width:760px){.brochure-strip{padding:40px 0}}

/* SB-BLOOM-MOBILE-FIX */
.bloom-deco{width:100%;min-height:1px}

@supports not (mix-blend-mode: multiply){.bloom-deco video{mix-blend-mode:normal}}

/* SB-LIGHTBOX */
.sb-lb-clickable{cursor:zoom-in;transition:opacity .2s}
.sb-lb-clickable:hover{opacity:.9}
.sb-lb-overlay{position:fixed;inset:0;background:rgba(15,36,64,.92);z-index:9999;display:none;align-items:center;justify-content:center;opacity:0;transition:opacity .25s;padding:5vh 5vw;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}
.sb-lb-overlay.sb-lb-show{display:flex;opacity:1}
.sb-lb-figure{margin:0;max-width:100%;max-height:100%;display:flex;flex-direction:column;align-items:center;gap:14px}
.sb-lb-img{max-width:90vw;max-height:80vh;width:auto;height:auto;display:block;box-shadow:0 30px 80px rgba(0,0,0,.4);background:#0e2440}
.sb-lb-cap{color:rgba(255,255,255,.85);font-size:14px;text-align:center;max-width:90vw}
.sb-lb-close,.sb-lb-prev,.sb-lb-next{position:absolute;background:rgba(255,255,255,.12);color:#fff;border:0;width:48px;height:48px;border-radius:50%;font-size:24px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s}
.sb-lb-close:hover,.sb-lb-prev:hover,.sb-lb-next:hover{background:rgba(255,255,255,.25)}
.sb-lb-close{top:24px;right:24px;font-size:32px}
.sb-lb-prev{left:24px;top:50%;transform:translateY(-50%)}
.sb-lb-next{right:24px;top:50%;transform:translateY(-50%)}
body.sb-lb-open{overflow:hidden}
@media (max-width:760px){
	.sb-lb-close{top:12px;right:12px;width:40px;height:40px}
	.sb-lb-prev,.sb-lb-next{width:40px;height:40px}
	.sb-lb-prev{left:8px} .sb-lb-next{right:8px}
}

/* SB-BLOOM-TALLER */
.bloom-deco{position:relative;aspect-ratio:9/16;background:transparent;overflow:hidden;will-change:transform;width:100%;max-width:520px;margin:0 auto}
.bloom-deco video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block;mix-blend-mode:multiply}
@media (max-width:760px){
	.bloom-deco{aspect-ratio:9/16;max-width:340px}
}

/* SB-TESTIMONIAL-CAROUSEL */
.testimonials-head{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:32px;gap:24px;flex-wrap:wrap}
.testimonials-head-text{flex:1;min-width:280px}
.t-controls{display:flex;gap:8px}
.t-prev,.t-next{width:44px;height:44px;border-radius:50%;border:1px solid var(--line,#d6d6d8);background:#fff;color:var(--blue,#0e72b9);font-size:24px;line-height:1;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center}
.t-prev:hover,.t-next:hover{background:var(--blue,#0e72b9);color:#fff;border-color:var(--blue,#0e72b9);transform:scale(1.05)}
.t-prev:disabled,.t-next:disabled{opacity:.3;cursor:not-allowed}

.t-carousel{position:relative;overflow:hidden}
.t-track{display:flex;gap:24px;overflow-x:auto;scroll-snap-type:x mandatory;scroll-behavior:smooth;padding:8px 4px 24px;scrollbar-width:none;-ms-overflow-style:none}
.t-track::-webkit-scrollbar{display:none}
.t-track .t-card{flex:0 0 calc((100% - 48px) / 3);scroll-snap-align:start;background:#fff;border:1px solid var(--line,#e5e5e7);border-radius:12px;padding:32px 28px;position:relative;display:flex;flex-direction:column;gap:16px;min-height:280px;transition:transform .25s,box-shadow .25s}
.t-track .t-card:hover{transform:translateY(-3px);box-shadow:0 12px 30px rgba(15,36,64,.08)}
.t-card .quote-mark{font-size:60px;line-height:.5;color:var(--blue,#0e72b9);opacity:.25;font-family:serif;margin-top:8px}
.t-card .quote{flex:1;font-size:15px;line-height:1.55;color:#2a2a30;margin:0}
.t-card .author{display:flex;align-items:center;gap:14px;padding-top:14px;border-top:1px solid var(--line,#eee)}
.t-card .avatar{width:48px;height:48px;border-radius:50%;background:var(--blue,#0e72b9);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:14px;flex-shrink:0;overflow:hidden}
.t-card .avatar-img{background:#fff;border:1px solid var(--line,#eee)}
.t-card .avatar-img img{width:100%;height:100%;object-fit:cover;display:block}
.t-card .info .n{font-weight:600;font-size:14px;color:#0e2440;line-height:1.3}
.t-card .info .r{font-size:13px;color:#6c6c75;line-height:1.4;margin-top:2px}

@media (max-width:1100px){
	.t-track .t-card{flex:0 0 calc((100% - 24px) / 2)}
}
@media (max-width:760px){
	.t-track .t-card{flex:0 0 calc(100% - 8px)}
	.testimonials-head{flex-direction:column;align-items:flex-start}
	.t-controls{align-self:flex-end}
}

/* SB-LOGO-GRIDS */
.section-title-center{text-align:center;margin-bottom:48px;font-size:32px;color:var(--blue,#0e72b9);font-weight:400;letter-spacing:-.01em}
.section-title-center b{font-weight:600}
.press-section,
.logo-grid{display:grid;gap:32px 24px;align-items:center;justify-items:center;max-width:1200px;margin:0 auto}
.press-grid{grid-template-columns:repeat(4,minmax(0,1fr));max-width:1000px}
.clients-grid{grid-template-columns:repeat(6,minmax(0,1fr))}
.logo-cell{display:flex;align-items:center;justify-content:center;aspect-ratio:1;padding:12px;border:0;border-radius:0;background:transparent;width:100%;max-width:160px;position:relative;text-decoration:none;transition:transform .25s}
.logo-cell img{max-width:100%;max-height:100%;width:auto;height:auto;display:block;object-fit:contain;transition:opacity .25s,transform .25s}
.logo-cell .logo-color{position:absolute;inset:12px;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .3s}
.logo-cell .logo-color img{mix-blend-mode:normal}
.logo-cell-link:hover{transform:translateY(-2px)}
.logo-cell-link:hover .logo-mono{opacity:0}
.logo-cell-link:hover .logo-color{opacity:1}
.logo-cell-link::after{content:'';position:absolute;left:50%;bottom:-2px;width:0;height:2px;background:var(--blue,#0e72b9);transform:translateX(-50%);transition:width .25s}
.logo-cell-link:hover::after{width:60%}
@media (max-width:1100px){
	.clients-grid{grid-template-columns:repeat(4,minmax(0,1fr))}
	.press-grid{grid-template-columns:repeat(4,minmax(0,1fr))}
}
@media (max-width:760px){
	.clients-grid,.press-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:20px 12px}
	.logo-cell{padding:8px;max-width:120px}
	.section-title-center{font-size:24px;margin-bottom:32px}
	.press-section,
}
@media (max-width:420px){.clients-grid,.press-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}

/* SB-HEADER-CONTRAST-FIX */
/* Pagine interne (non home) prima dello scroll: usa logo COLOR + menu scuro */
body:not(.home):not(.page-template-front-page) .site-header:not(.is-scrolled):not(.is-solid) .logo-color{display:inline-block !important}
body:not(.home):not(.page-template-front-page) .site-header:not(.is-scrolled):not(.is-solid) .logo-white{display:none !important}
body:not(.home):not(.page-template-front-page) .site-header:not(.is-scrolled):not(.is-solid) .nav-links a{color:var(--ink,#0e2440) !important}
body:not(.home):not(.page-template-front-page) .site-header:not(.is-scrolled):not(.is-solid) .nav-links a.cta-btn{color:#fff !important}
body:not(.home):not(.page-template-front-page) .site-header:not(.is-scrolled):not(.is-solid) .burger span,
body:not(.home):not(.page-template-front-page) .site-header:not(.is-scrolled):not(.is-solid) .burger span::before,
body:not(.home):not(.page-template-front-page) .site-header:not(.is-scrolled):not(.is-solid) .burger span::after{background:var(--ink,#0e2440) !important}
/* Scroll/solid state ovunque: logo color + menu scuro */
.site-header.is-scrolled .logo-color,.site-header.is-solid .logo-color{display:inline-block !important}
.site-header.is-scrolled .logo-white,.site-header.is-solid .logo-white{display:none !important}
.site-header.is-scrolled .nav-links a,.site-header.is-solid .nav-links a{color:var(--ink,#0e2440) !important}
.site-header.is-scrolled .nav-links a.cta-btn,.site-header.is-solid .nav-links a.cta-btn{color:#fff !important}
.site-header.is-scrolled .burger span,.site-header.is-solid .burger span,
.site-header.is-scrolled .burger span::before,.site-header.is-solid .burger span::before,
.site-header.is-scrolled .burger span::after,.site-header.is-solid .burger span::after{background:var(--ink,#0e2440) !important}

/* SB-OVERFLOW-DEFENSIVE */
html,body{overflow-x:hidden !important;max-width:100% !important}
*{box-sizing:border-box}
img,svg{max-width:100%;height:auto}
video,iframe{max-width:100%}
.container,.t-carousel,.case-content,article,section{max-width:100%}
section{overflow-x:clip}
.hero-pattern svg{max-width:100%}
/* iPad portrait + landscape specific (768-1100) */
@media (min-width:761px) and (max-width:1100px){
	.clients-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:18px}
	.press-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:18px}
	.logo-cell{max-width:130px;padding:10px}
	.hero-grid{grid-template-columns:1fr;gap:40px}
	.hero-video-wrap{max-width:280px;margin:0 auto}
	.t-track .t-card{flex:0 0 calc((100% - 24px) / 2)}
	.container{padding-left:24px;padding-right:24px}
}
/* iPhone Plus / Galaxy Note size */
@media (min-width:421px) and (max-width:760px){
	.container{padding-left:20px;padding-right:20px}
}

/* SB-POST-HERO */
.post-hero{position:relative;min-height:62vh;background-size:cover;background-position:center;background-color:var(--ink,#0e2440);background-repeat:no-repeat;display:flex;align-items:flex-end;color:#fff;padding:140px 0 60px;overflow:hidden}
.post-hero.no-image{min-height:48vh;background-image:linear-gradient(135deg,#0e2440 0%,#0e72b9 100%)}
.post-hero-overlay{position:absolute;inset:0;background:linear-gradient(135deg,rgba(15,36,64,.55) 0%,rgba(14,114,185,.30) 50%,rgba(15,36,64,.88) 100%);z-index:1;pointer-events:none}
.post-hero-inner{position:relative;z-index:2;max-width:880px;width:100%}
.post-hero .crumbs{color:rgba(255,255,255,.82);font-size:13px;margin-bottom:18px;letter-spacing:.04em}
.post-hero .crumbs a{color:#fff;text-decoration:none;border-bottom:1px solid rgba(255,255,255,.3);padding-bottom:1px;transition:border-color .2s}
.post-hero .crumbs a:hover{border-bottom-color:#fff}
.post-hero .eyebrow{display:inline-block;color:rgba(255,255,255,.9);font-size:13px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;margin-bottom:12px;background:rgba(14,114,185,.55);padding:6px 14px;border-radius:99px;backdrop-filter:blur(4px)}
.post-hero h1{color:#fff;font-size:clamp(28px, 4.5vw, 56px);line-height:1.12;font-weight:600;letter-spacing:-.015em;margin:0;text-shadow:0 2px 24px rgba(0,0,0,.25);max-width:18ch}
.post-hero h1 b{font-weight:800;background:linear-gradient(90deg,#fff 0%,#9ed5f5 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}

.post-content{font-size:17px;line-height:1.72;color:#222}
.post-content p{margin:0 0 24px}
.post-content h2{font-size:28px;font-weight:600;color:var(--ink,#0e2440);margin:48px 0 16px;line-height:1.25}
.post-content h3{font-size:22px;font-weight:600;color:var(--ink,#0e2440);margin:32px 0 12px}
.post-content img{border-radius:6px;margin:24px 0;height:auto;max-width:100%}
.post-content a{color:var(--blue,#0e72b9);text-decoration:underline;text-decoration-color:rgba(14,114,185,.3);text-underline-offset:3px;transition:text-decoration-color .2s}
.post-content a:hover{text-decoration-color:var(--blue,#0e72b9)}
.post-content blockquote{border-left:3px solid var(--blue,#0e72b9);margin:32px 0;padding:8px 0 8px 24px;font-style:italic;color:#444}
.post-content ul,.post-content ol{margin:0 0 24px;padding-left:28px}
.post-content li{margin-bottom:8px}

@media (max-width:760px){
	.post-hero{min-height:50vh;padding:120px 0 40px}
	.post-hero h1{font-size:clamp(24px, 8vw, 36px)}
	.post-content{font-size:16px}
	.post-content h2{font-size:24px}
}

/* SB-INFINITE-LOADER */
.infinite-status{display:flex;flex-direction:column;align-items:center;gap:16px;padding:60px 20px;color:#666}
.infinite-status .loader{display:flex;gap:6px}
.infinite-status .loader span{width:10px;height:10px;border-radius:50%;background:var(--blue,#0e72b9);opacity:.3;animation:sb-bounce 1.2s infinite ease-in-out}
.infinite-status .loader span:nth-child(2){animation-delay:.15s}
.infinite-status .loader span:nth-child(3){animation-delay:.3s}
.infinite-status .loader-text{font-size:14px;margin:0;letter-spacing:.04em}
.infinite-status:not(.is-loading) .loader{opacity:.3}
.infinite-status.all-loaded .loader{display:none}
.infinite-status.error .loader{display:none}
@keyframes sb-bounce{0%,80%,100%{transform:scale(.6);opacity:.3}40%{transform:scale(1);opacity:1}}

/* SB-PRESS-CLIENTS-WHITE */
.press-section{background:#ffffff;padding:80px 0}
.clients-section{background:#ffffff;padding:80px 0}
.press-section .logo-cell,.clients-section .logo-cell{background:transparent}
/* mix-blend rimosso: PNG con alpha vera ora */

/* SB-BLOOM-ALPHA-NATIVE */
.bloom-deco{position:relative;aspect-ratio:9/16;background:transparent;overflow:hidden;will-change:transform;width:100%;max-width:480px;margin:0 auto}
.bloom-deco video{position:absolute;inset:0;width:100%;height:100%;object-fit:contain;display:block;background:transparent !important;mix-blend-mode:normal}
/* Fallback per browser senza supporto alpha (Safari < 16): mix-blend funziona meglio su bg chiaro */
@supports not (selector(:has(*))) { /* Safari <16 hack indiretto */
	.bloom-deco video{mix-blend-mode:multiply}
}
@media (max-width:760px){.bloom-deco{max-width:320px}}

/* SB-WHITE-SECTIONS-TITLES */
.clients-section h3{color:var(--ink,#0e2440) !important}
.clients-section h3 b{color:var(--blue,#0e72b9) !important}
.press-section h3{color:var(--ink,#0e2440) !important}
.press-section h3 b{color:var(--blue,#0e72b9) !important}
.section-title-center{color:var(--ink,#0e2440) !important}
.section-title-center b{color:var(--blue,#0e72b9) !important}

/* SB-SVC-GALLERY */
.svc-gallery-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.svc-gallery-item{display:block;text-decoration:none;color:inherit;border-radius:8px;overflow:hidden;background:#f7f9fc;transition:transform .3s,box-shadow .3s;position:relative}
.svc-gallery-item:hover{transform:translateY(-4px);box-shadow:0 20px 40px rgba(15,36,64,.12)}
.svc-gallery-img{aspect-ratio:16/10;overflow:hidden;background:#e5e8ee}
.svc-gallery-img img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .5s}
.svc-gallery-item:hover .svc-gallery-img img{transform:scale(1.04)}
.svc-gallery-img .placeholder{width:100%;height:100%;background:linear-gradient(135deg,#0e72b9 0%,#0f2440 100%)}
.svc-gallery-meta{padding:20px 22px}
.svc-gallery-meta .cat{display:inline-block;font-size:11px;letter-spacing:.14em;text-transform:uppercase;font-weight:700;color:#0e72b9;margin-bottom:8px}
.svc-gallery-meta h4{font-size:17px;font-weight:600;color:#0f2440;margin:0;line-height:1.35;letter-spacing:-.005em}
.svc-cta .cta-btn:hover{background:#0e72b9 !important;color:#fff !important;transform:translateY(-2px)}
@media (max-width:900px){.svc-gallery-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:560px){.svc-gallery-grid{grid-template-columns:1fr}}

/* SB-IFRAME-FIT */
/* Reel YT (3 in home) — iframe deve riempire il container 9/16 */
.reels-grid .reel-card,.reels-grid .reel-card.yt-reel{position:relative;aspect-ratio:9/16;background:#0e2440;overflow:hidden;display:block;cursor:pointer;transition:transform .35s,box-shadow .35s;text-decoration:none;color:inherit}
.reels-grid .reel-card iframe{position:absolute !important;inset:0 !important;width:100% !important;height:100% !important;border:0 !important;display:block;pointer-events:auto}
.reels-grid .reel-card .tag,.reels-grid .reel-card .yt-link,.reels-grid .reel-card .meta{z-index:3}

/* Hero showreel — wrapper 9/16, iframe fill */
.hero-video-wrap{position:relative;overflow:hidden;aspect-ratio:9/16;max-width:380px;background:#0e2440;border-radius:6px}
.hero-video-yt{position:absolute;inset:0}
.hero-video-yt iframe{position:absolute !important;inset:0 !important;width:100% !important;height:100% !important;border:0 !important;transform:none !important;display:block}
.vid-label{position:absolute;top:12px;left:12px;background:rgba(255,255,255,.95);color:#0e72b9;padding:4px 10px;font-size:10px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;z-index:3;border-radius:2px}
@media (max-width:760px){.hero-video-wrap{max-width:280px;margin:0 auto}}

/* SB-YT-FACADE */
.yt-facade-play{position:absolute;inset:0;width:100%;height:100%;border:0;padding:0;cursor:pointer;background:#000;overflow:hidden;display:block;z-index:2;transition:transform .35s}
.yt-facade-thumb{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block;transition:transform .5s,filter .3s;filter:brightness(.9)}
.yt-facade-play:hover .yt-facade-thumb{transform:scale(1.04);filter:brightness(1)}
.yt-facade-icon{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);z-index:3;display:flex;align-items:center;justify-content:center;pointer-events:none;transition:transform .25s}
.yt-facade-play:hover .yt-facade-icon{transform:translate(-50%,-50%) scale(1.1)}
.yt-facade-icon svg{filter:drop-shadow(0 4px 12px rgba(0,0,0,.5))}

/* SB-FINAL-OVERRIDES */
/* 1. Testimonial card: testi nome/ruolo/azienda LEGGIBILI su sfondo bianco */
.testimonials .t-card,.testimonials-section .t-card{background:#fff !important;color:#1a1a1a}
.testimonials .t-card .quote,.testimonials-section .t-card .quote{color:#2a2a30 !important}
.testimonials .t-card .author{border-top-color:#e5e5e7 !important}
.testimonials .t-card .author .info .n,.testimonials-section .t-card .author .info .n{color:#0e2440 !important;font-weight:700 !important;font-size:14px !important;line-height:1.3}
.testimonials .t-card .author .info .r,.testimonials-section .t-card .author .info .r{color:#666 !important;font-weight:500 !important;font-size:12px !important;margin-top:3px !important;letter-spacing:.02em}
.t-card .author .info{flex:1;min-width:0}
.t-card .author{display:flex !important;align-items:center !important;gap:12px !important}

/* 2. Loghi clienti/press: NIENTE mix-blend, alpha PNG vera */
.logo-cell img,.press-section .logo-cell img,.clients-section .logo-cell img,.logo-grid .logo-cell img{mix-blend-mode:normal !important;filter:none !important}

/* 3. Sezioni press/clients SFONDO BIANCO esplicito */
section.press-section,section.clients-section{background:#ffffff !important}

/* 4. Bloom video: mix-blend multiply per Safari fallback (Safari non supporta VP9 alpha) */
.bloom-deco{background:transparent !important}
.bloom-deco video{mix-blend-mode:multiply !important;background:transparent !important}
/* La sezione manifesto deve avere sfondo NON-bianco perchè multiply contro bianco = no-op */
.manifesto{background:#ebebec !important}

/* 5. Reel mobile: thumbnail full cover, no letterbox */
.yt-facade-thumb{object-fit:cover !important;width:100% !important;height:100% !important}

/* 6. Bloom mostrato anche su mobile (mai display:none) */
.bloom-deco{display:block !important;width:100% !important;max-width:380px;margin:0 auto;aspect-ratio:9/16;position:relative;overflow:hidden}
@media (max-width:760px){.bloom-deco{max-width:280px;margin-top:32px}}

/* SB-LOGO-CLEAN-FINAL */
.press-section .logo-cell img,
.clients-section .logo-cell img,
.logo-grid .logo-cell img{
	max-width:100% !important;
	max-height:100% !important;
	width:auto !important;
	height:auto !important;
	object-fit:contain !important;
	filter:none !important;
	mix-blend-mode:normal !important;
	opacity:1 !important;
	transition:transform .25s !important;
}
.press-section .logo-cell:hover img,
.clients-section .logo-cell:hover img,
.logo-grid .logo-cell:hover img{
	filter:none !important;
	opacity:1 !important;
	transform:scale(1.05);
}
.press-section,.clients-section{background:#ffffff !important}
.press-section .logo-cell,.clients-section .logo-cell{background:transparent !important;border:0 !important}

/* SB-HEADER-INNER-PAGES-FIX */
/* Pagine interne (non home, non template front-page): mostra logo-color SENZA filter, nascondi logo-white */
body:not(.home):not(.page-template-front-page) .site-header:not(.is-scrolled):not(.is-solid) .brand .logo-color{
	opacity:1 !important;
	filter:none !important;
	display:inline-block !important;
}
body:not(.home):not(.page-template-front-page) .site-header:not(.is-scrolled):not(.is-solid) .brand .logo-white{
	opacity:0 !important;
	display:none !important;
}
body:not(.home):not(.page-template-front-page) .site-header:not(.is-scrolled):not(.is-solid) .brand img{
	filter:none !important;
}
/* Header su pagine interne: anche menu items in scuro */
body:not(.home):not(.page-template-front-page) .site-header:not(.is-scrolled):not(.is-solid) .nav-links a{
	color:var(--ink, #0e2440) !important;
}
body:not(.home):not(.page-template-front-page) .site-header:not(.is-scrolled):not(.is-solid) .nav-links a.cta-btn{
	color:#fff !important;
}


/* SB-MOBILE-FIXES-IPHONE */
/* === Loghi clienti più GRANDI === */
.logo-grid.clients-grid{gap:32px 28px}
.logo-grid.clients-grid .logo-cell,.logo-grid.press-grid .logo-cell{max-width:200px;padding:14px}
.logo-grid.clients-grid .logo-cell img,.logo-grid.press-grid .logo-cell img{max-width:100% !important;max-height:none !important;width:100% !important;height:auto !important}
@media (min-width:761px){
	.logo-grid.clients-grid .logo-cell{max-width:220px;padding:18px}
	.logo-grid.press-grid .logo-cell{max-width:200px;padding:18px}
}

/* === Press grid: RIMUOVO bordi laterali === */
.logo-grid.press-grid,.logo-grid.clients-grid{
	border:0 !important;
	box-shadow:none !important;
	outline:0 !important;
	padding:0 !important;
}
.logo-grid.press-grid::before,.logo-grid.press-grid::after,
.logo-grid.clients-grid::before,.logo-grid.clients-grid::after{display:none !important}

/* === Trust strip mobile: tipo carte / leggibile === */
.trust-strip{padding:50px 0;background:linear-gradient(135deg,#0e72b9 0%,#0f2440 100%);color:#fff;text-align:center}
.trust-strip .container{display:flex;flex-wrap:wrap;justify-content:center;align-items:center;gap:14px 24px;font-size:15px;font-weight:300;color:rgba(255,255,255,.92);letter-spacing:.01em}
.trust-strip strong{font-weight:700;color:#fff;font-size:1.08em}
.trust-strip span{display:inline-flex;align-items:center}
@media (max-width:760px){
	.trust-strip{padding:28px 0}
	.trust-strip .container{flex-direction:column;gap:14px;font-size:14px;padding:0 24px}
	.trust-strip span{display:block;text-align:center;padding:8px 16px;background:rgba(255,255,255,.08);border-radius:100px;border:1px solid rgba(255,255,255,.18);font-size:13px;letter-spacing:.04em;text-transform:uppercase;font-weight:600}
	.trust-strip .container > *:not(span){display:none}
}

/* === Bloom image (sostituisce video) === */
.bloom-deco{position:relative;width:100%;max-width:480px;margin:0 auto;background:transparent}
.bloom-image{display:block;width:100%;height:auto;background:transparent;animation:bloomFloat 6s ease-in-out infinite;mix-blend-mode:normal}
@keyframes bloomFloat{
	0%,100%{transform:translateY(0) rotate(0deg);filter:hue-rotate(0deg) saturate(1)}
	50%{transform:translateY(-8px) rotate(-.5deg);filter:hue-rotate(-3deg) saturate(1.08)}
}
@media (prefers-reduced-motion: reduce){.bloom-image{animation:none}}
@media (max-width:760px){.bloom-deco{max-width:320px}}

/* === Hero showreel mobile: rendi visibile sotto l'hero text === */
@media (max-width:900px){
	.hero-grid{grid-template-columns:1fr;gap:32px}
	.hero-video-wrap{display:block !important;max-width:280px;margin:0 auto}
}

/* === Form multistep: riduci interlinea pulsanti budget su mobile === */
@media (max-width:760px){
	.sb-option-grid{grid-template-columns:1fr;gap:8px !important}
	.sb-option{padding:14px 18px !important;font-size:14.5px !important;min-height:auto !important;margin:0 !important}
	.sb-fields-row{gap:12px}
	.sb-step h3{font-size:22px !important;margin-bottom:20px !important}
	.sb-progress{margin-bottom:24px !important}
}

/* === Press section: riduci padding mobile per più aria === */
@media (max-width:760px){
	.press-section,.clients-section{padding:48px 0 !important}
	.section-title-center{font-size:22px;margin-bottom:28px}
}


/* SB-MOBILE-MENU-REDESIGN */
/* === Menu mobile completamente ridisegnato === */
@media (max-width:780px){
	.nav-links{list-style:none !important;padding:0 !important;margin:0 !important}
	.nav-links li{list-style:none !important;list-style-type:none !important;display:block !important}
	.nav-links li::marker{display:none !important;content:'' !important}
	.nav-links.open{
		display:flex !important;
		position:fixed !important;
		top:0 !important;
		left:0 !important;
		right:0 !important;
		bottom:0 !important;
		width:100vw !important;
		height:100vh !important;
		min-height:100vh !important;
		flex-direction:column !important;
		background:linear-gradient(135deg,#ffffff 0%,#f4f9fd 60%,#e6f0fa 100%) !important;
		padding:90px 32px 32px 32px !important;
		gap:0 !important;
		align-items:stretch !important;
		justify-content:flex-start !important;
		border:0 !important;
		box-shadow:none !important;
		z-index:1000 !important;
		overflow-y:auto !important;
		list-style:none !important;
		animation:menuSlideIn .35s cubic-bezier(.22,1,.36,1)
	}
	@keyframes menuSlideIn{
		from{opacity:0;transform:translateY(-8px)}
		to{opacity:1;transform:translateY(0)}
	}
	.nav-links.open li{
		display:block !important;
		width:100% !important;
		margin:0 !important;
		padding:0 !important;
		border-bottom:1px solid rgba(15,36,64,.08);
		list-style:none !important;
	}
	.nav-links.open li:last-child{border-bottom:0 !important;margin-top:24px}
	.nav-links.open a{
		display:block !important;
		width:100% !important;
		padding:22px 8px !important;
		font-size:18px !important;
		font-weight:600 !important;
		letter-spacing:.02em !important;
		text-transform:none !important;
		color:#0f2440 !important;
		position:relative !important;
		transition:color .25s,transform .25s,padding-left .25s !important;
	}
	.nav-links.open a::before{
		content:'' !important;
		position:absolute !important;
		left:0 !important;
		top:50% !important;
		width:0 !important;
		height:2px !important;
		background:linear-gradient(90deg,#0e72b9,#1ba0e0) !important;
		transform:translateY(-50%) !important;
		transition:width .3s ease !important;
	}
	.nav-links.open a::after{display:none !important}
	.nav-links.open a:hover,
	.nav-links.open a.active{
		color:#0e72b9 !important;
		padding-left:20px !important;
	}
	.nav-links.open a:hover::before,
	.nav-links.open a.active::before{
		width:12px !important;
	}
	.nav-links.open a.cta-btn{
		background:linear-gradient(135deg,#0e72b9 0%,#0f2440 100%) !important;
		color:#fff !important;
		border-radius:14px !important;
		padding:20px 28px !important;
		text-align:center !important;
		font-size:16px !important;
		font-weight:700 !important;
		letter-spacing:.04em !important;
		text-transform:uppercase !important;
		box-shadow:0 10px 30px -6px rgba(14,114,185,.45) !important;
	}
	.nav-links.open a.cta-btn::before{display:none !important}
	.nav-links.open a.cta-btn:hover{
		transform:translateY(-2px) !important;
		padding-left:28px !important;
		box-shadow:0 14px 35px -6px rgba(14,114,185,.55) !important;
	}
	/* Burger animato quando aperto */
	body.menu-open{position:fixed;left:0;right:0;width:100%;overflow:hidden}
	.burger.is-active span{background:transparent !important}
	.burger.is-active span::before{transform:translateY(6px) rotate(45deg)}
	.burger.is-active span::after{transform:translateY(-6px) rotate(-45deg)}
	.burger{z-index:1001 !important}
}

/* SB-CASE-CTA */
/* CTA in fondo a ogni single case_study */
.sb-case-cta-section{padding:60px 0;background:linear-gradient(135deg,#0e72b9 0%,#0f2440 100%);text-align:center;color:#fff;margin-top:60px}
.sb-case-cta-section h3{font-size:28px;font-weight:300;line-height:1.3;margin:0 0 14px 0;color:#fff}
.sb-case-cta-section h3 b{font-weight:700;color:#9ed5f5}
.sb-case-cta-section .sb-case-cta-btn{
	display:inline-flex;align-items:center;gap:10px;
	padding:18px 36px;border-radius:0;
	background:#fff;color:#0e72b9;font-weight:700;font-size:15px;
	letter-spacing:.06em;text-transform:uppercase;
	transition:transform .25s,box-shadow .25s,background .25s;
	text-decoration:none;margin-top:14px
}
.sb-case-cta-section .sb-case-cta-btn:hover{transform:translateY(-3px);box-shadow:0 14px 30px -6px rgba(0,0,0,.3);background:#f4d35e;color:#0f2440}
.sb-case-cta-section .sb-case-cta-btn .arrow{display:inline-block;transition:transform .25s}
.sb-case-cta-section .sb-case-cta-btn:hover .arrow{transform:translateX(4px)}
@media (max-width:760px){
	.sb-case-cta-section{padding:48px 24px}
	.sb-case-cta-section h3{font-size:22px}
	.sb-case-cta-section .sb-case-cta-btn{padding:16px 28px;font-size:13px}
}


/* SB-HERO-VIDEO-MOBILE-FIX */
/* Hero showreel: dimensioni esplicite su mobile per WebKit */
@media (max-width:900px){
	.hero-grid{grid-template-columns:1fr !important;gap:36px;justify-items:center}
	.hero-left{order:1}
	.hero-video-wrap{
		order:2 !important;
		display:block !important;
		width:280px !important;
		max-width:280px !important;
		height:498px !important;
		min-height:498px !important;
		margin:0 auto !important;
		position:relative !important;
		overflow:hidden !important;
		background:#0e2440 !important;
		border-radius:8px !important;
	}
	.hero-video-yt{position:absolute !important;inset:0 !important;width:100% !important;height:100% !important}
	.hero-video-yt iframe{position:absolute !important;inset:0 !important;width:100% !important;height:100% !important;border:0 !important}
}
@media (max-width:480px){
	.hero-video-wrap{width:260px !important;height:462px !important;min-height:462px !important}
}


/* SB-COSAFACCIAMO-MEDIA */
.service-card-media{position:relative;overflow:hidden}
.service-card-thumb{position:relative;width:100%;aspect-ratio:16/9;overflow:hidden;background:#0e2440;margin:0 0 22px 0;border-radius:6px}
.service-card-thumb-img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .6s ease}
.service-card-media:hover .service-card-thumb-img{transform:scale(1.05)}
.service-card-thumb-video{cursor:pointer}
.service-card-thumb-video .yt-facade-play{width:100%;height:100%;border:0;padding:0;background:#000;position:relative;cursor:pointer;display:block}
.service-card-thumb-video .yt-facade-thumb{width:100%;height:100%;object-fit:cover;filter:brightness(.85);transition:filter .3s,transform .5s}
.service-card-thumb-video .yt-facade-icon{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);transition:transform .25s}
.service-card-thumb-video:hover .yt-facade-thumb{filter:brightness(1);transform:scale(1.04)}
.service-card-thumb-video:hover .yt-facade-icon{transform:translate(-50%,-50%) scale(1.1)}


/* SB-FORM-DICTATE */
.sb-textarea-wrap{position:relative}
.sb-textarea-wrap textarea{padding-right:90px}
.sb-dictate-btn{
	position:absolute;top:8px;right:8px;
	display:inline-flex;align-items:center;gap:6px;
	padding:8px 12px;border-radius:20px;
	background:#0e72b9;color:#fff;border:0;
	font-size:12px;font-weight:600;letter-spacing:.04em;
	cursor:pointer;transition:all .25s;
	box-shadow:0 2px 8px rgba(14,114,185,.3);z-index:2
}
.sb-dictate-btn:hover{background:#0a5e9c;transform:translateY(-1px);box-shadow:0 4px 12px rgba(14,114,185,.4)}
.sb-dictate-btn[data-state='recording']{background:#e74c3c;animation:dictPulse 1.4s infinite}
@keyframes dictPulse{0%,100%{box-shadow:0 0 0 0 rgba(231,76,60,.5)}50%{box-shadow:0 0 0 10px rgba(231,76,60,0)}}
.sb-dictate-btn .sb-mic-icon{flex-shrink:0}
.sb-dictate-hint{margin-top:8px;padding:10px 14px;background:#fff3cd;color:#856404;border-radius:6px;font-size:13px;display:flex;align-items:center;gap:12px;justify-content:space-between}
.sb-dictate-stop{padding:6px 14px;background:#e74c3c;color:#fff;border:0;border-radius:14px;font-size:11px;font-weight:700;cursor:pointer;text-transform:uppercase;letter-spacing:.06em}
.sb-dictate-stop:hover{background:#c0392b}
.sb-audio-alt{margin-top:14px}
.sb-audio-alt summary{cursor:pointer;font-size:14px;color:#0e72b9;padding:10px 0;list-style:none;font-weight:600;user-select:none}
.sb-audio-alt summary::-webkit-details-marker{display:none}
.sb-audio-alt summary::before{content:'+ ';font-weight:700;margin-right:4px}
.sb-audio-alt[open] summary::before{content:'− '}
.sb-audio-input-wrap{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-top:10px}
#sb-audio-input{position:absolute;left:-9999px;opacity:0}
.sb-audio-label{display:inline-flex;align-items:center;gap:6px;padding:10px 16px;background:#f4f9fd;border:1px dashed #0e72b9;color:#0e72b9;border-radius:6px;font-size:13px;font-weight:600;cursor:pointer;transition:all .2s}
.sb-audio-label:hover{background:#e6f0fa}
.sb-audio-filename{font-size:13px;color:#555}
.sb-audio-note{margin:8px 0 0;font-size:12px;color:#777;line-height:1.5}
@media (max-width:760px){
	.sb-dictate-btn .sb-dictate-label{display:none}
	.sb-dictate-btn{padding:8px}
	.sb-textarea-wrap textarea{padding-right:52px}
}


/* SB-VOICE-ONLY */
.sb-voice-intro{margin:14px auto 0;font-size:17px;color:#0e72b9;font-weight:400}
.sb-voice-intro b{font-weight:700;color:#0f2440}
.sb-voice-only{max-width:560px;margin:0 auto 60px;padding:0 16px}
.sb-voice-stage{
	position:relative;border-radius:20px;
	background:linear-gradient(135deg,#0e72b9 0%,#0f2440 100%);
	color:#fff;padding:44px 32px;
	box-shadow:0 24px 60px -20px rgba(14,114,185,.4);
	overflow:hidden;min-height:280px
}
.sb-voice-stage::before{
	content:'';position:absolute;top:-50%;right:-30%;
	width:400px;height:400px;border-radius:50%;
	background:radial-gradient(circle,rgba(244,211,94,.15) 0%,transparent 60%);
	pointer-events:none
}
.sb-voice-pane{display:none;text-align:center;position:relative;z-index:1}
.sb-voice-stage[data-stage='idle'] .sb-voice-pane-idle{display:block}
.sb-voice-stage[data-stage='recording'] .sb-voice-pane-recording{display:block}
.sb-voice-stage[data-stage='review'] .sb-voice-pane-review{display:block}
.sb-voice-stage[data-stage='success'] .sb-voice-pane-success{display:block}

/* IDLE */
.sb-voice-record-btn{
	display:inline-flex;align-items:center;gap:14px;
	background:#fff;color:#0e72b9;
	border:0;border-radius:60px;
	padding:20px 36px 20px 28px;
	font-size:17px;font-weight:700;letter-spacing:.02em;
	cursor:pointer;
	transition:all .3s cubic-bezier(.22,1,.36,1);
	box-shadow:0 12px 30px -8px rgba(0,0,0,.35),0 0 0 0 rgba(244,211,94,.5)
}
.sb-voice-record-btn:hover{transform:translateY(-3px);box-shadow:0 16px 40px -8px rgba(0,0,0,.45),0 0 0 8px rgba(244,211,94,.15)}
.sb-voice-record-btn:active{transform:translateY(-1px)}
.sb-voice-mic-icon{display:inline-flex;align-items:center;justify-content:center;width:46px;height:46px;border-radius:50%;background:linear-gradient(135deg,#0e72b9,#0f2440);color:#fff;flex-shrink:0}
.sb-voice-help{margin:24px 0 0;font-size:14px;color:rgba(255,255,255,.78);font-weight:300;max-width:340px;margin-left:auto;margin-right:auto;line-height:1.55}

/* RECORDING */
.sb-voice-pulse{position:relative;width:120px;height:120px;margin:0 auto 18px}
.sb-voice-pulse span{position:absolute;inset:0;margin:auto;width:42px;height:42px;border-radius:50%;background:#e74c3c;animation:vpulse 1.5s infinite}
.sb-voice-pulse span:nth-child(2){animation-delay:.4s}
.sb-voice-pulse span:nth-child(3){animation-delay:.8s}
@keyframes vpulse{0%{transform:scale(.7);opacity:.9}80%,100%{transform:scale(2.2);opacity:0}}
.sb-voice-pulse::before{
	content:'';position:absolute;inset:0;margin:auto;
	width:42px;height:42px;border-radius:50%;
	background:radial-gradient(circle,#fff 30%,#f4d35e 100%);
	z-index:2;box-shadow:0 0 30px rgba(244,211,94,.6)
}
.sb-voice-timer{font-size:36px;font-weight:300;letter-spacing:.04em;font-variant-numeric:tabular-nums;margin-bottom:8px}
.sb-voice-status{font-size:14px;color:#f4d35e;text-transform:uppercase;letter-spacing:.16em;font-weight:600;margin-bottom:24px}
.sb-voice-stop-btn{
	display:inline-flex;align-items:center;gap:10px;
	background:#e74c3c;color:#fff;border:0;border-radius:50px;
	padding:14px 28px;font-size:14px;font-weight:700;letter-spacing:.08em;
	text-transform:uppercase;cursor:pointer;transition:all .25s;
	box-shadow:0 6px 18px rgba(231,76,60,.4)
}
.sb-voice-stop-btn:hover{background:#c0392b;transform:translateY(-1px);box-shadow:0 8px 22px rgba(231,76,60,.5)}

/* REVIEW */
.sb-voice-preview{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.18);border-radius:14px;padding:18px;margin-bottom:24px}
.sb-voice-preview audio{width:100%;display:block;filter:invert(.9)}
.sb-voice-meta{display:flex;justify-content:space-between;align-items:center;margin-top:12px;font-size:13px}
.sb-voice-meta #sbVoiceDuration{color:rgba(255,255,255,.7);font-variant-numeric:tabular-nums}
.sb-voice-rerec{background:transparent;color:#9ed5f5;border:0;cursor:pointer;font-size:13px;font-weight:600;text-decoration:underline}
.sb-voice-rerec:hover{color:#f4d35e}
.sb-voice-form-title{font-size:20px;font-weight:300;margin:0 0 18px;text-align:left;color:#fff}
.sb-voice-form-title b{font-weight:700;color:#f4d35e}
.sb-voice-fields{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:14px;text-align:left}
.sb-voice-field label{display:block;font-size:11px;color:rgba(255,255,255,.7);font-weight:600;letter-spacing:.1em;text-transform:uppercase;margin-bottom:6px}
.sb-voice-field input{width:100%;padding:11px 14px;border-radius:8px;border:1px solid rgba(255,255,255,.2);background:rgba(255,255,255,.08);color:#fff;font-size:15px;font-family:inherit;transition:all .25s;box-sizing:border-box}
.sb-voice-field input:focus{outline:0;border-color:#f4d35e;background:rgba(255,255,255,.15)}
.sb-voice-field input::placeholder{color:rgba(255,255,255,.4)}
.sb-voice-privacy{display:block;font-size:13px;color:rgba(255,255,255,.78);font-weight:400;text-align:left;margin:14px 0 18px;line-height:1.5;padding-left:28px;position:relative;cursor:pointer}.sb-voice-privacy input{position:absolute;left:0;top:3px;margin:0;flex-shrink:0;accent-color:#f4d35e;width:18px;height:18px}

.sb-voice-privacy a{color:#f4d35e;text-decoration:underline}
.sb-voice-submit{
	width:100%;background:#f4d35e;color:#0f2440;
	border:0;border-radius:50px;padding:18px 28px;
	font-size:15px;font-weight:800;letter-spacing:.06em;text-transform:uppercase;
	cursor:pointer;transition:all .25s;
	box-shadow:0 8px 22px rgba(244,211,94,.35)
}
.sb-voice-submit:hover{transform:translateY(-2px);box-shadow:0 12px 28px rgba(244,211,94,.5)}
.sb-voice-submit:disabled{opacity:.6;cursor:wait}

/* SUCCESS */
.sb-voice-pane-success{padding:30px 10px}
.sb-voice-check{
	width:80px;height:80px;border-radius:50%;
	background:#f4d35e;color:#0f2440;
	font-size:42px;font-weight:800;
	display:flex;align-items:center;justify-content:center;
	margin:0 auto 20px;
	box-shadow:0 10px 30px rgba(244,211,94,.4);
	animation:vSuccessIn .5s cubic-bezier(.22,1.4,.36,1)
}
@keyframes vSuccessIn{from{transform:scale(0)}to{transform:scale(1)}}
.sb-voice-pane-success h4{font-size:22px;font-weight:300;margin:0 0 8px;color:#fff}
.sb-voice-pane-success p{font-size:15px;color:rgba(255,255,255,.78);margin:0}

/* SEPARATOR */
.sb-voice-or{display:flex;align-items:center;gap:20px;margin:36px auto 28px;max-width:480px}
.sb-voice-or::before,.sb-voice-or::after{content:'';flex:1;height:1px;background:rgba(15,36,64,.15)}
.sb-voice-or span{font-size:13px;color:#999;letter-spacing:.06em;text-transform:uppercase;font-weight:600}

/* MOBILE */
@media (max-width:600px){
	.sb-voice-only{padding:0 12px;margin-bottom:40px}
	.sb-voice-stage{padding:32px 22px;border-radius:16px}
	.sb-voice-record-btn{padding:16px 24px 16px 18px;font-size:15px;gap:12px}
	.sb-voice-mic-icon{width:40px;height:40px}
	.sb-voice-mic-icon svg{width:28px;height:28px}
	.sb-voice-timer{font-size:30px}
	.sb-voice-fields{grid-template-columns:1fr;gap:10px}
	.sb-voice-form-title{font-size:18px}
	.sb-voice-submit{font-size:13px;padding:16px 22px}
}

/* Browser non supportato */
.sb-voice-only.sb-voice-unsupported{display:none}

/* === SB-BLOOM-APNG (override) === */
.bloom-deco{position:relative;width:100%;max-width:380px;margin:0 auto;background:transparent;display:block !important;aspect-ratio:auto}
.bloom-image-wrap{display:block;width:100%;line-height:0}
.bloom-image{display:block;width:100%;height:auto;background:transparent;animation:none;mix-blend-mode:normal;opacity:0;transition:opacity .8s ease-out}
.bloom-image.is-loaded,.bloom-image[src]{opacity:1}
.bloom-deco picture{display:block;width:100%}
@media (max-width:760px){.bloom-deco{max-width:300px;margin-top:24px}}
@media (prefers-reduced-motion: reduce){
	/* APNG continua a riprodursi: per il rispetto di reduced-motion useremo il poster statico via JS se necessario */
	.bloom-image{animation:none}
}
/* End SB-BLOOM-APNG */



/* ============ PAGESPEED LCP FIX ============ */
/* 1. Hero elements: skip reveal animation — visibili al first paint */
.hero .reveal,
.hero .reveal-stagger > *{opacity:1 !important;transform:none !important;transition:none !important}
/* 2. Hero su mobile: align-items: flex-start invece di center, riduce min-height */
@media (max-width: 768px){
  .hero{min-height:auto;align-items:flex-start;padding-top:100px;padding-bottom:50px}
  .hero-left h1{margin-top:0}
}
/* 3. Hero H1 priorità render */
.hero-left h1{contain:layout style;content-visibility:visible}


/* ============ HERO YT FACADE ============ */
.hero-video-wrap[data-yt-id]{position:relative;width:100%;max-width:380px;aspect-ratio:9/16;justify-self:end}
@media (max-width:760px){.hero-video-wrap[data-yt-id]{max-width:280px;justify-self:center}}
.hero-video-poster{position:absolute;inset:0;width:100%;height:100%;display:block;transition:opacity .5s ease;z-index:1}
.hero-video-poster img{width:100%;height:100%;object-fit:cover;display:block}
.hero-video-play{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:64px;height:64px;background:transparent;border:0;cursor:pointer;z-index:2;padding:0;transition:opacity .5s ease}
.hero-video-play:hover{transform:translate(-50%,-50%) scale(1.08)}
.hero-video-yt iframe{z-index:3}


/* ============ FIX HEADER OVER POST-HERO IMAGE ============ */
/* Su single post (news, case_study, servizio) con hero image full-bleed, il header
   deve essere chiaramente leggibile sopra l'immagine. */

/* 1) Overlay pi\00f9 scuro in alto (dove sta il header) \2014 gradient da molto scuro a meno scuro */
.post-hero.has-image .post-hero-overlay{
  background:linear-gradient(180deg,
    rgba(15,36,64,.85) 0%,
    rgba(15,36,64,.55) 18%,
    rgba(15,36,64,.35) 45%,
    rgba(15,36,64,.55) 75%,
    rgba(15,36,64,.92) 100%) !important;
}

/* 2) Su single posts: forza logo BIANCO + nav BIANCA in stato non-scrolled */
body.single .site-header:not(.is-scrolled):not(.is-solid) .brand .logo-color,
body.single .site-header:not(.is-scrolled):not(.is-solid) .logo-color{
  opacity:0 !important;display:none !important;
}
body.single .site-header:not(.is-scrolled):not(.is-solid) .brand .logo-white,
body.single .site-header:not(.is-scrolled):not(.is-solid) .logo-white{
  opacity:1 !important;display:inline-block !important;
}
body.single .site-header:not(.is-scrolled):not(.is-solid) .brand img{
  filter:none !important;
}
body.single .site-header:not(.is-scrolled):not(.is-solid) .nav-links a{
  color:#fff !important;
}
body.single .site-header:not(.is-scrolled):not(.is-solid) .nav-links a.active{
  color:#9ed5f5 !important;
}
body.single .site-header:not(.is-scrolled):not(.is-solid) .nav-links a.cta-btn{
  color:#fff !important;
}
body.single .site-header:not(.is-scrolled):not(.is-solid) .burger,
body.single .site-header:not(.is-scrolled):not(.is-solid) .burger span,
body.single .site-header:not(.is-scrolled):not(.is-solid) .burger span::before,
body.single .site-header:not(.is-scrolled):not(.is-solid) .burger span::after{
  background:#fff !important;
  border-color:rgba(255,255,255,.4) !important;
}


/* ============ BLOOM HERO IMAGE (cross-browser, alpha PNG/WebP) ============ */
/* Sostituisce il vecchio approccio video+mix-blend-mode (rompeva su Safari) */
.bloom-deco{
  position:relative;
  width:100%;
  max-width:560px !important;
  margin:0 auto;
  background:transparent !important;
  aspect-ratio:9/16;
  overflow:visible;
  display:block;
  opacity:1 !important;
  transform:none !important;
}
.bloom-picture{display:block;width:100%;height:100%}
.bloom-image{
  display:block;
  width:100%;
  height:100%;
  object-fit:contain;
  background:transparent;
  mix-blend-mode:normal;
  animation:bloomFloat 7s ease-in-out infinite;
  will-change:transform;
}
@keyframes bloomFloat{
  0%,100%{transform:translateY(0) rotate(0deg)}
  50%{transform:translateY(-12px) rotate(.4deg)}
}
@media (prefers-reduced-motion: reduce){
  .bloom-image{animation:none}
}
@media (max-width: 760px){
  .bloom-deco{max-width:340px !important;margin-top:16px}
}


/* ============ HOME H1 SEO ============ */
.hero h1 .h1-place{
  display:inline;
  color:rgba(255,255,255,.92);
  font-weight:600;
}
.hero h1 .h1-subtitle{
  display:block;
  font-size:clamp(15px,1.4vw,18px);
  font-weight:400;
  line-height:1.45;
  margin-top:24px;
  color:rgba(255,255,255,.78);
  letter-spacing:-.005em;
  max-width:34em;
}
@media (max-width: 760px){
  .hero h1 .h1-subtitle{
    font-size:14px;
    margin-top:16px;
    max-width:none;
  }
}


/* ============ HOME SERVICES CARDS ============ */
.home-service-card:hover{
  border-color:var(--blue) !important;
  transform:translateY(-3px);
  box-shadow:-6px 6px 0 0 var(--blue);
}
.home-service-card:hover h3{
  color:var(--blue);
}


/* ============ BLOOM FORCE VISIBLE ============ */
.bloom-deco{ opacity: 1 !important; transform: none !important }


/* ============ CASE STUDY: HEADER OVERLAY (stile news) ============ */
.project-hero{
  position:relative;
  background:#fff;
  padding:120px 0 60px;
}
.project-hero.has-image{
  background-size:cover;
  background-position:center;
  background-repeat:no-repeat;
  color:#fff;
  padding:160px 0 80px;
  min-height:520px;
  display:flex;
  align-items:flex-end;
}
.project-hero-overlay{
  position:absolute;
  inset:0;
  background:linear-gradient(180deg, rgba(15,36,64,.30) 0%, rgba(15,36,64,.30) 40%, rgba(15,36,64,.78) 100%);
  z-index:1;
  pointer-events:none;
}
.project-hero.has-image .project-hero-inner{
  position:relative;
  z-index:2;
  color:#fff;
}
.project-hero.has-image .crumbs,
.project-hero.has-image .crumbs a{
  color:rgba(255,255,255,.85) !important;
}
.project-hero.has-image .client-tag{
  background:rgba(255,255,255,.18);
  color:#fff;
  border:1px solid rgba(255,255,255,.35);
  backdrop-filter:blur(4px);
}
.project-hero.has-image h1{
  color:#fff !important;
}
.project-hero.has-image .project-subtitle{
  color:rgba(255,255,255,.88) !important;
}
.project-hero.has-image .summary{
  color:rgba(255,255,255,.82) !important;
}
.project-hero.has-image .project-meta{
  border-top:1px solid rgba(255,255,255,.20);
  padding-top:24px;
  margin-top:32px;
}
.project-hero.has-image .project-meta .k{
  color:rgba(255,255,255,.6) !important;
}
.project-hero.has-image .project-meta .v{
  color:#fff !important;
}
.project-hero.has-image .btn-outline{
  border-color:#fff !important;
  color:#fff !important;
  background:rgba(255,255,255,.08);
  backdrop-filter:blur(6px);
}
.project-hero.has-image .btn-outline:hover{
  background:rgba(255,255,255,.18);
}
/* Body class .single per gestire header bianco sopra l'overlay */
body.single .site-header:not(.is-scrolled):not(.is-solid){
  /* l'header bianco diventa trasparente sopra l'immagine, gi\00e0 gestito da single posts */
}
@media (max-width: 760px){
  .project-hero.has-image{
    padding:140px 0 60px;
    min-height:420px;
  }
}


/* ============ NAV: DROPDOWN SETTORI ============ */
.nav-links{ position:relative }
.nav-links li.has-children{ position:relative }
.nav-links li.has-children > a .dd-arrow{
  display:inline-block;
  margin-left:4px;
  font-size:.8em;
  opacity:.65;
  transition:transform .2s ease;
}
.nav-links li.has-children:hover > a .dd-arrow,
.nav-links li.has-children.is-open > a .dd-arrow{
  transform:rotate(180deg);
  opacity:1;
}

/* Desktop dropdown */
@media (min-width: 901px){
  .nav-links li.has-children .sub-menu{
    list-style:none;
    margin:0;
    padding:10px 0;
    position:absolute;
    top:100%;
    left:50%;
    transform:translateX(-50%) translateY(8px);
    min-width:280px;
    background:#fff;
    border-radius:14px;
    box-shadow:0 14px 40px rgba(15,36,64,.14), 0 2px 8px rgba(15,36,64,.06);
    opacity:0;
    visibility:hidden;
    transition:opacity .18s ease, transform .18s ease, visibility .18s;
    z-index:2000;
  }
  .nav-links li.has-children:hover > .sub-menu,
  .nav-links li.has-children:focus-within > .sub-menu{
    opacity:1;
    visibility:visible;
    transform:translateX(-50%) translateY(0);
  }
  /* Bridge invisibile per evitare gap durante l'hover */
  .nav-links li.has-children::after{
    content:"";
    position:absolute;
    top:100%;
    left:0;
    right:0;
    height:14px;
  }
  .nav-links li.has-children .sub-menu li{
    list-style:none;
    margin:0;
    padding:0;
  }
  .nav-links li.has-children .sub-menu li a{
    display:block;
    padding:10px 22px;
    color:var(--ink);
    font-size:15px;
    font-weight:500;
    line-height:1.35;
    text-decoration:none;
    transition:background .15s ease, color .15s ease;
    white-space:nowrap;
  }
  .nav-links li.has-children .sub-menu li a:hover{
    background:rgba(14,114,185,.08);
    color:var(--blue, #0e72b9);
  }
  .nav-links li.has-children .sub-menu li.active a{
    color:var(--blue, #0e72b9);
    font-weight:600;
  }
}

/* Mobile: sub-menu \00e8 sempre visibile, indented sotto la parent */
@media (max-width: 900px){
  .nav-links li.has-children > a .dd-arrow{ display:none }
  .nav-links li.has-children .sub-menu{
    list-style:none;
    margin:0;
    padding:8px 0 8px 18px;
    border-left:2px solid rgba(14,114,185,.18);
    margin-left:6px;
  }
  .nav-links li.has-children .sub-menu li a{
    display:block;
    padding:8px 0;
    font-size:15px;
    opacity:.85;
  }
  .nav-links li.has-children .sub-menu li.active a{
    color:var(--blue, #0e72b9);
    font-weight:600;
    opacity:1;
  }
}


/* ============ NAV DROPDOWN: color override (header trasparente) ============ */
.site-header .nav-links li.has-children .sub-menu li a,
header .nav-links li.has-children .sub-menu li a{
  color:#0f2440 !important;
}
.site-header .nav-links li.has-children .sub-menu li a:hover,
header .nav-links li.has-children .sub-menu li a:hover{
  color:#0e72b9 !important;
  background:rgba(14,114,185,.08) !important;
}
.site-header .nav-links li.has-children .sub-menu li.active a,
header .nav-links li.has-children .sub-menu li.active a{
  color:#0e72b9 !important;
  font-weight:600;
}


/* ============ NAV DROPDOWN: estetica finale ============ */
@media (min-width: 901px){
  .site-header .nav-links li.has-children .sub-menu,
  header .nav-links li.has-children .sub-menu{
    background:#ffffff !important;
    border:1px solid rgba(15,36,64,.06) !important;
    box-shadow:0 18px 50px rgba(15,36,64,.18), 0 2px 10px rgba(15,36,64,.08) !important;
    padding:8px 0 !important;
    min-width:300px !important;
  }
  .site-header .nav-links li.has-children .sub-menu li a,
  header .nav-links li.has-children .sub-menu li a{
    color:#0f2440 !important;
    background:transparent !important;
    text-transform:none !important;
    letter-spacing:0 !important;
    font-weight:500 !important;
    font-size:15px !important;
    padding:11px 22px !important;
    line-height:1.4 !important;
    border:none !important;
    text-decoration:none !important;
  }
  .site-header .nav-links li.has-children .sub-menu li a:hover,
  header .nav-links li.has-children .sub-menu li a:hover{
    color:#0e72b9 !important;
    background:rgba(14,114,185,.07) !important;
  }
  .site-header .nav-links li.has-children .sub-menu li.active a,
  header .nav-links li.has-children .sub-menu li.active a{
    color:#0e72b9 !important;
    font-weight:600 !important;
  }
}

@media (max-width: 900px){
  .site-header .nav-links li.has-children .sub-menu li a,
  header .nav-links li.has-children .sub-menu li a{
    text-transform:none !important;
    letter-spacing:0 !important;
    font-size:15px !important;
    font-weight:500 !important;
  }
}


/* ============ BLOOM: ex Safari fix — non pi\00f9 necessario (alpha PNG/WebP) ============ */


/* ============ TEMPLATE SETTORE: HERO OVERLAY ============ */
.settore-hero{
  position:relative;
  background:#fff;
  padding:140px 0 80px;
}
.settore-hero.has-image{
  background-size:cover;
  background-position:center;
  background-repeat:no-repeat;
  color:#fff;
  padding:180px 0 100px;
  min-height:540px;
  display:flex;
  align-items:flex-end;
}
.settore-hero-overlay{
  position:absolute;
  inset:0;
  background:linear-gradient(180deg, rgba(15,36,64,.36) 0%, rgba(15,36,64,.32) 40%, rgba(15,36,64,.82) 100%);
  z-index:1;
  pointer-events:none;
}
.settore-hero-inner{
  position:relative;
  z-index:2;
}
.settore-hero.has-image .crumbs,
.settore-hero.has-image .crumbs a,
.settore-hero.has-image .crumbs span{
  color:rgba(255,255,255,.85) !important;
}
.settore-hero.has-image .eyebrow{
  color:#9ed5f5 !important;
}
.settore-hero.has-image h1{
  color:#fff !important;
  max-width:900px;
}
.settore-hero.has-image .settore-hero-sub{
  color:rgba(255,255,255,.92) !important;
  font-size:20px;
  line-height:1.5;
  font-weight:300;
  margin-top:18px;
  max-width:720px;
}

/* Body content layout */
.settore-content{
  font-size:17px;
  line-height:1.7;
  color:#1c2a3e;
}
.settore-content h2{
  font-size:30px;
  font-weight:600;
  color:#0e72b9;
  margin:36px 0 16px;
  line-height:1.25;
}
.settore-content p{ margin: 0 0 18px }
.settore-content ul{ margin: 0 0 24px; padding-left: 22px }
.settore-content ul li{ margin: 8px 0 }
.settore-content figure.wp-inline-img{
  margin:36px -60px;
  border-radius:12px;
  overflow:hidden;
  box-shadow:0 10px 30px rgba(15,36,64,.08);
}
.settore-content figure.wp-inline-img img{
  display:block;
  width:100%;
  height:auto;
}
.settore-content figure.wp-inline-img figcaption{
  padding:10px 18px;
  font-size:13px;
  color:#5a6675;
  background:#fff;
  border-top:1px solid rgba(15,36,64,.06);
}
@media (max-width: 920px){
  .settore-content figure.wp-inline-img{
    margin:24px 0;
  }
}

/* ============ SECTOR CTA SECTION ============ */
.sector-cta{
  background:linear-gradient(180deg, #f4f8fb 0%, #e9f0f6 100%);
  padding:80px 0 100px;
  border-top:1px solid rgba(14,114,185,.10);
}
.sector-cta-grid{
  display:grid;
  grid-template-columns: 1fr 1.1fr;
  gap:60px;
  align-items:start;
}
@media (max-width: 920px){
  .sector-cta-grid{ grid-template-columns: 1fr; gap:40px }
}
.sector-cta-intro .eyebrow{
  display:inline-block;
  font-size:13px;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:#0e72b9;
  font-weight:600;
  margin-bottom:12px;
}
.sector-cta-intro h2{
  font-size:38px;
  line-height:1.15;
  font-weight:600;
  color:#0f2440;
  margin:0 0 18px;
}
.sector-cta-intro p{
  font-size:17px;
  line-height:1.6;
  color:#475064;
  margin:0 0 28px;
}
.sector-cta-contacts{
  list-style:none;
  margin:0 0 30px;
  padding:0;
}
.sector-cta-contacts li{
  padding:8px 0;
  border-bottom:1px solid rgba(14,114,185,.10);
  font-size:15px;
  color:#1c2a3e;
}
.sector-cta-contacts li strong{
  color:#0f2440;
  margin-right:6px;
}
.sector-cta-contacts a{
  color:#0e72b9;
  text-decoration:none;
}

/* WhatsApp button */
.btn-wa{
  display:inline-flex;
  align-items:center;
  background:#25D366;
  color:#fff !important;
  padding:14px 26px;
  border-radius:50px;
  font-weight:600;
  font-size:16px;
  text-decoration:none;
  transition:background .2s, transform .2s, box-shadow .2s;
  box-shadow:0 4px 12px rgba(37,211,102,.30);
}
.btn-wa:hover{
  background:#1ebe5d;
  transform:translateY(-1px);
  box-shadow:0 6px 18px rgba(37,211,102,.45);
}
.sector-cta-hint{
  font-size:13px;
  color:#6a7689;
  margin-top:10px;
  font-style:italic;
}

/* Form */
.sector-cta-form-wrap{
  background:#fff;
  border-radius:14px;
  padding:36px 32px;
  box-shadow:0 12px 36px rgba(15,36,64,.08), 0 2px 8px rgba(15,36,64,.04);
}
.sector-cta-form label{
  display:block;
  margin-bottom:18px;
}
.sector-cta-form label span{
  display:block;
  font-size:13px;
  font-weight:600;
  color:#0f2440;
  margin-bottom:6px;
  letter-spacing:.01em;
}
.sector-cta-form input[type="text"],
.sector-cta-form input[type="email"],
.sector-cta-form input[type="tel"],
.sector-cta-form textarea{
  width:100%;
  padding:12px 14px;
  border:1px solid rgba(15,36,64,.14);
  border-radius:8px;
  font-size:15px;
  font-family:inherit;
  background:#fafbfc;
  color:#1c2a3e;
  transition:border-color .15s, background .15s;
  box-sizing:border-box;
}
.sector-cta-form input:focus,
.sector-cta-form textarea:focus{
  outline:none;
  border-color:#0e72b9;
  background:#fff;
}
.sector-cta-form textarea{ resize:vertical; min-height:100px }
.form-row-2{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap:14px;
}
@media (max-width: 520px){
  .form-row-2{ grid-template-columns: 1fr }
}
.form-privacy{
  display:flex !important;
  align-items:flex-start;
  gap:10px;
  margin: 8px 0 22px !important;
  cursor:pointer;
}
.form-privacy input[type="checkbox"]{
  margin-top:3px;
  flex-shrink:0;
}
.form-privacy span{
  display:inline !important;
  font-size:13px !important;
  font-weight:400 !important;
  color:#475064 !important;
  margin:0 !important;
  line-height:1.5;
}
.form-privacy a{ color:#0e72b9 }
.btn-submit{
  width:100%;
  background:#0e72b9;
  color:#fff;
  padding:14px 24px;
  border:none;
  border-radius:8px;
  font-size:16px;
  font-weight:600;
  cursor:pointer;
  transition:background .2s, transform .1s;
  font-family:inherit;
}
.btn-submit:hover:not(:disabled){
  background:#0c5e96;
  transform:translateY(-1px);
}
.btn-submit:disabled{ opacity:.6; cursor:not-allowed }
.btn-submit .arr{ margin-left:6px }

.form-response{
  margin-top:14px;
  padding:0;
  font-size:14px;
  border-radius:6px;
  text-align:center;
}
.form-response.is-success{
  padding:12px 16px;
  background:#e7f5ed;
  color:#1c7a3f;
  border:1px solid #b8e0c8;
}
.form-response.is-error{
  padding:12px 16px;
  background:#fbeded;
  color:#a4282b;
  border:1px solid #f0c2c4;
}


/* HERO SUBTITLE */
.hero-subtitle{ font-size: clamp(18px,2.2vw,24px); line-height:1.4; color: rgba(255,255,255,.92); margin: 16px 0 28px; max-width: 720px; font-weight:300 }
@media (max-width: 760px){ .hero-subtitle{ font-size:17px } }


/* ============ COSA FACCIAMO · 14 SERVIZI — REDESIGN EDITORIALE ============ */

.cf-content{
  --sb-blue:#0070BD; --sb-navy:#16243C; --sb-lemon:#F2CD5E; --sb-mint:#36ECD3;
  --sb-lime:#C3EA4F; --sb-strawberry:#D94848; --sb-paper:#f4f6f9;
  --cf-ink:#16243C; --cf-body:#4a5468; --cf-line:rgba(22,36,60,.13);
  --accent-color:var(--sb-blue);
  max-width:1180px; position:relative;
}
.lead-intro{ font-size:clamp(22px,2.7vw,32px); line-height:1.38; color:var(--cf-ink); margin:0 0 18px; font-weight:300; max-width:22ch; letter-spacing:-.015em; }
.lead-intro strong{ font-weight:700 }
.cf-content > p:not(.lead-intro){ font-size:16.5px; line-height:1.7; color:var(--cf-body); margin:0 0 34px; max-width:56ch; }

.cf-service-block[data-accent="deep-spring"]  {--accent-color:var(--sb-blue)}
.cf-service-block[data-accent="core-navy"]    {--accent-color:var(--sb-navy)}
.cf-service-block[data-accent="italian-lemon"]{--accent-color:var(--sb-lemon)}
.cf-service-block[data-accent="neon-mint"]    {--accent-color:var(--sb-mint)}
.cf-service-block[data-accent="juicy-lime"]   {--accent-color:var(--sb-lime)}
.cf-service-block[data-accent="strawberry"]   {--accent-color:var(--sb-strawberry)}

.cf-service-block{
  position:relative; display:grid; grid-template-columns:1.02fr 0.98fr;
  align-items:center; gap:clamp(34px,5vw,78px);
  padding:clamp(46px,6vw,82px) 0; margin:0;
  border-top:1px solid var(--cf-line);
  background:transparent; box-shadow:none; border-radius:0; overflow:visible;
}
.cf-service-block:first-of-type{ border-top:none; padding-top:28px }
.cf-service-block:last-of-type{ border-bottom:none }
.cf-service-block:nth-of-type(even) .cf-service-figure{ order:2 }
.cf-service-block:nth-of-type(even) .cf-service-body{ order:1 }

.cf-service-figure{ position:relative; margin:0; aspect-ratio:3/2; overflow:hidden; border-radius:3px; background:var(--sb-navy); box-shadow:0 26px 60px -30px rgba(22,36,60,.55) }
.cf-service-figure img{ width:100%; height:100%; object-fit:cover; display:block; transition:transform .9s cubic-bezier(.2,.6,.2,1) }
.cf-service-block:hover .cf-service-figure img{ transform:scale(1.05) }
.cf-service-figure::after{ content:""; position:absolute; left:0; top:0; bottom:0; width:5px; background:var(--accent-color); z-index:2 }
.cf-service-block:nth-of-type(even) .cf-service-figure::after{ left:auto; right:0 }
.cf-service-petal{ display:none !important }

.cf-service-num{
  position:absolute; left:0; bottom:0; z-index:3; margin:0; padding:11px 18px;
  font-family:"Montserrat",sans-serif; font-weight:300; font-size:clamp(28px,3.5vw,44px);
  line-height:1; letter-spacing:-.02em; color:rgba(255,255,255,.6);
  background:rgba(15,22,40,.62); backdrop-filter:blur(6px); -webkit-backdrop-filter:blur(6px);
  border-top-right-radius:4px; display:flex; align-items:baseline; gap:3px;
}
.cf-service-num b{ font-weight:800; color:#fff; font-size:1em }
.cf-service-block:nth-of-type(even) .cf-service-num{ left:auto; right:0; border-top-right-radius:0; border-top-left-radius:4px }

.cf-service-body{ position:relative; padding:0 }
.cf-service-block h2{ font-size:clamp(26px,3vw,40px); font-weight:700; color:var(--cf-ink); margin:0; padding:0; letter-spacing:-.02em; line-height:1.08 }
.cf-service-block h2::before{ display:none }
.cf-service-block h2 a{ color:inherit; text-decoration:none; background-image:linear-gradient(var(--accent-color),var(--accent-color)); background-size:0% 2px; background-position:left 100%; background-repeat:no-repeat; transition:background-size .4s ease }
.cf-service-block h2 a:hover{ background-size:100% 2px }
.cf-service-body > h2::after{ content:""; display:block; width:54px; height:4px; border-radius:2px; background:var(--accent-color); margin:18px 0 24px }

.cf-micro-grid{ display:flex; flex-direction:column; gap:0; margin:0; grid-template-columns:none }
.cf-micro{ padding:17px 0; border:none; border-top:1px solid var(--cf-line); position:relative }
.cf-micro:first-child{ border-top:none; padding-top:0 }
.cf-micro + .cf-micro{ padding-left:0 }
.cf-micro:last-child{ padding-right:0 }
.cf-micro h3{ font-size:11.5px; font-weight:800; letter-spacing:.16em; text-transform:uppercase; color:var(--cf-ink); margin:0 0 9px; display:flex; align-items:center; gap:10px }
.cf-micro h3::before{ content:""; display:inline-block; width:9px; height:9px; background:var(--accent-color); border-radius:50% 50% 50% 2px; transform:rotate(35deg); flex-shrink:0 }
.cf-micro p{ font-size:15px; line-height:1.66; color:var(--cf-body); margin:0 }

@media (max-width:880px){
  .cf-service-block{ grid-template-columns:1fr; gap:26px; padding:40px 0 }
  .cf-service-block:nth-of-type(even) .cf-service-figure{ order:0 }
  .cf-service-block:nth-of-type(even) .cf-service-body{ order:0 }
  .cf-service-figure{ aspect-ratio:16/10 }
}
@media (max-width:560px){ .cf-service-block h2{ font-size:24px } .lead-intro{ font-size:21px } }

.cf-content.cf-reveal-ready .cf-service-block,
.cf-content.cf-reveal-ready .cf-bridge{ opacity:0; transform:translateY(26px); transition:opacity .7s ease, transform .7s cubic-bezier(.2,.6,.2,1) }
.cf-content.cf-reveal-ready .cf-service-block.in-view,
.cf-content.cf-reveal-ready .cf-bridge.in-view{ opacity:1; transform:none }

.cf-bridge{ background:var(--sb-navy); color:#fff; padding:clamp(40px,5vw,62px) clamp(28px,4vw,56px); border-radius:6px; margin-top:74px; position:relative; overflow:hidden }
.cf-bridge::before{ content:""; position:absolute; right:-110px; top:-110px; width:340px; height:340px; background:radial-gradient(circle at center, rgba(0,112,189,.4), transparent 70%); pointer-events:none }
.cf-bridge > *{ position:relative; z-index:1 }
.cf-bridge h2{ font-size:clamp(24px,2.8vw,34px); font-weight:700; color:#fff; margin:0 0 18px; letter-spacing:-.01em; max-width:24ch }
.cf-bridge p{ font-size:16px; line-height:1.7; color:rgba(255,255,255,.85); margin:0 0 14px; max-width:62ch }
.cf-bridge p strong{ color:#fff }
.cf-bridge-list{ display:grid; grid-template-columns:repeat(2,1fr); gap:4px 28px; margin:24px 0 0; padding:0; list-style:none }
.cf-bridge-list li{ padding:10px 0 10px 24px; font-size:15px; position:relative; border-top:1px solid rgba(255,255,255,.1) }
.cf-bridge-list li::before{ content:""; position:absolute; left:0; top:16px; width:9px; height:9px; background:var(--sb-mint); border-radius:50% 50% 50% 2px; transform:rotate(35deg) }
.cf-bridge-list a{ color:#fff; text-decoration:none; border-bottom:1px solid rgba(255,255,255,.3); transition:border-color .2s }
.cf-bridge-list a:hover{ border-bottom-color:var(--sb-mint) }
@media (max-width:720px){ .cf-bridge-list{ grid-template-columns:1fr } }

/* ============ CASE STUDY: SERVIZI COLLEGATI + PROGETTI SIMILI + CTA ============ */
.case-divider{
  border: none;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(14,114,185,.20), transparent);
  margin: 50px 0 30px;
}
.case-related-box,
.case-similar-box{
  background: #fff;
  border-left: 3px solid #0e72b9;
  padding: 24px 26px;
  border-radius: 0 10px 10px 0;
  margin: 22px 0 22px;
  box-shadow: 0 2px 12px rgba(15,36,64,.04);
}
.case-similar-box{
  border-left-color: #9ed5f5;
}
.case-related-box h3,
.case-similar-box h3{
  font-size: 14px;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: #0e72b9;
  margin: 0 0 14px;
}
.case-similar-box h3{
  color: #1c2a3e;
}
.case-related-list,
.case-similar-list{
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 6px 24px;
}
@media (max-width: 640px){
  .case-related-list,
  .case-similar-list{ grid-template-columns: 1fr }
}
.case-related-list li,
.case-similar-list li{
  padding: 4px 0 4px 16px;
  position: relative;
  font-size: 14px;
}
.case-related-list li::before,
.case-similar-list li::before{
  content: "\2192";
  position: absolute;
  left: 0;
  top: 4px;
  color: #0e72b9;
  font-weight: 700;
}
.case-related-list a,
.case-similar-list a{
  color: #1c2a3e;
  text-decoration: none;
  border-bottom: 1px solid transparent;
  transition: border-color .15s, color .15s;
}
.case-related-list a:hover,
.case-similar-list a:hover{
  color: #0e72b9;
  border-bottom-color: #0e72b9;
}
.case-cta-final{
  margin: 36px 0 0;
  padding: 28px 30px;
  background: linear-gradient(135deg, #f4f8fb 0%, #e9f0f6 100%);
  border-radius: 10px;
  font-size: 17px;
  line-height: 1.6;
  color: #0f2440;
  font-weight: 500;
}
.case-cta-final a{
  color: #0e72b9;
  font-weight: 600;
  text-decoration: none;
  border-bottom: 2px solid #9ed5f5;
}
.case-cta-final a:hover{
  border-bottom-color: #0e72b9;
}


/* ============ SEO CLUSTER (in fondo a pagine/case) ============ */
.seo-cluster{
  background: linear-gradient(135deg, #fafbfc 0%, #f4f8fb 100%);
  border-left: 4px solid #0e72b9;
  padding: 30px 32px;
  margin: 48px 0 0;
  border-radius: 0 12px 12px 0;
  box-shadow: 0 2px 16px rgba(15,36,64,.05);
}
.seo-cluster h3{
  font-size: 22px;
  font-weight: 600;
  color: #0f2440;
  margin: 0 0 14px;
  line-height: 1.3;
}
.seo-cluster p{
  font-size: 15px;
  line-height: 1.65;
  color: #475064;
  margin: 0 0 14px;
}
.seo-cluster-explore{
  margin-top: 18px !important;
  margin-bottom: 8px !important;
  color: #0f2440 !important;
  font-size: 14px !important;
}
.seo-cluster-links{
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 4px 24px;
}
@media (max-width: 640px){
  .seo-cluster-links{ grid-template-columns: 1fr }
}
.seo-cluster-links li{
  padding: 4px 0 4px 16px;
  position: relative;
  font-size: 14px;
}
.seo-cluster-links li::before{
  content: "\001192 ";
  position: absolute;
  left: 0;
  top: 4px;
  color: #0e72b9;
  font-weight: 700;
}
.seo-cluster-links a{
  color: #1c2a3e;
  text-decoration: none;
  border-bottom: 1px solid transparent;
  transition: border-color .15s, color .15s;
}
.seo-cluster-links a:hover{
  color: #0e72b9;
  border-bottom-color: #0e72b9;
}

/* Cluster grande con due colonne (Casi successo, Blog) */
.cluster-explore{
  padding: 38px 36px;
}
.cluster-double{
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 36px;
  margin-top: 22px;
}
@media (max-width: 720px){
  .cluster-double{ grid-template-columns: 1fr; gap: 24px }
}
.cluster-col h4{
  font-size: 13px;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: #0e72b9;
  margin: 0 0 12px;
  padding-bottom: 6px;
  border-bottom: 2px solid #9ed5f5;
}
.cluster-col .seo-cluster-links{
  grid-template-columns: 1fr;
  gap: 2px;
}


/* ============ CASE STUDY: FILTRI CATEGORIA ============ */
.case-filters{
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  padding: 0 0 10px;
  border-bottom: 1px solid rgba(14,114,185,.15);
}
.case-filter{
  font-family: inherit;
  font-size: 13px;
  font-weight: 600;
  letter-spacing: .03em;
  padding: 9px 18px;
  border: 1px solid rgba(14,114,185,.30);
  background: #fff;
  color: #0f2440;
  border-radius: 99px;
  cursor: pointer;
  transition: all .18s;
}
.case-filter:hover{
  border-color: #0e72b9;
  color: #0e72b9;
}
.case-filter.is-active{
  background: #0e72b9;
  color: #fff;
  border-color: #0e72b9;
}
.case-filter:focus-visible{
  outline: 2px solid #9ed5f5;
  outline-offset: 2px;
}
@media (max-width: 640px){
  .case-filter{ font-size: 12px; padding: 7px 14px }
}


/* ============ PAGINE SERVIZIO: BENEFIT + TECH DETAILS ============ */
.benefit-grid{
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 16px;
  margin: 30px 0 40px;
}
@media (max-width: 920px){ .benefit-grid{ grid-template-columns: repeat(2, 1fr) } }
@media (max-width: 540px){ .benefit-grid{ grid-template-columns: 1fr } }
.benefit-card{
  background: linear-gradient(135deg, #f4f8fb 0%, #e9f0f6 100%);
  border-left: 3px solid #0e72b9;
  padding: 22px 20px;
  border-radius: 0 10px 10px 0;
}
.benefit-card h4{
  font-size: 16px;
  font-weight: 600;
  color: #0e72b9;
  margin: 0 0 8px;
}
.benefit-card p{
  font-size: 14px;
  line-height: 1.55;
  color: #475064;
  margin: 0;
}

.tech-details{
  background: #f7f9fb;
  border-radius: 8px;
  padding: 14px 22px;
  margin: 24px 0;
}
.tech-details summary{
  cursor: pointer;
  font-weight: 600;
  font-size: 14px;
  color: #0e72b9;
  padding: 4px 0;
  user-select: none;
}
.tech-details summary:focus-visible{
  outline: 2px solid #9ed5f5;
  outline-offset: 2px;
  border-radius: 4px;
}
.tech-details[open] summary{
  margin-bottom: 12px;
  padding-bottom: 10px;
  border-bottom: 1px solid rgba(14,114,185,.15);
}


/* ============ NAV DROPDOWN: ACCESSIBILIT\00c0 TASTIERA ============ */
.nav-links li.has-children > a:focus-visible,
.nav-links li.has-children > a:focus-within {
  outline: 2px solid #9ed5f5;
  outline-offset: 2px;
  border-radius: 4px;
}
.nav-links li.has-children:focus-within > .sub-menu,
.nav-links li.has-children.is-open > .sub-menu {
  display: block !important;
  opacity: 1 !important;
  visibility: visible !important;
  pointer-events: auto !important;
}
.nav-links .sub-menu a:focus-visible {
  outline: 2px solid #9ed5f5;
  outline-offset: -2px;
  background: rgba(158, 213, 245, .15);
}
/* Form: focus visibile */
.sector-cta-form input:focus-visible,
.sector-cta-form textarea:focus-visible,
.sector-cta-form button:focus-visible {
  outline: 2px solid #0e72b9;
  outline-offset: 2px;
  border-color: #0e72b9;
}
/* Filtri case: focus tastiera */
.case-filter:focus-visible {
  outline: 2px solid #0e72b9;
  outline-offset: 3px;
}


/* ============ FIX: case-tile sempre visibili ============ */
.cases-grid.reveal-stagger > .case-tile,
.cases-grid > .case-tile {
  opacity: 1 !important;
  transform: none !important;
}


/* ============ BLOOM FINAL OVERRIDE (alpha image, cross-browser) ============ */
.bloom-deco{
  display:block !important;
  width:100% !important;
  max-width:560px !important;
  margin:0 auto !important;
  background:transparent !important;
  aspect-ratio:9/16 !important;
  overflow:visible !important;
  opacity:1 !important;
  transform:none !important;
  position:relative;
}
.bloom-deco .bloom-picture{
  display:block !important;
  width:100% !important;
  height:100% !important;
  line-height:0;
}
.bloom-deco .bloom-image{
  display:block !important;
  width:100% !important;
  height:100% !important;
  object-fit:contain !important;
  background:transparent !important;
  mix-blend-mode:normal !important;
  opacity:1 !important;
  transition:none !important;
  animation:bloomFloat 7s ease-in-out infinite;
  will-change:transform;
}
@keyframes bloomFloat{
  0%,100%{transform:translateY(0) rotate(0deg)}
  50%{transform:translateY(-14px) rotate(.4deg)}
}
@media (prefers-reduced-motion: reduce){
  .bloom-deco .bloom-image{animation:none}
}
@media (max-width:760px){
  .bloom-deco{max-width:340px !important;margin-top:16px !important}
}
/* ============ BLOOM FINAL OVERRIDE END ============ */


/* ============ SB LOGO ASPECT-RATIO LOCK ============ */
.logo-color,
.logo-white,
.site-logo img,
.brand img,
.site-header img[alt*="Sidebloom" i],
footer img[alt*="Sidebloom" i]{
  aspect-ratio: 5 / 1 !important;
  object-fit: contain !important;
  height: auto;
  max-width: 100%;
}
/* Header: lock height, width follows ratio */
.site-header .logo-color,
.site-header .logo-white{
  height: 40px !important;
  width: auto !important;
}
/* ============ END SB LOGO ASPECT-RATIO LOCK ============ */


/* ============ TABLET PORTRAIT (iPad 768-1024px) ============ */
@media (min-width: 761px) and (max-width: 1024px){
  /* Manifesto: keep 2-col on tablet portrait, text takes more space */
  .manifesto-grid{
    grid-template-columns: 1.15fr 1fr !important;
    gap: 36px !important;
    align-items: center;
  }
  /* Bloom: stay contained, never bigger than ~360px on tablet */
  .bloom-deco{
    max-width: 360px !important;
    margin: 0 auto !important;
    align-self: center;
  }

  /* Cases grid: 2-col on tablet portrait (not 1-col stack) */
  .cases-grid .case-tile,
  .cases-grid .case-tile.third{
    grid-column: span 6 !important;
  }
  .cases-grid .case-tile.wide{
    grid-column: span 12 !important;
  }
  .cases-grid .case-tile.full{
    grid-column: span 12 !important;
  }

  /* Services on home: 2-col instead of full-width */
  .services-grid .service-card,
  .services-grid .service-card:nth-child(3),
  .services-grid .service-card:nth-child(4),
  .services-grid .service-card:nth-child(5){
    grid-column: span 6 !important;
  }

  /* cosa-facciamo micro grid: keep 3-col on tablet, just tighter spacing */
  .cf-micro-grid{
    grid-template-columns: 1fr 1fr 1fr !important;
    gap: 0 !important;
  }
  .cf-micro{
    padding: 4px 18px 4px 0 !important;
    border-right: 1px solid rgba(22,36,60,.08) !important;
    border-bottom: none !important;
    padding-bottom: 4px !important;
    font-size: 14px;
  }
  .cf-micro:last-child{
    border-right: none !important;
    padding-right: 0 !important;
  }
  .cf-service-body{ padding: 28px 28px 32px !important }

  /* Contacts: 2-col offices (Pisa | Potenza side-by-side) */
  .offices-grid{
    grid-template-columns: 1fr 1fr !important;
  }
  .office-card:nth-child(2){
    border-left: 1.5px solid var(--ink) !important;
    border-top: 1.5px solid var(--ink) !important;
  }

  /* News: 2-col grid on tablet */
  .news-grid{
    grid-template-columns: 1fr 1fr !important;
  }

  /* H1 sizing: avoid huge titles that take 5+ rows */
  .post-hero h1, .hero h1{
    font-size: clamp(34px, 5.5vw, 52px);
    line-height: 1.1;
  }
}
/* ============ TABLET PORTRAIT END ============ */

/* SB-HEADER-SCRIM */
.site-header::before{content:"";position:absolute;inset:0 0 auto 0;height:150px;background:linear-gradient(180deg,rgba(10,22,40,.6) 0%,rgba(10,22,40,.32) 40%,rgba(10,22,40,0) 100%);pointer-events:none;transition:opacity .35s ease;z-index:-1}
.site-header.is-scrolled::before,.site-header.is-solid::before{opacity:0}


/* SB-SHORTS (reel verticali nei casi studio) */
.project-shorts{padding:70px 0;background:#fff}
.project-shorts .container{max-width:1200px}
.project-shorts h2{margin-bottom:26px}
.shorts-grid{display:flex;gap:18px;overflow-x:auto;padding:6px 2px 20px;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch}
.shorts-grid::-webkit-scrollbar{height:8px}
.shorts-grid::-webkit-scrollbar-thumb{background:rgba(0,0,0,.16);border-radius:8px}
.short-card{flex:0 0 auto;width:248px;aspect-ratio:9/16;border-radius:16px;overflow:hidden;background:#000;scroll-snap-align:start;box-shadow:0 8px 28px rgba(15,36,64,.16)}
.short-card iframe{width:100%;height:100%;border:0;display:block}
@media(max-width:600px){.short-card{width:210px}}

/* SB fix: center case reels */
.project-shorts .shorts-grid{justify-content:safe center}


/* ===== SB v2: home service cards (piu' audaci) ===== */
.home-services .home-service-card{position:relative;background:var(--white) !important;border:1px solid var(--line) !important;padding:30px 30px 54px !important;overflow:hidden}
.home-services .home-service-card::before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--blue),var(--blue-bright));transform:scaleX(0);transform-origin:left;transition:transform .35s ease}
.home-services .home-service-card:hover::before{transform:scaleX(1)}
.home-services .home-service-card .hsc-num{font-size:13px !important;letter-spacing:.2em !important}
.home-services .home-service-card h3{font-size:21px !important;transition:color .2s}
.home-services .home-service-card::after{content:"Scopri \2192";position:absolute;left:30px;bottom:20px;color:var(--blue);font-size:11px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;opacity:.5;transition:opacity .25s,transform .25s}
.home-services .home-service-card:hover::after{opacity:1;transform:translateX(5px)}
.home-services .home-service-card:hover{border-color:var(--blue) !important;transform:translateY(-4px);box-shadow:-8px 8px 0 0 var(--blue)}
@media(max-width:600px){.home-services .home-service-card{padding:26px 24px 50px !important}}



/* ===== SB v2: why-us reasons (impaginazione) ===== */
.why-us .why-us-inner{max-width:1060px !important}
.why-us .why-us-grid{counter-reset:whyc;gap:20px !important;margin-top:46px !important;grid-template-columns:repeat(auto-fit,minmax(300px,1fr)) !important}
.why-us .why-us-grid > div{counter-increment:whyc;position:relative;background:var(--white);border:1px solid var(--line);border-top:3px solid var(--blue);padding:26px 26px 24px;transition:transform .25s ease,box-shadow .25s ease,border-color .25s ease}
.why-us .why-us-grid > div::before{content:counter(whyc,decimal-leading-zero);display:block;color:var(--blue);font-size:12px;font-weight:800;letter-spacing:.2em;margin-bottom:12px}
.why-us .why-us-grid > div h3{font-size:18px !important;margin:0 0 10px !important;transition:color .2s}
.why-us .why-us-grid > div:hover{transform:translateY(-4px);box-shadow:-7px 7px 0 0 var(--blue);border-color:var(--blue)}
.why-us .why-us-grid > div:hover h3{color:var(--blue)}
@media(max-width:600px){.why-us .why-us-grid{gap:16px !important}.why-us .why-us-grid > div{padding:24px 22px}}
/* ===== SB fix: trust-strip separators (robusti anche senza flex-gap, Safari/iPad) ===== */

/* SB v2: trust-strip ts-sep */
.trust-strip .container{column-gap:0 !important;row-gap:10px !important}
.trust-strip .ts-sep{margin:0 16px;color:var(--gray);font-weight:400;display:inline-block}


/* ===== SB v2: NAV redesign (responsive + polish) ===== */
@media (min-width:1181px){
  .site-header .nav-links{gap:24px}
  .site-header .nav-links > li > a:not(.cta-btn){padding-bottom:2px}
  .site-header .nav-links > li > a:not(.cta-btn)::after{content:"";position:absolute;left:0;right:100%;bottom:-5px;height:2px;background:currentColor;opacity:.9;transition:right .28s cubic-bezier(.4,0,.2,1)}
  .site-header .nav-links > li > a:not(.cta-btn):hover::after,
  .site-header .nav-links > li > a.active::after,
  .site-header .nav-links > li.active > a::after{right:0}
}
@media (max-width:1180px){
  .site-header .burger{display:flex !important}
  .site-header .nav-links{display:none !important}
  .site-header .nav-links.open{display:flex !important;position:absolute;top:100%;left:0;right:0;flex-direction:column;align-items:stretch;gap:2px;background:#fff;padding:14px var(--pad) 24px;border-top:1px solid var(--line);box-shadow:0 26px 44px -18px rgba(15,36,64,.28);max-height:calc(100vh - 60px);overflow-y:auto}
  .site-header .nav-links.open li{width:100%}
  .site-header .nav-links.open > li > a{display:block;padding:13px 2px;font-size:15px;color:var(--ink) !important;border-bottom:1px solid rgba(15,36,64,.06);text-transform:none;letter-spacing:0}
  .site-header .nav-links.open > li > a.active,.site-header .nav-links.open > li.active > a{color:var(--blue) !important}
  .site-header .nav-links.open li.has-children > a{display:flex;justify-content:space-between;align-items:center}
  .site-header .nav-links.open li.has-children > a .dd-arrow{display:none}
  .site-header .nav-links.open .sub-menu{position:static !important;opacity:1 !important;visibility:visible !important;transform:none !important;min-width:0 !important;background:transparent !important;box-shadow:none !important;border-radius:0 !important;padding:4px 0 10px 12px !important;margin:0 !important;list-style:none}
  .site-header .nav-links.open .sub-menu li a{display:block;padding:9px 2px;font-size:13.5px;text-transform:none;letter-spacing:0;color:var(--gray) !important;border:0}
  .site-header .nav-links.open .sub-menu li a:hover,.site-header .nav-links.open .sub-menu li.active a{color:var(--blue) !important}
  .site-header .nav-links.open > li:last-child{margin-top:14px;border:0}
  .site-header .nav-links.open .cta-btn{display:flex !important;justify-content:center;width:100%;padding:15px;font-size:13px}
}


/* SB legal meta-list */
.legal-page .meta-list{margin:0}
.legal-page .meta-list dt{font-weight:700;color:var(--ink);margin-top:12px;font-size:12.5px;letter-spacing:.02em;text-transform:uppercase}
.legal-page .meta-list dt:first-child{margin-top:0}
.legal-page .meta-list dd{margin:3px 0 0;color:var(--navy-soft);font-size:14.5px}
.legal-page .badge.partial{background:#fef3c7;color:#92400e}

/* SB legal tables */
.legal-page table{width:100%;border-collapse:collapse;margin:18px 0 8px;font-size:14px}
.legal-page table th{text-align:left;background:var(--paper-2);padding:10px 12px;font-weight:700;font-size:12px;text-transform:uppercase;letter-spacing:.03em;border:1px solid var(--line)}
.legal-page table td{padding:10px 12px;border:1px solid var(--line);color:var(--navy-soft);vertical-align:top}
.legal-page table code{font-size:12.5px}
.legal-page ol{margin:0 0 16px;padding-left:22px}
.legal-page ol li{margin:6px 0}


/* ===== SB v2: hero scrim piu' scuro (leggibilita' testi su immagini, pagine interne) ===== */
.settore-hero-overlay{background:linear-gradient(180deg,rgba(12,28,50,.62) 0%,rgba(12,28,50,.56) 45%,rgba(12,28,50,.93) 100%) !important}
.project-hero-overlay{background:linear-gradient(180deg,rgba(12,28,50,.60) 0%,rgba(12,28,50,.54) 45%,rgba(12,28,50,.92) 100%) !important}
.post-hero.has-image .post-hero-overlay{background:linear-gradient(180deg,rgba(12,28,50,.88) 0%,rgba(12,28,50,.66) 28%,rgba(12,28,50,.58) 52%,rgba(12,28,50,.72) 80%,rgba(12,28,50,.94) 100%) !important}


/* ===== SB leadgen styles ===== */
.leadgen .container{max-width:1080px}
.lg-hero{background:var(--paper);padding:150px var(--pad) 60px;text-align:center}
.lg-eyebrow{display:inline-block;color:var(--blue);font-size:12px;font-weight:800;letter-spacing:.22em;text-transform:uppercase;margin-bottom:20px;position:relative;padding-left:42px}
.lg-eyebrow::before{content:"";position:absolute;left:0;top:50%;width:30px;height:2px;background:var(--blue)}
.lg-hero h1{font-size:clamp(34px,6vw,62px);line-height:1.05;letter-spacing:-.02em;margin:0 0 22px;color:var(--ink);font-weight:800}
.lg-hero h1 b{color:var(--blue)}
.lg-sub{max-width:680px;margin:0 auto 30px;font-size:clamp(16px,2.2vw,20px);line-height:1.55;color:var(--navy-soft)}
.lg-hero-cta{display:inline-flex;align-items:center;gap:10px;background:var(--blue);color:#fff;text-decoration:none;padding:16px 34px;font-weight:700;font-size:15px;letter-spacing:.02em;box-shadow:-7px 7px 0 0 var(--navy);transition:transform .2s,box-shadow .2s}
.lg-hero-cta:hover{transform:translate(2px,-2px);box-shadow:-10px 10px 0 0 var(--blue-bright)}
.lg-steps{background:var(--white);padding:64px var(--pad)}
.lg-steps-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.lg-step{background:var(--paper);padding:32px 28px;border-top:3px solid var(--blue);position:relative}
.lg-step .lg-num{font-size:13px;font-weight:800;color:var(--blue);letter-spacing:.1em;display:block;margin-bottom:14px}
.lg-step h3{font-size:19px;margin:0 0 10px;color:var(--ink);font-weight:700}
.lg-step p{margin:0;font-size:14.5px;line-height:1.55;color:var(--gray)}
.lg-formwrap{background:var(--paper);padding:64px var(--pad) 90px}
.lg-card{max-width:680px;margin:0 auto;background:var(--white);padding:clamp(28px,5vw,52px);box-shadow:-12px 12px 0 0 var(--blue)}
.lg-card h2{font-size:clamp(24px,4vw,34px);margin:0 0 6px;color:var(--ink);font-weight:800;letter-spacing:-.01em}
.lg-card-sub{margin:0 0 26px;color:var(--gray);font-size:15px}
.lg-field{margin-bottom:18px;display:flex;flex-direction:column}
.lg-field label{font-size:13px;font-weight:700;color:var(--navy);margin-bottom:7px;letter-spacing:.01em}
.lg-field input{padding:13px 15px;border:1.5px solid var(--line);background:#fff;font-size:15px;font-family:inherit;color:var(--ink);transition:border-color .15s,box-shadow .15s}
.lg-field input:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px rgba(20,148,230,.15)}
.lg-field input[type=file]{padding:11px 14px;background:var(--paper);cursor:pointer}
.lg-hint{font-size:12.5px;color:var(--gray);margin-top:6px}
.lg-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.lg-consent{display:flex;gap:11px;align-items:flex-start;margin:6px 0 24px;font-size:13.5px;line-height:1.5;color:var(--navy-soft);cursor:pointer}
.lg-consent input{margin-top:3px;width:17px;height:17px;flex:0 0 auto;accent-color:var(--blue)}
.lg-consent a{color:var(--blue);font-weight:600}
.lg-submit{width:100%;background:var(--blue);color:#fff;border:0;padding:16px 24px;font-size:15px;font-weight:700;font-family:inherit;letter-spacing:.02em;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:9px;box-shadow:-6px 6px 0 0 var(--navy);transition:transform .2s,box-shadow .2s,background .2s}
.lg-submit:hover:not(:disabled){transform:translate(2px,-2px);box-shadow:-9px 9px 0 0 var(--blue-bright)}
.lg-submit:disabled{opacity:.6;cursor:default;box-shadow:-6px 6px 0 0 var(--gray)}
.lg-trust{text-align:center;font-size:12.5px;color:var(--gray);margin:16px 0 0}
.lg-banner{display:none;padding:14px 18px;margin-bottom:22px;font-size:14.5px;line-height:1.5;border-left:4px solid}
.lg-banner.lg-ok{background:#e8f5ec;border-color:#1a7f37;color:#0f5128}
.lg-banner.lg-err{background:#fdecea;border-color:#c0392b;color:#8a2017}
.lg-hp{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}
@media(max-width:820px){ .lg-steps-grid{grid-template-columns:1fr;gap:18px} .lg-hero{padding-top:120px} }
@media(max-width:560px){ .lg-row{grid-template-columns:1fr} }


/* ===================== v5 . HOME POLISH ===================== */
.hero-left h1{max-width:22ch}
.hero::before{background:
  radial-gradient(115% 85% at 82% 18%, rgba(20,148,230,.45) 0%, rgba(20,148,230,0) 55%),
  radial-gradient(85% 75% at 12% 92%, rgba(15,36,64,.6) 0%, rgba(15,36,64,0) 60%),
  linear-gradient(135deg, rgba(15,36,64,.5) 0%, rgba(14,114,185,.18) 55%, rgba(15,36,64,.72) 100%) !important;
}
.hero-pattern{opacity:.5}
.press-grid .logo-cell img{max-height:44px;max-width:120px;width:auto;height:auto;object-fit:contain;filter:grayscale(100%);opacity:.55;transition:filter .3s,opacity .3s}
.press-grid .logo-cell:hover img{filter:grayscale(0);opacity:1}
.clients-grid .logo-cell img{max-height:46px;max-width:130px;width:auto;height:auto;object-fit:contain;filter:brightness(0) invert(1);opacity:.62;transition:filter .3s,opacity .3s,transform .3s}
.clients-grid .logo-cell:hover img{opacity:1;transform:scale(1.06)}
.home-service-card{transition:border-color .25s,transform .25s,box-shadow .25s !important}
.home-service-card:hover{border-color:var(--blue) !important;transform:translate(3px,-5px);box-shadow:-8px 8px 0 0 var(--blue)}
@media (max-width:600px){
  .trust-strip{overflow:hidden}
  .trust-strip .container{gap:6px 14px;row-gap:8px;font-size:11px;padding-left:18px;padding-right:18px}
  .trust-strip .ts-sep{display:none}
  .trust-strip .container > span{flex:0 1 auto;white-space:normal;text-align:center}
}
/* =========================================================== */

/* trust-strip mobile fix v2 */
@media (max-width:600px){
  .trust-strip .container{gap:6px 12px !important;font-size:11px !important;padding:0 16px !important;justify-content:center !important}
  .trust-strip .ts-sep{display:none !important}
  .trust-strip .container>span{flex:0 1 auto !important;white-space:normal !important;overflow-wrap:anywhere !important;text-align:center}
}

.press-grid .logo-cell img{opacity:.72 !important}

/* ===== mobile horizontal-overflow fix ===== */
html,body{overflow-x:hidden;max-width:100%}
@media (max-width:600px){
  .hero-left h1{font-size:clamp(26px,7.2vw,38px) !important;max-width:100% !important;overflow-wrap:break-word;word-break:normal;line-height:1.12}
  .hero-left .lead,.hero-left p{max-width:100% !important}
  .hero-grid{max-width:100%}
}

/* ===== mobile overflow fix v3 (viewport-relative) ===== */
@media (max-width:600px){
  .hero-left h1{font-size:clamp(24px,6.2vw,34px) !important;max-width:88vw !important;overflow-wrap:break-word !important}
  .hero-left .lead,.hero-left p{max-width:88vw !important;overflow-wrap:break-word}
  .trust-strip .container{align-items:stretch !important}
  .trust-strip span{max-width:88vw !important;box-sizing:border-box;white-space:normal !important;overflow-wrap:anywhere !important}
}

/* ===================== v6 . HOME SHOWCASE ===================== */
.hero-wall{position:absolute;top:-12%;right:-6%;width:62%;height:130%;display:grid;grid-template-columns:repeat(3,1fr);gap:16px;transform:rotate(-8deg);opacity:.14;z-index:0;pointer-events:none;animation:hero-wall-pan 26s ease-in-out infinite alternate}
.hero-wall img{width:100%;height:200px;object-fit:cover;display:block}
@keyframes hero-wall-pan{from{transform:rotate(-8deg) translateY(0)}to{transform:rotate(-8deg) translateY(-70px)}}
@media (max-width:780px){.hero-wall{width:120%;right:-30%;opacity:.10}}
.film-strip{background:var(--ink);padding:26px 0;overflow:hidden}
.fs-row{overflow:hidden;position:relative}
.fs-row+.fs-row{margin-top:14px}
.fs-track{display:flex;gap:14px;width:max-content;animation:scroll 70s linear infinite}
.fs-row-1 .fs-track{animation-duration:88s;animation-direction:reverse}
.fs-row:hover .fs-track{animation-play-state:paused}
.fs-item{position:relative;flex:0 0 auto;width:300px;height:200px;overflow:hidden;display:block}
.fs-item img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .5s,filter .4s;filter:brightness(.94)}
.fs-item:hover img{transform:scale(1.06);filter:brightness(1.02)}
.fs-cap{position:absolute;left:0;right:0;bottom:0;padding:24px 14px 10px;font-size:12px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:#fff;background:linear-gradient(180deg,transparent,rgba(15,36,64,.85));opacity:0;transition:opacity .3s}
.fs-item:hover .fs-cap{opacity:1}
@media (max-width:600px){.fs-item{width:210px;height:140px}.film-strip{padding:18px 0}.fs-row+.fs-row{margin-top:10px}}
.history-band{background:var(--navy);color:#fff;padding:110px 0;position:relative;overflow:hidden}
.history-band::before{content:"2010";position:absolute;right:-2vw;top:-6vw;font-size:26vw;font-weight:800;color:rgba(255,255,255,.04);line-height:.8;pointer-events:none}
.history-band .eyebrow{color:#9ed5f5}
.history-band h2{color:#fff;font-size:clamp(30px,3.8vw,50px);margin:10px 0 64px;letter-spacing:-.02em}
.history-band h2 b{color:#9ed5f5}
.timeline{list-style:none;margin:0;padding:0;display:grid;grid-template-columns:repeat(4,1fr);gap:40px;position:relative}
.timeline::before{content:"";position:absolute;left:0;right:0;top:7px;height:2px;background:rgba(255,255,255,.16)}
.timeline li{position:relative;padding-top:34px}
.timeline li::before{content:"";position:absolute;left:2px;top:0;width:16px;height:16px;background:var(--blue-bright);transform:rotate(45deg)}
.tl-year{display:block;font-size:clamp(40px,4.6vw,64px);font-weight:800;letter-spacing:-.03em;color:transparent;-webkit-text-stroke:1.5px rgba(255,255,255,.6);line-height:1;margin-bottom:14px}
@supports not (-webkit-text-stroke:1px #fff){.tl-year{color:rgba(255,255,255,.25)}}
.timeline h3{color:#fff;font-size:19px;font-weight:700;margin:0 0 10px}
.timeline p{color:rgba(255,255,255,.72);font-size:14.5px;line-height:1.6;margin:0;max-width:30ch}
@media (max-width:900px){.timeline{grid-template-columns:1fr 1fr;gap:46px 30px}.timeline::before{display:none}}
@media (max-width:540px){.timeline{grid-template-columns:1fr}.history-band{padding:80px 0}}
.svc-img{display:block;margin:-32px -32px 22px;height:158px;overflow:hidden;background:var(--navy)}
.svc-img img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .55s;filter:saturate(.95)}
.home-service-card:hover .svc-img img{transform:scale(1.06)}
.case-preview::before{content:"PORTFOLIO";position:absolute;right:-3vw;top:-2vw;font-size:13vw;font-weight:800;letter-spacing:-.04em;color:rgba(14,114,185,.055);line-height:.8;pointer-events:none;user-select:none}
.ai-cta{background:var(--paper);padding:0 0 110px}
.ai-cta-box{background:linear-gradient(135deg,#0e72b9 0%,#0f2440 100%);color:#fff;padding:clamp(36px,5vw,64px);display:flex;align-items:center;justify-content:space-between;gap:40px;box-shadow:-12px 12px 0 0 var(--navy);position:relative;overflow:hidden}
.ai-cta-box::before{content:"";position:absolute;right:-90px;top:-90px;width:300px;height:300px;background:rgba(255,255,255,.06);transform:rotate(45deg);pointer-events:none}
.ai-cta .eyebrow{color:#9ed5f5}
.ai-cta h2{color:#fff;font-size:clamp(26px,3.2vw,42px);letter-spacing:-.02em;margin:10px 0 14px;max-width:18ch}
.ai-cta p{color:rgba(255,255,255,.85);font-size:16px;line-height:1.55;margin:0;max-width:48ch}
.ai-cta-btn{flex:0 0 auto;display:inline-block;background:#fff;color:var(--blue)!important;font-weight:800;font-size:14px;letter-spacing:.08em;text-transform:uppercase;padding:18px 30px;text-decoration:none;transition:transform .2s,box-shadow .2s;position:relative;z-index:1}
.ai-cta-btn:hover{transform:translate(3px,-3px);box-shadow:-6px 6px 0 0 rgba(255,255,255,.35)}
@media (max-width:780px){.ai-cta-box{flex-direction:column;align-items:flex-start}}
.home-services .home-services-head h2{font-size:clamp(30px,3.8vw,48px)!important}
.why-us h2{font-size:clamp(30px,3.8vw,48px)!important}
/* ============================================================ */

/* ===================== v7 . IMPIANTO 2.0 ===================== */
.hero-v2{min-height:88vh}
.hero-v2 .hero-stack{position:relative;z-index:2;max-width:900px}
.hero-v2 h1{font-size:clamp(40px,6.4vw,86px);line-height:1.04;letter-spacing:-.025em;font-weight:800;max-width:15ch;margin-bottom:26px;color:#fff}
.hero-v2 h1 em{font-style:italic;font-weight:800;background:linear-gradient(90deg,#fff 0%,#9ed5f5 90%);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:#9ed5f5}
.hero-v2 .hero-subtitle{font-size:clamp(16px,1.4vw,19px);color:rgba(255,255,255,.88);max-width:54ch;line-height:1.6;margin-bottom:34px}
.hero-v2 .hero-eyebrow{margin-bottom:26px}
.hero-meta{margin-top:32px;font-size:11.5px;letter-spacing:.18em;text-transform:uppercase;color:rgba(255,255,255,.6);font-weight:700}
.trust-strip{background:var(--paper) !important;border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:15px 0 !important;text-align:center}
.trust-strip .container{display:flex !important;flex-direction:row !important;flex-wrap:wrap !important;justify-content:center !important;align-items:center !important;gap:8px 28px !important;font-size:11.5px !important;font-weight:700 !important;letter-spacing:.14em !important;text-transform:uppercase !important;color:var(--gray) !important}
.trust-strip .container span{display:inline-block !important;background:none !important;border:0 !important;border-radius:0 !important;padding:0 !important;font-size:11.5px !important;letter-spacing:.14em !important;color:var(--gray) !important;max-width:none !important;text-transform:uppercase !important}
.trust-strip strong{color:var(--blue) !important;font-size:1.05em}
.trust-strip .ts-sep{display:none !important}
.showreel-feature{display:flex;justify-content:center;margin:4px 0 44px}
.showreel-feature .hero-video-wrap{max-width:280px;width:100%;box-shadow:-12px 12px 0 0 rgba(15,36,64,.45)}
@media (max-width:600px){
  .hero-v2{min-height:auto !important;padding-top:106px !important;padding-bottom:52px !important}
  .hero-v2 h1{font-size:clamp(34px,9.8vw,42px);max-width:100%}
  .hero-v2 .hero-subtitle{font-size:15.5px}
  .hero-v2 .hero-actions{gap:10px}
  .hero-v2 .hero-actions a{padding:13px 18px;font-size:12.5px}
  .hero-meta{font-size:10px;letter-spacing:.13em}
  .trust-strip .container{gap:6px 18px !important;font-size:10.5px !important}
  .trust-strip .container span{font-size:10.5px !important}
  .home-services,.why-us{padding:64px 0 !important}
  .home-services-head{margin:0 auto 36px !important}
  .history-band{padding:70px 0}
  .history-band h2{margin-bottom:42px}
  .timeline{grid-template-columns:1fr;gap:34px;position:relative;padding-left:30px}
  .timeline::before{display:block;left:10px;right:auto;top:4px;bottom:4px;width:2px;height:auto}
  .timeline li{padding-top:0;padding-left:4px}
  .timeline li::before{left:-26px;top:5px;width:12px;height:12px}
  .tl-year{font-size:38px}
  .manifesto::before{font-size:40vw;bottom:-7vw}
  .ai-cta{padding:0 0 64px}
  .ai-cta-box{padding:30px 22px;box-shadow:-8px 8px 0 0 var(--navy)}
  .ai-cta h2{font-size:24px}
  .svc-img{height:140px;margin:-32px -32px 18px}
  .fs-item{width:200px;height:132px}
  .showreel-feature .hero-video-wrap{max-width:240px}
}
/* ============================================================= */

/* hero flex-item width fix */
.hero-v2 .container{width:100%}
@media (max-width:600px){.hero-v2 h1{font-size:clamp(30px,8.6vw,38px)}}

/* =============================================================
   v8 BRAND DECOR — petali Sidebloom + pittogramma "b" animati
   ============================================================= */
.sb-decor-host{position:relative}
.sb-decor-layer{position:absolute;inset:0;overflow:hidden;pointer-events:none;z-index:0}
.sb-decor{position:absolute;will-change:transform}
.sb-float{width:100%;animation:sbFloat var(--fd,9s) ease-in-out var(--fdel,0s) infinite}
@keyframes sbFloat{0%,100%{transform:translate3d(0,0,0) rotate(0deg)}50%{transform:translate3d(0,-9px,0) rotate(1.5deg)}}
.sb-shape{display:block;width:100%;opacity:0;transform:scale(.25) rotate(-22deg);transition:opacity .9s ease var(--bdel,0s),transform 1.05s cubic-bezier(.16,1,.3,1) var(--bdel,0s)}
.sb-decor-in .sb-shape{opacity:var(--o,.08);transform:none}
.sb-petal{aspect-ratio:1/1;background:currentColor}
.sb-b{aspect-ratio:100/140}
.sb-b svg{display:block;width:100%;height:auto}
.sb-b .sb-b-dot{opacity:0;transform:translateY(-14px);transition:opacity .6s ease calc(var(--bdel,0s) + .45s),transform .7s cubic-bezier(.34,1.56,.64,1) calc(var(--bdel,0s) + .45s)}
.sb-decor-in .sb-b .sb-b-dot{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){
  .sb-float{animation:none}
  .sb-shape,.sb-b .sb-b-dot{transition:none}
  .sb-shape{opacity:var(--o,.08);transform:none}
  .sb-b .sb-b-dot{opacity:1;transform:none}
}

/* ================================================================
   SB REDESIGN v5.0.65 — menu overlay, hero showreel, shorts, servizi
   ================================================================ */

/* ----- Burger sempre visibile, con label ----- */
.nav-links{display:none!important}
.burger{display:inline-flex!important;gap:10px;width:auto;height:44px;padding:0 18px;align-items:center;justify-content:center;border:1.5px solid var(--line);background:transparent;cursor:pointer;color:var(--ink);transition:border-color .25s,color .25s;position:relative;z-index:1102}
.burger em{font-style:normal;font-size:12px;font-weight:800;letter-spacing:.2em;text-transform:uppercase;line-height:1}
.burger span,.burger span::before,.burger span::after{transition:transform .3s,background .3s,top .3s}
.burger:hover{border-color:var(--blue);color:var(--blue)}
.burger.is-active span{background:transparent!important}
.burger.is-active span::before{top:0;transform:rotate(45deg)}
.burger.is-active span::after{top:0;transform:rotate(-45deg)}
body.menu-open .burger,
body.menu-open .site-header:not(.is-scrolled):not(.is-solid) .burger{color:#fff;border-color:rgba(255,255,255,.4)}
body.menu-open .site-header{background:transparent!important;box-shadow:none!important;border-bottom-color:transparent!important}
body.menu-open .site-header .brand img{filter:brightness(0) invert(1)!important}
.site-header{z-index:1101}
body.menu-open{position:fixed;left:0;right:0;width:100%;overflow:hidden}

/* ----- Overlay full-screen ----- */
.sb-menu{position:fixed;inset:0;z-index:1100;background:linear-gradient(150deg,#16243C 0%,#0f1c33 55%,#101e36 100%);visibility:hidden;opacity:0;transition:opacity .5s ease,visibility .5s ease;overflow-y:auto;-webkit-overflow-scrolling:touch}
.sb-menu.open{visibility:visible;opacity:1}
.sbm-bg{position:fixed;inset:0;pointer-events:none;overflow:hidden}
.sbm-petal{position:absolute;display:block;transform:rotate(45deg) scale(.6);opacity:0;transition:transform 1s cubic-bezier(.22,1,.36,1),opacity 1s}
.sb-menu.open .sbm-petal{transform:rotate(45deg) scale(1);opacity:1}
.sbm-p1{width:54vmin;height:54vmin;border-radius:50% 50% 50% 0;background:#0070BD;top:-14vmin;right:-10vmin;opacity:0;filter:none}
.sb-menu.open .sbm-p1{opacity:.5}
.sbm-p2{width:30vmin;height:30vmin;border-radius:0 50% 50% 50%;background:#F2CD5E;bottom:-8vmin;left:-7vmin}
.sb-menu.open .sbm-p2{opacity:.16}
.sbm-p3{width:18vmin;height:18vmin;border-radius:50% 0 50% 50%;background:#36ECD3;top:58%;right:16%}
.sb-menu.open .sbm-p3{opacity:.13}
.sbm-ring{position:absolute;width:74vmin;height:74vmin;border:1.5px solid rgba(255,255,255,.07);border-radius:50% 50% 50% 0;transform:rotate(45deg);top:-26vmin;left:22%}
.sbm-wrap{position:relative;z-index:2;display:grid;grid-template-columns:1.35fr .85fr;gap:7vw;max-width:1240px;margin:0 auto;padding:128px 32px 70px;align-items:center;min-height:100%}
.sbm-list{list-style:none;margin:0;padding:0}
.sbm-list>li{transform:translateY(28px);opacity:0;transition:transform .55s cubic-bezier(.22,1,.36,1),opacity .55s;transition-delay:calc(80ms + var(--i)*55ms)}
.sb-menu.open .sbm-list>li{transform:none;opacity:1}
.sbm-list a,.sbm-sub-toggle{display:flex;align-items:baseline;gap:20px;width:100%;text-align:left;background:none;border:0;cursor:pointer;color:#fff;text-decoration:none;font-family:inherit;font-weight:800;font-size:clamp(27px,4.4vw,50px);line-height:1.12;letter-spacing:-.015em;padding:9px 0;position:relative}
.sbm-n{font-size:12px;font-weight:700;letter-spacing:.22em;color:#F2CD5E;min-width:34px;flex:none}
.sbm-t{position:relative;transition:color .25s,transform .25s}
.sbm-t::before{content:"";position:absolute;left:-24px;top:54%;width:13px;height:13px;border-radius:50% 50% 50% 0;background:#F2CD5E;transform:translateY(-50%) rotate(45deg) scale(0);transition:transform .28s cubic-bezier(.34,1.56,.64,1)}
.sbm-list a:hover .sbm-t,.sbm-sub-toggle:hover .sbm-t{color:#9ed5f5;transform:translateX(10px)}
.sbm-list a:hover .sbm-t::before,.sbm-sub-toggle:hover .sbm-t::before{transform:translateY(-50%) rotate(45deg) scale(1)}
.sbm-plus{width:30px;height:30px;flex:none;margin-left:auto;position:relative;align-self:center;transition:transform .35s}
.sbm-plus::before,.sbm-plus::after{content:"";position:absolute;left:50%;top:50%;background:#F2CD5E;transform:translate(-50%,-50%)}
.sbm-plus::before{width:18px;height:2px}
.sbm-plus::after{width:2px;height:18px;transition:transform .3s}
.sbm-has-sub.expanded .sbm-plus{transform:rotate(180deg)}
.sbm-has-sub.expanded .sbm-plus::after{transform:translate(-50%,-50%) scaleY(0)}
.sbm-sub{list-style:none;margin:0;padding:0 0 0 54px;max-height:0;overflow:hidden;transition:max-height .5s ease}
.sbm-has-sub.expanded .sbm-sub{max-height:560px}
.sbm-sub a{display:block;color:rgba(255,255,255,.75);font-size:16px;font-weight:600;padding:8px 0;text-decoration:none;transition:color .2s,transform .2s}
.sbm-sub a:hover{color:#36ECD3;transform:translateX(6px)}
.sbm-side{color:#fff;transform:translateY(24px);opacity:0;transition:transform .6s cubic-bezier(.22,1,.36,1) .45s,opacity .6s .45s}
.sb-menu.open .sbm-side{transform:none;opacity:1}
.sbm-kicker{font-size:12px;font-weight:700;letter-spacing:.24em;text-transform:uppercase;color:#36ECD3;margin:0 0 16px}
.sbm-mail{display:block;color:#fff;font-weight:700;font-size:clamp(18px,2vw,23px);text-decoration:none;margin-bottom:6px;border-bottom:2px solid transparent;width:fit-content;transition:border-color .25s}
.sbm-mail:hover{border-color:#F2CD5E}
.sbm-tel{display:block;color:rgba(255,255,255,.85);font-weight:600;font-size:16px;text-decoration:none;margin-bottom:20px}
.sbm-tel:hover{color:#fff}
.sbm-sedi{color:rgba(255,255,255,.55);font-size:13.5px;line-height:1.75;margin:0 0 28px}
.sbm-sedi strong{color:rgba(255,255,255,.85)}
.sbm-cta{display:inline-flex;align-items:center;gap:10px;background:#F2CD5E;color:#16243C;font-weight:800;font-size:13px;letter-spacing:.1em;text-transform:uppercase;padding:16px 26px;text-decoration:none;transition:transform .25s,box-shadow .25s}
.sbm-cta:hover{transform:translate(3px,-3px);box-shadow:-7px 7px 0 0 #0070BD}
.sbm-social{display:flex;flex-wrap:wrap;gap:8px 20px;margin-top:30px}
.sbm-social a{color:rgba(255,255,255,.65);font-size:12px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;text-decoration:none;border-bottom:1.5px solid transparent;padding-bottom:2px;transition:color .2s,border-color .2s}
.sbm-social a:hover{color:#fff;border-color:#36ECD3}
@media(max-width:920px){
  .sbm-wrap{grid-template-columns:1fr;gap:46px;padding:108px 24px 56px;align-items:start}
  .sbm-side{border-top:1px solid rgba(255,255,255,.12);padding-top:34px}
  .sbm-list a,.sbm-sub-toggle{font-size:clamp(25px,7.4vw,34px)}
}

/* ----- Hero con showreel ----- */
.hero-cols{display:grid;grid-template-columns:1.22fr .78fr;gap:52px;align-items:center;width:100%}
.hero-cols .hero-stack{max-width:none}
.hero-reel{justify-self:end;width:min(295px,28vw);position:relative;animation:sbFloat 7s ease-in-out infinite}
.hero-reel-frame{aspect-ratio:9/16;background:#0a1626;overflow:hidden;border:1.5px solid rgba(255,255,255,.3);box-shadow:-12px 12px 0 0 rgba(255,255,255,.94)}
.hero-reel-frame iframe{width:100%;height:100%;border:0;display:block}
.hero-reel-tag{position:absolute;top:-13px;left:-13px;background:#F2CD5E;color:#16243C;font-size:10px;font-weight:800;letter-spacing:.2em;text-transform:uppercase;padding:6px 12px;z-index:3}
@keyframes sbFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-9px)}}
@media(max-width:980px){
  .hero-cols{grid-template-columns:1fr;gap:38px}
  .hero-reel{justify-self:center;width:min(225px,60vw);animation:none}
  .hero-reel-frame{box-shadow:-8px 8px 0 0 rgba(255,255,255,.94)}
}

/* ----- Shorts verticali (yt-reel) ----- */
.reel-card.yt-reel{position:relative;aspect-ratio:9/16;background:#0a1626;overflow:hidden;display:block;transition:transform .35s,box-shadow .35s}
.reel-card.yt-reel:hover{transform:translate(4px,-4px);box-shadow:-8px 8px 0 0 var(--blue)}
.reel-card.yt-reel .yt-facade-play{position:absolute;inset:0;width:100%;height:100%;border:0;background:#0a1626;cursor:pointer;padding:0;display:block}
.reel-card.yt-reel .yt-facade-thumb{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center;display:block}
.reel-card.yt-reel .yt-facade-icon{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;z-index:2;filter:drop-shadow(0 8px 22px rgba(0,0,0,.5));transition:transform .3s}
.reel-card.yt-reel:hover .yt-facade-icon{transform:scale(1.08)}
.reel-card.yt-reel::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 55%,rgba(0,0,0,.62) 100%);pointer-events:none;z-index:1}
.reel-card.yt-reel .tag{position:absolute;top:16px;left:16px;background:var(--blue);color:#fff;padding:5px 10px;font-size:10px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;z-index:3}
.reel-card.yt-reel .yt-link{position:absolute;top:14px;right:14px;z-index:5;width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:rgba(0,0,0,.45);color:#fff;border-radius:0}
.reel-card.yt-reel .meta{position:absolute;bottom:0;left:0;right:0;padding:18px;color:#fff;z-index:2;pointer-events:none}
.reel-card.yt-reel .meta .t{font-size:14.5px;font-weight:600;line-height:1.3;margin-bottom:3px}
.reel-card.yt-reel .meta .a{font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.8)}
@media(max-width:760px){
  .reels-grid{display:grid!important;grid-auto-flow:column;grid-auto-columns:62%;overflow-x:auto;scroll-snap-type:x mandatory;gap:16px;padding:4px 4px 16px;-webkit-overflow-scrolling:touch;scrollbar-width:none}
  .reels-grid::-webkit-scrollbar{display:none}
  .reels-grid>.reel-card{scroll-snap-align:center;width:auto}
}

/* ----- Immagini servizi: trattamento uniforme duotone ----- */
.svc-img{position:relative;display:block;aspect-ratio:16/10;overflow:hidden;margin:-32px -32px 24px}
.svc-img img{width:100%;height:100%;object-fit:cover;display:block;filter:grayscale(1) contrast(1.05) brightness(.97);transition:filter .45s,transform .45s}
.svc-img::after{content:"";position:absolute;inset:0;background:linear-gradient(160deg,rgba(0,112,189,.42),rgba(22,36,60,.55));mix-blend-mode:multiply;transition:opacity .45s;pointer-events:none}
.home-service-card{overflow:hidden}
.home-service-card:hover .svc-img img{filter:grayscale(0) contrast(1) brightness(1);transform:scale(1.045)}
.home-service-card:hover .svc-img::after{opacity:0}
.cf-service-block img{filter:grayscale(1) contrast(1.05) brightness(.97);transition:filter .45s}
.cf-service-block:hover img{filter:none}

/* ----- Case study: layer storytelling ----- */
.story-content>p:first-of-type{font-size:19.5px;line-height:1.78;color:var(--ink);font-weight:450}
.story-content>p:first-of-type::first-line{font-weight:600}
.story-content h2{display:flex;align-items:center;gap:14px}
.story-content h2::before{content:"";flex:none;width:13px;height:13px;border-radius:50% 50% 50% 0;background:var(--blue);transform:rotate(45deg)}
.story-content strong{color:var(--ink)}
/* fix: logo visibile con menu aperto */
body.menu-open .site-header .brand,body.menu-open .site-header .brand img{opacity:1!important;visibility:visible!important}

/* fix: brand+burger sopra overlay (stesso stacking context) */
.site-header .brand{position:relative;z-index:1102}
.site-header .burger,.site-header #burger{z-index:1102!important;position:relative}

/* fix: voci menu che scorrono sotto logo/burger — dissolvenza in alto */
.sb-menu::after{content:"";position:fixed;top:0;left:0;right:0;height:104px;background:linear-gradient(180deg,#16243C 0%,rgba(20,32,56,.94) 50%,rgba(20,32,56,0) 100%);pointer-events:none;z-index:3;opacity:0;transition:opacity .4s ease}
.sb-menu.open::after{opacity:1}
@media(max-width:920px){
  .sb-menu::after{height:96px}
  .sbm-wrap{padding-top:118px}
}

/* ============ SB v3: DESKTOP NAV orizzontale interattiva + overlay mobile elegante ============ */
.sb-deskmenu{display:none}
@media(min-width:1024px){
  .site-header .burger{display:none!important}
  .sb-menu{display:none!important}
  .sb-deskmenu{display:block;margin-left:auto}
  .sbd-list{display:flex;align-items:center;gap:22px;list-style:none;margin:0;padding:0}
  .sbd-item{position:relative}
  .sbd-link{display:inline-flex;align-items:center;gap:6px;background:none;border:0;cursor:pointer;font-family:inherit;font-size:14px;font-weight:600;letter-spacing:.01em;color:#fff;text-decoration:none;padding:10px 0;position:relative;transition:color .2s}
  .sbd-link::after{content:"";position:absolute;left:0;right:100%;bottom:2px;height:2px;background:#0e72b9;transition:right .3s cubic-bezier(.4,0,.2,1)}
  .sbd-item:hover>.sbd-link::after,.sbd-link:focus-visible::after{right:0}
  .site-header.is-scrolled .sbd-link,.site-header.is-solid .sbd-link{color:#0e2440}
  body:not(.home):not(.page-template-front-page) .site-header:not(.is-scrolled):not(.is-solid) .sbd-link{color:#0e2440}
  .sbd-caret{width:7px;height:7px;border-right:2px solid currentColor;border-bottom:2px solid currentColor;transform:rotate(45deg) translateY(-2px);transition:transform .25s;opacity:.75}
  .sbd-has-sub:hover .sbd-caret,.sbd-has-sub.open .sbd-caret{transform:rotate(225deg) translateY(2px)}
  .sbd-has-sub::after{content:"";position:absolute;left:-14px;right:-14px;top:100%;height:18px}
  .sbd-drop{position:absolute;top:calc(100% + 16px);left:50%;transform:translateX(-50%) translateY(8px);min-width:248px;background:#fff;border-radius:14px;box-shadow:0 32px 64px -24px rgba(11,26,48,.45);padding:10px;opacity:0;visibility:hidden;transition:opacity .26s,transform .26s,visibility .26s;z-index:90}
  .sbd-drop::before{content:"";position:absolute;top:-7px;left:50%;transform:translateX(-50%) rotate(45deg);width:14px;height:14px;background:#fff;border-radius:3px}
  .sbd-has-sub:hover .sbd-drop,.sbd-has-sub.open .sbd-drop{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)}
  .sbd-drop ul{list-style:none;margin:0;padding:0}
  .sbd-drop a{display:block;padding:11px 15px;border-radius:9px;color:#0b1a30;font-size:13.5px;font-weight:600;text-decoration:none;white-space:nowrap;transition:background .18s,color .18s,transform .18s}
  .sbd-drop a:hover{background:#eaf3fb;color:#0e72b9;transform:translateX(3px)}
}
.sbm-list a,.sbm-sub-toggle{font-weight:300;font-size:clamp(23px,5.6vw,32px);letter-spacing:-.005em}
.sbm-list>li{border-bottom:1px solid rgba(255,255,255,.08)}
.sbm-list>li:last-child{border-bottom:0}
.sbm-n{font-weight:400;opacity:.6}
.sbm-t::before{width:10px;height:10px;left:-20px}

/* ============ SB v4: hero reel sopra il gradiente + gallery eventi ============ */
.hero-reel{position:relative;z-index:3}
.hero-reel-frame{background:#000}
.sb-eventi .ev-cases{max-width:980px;margin:0 auto;padding:48px 20px}
.sb-eventi .ev-cases h2{font-size:1.9rem;margin:0 0 6px}
.sb-eventi .ev-cases-sub{color:#5a6779;margin:0 0 24px}
.sb-eventi .ev-cases-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px}
.sb-eventi .ev-case{display:block;border-radius:14px;overflow:hidden;background:#0b1a30;text-decoration:none;box-shadow:0 18px 40px -22px rgba(11,26,48,.5);transition:transform .2s}
.sb-eventi .ev-case:hover{transform:translateY(-3px)}
.sb-eventi .ev-case-img{display:block;width:100%;aspect-ratio:16/10;background-size:cover;background-position:center}
.sb-eventi .ev-case-t{display:block;padding:14px 16px;color:#fff;font-size:.96rem;font-weight:600;line-height:1.3}
.sb-eventi .ev-video{margin-top:22px;border-radius:16px;overflow:hidden;aspect-ratio:16/9;box-shadow:0 24px 50px -24px rgba(11,26,48,.5)}
.sb-eventi .ev-video iframe{width:100%;height:100%;border:0;display:block}

/* ===== SB v5: showreel chromeless+fullscreen mobile, fondo card blu, pulsante servizi ===== */
.hero-reel-frame{position:relative}
.hero-reel-frame iframe{position:absolute;top:-13%;left:0;width:100%;height:126%;pointer-events:none}
@media(max-width:760px){ .hero-reel{width:100%;max-width:none;margin:0 auto} }
.reels .film-play{background:var(--blue)}
.reels .reel-card,.reels .reel-card.yt-reel,.reels .reel-card.video-reel{background:var(--blue)}
.reels .reel-card.yt-reel .yt-facade-play{background:var(--blue)}
.reels-grid .reel-card,.reels-grid .reel-card.yt-reel{background:var(--blue)}
.home-services .home-service-card{padding-bottom:66px !important}
.home-services .home-service-card::after{content:"Scopri \2192";position:absolute;left:30px;bottom:22px;display:inline-flex;align-items:center;gap:6px;padding:9px 17px;border-radius:999px;background:var(--blue);color:#fff;font-size:11.5px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;opacity:1;box-shadow:0 10px 22px -10px rgba(14,114,185,.7);transition:transform .25s,box-shadow .25s,background .25s}
.home-services .home-service-card:hover::after{transform:translateX(5px);background:#0b5fa0;box-shadow:0 14px 28px -10px rgba(14,114,185,.85)}
@media(max-width:600px){ .home-services .home-service-card{padding-bottom:62px !important} }

/* ===== SB v6: immagini servizi coerenti (icona + gradiente brand) ===== */
.home-services .svc-img.svc-ic{position:relative;display:flex;align-items:center;justify-content:center;aspect-ratio:16/10;margin:-30px -30px 24px;overflow:hidden;background:linear-gradient(135deg,#1183d4 0%,#0e6db0 45%,#0b3f6e 100%)}
.home-services .svc-img.svc-ic::after{content:none !important}
.home-services .svc-img.svc-ic::before{content:"";position:absolute;right:-34px;top:-34px;width:130px;height:130px;border-radius:50%;background:radial-gradient(circle,rgba(255,255,255,.16),transparent 70%)}
.home-services .svc-img.svc-ic svg{position:relative;z-index:2;width:52px;height:52px;color:#fff;transition:transform .45s}
.home-services .home-service-card:hover .svc-img.svc-ic svg{transform:scale(1.09)}
@media(max-width:600px){ .home-services .svc-img.svc-ic{margin:-26px -24px 18px} }
/* Hero reel rotation cover (SB v7) */
.hero-reel-frame iframe.reel-cover-port{top:-13%;left:0;width:100%;height:126%;transform:none}
.hero-reel-frame iframe.reel-cover-land{top:50%;left:50%;width:348%;height:110%;transform:translate(-50%,-50%)}

/* ===== Hero cinematic full-bleed video (SB v8) ===== */
.hero-video{position:absolute;inset:0;overflow:hidden;z-index:0;background:#0a1626}
.hero-video iframe{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:100vw;height:56.25vw;min-height:100vh;min-width:177.78vh;border:0;pointer-events:none}
.hero.hero-v2::before{content:"";position:absolute;inset:0;z-index:1;background:linear-gradient(90deg,rgba(11,18,30,.9),rgba(11,18,30,.66) 42%,rgba(11,18,30,.38) 76%,rgba(11,18,30,.54)),linear-gradient(0deg,rgba(11,18,30,.66),rgba(11,18,30,0) 48%)}
.hero-pattern{z-index:1}
.hero .container{position:relative;z-index:3}
.hero-scroll{z-index:3}
.hero-cols{display:block}
.hero-stack{max-width:760px;position:relative;z-index:3}
@media(max-width:760px){ .hero-stack{max-width:none} }
