/* =========================================================
   ACCESSIBILITÀ — Skip link (EAA)
========================================================= */
.skip-link{
  position:absolute;
  top:-48px;
  left:16px;
  z-index:9999;
  background:var(--surface-deep);
  color:#fff;
  padding:10px 18px;
  border-radius:0 0 var(--radius-md) var(--radius-md);
  font-size:14px;
  font-weight:600;
  text-decoration:none;
  transition:top .15s;
}
.skip-link:focus{top:0}

/* =========================================================
   DVR CORPORATE — DESIGN TOKENS (Hydra Pulse adapted)
========================================================= */
:root{
  /* Surfaces */
  --surface-ice:#EAF2F7;
  --surface-abyss:#0E1414;
  --surface-paper:#FAFBFC;
  --surface-deep:#13343C;
  --surface-glass:rgba(255,255,255,.08);

  /* Aqua scale */
  --aqua-50:#E5F0F7; --aqua-100:#D2E3EE; --aqua-200:#A8C9DE;
  --aqua-400:#5B9DC2; --aqua-600:#1F6B8E; --aqua-800:#0F3D52; --aqua-950:#022677;

  /* Pulse */
  --pulse-lime:#81ecf1; --pulse-lime-soft:#48d7df; --pulse-mint:#7FE3C4;

  /* Text */
  --text-primary:#0A2330;
  --text-primary-dark:#FAFBFC;
  --text-muted:#5C7682;
  --text-muted-dark:#9DB3BC;

  /* Semantic */
  --success:#7FE3C4; --warning:#F5C84B; --error:#E66B6B; --info:#5B9DC2;

  /* Font stack */
  --font-display:"Anton","Bebas Neue","Archivo Narrow",system-ui,sans-serif;
  --font-serif:"Fraunces","PP Editorial New",Georgia,serif;
  --font-body:"Manrope","Inter","SF Pro Text",system-ui,sans-serif;
  --font-numeric:"Space Grotesk","JetBrains Mono",ui-monospace,monospace;

  /* Radii */
  --radius-sm:8px; --radius-md:16px; --radius-lg:24px; --radius-xl:32px; --radius-pill:999px;

  /* Shadows */
  --shadow-sm:0 1px 2px rgba(10,35,48,.06);
  --shadow-md:0 8px 24px rgba(10,35,48,.10);
  --shadow-lg:0 24px 48px rgba(10,35,48,.18);
  --shadow-glow:0 0 0 4px rgba(212,245,66,.35);

  /* Motion */
  --ease-out:cubic-bezier(.22,1,.36,1);
  --ease-in:cubic-bezier(.7,0,.84,0);

  /* Layout */
  --container:1280px;
  --nav-height:88px;
}

/* Reset */
*,*::before,*::after{box-sizing:border-box}
html,body{margin:0;padding:0}
html{scroll-behavior:auto}
body{
  font-family:var(--font-body);
  font-size:17px;line-height:1.55;font-weight:400;
  color:var(--text-primary);
  /* background:var(--surface-ice); */
  background:#fff;
  -webkit-font-smoothing:antialiased;
  font-feature-settings:"ss01","cv11";
  overflow-x:hidden;

  background-image: url(../img/section_separator.webp);
  background-size: 100% auto;
  background-position: center bottom -300px;
  background-repeat: no-repeat;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer;border:none;background:none;color:inherit}
input,textarea,select{font:inherit;color:inherit}
::selection{background:var(--pulse-lime);color:var(--aqua-950)}

/* =========================================================
   TYPOGRAPHY
========================================================= */
.t-display-2xl{font-family:var(--font-display);font-size:clamp(64px,11vw,140px);line-height:.88;letter-spacing:-.025em;text-transform:uppercase;font-weight:400;margin:0}
.t-display-xl{font-family:var(--font-display);font-size:clamp(56px,8vw,96px);line-height:.92;letter-spacing:-.02em;text-transform:uppercase;font-weight:400;margin:0}
.t-display-l{font-family:var(--font-display);font-size:clamp(44px,6vw,72px);line-height:.95;letter-spacing:-.015em;text-transform:uppercase;font-weight:400;margin:0}
.t-display-m{font-family:var(--font-display);font-size:clamp(36px,5vw,56px);line-height:1;letter-spacing:-.01em;text-transform:uppercase;font-weight:400;margin:0}
.t-heading-xl{font-family:var(--font-display);font-size:clamp(28px,3.4vw,40px);line-height:1.05;text-transform:uppercase;font-weight:400;margin:0}
.t-heading-l{font-family:var(--font-display);font-size:clamp(24px,2.6vw,32px);line-height:1.1;text-transform:uppercase;font-weight:400;margin:0}
.t-heading-m{font-family:var(--font-display);font-size:24px;line-height:1.15;text-transform:uppercase;font-weight:400;margin:0}
.t-editorial-l{font-family:var(--font-serif);font-size:clamp(28px,3.4vw,40px);line-height:1.2;letter-spacing:-.01em;font-weight:500;font-style:italic;margin:0}
.t-editorial-m{font-family:var(--font-serif);font-size:clamp(22px,2.4vw,28px);line-height:1.3;font-weight:500;margin:0}
.t-body-xl{font-family:var(--font-body);font-size:clamp(18px,1.6vw,20px);line-height:1.55;font-weight:400;margin:0}
.t-body-l{font-size:17px;line-height:1.6;margin:0}
.t-body-m{font-size:15px;line-height:1.55;margin:0}
.t-body-s{font-size:13px;line-height:1.5;font-weight:500;margin:0}
.t-label{font-size:13px;line-height:1.2;font-weight:600;letter-spacing:.02em;margin:0}
.t-overline{font-family:var(--font-body);font-size:11px;line-height:1;font-weight:700;letter-spacing:.14em;text-transform:uppercase;margin:0}
.t-numeric-xl{font-family:var(--font-numeric);font-size:clamp(56px,9vw,96px);line-height:.9;font-weight:600;letter-spacing:-.04em;font-variant-numeric:tabular-nums;margin:0}
.t-numeric-l{font-family:var(--font-numeric);font-size:56px;line-height:.95;font-weight:600;letter-spacing:-.03em;margin:0}
.t-mono-s{font-family:var(--font-numeric);font-size:12px;line-height:1.4;font-weight:500;letter-spacing:.04em}

.serif-em{font-family:var(--font-serif);font-style:italic;font-weight:500;text-transform:none;letter-spacing:0}

/* serif-em dentro titoli display Anton: uppercase + compressione verticale */
.t-display-2xl .serif-em,
.t-display-xl .serif-em,
.t-display-l .serif-em,
.t-display-m .serif-em,
.t-heading-xl .serif-em,
.t-heading-l .serif-em{
  text-transform:uppercase;
  letter-spacing:-3px;
  transform:scaleY(1.1) scaleX(1) translateY(-7%);
  display:inline-block;
}
.muted{color:var(--text-muted)}
.muted-d{color:var(--text-muted-dark)}
.mark-lime{
  mix-blend-mode: color-burn;
  background:linear-gradient(120deg,transparent 6%,var(--pulse-lime) 6% 94%,transparent 94%);padding:0 .15em;border-radius:6px;color:var(--aqua-950)
}

/* =========================================================
   LAYOUT HELPERS
========================================================= */
.container{max-width:var(--container);margin:0 auto;padding:0 clamp(20px,4vw,32px)}
.row{display:flex;flex-wrap:wrap;gap:16px;align-items:center}
.section{padding:clamp(72px,10vw,128px) 0}
.section--paper{background:var(--surface-paper)}
.section--ice{background:var(--surface-ice)}
.section--deep{position: relative;z-index: 10;background: #13343ced;
    color: var(--text-primary-dark);
    backdrop-filter: blur(16px);}
.section--abyss{background:var(--surface-abyss);color:var(--text-primary-dark)}
.section__head{margin-bottom:clamp(40px,6vw,72px);display:grid;gap:18px;max-width:760px}
.section__head > p.t-body-l{
  padding-top: 30px;
  padding-bottom: 30px;
}
.section__head .eyebrow{display:inline-flex;width:fit-content;padding:6px 14px;border-radius:var(--radius-pill);background:var(--aqua-950);color:var(--pulse-lime-soft)}

.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:clamp(32px,5vw,64px); margin-top: 30px !important;}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(20px,3vw,32px); margin-top: 30px !important;}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(16px,2.5vw,28px); margin-top: 30px !important;}
@media (max-width:960px){.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}}
@media (min-width:961px) and (max-width:1100px){.grid-4{grid-template-columns:repeat(2,1fr)}}

/* =========================================================
   BUTTONS
========================================================= */
.btn{
  display:inline-flex;align-items:center;gap:10px;
  padding:14px 24px;border-radius:var(--radius-pill);
  font-family:var(--font-body);font-weight:600;font-size:14px;
  letter-spacing:.01em;border:1px solid transparent;cursor:pointer;
  transition:transform .22s var(--ease-out),box-shadow .22s var(--ease-out),background .22s,color .22s;
  text-decoration:none;
}
.btn:hover{transform:translateY(-2px)}
.btn:active{transform:translateY(0) scale(.98)}
.btn:focus-visible{outline:none;box-shadow:var(--shadow-glow)}
.btn--lime{background:var(--pulse-lime);color:var(--aqua-950)}
.btn--lime:hover{background:var(--pulse-lime-soft);box-shadow:var(--shadow-md)}
.btn--dark{background:var(--surface-abyss);color:#fff}
.btn--dark:hover{box-shadow:var(--shadow-md);background:var(--aqua-800)}
.btn--ghost{background:transparent;color:#fff;border-color:rgba(255,255,255,.3)}
.btn--ghost:hover{background:rgba(255,255,255,.08)}
.btn--ghost-dark{background:transparent;color:var(--aqua-950);border-color:var(--aqua-400)}
.btn--ghost-dark:hover{background:var(--aqua-50)}
.btn--pill-light{background:#fff;color:var(--aqua-950);padding:10px 18px;font-size:13px}
.btn--icon{width:44px;height:44px;padding:0;justify-content:center;border-radius:50%}
.btn--link{padding:0;background:none;color:var(--aqua-950);border-bottom:1px solid var(--aqua-600);border-radius:0;font-weight:500}
.btn--link:hover{color:var(--aqua-600);transform:none}
.btn--lg{padding:16px 30px;font-size:15px}

/* =========================================================
   CHIPS / TAGS
========================================================= */
.chip{display:inline-flex;align-items:center;gap:6px;padding:7px 14px;border-radius:var(--radius-pill);font-family:var(--font-body);font-size:11px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;line-height:1;height:28px}
.chip--lime{background:var(--pulse-lime);color:var(--aqua-950)}
.chip--dark{background:var(--aqua-950);color:#fff}
.chip--mint{background:var(--pulse-mint);color:var(--aqua-950)}
.chip--outline{background:transparent;border:1px solid var(--aqua-400);color:var(--aqua-600)}
.chip--glass{background:rgba(15,20,20,.55);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);color:#fff;border:1px solid rgba(255,255,255,.18)}

/* chip--glass negli hero: larghezza auto, font più grande */
.page-hero .chip--glass,
.hero .chip--glass{
  margin: 0 auto;
  width:auto;
  align-self:start;
  justify-self:start;
  display:inline-flex;
  font-size:14px;
  letter-spacing:.12em;
  padding:10px 20px;
  height:auto;
  line-height:1;
}
.page-hero .chip{
  margin: 0;
}

.chip .dot{width:6px;height:6px;border-radius:50%;background:currentColor}

/* =========================================================
   PRELOADER
========================================================= */
.preloader {
  position: fixed;
  inset: 0;
  z-index: 9999;
  background: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  pointer-events: none;
  transition: opacity .6s var(--ease-out), visibility .6s;
}
.preloader.is-done {
  opacity: 0;
  visibility: hidden;
}
.preloader__bar {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%) scaleX(0);
  transform-origin: center center;
  width: 240px;
  height: 1.5px;
  background: linear-gradient(90deg, var(--aqua-400), var(--aqua-600), var(--pulse-lime-soft));
  transition: transform .9s cubic-bezier(.22, 1, .36, 1);
}
.preloader__bar.is-growing {
  transform: translate(-50%, -50%) scaleX(1);
}

/* Blocca scroll durante preload */
html.is-loading body {
  overflow: hidden;
}

/* =========================================================
   NAV / HEADER
========================================================= */
.site-header{
  position:fixed;top:0;left:0;right:0;z-index:100;
  padding:18px 0;
  transition:background .35s var(--ease-out),backdrop-filter .35s,box-shadow .35s,padding .3s;
}
.site-header.is-scrolled{
  background:rgba(250,251,252,.85);
  backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);
  box-shadow:0 1px 0 rgba(10,35,48,.06);
  padding:12px 0;
}
.site-header.is-light{color:var(--text-primary)}
.site-header.is-light.is-scrolled{color:var(--text-primary)}

/* Quando il menu mobile è aperto: header bianco solido, testo scuro */
.site-header.menu-is-open{
  background:#fff !important;
  backdrop-filter:none !important;
  -webkit-backdrop-filter:none !important;
  box-shadow:0 1px 0 rgba(10,35,48,.06) !important;
  color:var(--text-primary) !important;
}

.nav{display:flex;align-items:center;justify-content:space-between;gap:32px}
.nav__brand{display:inline-flex;align-items:center;gap:6px}
.nav__brand i{color:var(--pulse-lime);font-style:normal;display:inline-block;transform:translateY(-2px)}
.nav__brand small{font-family:var(--font-body);font-size:9px;letter-spacing:.3em;font-weight:700;display:block;margin-top:2px;opacity:.7}

/* Logo nav: mark + type affiancati */
.nav__brand-link{display:inline-flex;align-items:center;gap:5px;text-decoration:none}
.nav__logo-mark{
  height:36px;width:auto;display:block;object-fit:contain;
  transition:height .3s var(--ease-out);
  flex-shrink:0;
}
.nav__logo-type{
  height:26px;margin-top: 3px;width:auto;display:block;object-fit:contain;
  transition:height .3s var(--ease-out), opacity .3s;
  flex-shrink:0;
}
.is-scrolled .nav__logo-mark{height:28px}
.is-scrolled .nav__logo-type{height:17px}

.nav__menu{display:flex;align-items:center;gap:4px;list-style:none;margin:0;padding:0}
.nav__link{
  display:inline-block;padding:10px 14px;border-radius:var(--radius-pill);
  font-size:13px;font-weight:600;letter-spacing:.02em;
  transition:background .2s,color .2s;
  position:relative;
}
.nav__link:hover{background:rgba(10,35,48,.06)}
.site-header.is-light:not(.is-scrolled) .nav__link:hover{background:rgba(10,35,48,.06)}
.nav__link.is-active::after{
  content:"";position:absolute;left:50%;bottom:4px;
  width:5px;height:5px;border-radius:50%;background:var(--pulse-lime);
  transform:translateX(-50%);
}
.nav__cta{display:flex;align-items:center;gap:10px}

.nav__toggle{
  display:none;width:44px;height:44px;border-radius:50%;
  background:rgba(10,35,48,.06);align-items:center;justify-content:center;
  flex-direction:column;gap:5px;
}
.site-header.is-light:not(.is-scrolled) .nav__toggle{background:rgba(10,35,48,.06)}
.nav__toggle span{display:block;width:18px;height:2px;background:currentColor;transition:transform .3s var(--ease-out),opacity .2s,width .3s var(--ease-out)}
.nav__toggle.is-open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav__toggle.is-open span:nth-child(2){opacity:0;width:0}
.nav__toggle.is-open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

.nav__mobile{
  position:fixed;inset:0;z-index:99;
  background:var(--aqua-950);color:#fff;
  display:flex;flex-direction:column;justify-content:space-between;
  padding:120px 32px 48px;
  opacity:0;pointer-events:none;
  transition:opacity .4s var(--ease-out);
}
.nav__mobile.is-open{opacity:1;pointer-events:auto}
.nav__mobile ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px}
.nav__mobile a{
  font-family:var(--font-display);font-size:clamp(26px,6vw,56px);line-height:1;
  text-transform:uppercase;letter-spacing:-.01em;
  display:inline-block;padding:8px 0;
  transform:translateY(20px);opacity:0;
  transition:opacity .5s var(--ease-out),color .2s;
}
.nav__mobile.is-open a{transform:translateY(0);opacity:1}
.nav__mobile.is-open li:nth-child(1) a{transition-delay:.1s}
.nav__mobile.is-open li:nth-child(2) a{transition-delay:.16s}
.nav__mobile.is-open li:nth-child(3) a{transition-delay:.22s}
.nav__mobile.is-open li:nth-child(4) a{transition-delay:.28s}
.nav__mobile.is-open li:nth-child(5) a{transition-delay:.34s}
.nav__mobile.is-open li:nth-child(6) a{transition-delay:.4s}
.nav__mobile.is-open li:nth-child(7) a{transition-delay:.46s}
.nav__mobile.is-open li:nth-child(8) a{transition-delay:.52s}
.nav__mobile a:hover{color:var(--pulse-lime)}
.nav__mobile-foot{display:flex;flex-direction:column;gap:14px;color:var(--text-muted-dark);font-size:14px}
.nav__mobile-foot a{font-family:var(--font-body);font-size:14px;text-transform:none;letter-spacing:0;padding:0}
.nav__mobile-foot a:hover{color:var(--pulse-lime)}

/* =========================================================
   NAV DROPDOWN — Soluzioni
========================================================= */
.nav__item--dropdown{position:relative}

.nav__link--dropdown::after{
  content:"";display:inline-block;
  width:5px;height:5px;
  border-right:1.5px solid currentColor;
  border-bottom:1.5px solid currentColor;
  transform:rotate(45deg) translateY(-2px);
  margin-left:6px;
  transition:transform .2s var(--ease-out);
  vertical-align:middle;
}
.nav__item--dropdown:hover .nav__link--dropdown::after{
  transform:rotate(-135deg) translateY(-2px);
}

.nav__dropdown{
  position:absolute;top:calc(100% + 8px);left:50%;
  transform:translateX(-50%) translateY(6px);
  min-width:200px;
  background:#fff;
  border-radius:var(--radius-lg);
  box-shadow:var(--shadow-lg);
  border:1px solid var(--aqua-100);
  list-style:none;margin:0;padding:8px;
  opacity:0;pointer-events:none;
  transition:opacity .22s var(--ease-out),transform .22s var(--ease-out);
  z-index:200;
}
.nav__item--dropdown:hover .nav__dropdown,
.nav__item--dropdown:focus-within .nav__dropdown{
  opacity:1;pointer-events:auto;
  transform:translateX(-50%) translateY(0);
}

.nav__dropdown li a{
  display:block;padding:9px 14px;border-radius:var(--radius-md);
  font-size:13px;font-weight:600;color:var(--text-primary);
  transition:background .15s,color .15s;
  white-space:nowrap;
}
.nav__dropdown li a:hover{background:var(--aqua-50);color:var(--aqua-950)}

.nav__dropdown-divider{
  height:1px;background:var(--aqua-100);
  margin:6px 8px;
}

.nav__dropdown-highlight{
  color:var(--aqua-600) !important;
  display:flex !important;align-items:center;gap:6px;
}
.nav__dropdown-highlight::before{
  content:"";display:inline-block;
  width:6px;height:6px;border-radius:50%;
  background:var(--pulse-lime);flex-shrink:0;
}

/* Mobile sub-voce */
.nav__mobile-sub{
  font-size:clamp(22px,5vw,38px) !important;
  padding-left:28px !important;
  opacity:.7;
}
.nav__mobile-sub::before{content:"↳ ";font-size:.7em;opacity:.6}

@media (max-width:960px){
  .nav__menu,.nav__cta .btn--cta-desktop{display:none}
  .nav__toggle{display:inline-flex}
  .hero__eyebrow{display:none}
}

/* =========================================================
   HERO HOME — LIGHT MODE
========================================================= */
.hero{
  position:relative;min-height:100vh;color:var(--text-primary);overflow:hidden;
  background:#fff;
  background-image:radial-gradient(ellipse 120% 70% at 50% 100%, rgba(128, 187, 224, 0.78) 0%, rgba(25, 71, 99, 0.105) 55%, transparent 100%);
  display:flex;align-items:center;justify-content:center;
  text-align:center;padding:calc(var(--nav-height) + 24px) 0 80px;
}
.hero__bg{
  display:none;
}
.hero__inner{position:relative;width:100%;max-width:1100px;padding:0 clamp(20px,4vw,32px);display:flex;flex-direction:column;align-items:center;gap:32px;z-index:43}
.hero__eyebrow{opacity:0;transform:translateY(20px)}
.hero__logo{
  height: clamp(86px,16vw,286px);
  margin-bottom: -10px;
  margin-top: -60px;
  width: auto;
  display: block;
  object-fit: contain;
  opacity: 0;
  transform: translateY(16px);
  transition: opacity .9s cubic-bezier(.22,1,.36,1),transform .9s cubic-bezier(.22,1,.36,1);
  transition-delay: .05s;
   
}
.hero__logo.is-visible{opacity:1;transform:none}
.hero__title{
  font-family:var(--font-display);
  font-size: clamp(26px,4.5vw,68px);line-height:.92;letter-spacing:-.02em;
  text-transform:uppercase;font-weight:400;margin:0;max-width:14ch;
}
.hero__title .word{display:inline-block;overflow:visible;line-height:1;padding-bottom:.06em;vertical-align:bottom}
.hero__title .word > span{display:inline-block;will-change:transform,opacity;overflow:visible}
.hero__title em{
  font-family:var(--font-serif);font-style:italic;font-weight:500;
  text-transform:none;color:var(--aqua-600);letter-spacing:-.005em;
}
.hero__lede{
  /* moved out of hero — kept for GSAP targeting, hidden in hero */
  display:none;
}
.hero__cta{display:flex;gap:12px;flex-wrap:wrap;justify-content:center;opacity:0;transform:translateY(20px)}
.hero__scroll{
  position:absolute;bottom:32px;left:50%;transform:translateX(-50%);
  font-size:11px;letter-spacing:.24em;text-transform:uppercase;color:var(--text-muted);
  display:inline-flex;flex-direction:column;align-items:center;gap:10px;font-weight:600;
  opacity:0;z-index:2;
}
.hero__scroll-line{
  width:1px;height:40px;background:linear-gradient(180deg,var(--aqua-400),transparent);
  animation:scroll-pulse 2.4s ease-in-out infinite;
}
@keyframes scroll-pulse{
  0%,100%{opacity:1;transform:scaleY(1)}
  50%{opacity:.3;transform:scaleY(.6)}
}

/* =========================================================
   HERO LIGHT — overrides specifici
========================================================= */
/* Bottone ghost nel hero light: bordo e testo scuri */
.hero .btn--ghost{
  color:var(--aqua-950);
  border-color:rgba(10,35,48,.25);
}
.hero .btn--ghost:hover{
  background:rgba(10,35,48,.06);
}
/* Feature lines nel hero light */
.hero .hf__label{color:var(--aqua-800);font-weight:700}
.hero .hf:hover .hf__label{color:var(--aqua-950)}
.hero .hf__label em{color:var(--aqua-600);font-weight:600}
.hero .hf:hover .hf__label em{color:var(--aqua-800)}
.hero .hf:active .hf__label{color:var(--aqua-600)}
.hero .hf__line{
  background: linear-gradient(90deg, rgb(0 56 91 / 55%), rgb(14 62 65 / 15%));
}
.hero .hf--right .hf__line{
  background: linear-gradient(90deg, rgb(0 56 91 / 55%), rgb(14 62 65 / 15%));
}
.hero .hf:hover .hf__line{opacity:1}
.hero .hf__dot{
  background:var(--aqua-600);
  box-shadow:0 0 8px 2px rgba(31,107,142,.3);
}
.hero .hf__dot::after{border-color:rgba(31,107,142,.4)}
.hero .hf:hover .hf__dot{box-shadow:0 0 14px 4px rgba(31,107,142,.5)}

/* =========================================================
   FADE-IN LENTO CON DELAY PER SOTTO-SEZIONI
========================================================= */
.fade-section{
  opacity:0;
  transform:translateY(18px);
  transition:
    opacity 1.6s cubic-bezier(.22,1,.36,1),
    transform 1.6s cubic-bezier(.22,1,.36,1);
  transition-delay:var(--fade-delay, 0s);
}
.fade-section.is-visible{
  opacity:1;
  transform:none;
}

/* =========================================================
   SEZIONE CHIARA — ACQUA E SALUTE
========================================================= */
.section--light-feature{
  background:var(--surface-paper);
  position:relative;
  overflow:hidden;
}
.section--light-feature::before{
  content:"";
  position:absolute;
  top:-120px;right:-80px;
  width:480px;height:480px;
  border-radius:50%;
  background:radial-gradient(circle,rgba(91,157,194,.08),transparent 70%);
  pointer-events:none;
}
.light-feature-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:clamp(20px,3vw,32px);
  margin-top:clamp(40px,6vw,64px) !important;
}
@media(max-width:900px){.light-feature-grid{grid-template-columns:1fr}}
.light-feature-card{
  padding:36px 32px;
  border-radius:var(--radius-xl);
  background:#fff;
  border:1px solid var(--aqua-100);
  display:grid;
  gap:16px;
  transition:transform .35s var(--ease-out),box-shadow .35s var(--ease-out),border-color .35s;
}
.light-feature-card:hover{
  transform:translateY(-5px);
  box-shadow:var(--shadow-md);
  border-color:var(--aqua-200);
}
.light-feature-card__icon{
  width:52px;height:52px;
  border-radius:var(--radius-md);
  background:var(--aqua-50);
  display:grid;place-items:center;
  color:var(--aqua-600);
}
.light-feature-card h3{
  font-family:var(--font-display);
  font-size:22px;
  text-transform:uppercase;
  line-height:1.1;
  margin:0;
  color:var(--aqua-950);
}
.light-feature-card p{
  margin:0;
  color:var(--text-muted);
  font-size:15px;
  line-height:1.65;
}
.light-feature-card .stat{
  font-family:var(--font-numeric);
  font-size:36px;
  font-weight:600;
  color:var(--aqua-600);
  letter-spacing:-.03em;
  line-height:1;
}

/* =========================================================
   COMMON PAGE HEADER (non-home)
========================================================= */
.page-hero{
  position:relative;min-height:42vh;color:#fff;overflow:hidden;
  background:var(--surface-deep);
  display:flex;align-items:flex-end;
  padding:calc(var(--nav-height) + 48px) 0 56px;
}
.page-hero__bg{
  position:absolute;inset:0;
  /* Sfondo unico per la sezione titolo di TUTTE le pagine interne (non home).
     !important neutralizza il background-image inline ancora presente nei
     pattern .php e nel DB delle singole pagine (vecchie cover specifiche).
     Gli inline NON vengono rimossi di proposito: la var $cover serve anche ad
     altre immagini nel corpo dei pattern. Centralizzato qui = a prova di futuro. */
  background-image:url('../img/pattern_invert.webp') !important;
  background-size:cover;background-position:center;
  background-color:var(--surface-deep);
}
.page-hero__bg::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(10,35,48,.35),rgba(10,35,48,.7));
}
.page-hero__inner{position:relative;width:100%;display:grid;gap:18px;max-width:880px}

/* =========================================================
   FEATURE / PROTOCOL STEPS
========================================================= */
.step{
  padding:32px;border-radius:var(--radius-xl);background:#fff;
  box-shadow:var(--shadow-sm);display:grid;gap:14px;
  border:1px solid var(--aqua-100);height:100%;
  transition:transform .35s var(--ease-out),box-shadow .35s var(--ease-out),border-color .35s;
}
.step:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);border-color:var(--aqua-200)}
.step__num{
  font-family:var(--font-numeric);font-size:48px;font-weight:600;line-height:1;
  color:var(--aqua-600);letter-spacing:-.03em;
}
.step__num::after{content:"";display:inline-block;width:24px;height:1px;background:var(--pulse-lime);margin-left:10px;vertical-align:middle}
.step h3{font-family:var(--font-display);font-size:22px;text-transform:uppercase;line-height:1.1;margin:0;color:var(--aqua-950)}
.step p{margin:0;color:var(--text-muted);font-size:14px;line-height:1.55}

/* =========================================================
   SOLUTION CARDS
========================================================= */
.solution{
  display:grid;grid-template-columns:1fr;
  background:#fff;border-radius:var(--radius-xl);overflow:hidden;
  box-shadow:var(--shadow-sm);border:1px solid var(--aqua-100);
  transition:transform .35s var(--ease-out),box-shadow .35s var(--ease-out);
}
.solution:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}
.solution__media{aspect-ratio:4/3;background:#fff;position:relative;overflow:hidden}
.solution__media img{width:100%;height:100%;object-fit:cover;transition:transform .8s var(--ease-out)}
.solution:hover .solution__media img{transform:scale(1.04)}
.solution__media .chip{
  position:absolute;
  top:50%;left:50%;
  transform:translate(-50%,-50%);
  z-index:2;
  font-size:20px;
  letter-spacing:.06em;
  padding:16px 32px;
  height:auto;
  pointer-events:none;
  transition:opacity .3s, background .3s;
}
.solution__media .chip.blotter-active{
  /* hide text once blotter canvas replaces it */
  color:transparent !important;
  background:transparent !important;
  border-color:transparent !important;
  padding:0;
  width:auto;height:auto;
}
.solution__media .chip canvas{display:block}
.solution__body{padding:32px;display:grid;gap:18px}
.solution__body h3{font-family:var(--font-display);font-size:28px;text-transform:uppercase;line-height:1.05;margin:0;color:var(--aqua-950)}
.solution__body p{margin:0;color:var(--text-muted);font-size:15px;line-height:1.6}
.solution__body .btn{
  justify-self:start;
  background:var(--aqua-950);color:#fff;
  border-radius:var(--radius-pill);
  padding:12px 22px;font-size:13px;font-weight:600;
  letter-spacing:.02em;border:none;
  display:inline-flex;align-items:center;gap:8px;
  transition:transform .22s var(--ease-out),box-shadow .22s var(--ease-out),background .22s;
}
.solution__body .btn:hover{
  background:var(--aqua-600);
  transform:translateY(-2px);
  box-shadow:var(--shadow-md);
}
.solution:hover .solution__body .btn{
  background:var(--aqua-600);
}

/* =========================================================
   SOLUTIONS SLIDER — mobile horizontal scroll snap
========================================================= */
@media (max-width: 960px) {
  .solutions-slider {
    display: flex;
    flex-direction: row;
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
    gap: 16px;
    padding-bottom: 20px;
    /* Estende oltre il container per toccare i bordi */
    margin-left: calc(-1 * clamp(20px, 4vw, 32px));
    margin-right: calc(-1 * clamp(20px, 4vw, 32px));
    padding-left: clamp(20px, 4vw, 32px);
    padding-right: clamp(20px, 4vw, 32px);
    /* Nasconde scrollbar ma mantiene funzionalità */
    scrollbar-width: none;
  }
  .solutions-slider::-webkit-scrollbar { display: none; }

  .solutions-slider > .solution {
    flex: 0 0 80vw;
    max-width: 320px;
    scroll-snap-align: start;
    /* Annulla l'animazione stagger su mobile — già visibili */
    opacity: 1 !important;
    transform: none !important;
  }

  /* Indicatore dots sotto lo slider */
  .solutions-slider::after {
    content: '';
    flex: 0 0 clamp(20px, 4vw, 32px);
    /* spacer finale per padding visivo */
  }
}

/* =========================================================
   TESTIMONIAL CARD
========================================================= */
.testimonial{
  padding:32px;border-radius:var(--radius-xl);background:#fff;
  box-shadow:var(--shadow-sm);border:1px solid var(--aqua-100);
  display:grid;gap:20px;height:100%;
  transition:transform .35s var(--ease-out),box-shadow .35s var(--ease-out);
}
.testimonial:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}
.testimonial__quote{
  font-family:var(--font-serif);font-style:italic;font-weight:500;
  font-size:18px;line-height:1.5;color:var(--aqua-950);
  border-left:3px solid var(--pulse-lime);padding-left:18px;margin:0;
}
.testimonial__author{display:flex;align-items:center;gap:14px}
.testimonial__avatar{width:54px;height:54px;border-radius:50%;overflow:hidden;background:var(--aqua-100);flex-shrink:0}
.testimonial__avatar img{width:100%;height:100%;object-fit:cover}
.testimonial__name{font-family:var(--font-display);text-transform:uppercase;font-size:18px;line-height:1.1;color:var(--aqua-950);margin:0}
.testimonial__role{font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--text-muted);font-weight:600;margin-top:4px}

/* =========================================================
   FORM
========================================================= */
.form-card{
  background:#fff;border-radius:var(--radius-xl);
  padding:clamp(28px,5vw,56px);
  box-shadow:var(--shadow-md);
  border:1px solid var(--aqua-100);
  display:grid;gap:24px;
}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.form-grid--full{grid-template-columns:1fr}
@media (max-width:720px){.form-grid{grid-template-columns:1fr}}
.field{display:grid;gap:8px;width:100%}
.field > label{font-family:var(--font-body);font-size:11px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--text-muted)}
.field > label .req{color:var(--error)}
.input,.textarea,.select{
  width:100%;padding:14px 16px;border-radius:var(--radius-md);
  border:1px solid var(--aqua-200);background:#fff;
  font-size:15px;color:var(--text-primary);
  transition:border-color .2s,box-shadow .2s;
}
.input::placeholder,.textarea::placeholder{color:#9CB1BC}
.input:focus,.textarea:focus,.select:focus{outline:none;border-color:var(--aqua-600);box-shadow:0 0 0 3px rgba(91,157,194,.22)}
.textarea{resize:vertical;min-height:96px}

/* Input file (CV PDF) */
.input.dvr-file{padding:11px 14px;cursor:pointer;font-size:14px;color:var(--text-muted)}
.input.dvr-file::file-selector-button{
  margin-right:14px;padding:9px 16px;border:none;border-radius:var(--radius-sm,8px);
  background:var(--aqua-950);color:#fff;font-weight:600;font-size:13px;cursor:pointer;
  transition:background .2s;
}
.input.dvr-file::file-selector-button:hover{background:var(--aqua-800,#123)}
.dvr-file-hint{display:block;margin-top:8px}

.check-group{display:flex;gap:18px;flex-wrap:wrap;padding-top:2px}
.check{display:flex;align-items:center;gap:10px;cursor:pointer;font-size:14px}
.check input{appearance:none;width:20px;height:20px;border-radius:6px;border:1.5px solid var(--aqua-400);background:#fff;display:grid;place-items:center;transition:.18s;cursor:pointer}
.check input:checked{background:var(--pulse-lime);border-color:var(--pulse-lime)}
.check input:checked::after{content:"";width:10px;height:6px;border:2px solid var(--aqua-950);border-top:none;border-right:none;transform:rotate(-45deg) translate(1px,-1px)}
.check.radio input{border-radius:50%}
.check.radio input:checked{background:#fff;border-color:var(--aqua-600)}
.check.radio input:checked::after{content:"";width:10px;height:10px;border:none;border-radius:50%;background:var(--pulse-lime);transform:none}

/* =========================================================
   CONTACT BLOCK
========================================================= */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:stretch;padding-top: 60px;}
@media (max-width:960px){.contact-grid{grid-template-columns:1fr}}
.contact-info{display:grid;gap:12px;align-content:start}
.contact-row{
  display:flex;gap:0;align-items:stretch;
  background:#fff;border-radius:var(--radius-lg);
  border:1px solid var(--aqua-100);
  overflow:hidden;
  transition:transform .3s var(--ease-out),box-shadow .3s var(--ease-out),border-color .3s;
}
.contact-row:hover{transform:translateY(-3px);box-shadow:var(--shadow-md);border-color:var(--aqua-200)}
.contact-row__icon{
  width:68px;
  flex-shrink:0;
  background:var(--aqua-950);
  color:var(--pulse-lime);
  display:flex;align-items:center;justify-content:center;
  padding:0;
}
.contact-row__icon svg{display:block;flex-shrink:0;width:26px;height:26px}
.contact-row__body{
  padding:18px 22px;
  display:flex;flex-direction:column;justify-content:center;gap:3px;
  flex:1;min-width:0;
}
.contact-row b{
  font-size:10px;letter-spacing:.16em;text-transform:uppercase;
  color:var(--text-muted);font-weight:700;display:block;
}
.contact-row__body span{
  font-size:15px;color:var(--aqua-950);font-weight:600;line-height:1.35;
  overflow:hidden;text-overflow:ellipsis;
}

.map-wrap{
  border-radius:var(--radius-lg);overflow:hidden;background:var(--aqua-100);
  border:1px solid var(--aqua-200);min-height:420px;
}
.map-wrap iframe{width:100%;height:100%;border:0;display:block;min-height:420px}

/* =========================================================
   FOOTER
========================================================= */
.site-footer{
  background:var(--surface-abyss);
  color:#fff;
  padding:0 0 32px;
  position:relative;
  max-width: 1600px;
  margin-left: auto;
  margin-right: auto;
  display: block;
  /* overflow:hidden; */
}

body:not(.home) .site-footer{
  margin-top: -24px;
  border-radius: 0 !important;
  max-width: 1920px;
}

@media (min-width:1025px) {

  .site-footer{
    border-top-left-radius:var(--radius-lg);
    border-top-right-radius:var(--radius-lg);
    
    overflow: hidden;
  }
  
}
/* Foto acqua locale come sfondo */
.site-footer::before{
  content:"";
  position:absolute;inset:0;
  background:url('../img/footer_bg.webp') center/cover no-repeat;
  opacity:1;
  pointer-events:none;
}
.site-footer::after{
  opacity: 0.7;
  content:"";
  position:absolute;inset:0;
  background:linear-gradient(180deg,var(--surface-abyss) 0%,rgba(14,20,20,.92) 40%,var(--surface-abyss) 100%);
  pointer-events:none;
}
.footer__inner{position:relative;z-index:1}

/* Top CTA band */
.footer__cta-band{
  text-align:center;
  padding:clamp(64px,9vw,112px) 0 clamp(56px,7vw,88px); 
  margin-bottom:clamp(48px,6vw,72px);
  padding-top: 0;
  border-radius:var(--radius-lg);
}
.footer__logo{
  height: 222px;width:auto;display:block;margin:0 auto 32px;object-fit:contain;
  border-radius: 0 0 20px 20px;
  background-color: #fff;
  padding-bottom: 20px; 
}
.footer__cta-band .eyebrow{
  font-size:11px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;
  color:var(--text-muted-dark);display:block;margin-bottom:20px;
}
.footer__cta-band h2{
  font-family:var(--font-display);
  font-size:clamp(40px,7vw,88px);
  line-height:.92;letter-spacing:-.02em;text-transform:uppercase;
  color:#fff;margin:0 0 32px;
  padding-top: 60px;
  padding-bottom: 60px;
}
.footer__cta-band h2 em{
  font-family:var(--font-serif);font-style:italic;font-weight:500;
  text-transform:none;color:var(--pulse-lime);letter-spacing:-.005em;
}
.footer__cta-band .footer__cta-btns{
  display:flex;gap:12px;justify-content:center;flex-wrap:wrap;
}

.footer-grid{
  display:grid;
  grid-template-columns:2fr 1fr 1fr 1fr;
  gap:0;
  margin-bottom:56px;
  border-top:1px solid rgba(255,255,255,.08);
  padding-top:56px;
}
@media (max-width:900px){.footer-grid{grid-template-columns:1fr 1fr;gap:0}}
@media (max-width:560px){.footer-grid{grid-template-columns:1fr}}

.footer-grid > div{
  padding-right:40px;
}
@media (max-width:900px){.footer-grid > div{padding-right:24px;padding-bottom:40px}}

.footer__brand{
  font-family:var(--font-display);font-size:26px;letter-spacing:.16em;
  margin-bottom:14px;display:inline-block;line-height:1;
}
.footer__brand i{color:var(--pulse-lime);font-style:normal}
.footer__tag{
  color:var(--text-muted-dark);font-size:13px;line-height:1.7;
  max-width:300px;margin:0 0 28px;
}

.footer__col-label{
  font-size:10px;font-weight:700;letter-spacing:.2em;text-transform:uppercase;
  color:rgba(255,255,255,.3);margin:0 0 20px;display:block;
}

.footer__nav{
  display:flex;flex-direction:column;gap:0;
}
.footer__nav a{
  color:rgba(255,255,255,.65);
  font-size:14px;font-weight:500;
  line-height:1;
  padding:9px 0;
  border-bottom:1px solid rgba(255,255,255,.05);
  transition:color .2s,padding-left .2s;
  display:block;
}
.footer__nav a:first-child{border-top:1px solid rgba(255,255,255,.05)}
.footer__nav a:hover{color:#fff;padding-left:6px}

.footer__address{
  display:flex;flex-direction:column;gap:0;
}
.footer__address-item{
  color:rgba(255,255,255,.65);
  font-size:14px;font-weight:500;
  line-height:1.4;
  padding:9px 0;
  border-bottom:1px solid rgba(255,255,255,.05);
}
.footer__address-item:first-child{border-top:1px solid rgba(255,255,255,.05)}
.footer__address-item a{
  color:inherit;transition:color .2s;
}
.footer__address-item a:hover{color:#fff}

.footer__social{display:flex;gap:8px;margin-top:8px}
.footer__social a{
  width:38px;height:38px;border-radius:var(--radius-md);
  background:rgba(255,255,255,.06);
  display:grid;place-items:center;
  transition:background .2s,color .2s;
  border:1px solid rgba(255,255,255,.06);
}
.footer__social a:hover{background:var(--pulse-lime);color:var(--aqua-950);border-color:var(--pulse-lime)}
.footer__social svg{display:block}

.footer__bottom{
  padding-top:24px;border-top:1px solid rgba(255,255,255,.08);
  display:flex;flex-wrap:wrap;justify-content:space-between;gap:16px;
  font-size:12px;color:rgba(255,255,255,.3);letter-spacing:.04em;
}
.footer__bottom a{color:rgba(255,255,255,.4);transition:color .2s}
.footer__bottom a:hover{color:var(--pulse-lime)}

/* =========================================================
   SCROLL REVEAL — CSS transition system (no GSAP)
   Elements start hidden, get .is-visible via IntersectionObserver.
   Children of [data-stagger] get --reveal-delay set by JS.
========================================================= */

/* Base hidden state — only opacity + transform, never layout properties */
[data-reveal],
[data-stagger] > * {
  opacity: 0;
  transform: translateY(20px);
  transition:
    opacity 0.85s cubic-bezier(.22,1,.36,1),
    transform 0.85s cubic-bezier(.22,1,.36,1);
  transition-delay: var(--reveal-delay, 0s);
}

/* Visible state */
[data-reveal].is-visible,
[data-stagger] > *.is-visible {
  opacity: 1;
  transform: none;
}

/* Grid/flex containers that use data-reveal: children must NOT inherit hidden state.
   .split columns must always be visible — animate the container, not the columns. */
.split[data-reveal] > *,
.split[data-stagger] > * {
  opacity: 1 !important;
  transform: none !important;
  transition: none !important;
}

/* no-js fallback */
.no-js [data-reveal],
.no-js [data-stagger] > * {
  opacity: 1;
  transform: none;
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce) {
  [data-reveal],
  [data-stagger] > * {
    transition: none;
    opacity: 1;
    transform: none;
  }
}

/* =========================================================
   HERO CHAR ANIMATION — CSS-driven
========================================================= */
.hero-char {
  display: inline-block;
  opacity: 0;
  transform: translateY(22px);
  transition:
    opacity 1.4s cubic-bezier(.22,1,.36,1),
    transform 1.4s cubic-bezier(.22,1,.36,1);
  /* delay = index * 50ms, set via --char-i */
  transition-delay: calc(var(--char-i, 0) * 50ms + 400ms);
}
.hero__title.is-animating .hero-char {
  opacity: 1;
  transform: none;
}

/* Hero eyebrow / cta / scroll — simple fade+up */
.hero__eyebrow {
  opacity: 0;
  transform: translateY(16px);
  transition: opacity 1.8s cubic-bezier(.22,1,.36,1), transform 1.8s cubic-bezier(.22,1,.36,1);
}
.hero__eyebrow.is-visible { opacity: 1; transform: none; }

.hero__cta {
  opacity: 0;
  transform: translateY(16px);
  transition: opacity 2s cubic-bezier(.22,1,.36,1), transform 2s cubic-bezier(.22,1,.36,1);
}
.hero__cta.is-visible { opacity: 1; transform: none; }

.hero__scroll {
  opacity: 0;
  transition: opacity 2s cubic-bezier(.22,1,.36,1);
}
.hero__scroll.is-visible { opacity: 1; }

/* Fix capo a capo titoli data-split-text: il wrapper non deve tagliare */
[data-split-text] > span{
  display:inline;
  overflow:visible;
}
[data-split-text] > span > span{
  display:inline-block;
  overflow:visible;
  vertical-align:bottom;
}
 

/* =========================================================
   ASYM IMAGE BLOCKS / EDITORIAL
========================================================= */
.split{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:clamp(32px,5vw,80px);
  align-items:center;
}
.split--reverse .split__media{grid-column:2;grid-row:1}
.split--reverse .split__copy{grid-column:1;grid-row:1}
@media (max-width:900px){
  .split{grid-template-columns:1fr}
  .split--reverse .split__media{grid-column:auto;grid-row:auto}
  .split--reverse .split__copy{grid-column:auto;grid-row:auto}
}
.split__media{
  border-radius:var(--radius-xl);overflow:hidden;aspect-ratio:4/5;background:var(--aqua-100);
  position:relative;
}
.split__media img{width:100%;height:100%;object-fit:cover}
.split__copy{display:grid;gap:20px;align-content:center}

/* Desktop overlap — removed, was causing grid layout issues */

/* =========================================================
   SECTION SEPARATOR (acqua image, white top → #002e3e bottom)
========================================================= */
.section-separator{
  position:relative;
  width:100%;
  height:clamp(280px,30vw,480px);
  overflow:hidden;
  display:block;
}
.section-separator img{
  position:absolute;inset:0;
  width:100%;height:100%;
  object-fit:cover;
  object-position:center 40%;
  display:block;
}


/* Gradient: white from top, #002e3e from bottom */
.section-separator::after{
  content:"";
  position:absolute;inset:0;
  background:linear-gradient(
    180deg,
    #fff 0%,
    rgba(255,255,255,0) 28%,
    rgba(0,46,62,0) 68%,
    #002e3e 100%
  );
  pointer-events:none;
}

@media(max-width:991px){

  .section-separator{
    margin-top: 40vw;
    min-height: 70vw;
  }

  .section-separator::after{display:none}
}
/* =========================================================
   LEDE BAND (ex hero__lede, now standalone section)
========================================================= */
.lede-band{
  background:#002e3e;
  padding:clamp(64px,9vw,112px) 0;
  position:relative;
  overflow:hidden;
}
.lede-band::before{
  content:"";
  position:absolute;inset:0;
  background:
    radial-gradient(ellipse at 10% 50%, rgba(212,245,66,.06), transparent 60%),
    radial-gradient(ellipse at 90% 50%, rgba(31,107,142,.18), transparent 60%);
  pointer-events:none;
}
.lede-band__inner{
  position:relative;z-index:1;
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:clamp(40px,6vw,96px);
  align-items:center;
}
@media(max-width:760px){.lede-band__inner{grid-template-columns:1fr;gap:32px}}
.lede-band__quote{
  font-family:var(--font-serif);
  font-style:italic;
  font-weight:500;
  font-size:clamp(22px,3vw,36px);
  line-height:1.3;
  color:#fff;
  margin:0;
  padding-left:24px;
  border-left:3px solid var(--pulse-lime);
}
.lede-band__quote em{
  font-style:normal;
  color:var(--pulse-lime);
}
.lede-band__facts{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:1px;
  background:rgba(255,255,255,.08);
  border-radius:var(--radius-xl);
  overflow:hidden;
}
.lede-band__fact{
  background:#002e3e;
  padding:28px 24px;
  display:grid;
  gap:6px;
}
.lede-band__fact-num{
  font-family:var(--font-numeric);
  font-size:clamp(36px,4vw,52px);
  font-weight:600;
  line-height:1;
  color:var(--pulse-lime);
  letter-spacing:-.03em;
}
.lede-band__fact-label{
  font-size:12px;
  font-weight:600;
  letter-spacing:.1em;
  text-transform:uppercase;
  color:rgba(255,255,255,.45);
}

.editorial-quote{
  padding:clamp(80px,11vw,140px) 0;
  background:#002e3e;
  color:#fff;
  position:relative;
  overflow:hidden;
}
/* Accent line sinistra */
.editorial-quote::after{
  content:"";
  position:absolute;left:0;top:0;bottom:0;
  width:3px;
  background:linear-gradient(180deg,transparent,var(--pulse-lime) 30%,var(--pulse-lime) 70%,transparent);
}
.editorial-quote .container{position:relative;z-index:1}
.editorial-quote .label{
  display:inline-flex;font-size:11px;font-weight:700;letter-spacing:.18em;
  text-transform:uppercase;color:var(--pulse-lime);margin-bottom:28px;
  gap:10px;align-items:center;
}
.editorial-quote .label::before{
  content:"";display:inline-block;width:32px;height:1px;background:var(--pulse-lime);
}
.editorial-quote p{
  font-family:var(--font-serif);
  font-size:clamp(28px,5vw,56px);
  line-height:1.15;font-weight:500;
  max-width:900px;margin:0;color:#fff;
  font-style:italic;
}
.editorial-quote em{font-style:normal;color:var(--pulse-lime)}
.editorial-quote .eq-foot{
  margin-top:40px;
  display:flex;align-items:center;gap:20px;
  font-size:12px;letter-spacing:.14em;text-transform:uppercase;
  color:var(--text-muted-dark);font-weight:600;
}
.editorial-quote .eq-foot::before{
  content:"";display:inline-block;width:48px;height:1px;background:rgba(255,255,255,.2);
}

/* Split variant — immagine + testo affiancati, colonne invertite (img sx, testo dx) */
.editorial-quote--split .eq-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:clamp(40px,6vw,96px);
  align-items:center;
}
/* Immagine a sinistra (colonna 1), testo a destra (colonna 2) */
.editorial-quote--split .eq-media{grid-column:1;grid-row:1}
.editorial-quote--split .eq-content{grid-column:2;grid-row:1}

.editorial-quote--split .eq-media{
  border-radius:var(--radius-xl);
  overflow:hidden;
  aspect-ratio:4/5;
  position:relative;
}
.editorial-quote--split .eq-media img{
  width:100%;height:100%;object-fit:cover;display:block;
}

/* Reveal clip: immagine parte coperta da un overlay che scivola via */
.editorial-quote--split .eq-media::after{
  content:"";
  position:absolute;inset:0;
  background:var(--surface-abyss);
  transform-origin:left center;
  transform:scaleX(1);
  transition:transform 1.1s cubic-bezier(.77,0,.18,1);
  transition-delay:.2s;
}
.editorial-quote--split .eq-media.is-visible::after{
  transform:scaleX(0);
  transform-origin:right center;
}

@media(max-width:860px){
  .editorial-quote--split .eq-grid{
    grid-template-columns:1fr;
    gap:clamp(32px,5vw,56px);
  }
  .editorial-quote--split .eq-media{grid-column:auto;grid-row:auto;aspect-ratio:16/9}
  .editorial-quote--split .eq-content{grid-column:auto;grid-row:auto}
}

/* =========================================================
   FAQ ACCORDION
========================================================= */
.faq{display:grid;gap:6px}
.faq__item{
  background:#fff;border:1px solid var(--aqua-100);border-radius:var(--radius-lg);
  overflow:hidden;transition:border-color .25s,box-shadow .25s;
}
.faq__item[open]{
  border-color:var(--aqua-200);
  box-shadow:var(--shadow-sm);
}
.faq__item summary{
  padding:22px 24px;cursor:pointer;list-style:none;
  display:flex;align-items:center;justify-content:space-between;gap:16px;
  font-family:var(--font-display);font-size:18px;text-transform:uppercase;color:var(--aqua-950);
  line-height:1.2;
  user-select:none;
  transition:color .2s;
}
.faq__item[open] summary{color:var(--aqua-600)}
.faq__item summary::-webkit-details-marker{display:none}
.faq__item summary::marker{display:none}

/* Icona: croce/più via CSS puro — niente testo */
.faq__icon{
  width:32px;height:32px;border-radius:50%;flex-shrink:0;
  background:var(--aqua-50);
  display:grid;place-items:center;
  transition:transform .35s var(--ease-out),background .25s;
  position:relative;
}
.faq__icon::before,
.faq__icon::after{
  content:"";position:absolute;
  background:var(--aqua-600);
  border-radius:2px;
  transition:transform .35s var(--ease-out),opacity .25s;
}
.faq__icon::before{width:12px;height:1.5px}   /* barra orizzontale */
.faq__icon::after {width:1.5px;height:12px}   /* barra verticale */

.faq__item[open] .faq__icon{
  background:var(--pulse-lime);
  transform:rotate(45deg);
}
.faq__item[open] .faq__icon::before,
.faq__item[open] .faq__icon::after{background:var(--aqua-950)}

/* Animazione apertura/chiusura via grid-template-rows */
.faq__body-wrap{
  display:grid;
  grid-template-rows:0fr;
  transition:grid-template-rows .38s var(--ease-out);
}
.faq__item[open] .faq__body-wrap{
  grid-template-rows:1fr;
}
.faq__body-inner{overflow:hidden}
.faq__body{
  padding:0 24px 22px;
  color:var(--text-muted);font-size:15px;line-height:1.65;
  border-top:1px solid var(--aqua-100);
  padding-top:16px;
}

/* =========================================================
   FAQ PAGE LAYOUT
========================================================= */
.faq-page-layout{
  display:grid;
  grid-template-columns:220px 1fr;
  gap:clamp(40px,6vw,80px);
  align-items:start;
}
@media(max-width:860px){.faq-page-layout{grid-template-columns:1fr}}

/* Sidebar nav categorie */
.faq-nav{
  position:sticky;
  top:calc(var(--nav-height) + 24px);
}
.faq-nav ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:2px}
.faq-nav__link{
  display:block;padding:10px 14px;border-radius:var(--radius-md);
  font-size:13px;font-weight:600;letter-spacing:.02em;color:var(--text-muted);
  transition:background .2s,color .2s;
}
.faq-nav__link:hover{background:var(--aqua-50);color:var(--aqua-950)}
.faq-nav__link.is-active{background:var(--aqua-950);color:#fff}
@media(max-width:860px){.faq-nav{display:none}}

/* Gruppi di domande */
.faq-page-content{display:flex;flex-direction:column;gap:clamp(48px,7vw,72px)}
.faq-group{display:flex;flex-direction:column;gap:16px}
.faq-group__title{
  font-family:var(--font-display);font-size:clamp(20px,2.2vw,26px);
  text-transform:uppercase;font-weight:400;color:var(--aqua-950);
  margin:0;padding-bottom:16px;
  border-bottom:2px solid var(--aqua-100);
}

/* CTA finale */
.faq-cta{
  padding:clamp(32px,5vw,48px);border-radius:var(--radius-lg);
  background:var(--aqua-50);border:1px solid var(--aqua-100);
}

/* =========================================================
   PRESS / LOGO ROW
========================================================= */
.press-row{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));
  gap:24px;align-items:center;
  padding:32px;border-radius:var(--radius-xl);
  background:#fff;border:1px solid var(--aqua-100);
}
.press-row img{max-height:60px;width:auto;margin:0 auto;opacity:.75;filter:grayscale(.3);transition:opacity .2s,filter .2s}
.press-row img:hover{opacity:1;filter:none}

/* =========================================================
   UTIL
========================================================= */
.text-center{text-align:center}
.mx-auto{margin-left:auto;margin-right:auto}
.mt-auto{margin-top:auto}
.mb-l{margin-bottom:24px}
.mb-xl{margin-bottom:48px}
.gap-s{gap:8px}.gap-m{gap:16px}.gap-l{gap:24px}.gap-xl{gap:32px}
.dark-img{filter:saturate(.85) brightness(.95)}

/* Reduced motion */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}
  [data-reveal],[data-stagger] > *,.hero-char,.hero__eyebrow,.hero__cta,.hero__scroll{opacity:1!important;transform:none!important}
}

/* =========================================================
   PAGE HERO VARIANTS
========================================================= */
.page-hero__inner h1{
  font-family:var(--font-display);font-size:clamp(48px,8vw,96px);
  line-height:.95;letter-spacing:-.02em;text-transform:uppercase;
  font-weight:400;margin:0;color:#fff;max-width:14ch;
}
.page-hero__inner em{font-family:var(--font-serif);font-style:italic;font-weight:500;text-transform:none;color:var(--pulse-lime)}
.page-hero__inner .lede{font-size:clamp(16px,1.6vw,20px);color:#cfd8dd;max-width:640px;margin:0;line-height:1.55}
.page-hero__breadcrumb{display:flex;gap:8px;align-items:center;font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:#cfd8dd;font-weight:600}
.page-hero__breadcrumb a{color:#cfd8dd}
.page-hero__breadcrumb a:hover{color:var(--pulse-lime)}
.page-hero__breadcrumb .sep{color:rgba(255,255,255,.3)}

/* =========================================================
   ARTICLE / BLOG
========================================================= */
.article{max-width:780px;margin:0 auto;padding:0 clamp(20px,4vw,32px)}
.article > * + *{margin-top:24px}
.article h2{font-family:var(--font-display);font-size:clamp(28px,3.4vw,40px);line-height:1.1;text-transform:uppercase;font-weight:400;color:var(--aqua-950);margin-top:64px}
.article h3{font-family:var(--font-display);font-size:24px;line-height:1.2;text-transform:uppercase;font-weight:400;color:var(--aqua-950);margin-top:48px}
.article p{font-size:17px;line-height:1.75;color:var(--text-primary);margin:0}
.article p.lede{font-family:var(--font-serif);font-style:italic;font-size:22px;line-height:1.5;color:var(--aqua-950);font-weight:500}
.article ul,.article ol{padding-left:22px;display:grid;gap:10px;color:var(--text-primary)}
.article ul li::marker{color:var(--pulse-lime)}
.article ol{padding-left:0;list-style:none;counter-reset:art}
.article ol li{counter-increment:art;padding-left:48px;position:relative}
.article ol li::before{
  content:counter(art,decimal-leading-zero);
  position:absolute;left:0;top:-2px;
  font-family:var(--font-numeric);font-size:18px;font-weight:600;color:var(--aqua-600);
}
.article strong{color:var(--aqua-950);font-weight:700}
.article figure{margin:48px 0}
.article figure img{border-radius:var(--radius-lg);width:100%}
.article figcaption{font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--text-muted);font-weight:600;margin-top:12px}

.article-meta{
  display:flex;gap:20px;flex-wrap:wrap;align-items:center;
  padding:24px 0;border-top:1px solid var(--aqua-200);border-bottom:1px solid var(--aqua-200);
  font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--text-muted);font-weight:600;
  margin:32px 0;
}
.article-meta .dot{width:4px;height:4px;border-radius:50%;background:var(--pulse-lime)}

.article-gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin:48px 0}
@media (max-width:720px){.article-gallery{grid-template-columns:repeat(2,1fr)}}
.article-gallery img{aspect-ratio:1;object-fit:cover;border-radius:var(--radius-md);width:100%}

/* Blog index list */
.blog-list{display:grid;gap:32px}
.blog-card{
  display:grid;grid-template-columns:340px 1fr;gap:32px;align-items:center;
  background:#fff;border-radius:var(--radius-xl);overflow:hidden;
  border:1px solid var(--aqua-100);
  transition:transform .35s var(--ease-out),box-shadow .35s var(--ease-out);
}
.blog-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}
@media (max-width:720px){.blog-card{grid-template-columns:1fr}}
.blog-card__media{aspect-ratio:4/3;overflow:hidden;background:var(--aqua-100)}
.blog-card__media img{width:100%;height:100%;object-fit:cover;transition:transform .8s var(--ease-out)}
.blog-card:hover .blog-card__media img{transform:scale(1.04)}
.blog-card__body{padding:28px 32px 28px 0;display:grid;gap:14px}
@media (max-width:720px){.blog-card__body{padding:0 28px 28px}}
.blog-card h3{font-family:var(--font-display);font-size:clamp(22px,2.4vw,28px);line-height:1.1;text-transform:uppercase;color:var(--aqua-950);margin:0;font-weight:400}
.blog-card p{margin:0;color:var(--text-muted);font-size:15px;line-height:1.6}

/* =========================================================
   CAREERS / LAVORA CON NOI
========================================================= */
.values-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
@media (max-width:900px){.values-grid{grid-template-columns:1fr}}
.value-card{
  padding:32px;border-radius:var(--radius-xl);background:#fff;
  border:1px solid var(--aqua-100);display:grid;gap:14px;
  transition:transform .35s var(--ease-out),box-shadow .35s var(--ease-out);
  height:100%;
}
.value-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}
.value-card__num{font-family:var(--font-numeric);font-size:36px;font-weight:600;color:var(--aqua-600);line-height:1}
.value-card h4{font-family:var(--font-display);font-size:20px;text-transform:uppercase;line-height:1.15;margin:0;color:var(--aqua-950)}
.value-card p{margin:0;color:var(--text-muted);font-size:14px;line-height:1.6}

.list-block{display:grid;gap:14px;list-style:none;padding:0;margin:0}
.list-block li{
  padding:18px 22px;background:#fff;border-radius:var(--radius-lg);
  border:1px solid var(--aqua-100);display:flex;gap:14px;align-items:flex-start;
  font-size:15px;line-height:1.5;
}
.list-block li::before{
  content:"+";flex-shrink:0;color:var(--pulse-lime);font-weight:700;font-size:20px;line-height:1.2;
}
.list-block.list-block--dark li{background:rgba(255,255,255,.04);border-color:rgba(255,255,255,.08);color:#cfd8dd}

.cta-banner{
  padding:clamp(48px,7vw,96px);border-radius:var(--radius-xl);
  background:var(--aqua-950);color:#fff;
  display:grid;gap:24px;
  position:relative;overflow:hidden;
}
.cta-banner::before{
  content:"";position:absolute;top:-40%;right:-10%;
  width:520px;height:520px;border-radius:50%;
  background:radial-gradient(circle,rgba(212,245,66,.18),transparent 70%);
}
.cta-banner > *{position:relative;z-index:1}
.cta-banner h2{margin:0}

/* =========================================================
   TESTIMONIAL WALL
========================================================= */
.testi-wall{
  columns:3 320px;column-gap:24px;
}
.testi-wall .testimonial{
  break-inside:avoid;display:grid;gap:18px;margin:0 0 24px;
  padding:28px;
}

/* =========================================================
   PRESS
========================================================= */
.press-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
@media (max-width:900px){.press-grid{grid-template-columns:1fr}}
.press-card{
  padding:24px;background:#fff;border-radius:var(--radius-xl);
  border:1px solid var(--aqua-100);
  display:grid;gap:14px;
  transition:transform .35s var(--ease-out),box-shadow .35s var(--ease-out);
}
.press-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}
.press-card__media{aspect-ratio:4/3;overflow:hidden;border-radius:var(--radius-lg);background:var(--aqua-50)}
.press-card__media img{width:100%;height:100%;object-fit:cover}
.press-card span{font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--text-muted);font-weight:700}
.press-card h4{font-family:var(--font-display);font-size:20px;text-transform:uppercase;line-height:1.1;margin:0;color:var(--aqua-950);font-weight:400}

/* =========================================================
   GOOGLE REVIEWS
========================================================= */
.greviews__summary{
  display:flex;align-items:center;gap:20px;flex-wrap:wrap;
  margin:48px 0 56px;padding:22px 26px;
  background:#fff;border:1px solid var(--aqua-100);border-radius:var(--radius-xl);
  box-shadow:var(--shadow-sm);
}
.greviews__summary-score{display:flex;align-items:baseline;gap:8px}
.greviews__summary-num{
  font-family:var(--font-numeric);font-size:clamp(34px,4vw,44px);
  font-weight:600;line-height:1;letter-spacing:-.03em;color:var(--aqua-950);
}
.greviews__summary-stars{color:#fbbc05;font-size:18px;letter-spacing:2px;line-height:1}
.greviews__summary-meta{display:grid;gap:2px}
.greviews__summary-meta b{font-weight:700;color:var(--aqua-950)}
.greviews__summary-meta span{font-size:14px;color:var(--text-muted)}
.greviews__summary .greviews__g{width:26px;height:26px;flex:0 0 auto}
.greviews__btn{margin-left:auto}
@media (max-width:560px){.greviews__btn{margin-left:0;width:100%;justify-content:center}}

/* Collapse: muro alto max 600px con fade, espandibile via JS */
.greviews-collapse{position:relative;max-height:600px;min-height:300px;overflow:hidden;transition:max-height .55s var(--ease-out)}
.greviews-collapse.is-expanded{max-height:none}
.greviews-collapse::after{
  content:"";position:absolute;left:0;right:0;bottom:0;height:200px;
  background:linear-gradient(to bottom,rgba(255,255,255,0) 0%,rgba(255,255,255,.85) 55%,#fff 100%);
  pointer-events:none;transition:opacity .4s ease;
}
.greviews-collapse.is-expanded::after{opacity:0}
.greviews-more{
  display:flex;justify-content:center;margin-top:28px;
}
.greviews-collapse.is-expanded + .greviews-more{margin-top:36px}

.greviews-wall{columns:3 320px;column-gap:24px}
@media (max-width:980px){.greviews-wall{columns:2 320px}}
@media (max-width:560px){.greviews-wall{columns:1}}
.greview{
  break-inside:avoid;margin:0 0 24px;padding:24px;
  background:#fff;border:1px solid var(--aqua-100);border-radius:var(--radius-xl);
  display:grid;gap:14px;
  transition:transform .35s var(--ease-out),box-shadow .35s var(--ease-out);
}
.greview:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}
.greview__head{display:flex;align-items:center;gap:12px}
.greview__avatar{
  width:44px;height:44px;flex:0 0 auto;border-radius:50%;
  display:grid;place-items:center;
  font-family:var(--font-display);font-size:18px;font-weight:400;color:#fff;
}
.greview__who{display:grid;gap:1px;min-width:0}
.greview__name{margin:0;font-weight:700;color:var(--aqua-950);font-size:15px;line-height:1.2}
.greview__date{font-size:12.5px;color:var(--text-muted)}
.greview__top{display:flex;align-items:center;justify-content:space-between;gap:8px}
.greview__stars{color:#fbbc05;font-size:15px;letter-spacing:1px;line-height:1}
.greview__g{width:18px;height:18px;flex:0 0 auto;opacity:.95}
.greview__text{margin:0;font-size:15px;line-height:1.6;color:var(--text-primary)}

/* =========================================================
   SOLUTION DETAIL ANCHORS
========================================================= */
.sol-detail{padding:clamp(48px,8vw,96px) 0;border-bottom:1px solid var(--aqua-100)}
.sol-detail:last-of-type{border-bottom:none}
.sol-detail .num{
  font-family:var(--font-numeric);font-size:14px;font-weight:600;
  color:var(--aqua-600);letter-spacing:.04em;
}
.sol-detail h2{font-family:var(--font-display);font-size:clamp(36px,5vw,64px);line-height:1;text-transform:uppercase;font-weight:400;color:var(--aqua-950);margin:8px 0 24px}

.sol-flow{
  border-radius:var(--radius-xl);overflow:hidden;
  background:#fff;border:1px solid var(--aqua-100);padding:32px;
}
.sol-flow img{width:100%;height:auto}

.video-frame{
  aspect-ratio:16/9;border-radius:var(--radius-xl);overflow:hidden;
  background:var(--aqua-950);position:relative;
}
.video-frame iframe{width:100%;height:100%;border:0;position:absolute;inset:0}

/* Compact form (lavora con noi) */
.form-card--compact{max-width:560px;margin:0 auto}


/* =========================================================
   BLOG ARTICLE TYPOGRAPHY
========================================================= */
.article{max-width:780px;margin:0 auto;padding:0 clamp(20px,4vw,32px)}
.article h2{font-family:var(--font-display);font-size:clamp(28px,3.6vw,40px);text-transform:uppercase;line-height:1.1;margin:64px 0 20px;color:var(--aqua-950)}
.article h3{font-family:var(--font-display);font-size:24px;text-transform:uppercase;margin:48px 0 14px;color:var(--aqua-950)}
.article p{font-size:17px;line-height:1.7;margin:0 0 18px;color:var(--aqua-950)}
.article ul,.article ol{font-size:17px;line-height:1.7;color:var(--aqua-950);padding-left:24px;margin:0 0 24px}
.article ul li,.article ol li{margin-bottom:8px}
.article ul li strong,.article ol li strong{color:var(--aqua-600)}
.article .lead{font-family:var(--font-serif);font-style:italic;font-size:clamp(20px,2.4vw,26px);line-height:1.5;color:var(--aqua-800);font-weight:500;border-left:3px solid var(--pulse-lime);padding-left:24px;margin:0 0 48px}
.article figure{margin:48px 0}
.article figure img{width:100%;border-radius:var(--radius-xl);display:block}
.article figcaption{font-size:13px;color:var(--text-muted);margin-top:12px;font-style:italic;text-align:center}
.article-meta{display:flex;flex-wrap:wrap;gap:14px;align-items:center;margin-bottom:32px;font-size:12px;color:var(--text-muted);font-weight:600;letter-spacing:.08em;text-transform:uppercase}
.article-meta .dot{width:4px;height:4px;border-radius:50%;background:var(--aqua-400)}

/* Blog list cards */
.post-card{
  display:grid;grid-template-columns:1fr;gap:0;
  background:#fff;border-radius:var(--radius-xl);overflow:hidden;
  border:1px solid var(--aqua-100);box-shadow:var(--shadow-sm);
  transition:transform .35s var(--ease-out),box-shadow .35s var(--ease-out);
  height:100%;
}
.post-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}
.post-card__media{aspect-ratio:16/10;overflow:hidden;background:var(--aqua-100)}
.post-card__media img{width:100%;height:100%;object-fit:cover;transition:transform .8s var(--ease-out)}
.post-card:hover .post-card__media img{transform:scale(1.04)}
.post-card__body{padding:28px;display:grid;gap:12px}
.post-card__body h3{font-family:var(--font-display);font-size:24px;text-transform:uppercase;line-height:1.1;margin:0;color:var(--aqua-950)}

/* Press row improvements */
.press-card{
  padding:20px;border-radius:var(--radius-lg);background:#fff;
  border:1px solid var(--aqua-100);
  display:flex;flex-direction:column;gap:14px;
  transition:border-color .25s,transform .35s var(--ease-out);
}
.press-card:hover{transform:translateY(-3px);border-color:var(--aqua-200)}
.press-card__media{aspect-ratio:4/3;overflow:hidden;border-radius:var(--radius-md);background:var(--aqua-50)}
.press-card__media img{width:100%;height:100%;object-fit:contain;background:#fff}

/* Job posting card */
.job-card{
  padding:32px;border-radius:var(--radius-xl);background:#fff;
  border:1px solid var(--aqua-100);box-shadow:var(--shadow-sm);
  display:grid;gap:18px;
}
.job-card h3{font-family:var(--font-display);text-transform:uppercase;font-size:22px;margin:0;color:var(--aqua-950)}
.job-card ul{margin:0;padding-left:0;list-style:none;display:grid;gap:10px}
.job-card ul li{padding-left:24px;position:relative;font-size:14px;line-height:1.55;color:var(--text-primary)}
.job-card ul li::before{content:"+";position:absolute;left:0;top:0;color:var(--pulse-lime);font-weight:700;font-size:18px}

/* Centered narrow form */
.form-card--short{max-width:560px;margin:0 auto}

/* Featured testimonial big */
.featured-testimonial{
  padding:clamp(40px,6vw,64px);border-radius:var(--radius-xl);
  background:var(--surface-deep);color:#fff;
  display:grid;gap:24px;
}
.featured-testimonial blockquote{
  font-family:var(--font-serif);font-style:italic;font-weight:500;
  font-size:clamp(22px,3vw,32px);line-height:1.4;color:#fff;
  margin:0;padding-left:20px;border-left:3px solid var(--pulse-lime);
}

/* =========================================================
   WATER SPHERE — hero canvas + feature lines
========================================================= */
.hero__water-sphere {
    position: absolute;
    left: 50%;
    top: 79%;
    transform: translate(-50%, -50%);
    width: min(1050px, 95vw);
    height: min(1050px, 95vw);
    pointer-events: none;
    z-index: 6;
    border-radius: 50%;
    overflow: hidden; 
    opacity: 0.4;
    filter: brightness(2.5);
}

@media (min-width:1025px) {

  .hero__water-sphere {
    width: min(1350px, 95vw);
    height: min(1350px, 95vw);
  }
  
}


.hero__water-sphere:hover {
  opacity: 1;
}
/* Three.js crea un canvas figlio — deve riempire il container */
.hero__water-sphere canvas {
  width: 100% !important;
  height: 100% !important;
  border-radius: 50%;
}

/* Feature lines container — same stacking as canvas */
.hero__features {
  position: absolute;
  inset: 0;
  /* pointer-events: none; */
  z-index: 7;
}

/* Griglia tecnica — linee */
.hero__features::before {
  content: '';
  position: absolute;
  inset: 0;
  pointer-events: none;
  z-index: 1;
  background-image:
    linear-gradient(rgba(15,61,82,.12) 1px, transparent 1px),
    linear-gradient(90deg, rgba(15,61,82,.12) 1px, transparent 1px);
  background-size: 48px 48px;
  -webkit-mask-image: radial-gradient(
    ellipse 72% 60% at 50% 88%,
    transparent 26%,
    rgba(0,0,0,.15) 44%,
    rgba(0,0,0,.55) 62%,
    rgba(0,0,0,.88) 80%,
    #000 100%
  );
  mask-image: radial-gradient(
    ellipse 72% 60% at 50% 88%,
    transparent 26%,
    rgba(0,0,0,.15) 44%,
    rgba(0,0,0,.55) 62%,
    rgba(0,0,0,.88) 80%,
    #000 100%
  );
}

/* Griglia tecnica — dot agli incroci */
.hero__features::after {
  content: '';
  position: absolute;
  inset: 0;
  pointer-events: none;
  z-index: 1;
  background-image: radial-gradient(circle, rgba(31,107,142,.32) 1.5px, transparent 1.5px);
  background-size: 48px 48px;
  -webkit-mask-image: radial-gradient(
    ellipse 72% 60% at 50% 88%,
    transparent 26%,
    rgba(0,0,0,.1) 44%,
    rgba(0,0,0,.45) 62%,
    rgba(0,0,0,.75) 80%,
    #000 100%
  );
  mask-image: radial-gradient(
    ellipse 72% 60% at 50% 88%,
    transparent 26%,
    rgba(0,0,0,.1) 44%,
    rgba(0,0,0,.45) 62%,
    rgba(0,0,0,.75) 80%,
    #000 100%
  );
}

/* Each feature item */
.hf {
  position: absolute;
  display: flex;
  align-items: center;
  gap: 0;
  opacity: 0;
  transition:
    opacity 1.2s var(--ease-out),
    transform 0.35s var(--ease-out);
  background: none;
  border: none;
  padding: 10px 0;
  cursor: pointer;
  /* pointer-events attivi — override del parent */
  pointer-events: all;
}
.hf.is-visible { opacity: 1; }

/* Hover: sposta leggermente verso la sfera */
.hf--left:hover  { transform: translateX(6px); }
.hf--right:hover { transform: translateX(-6px); }

/* Active: leggero scale down */
.hf:active { transform: scale(0.97); }

/* Left side — label · line · dot */
.hf--left {
  right: 50%;
  flex-direction: row;
  padding-right: calc(min(100px, 40vw) + 32px);
}
.hf--left .hf__label { text-align: right; }

/* Right side — dot · line · label */
.hf--right {
  left: 50%;
  flex-direction: row;
  padding-left: calc(min(100px, 40vw) + 32px);
}
.hf--right .hf__label { text-align: left; }

/* Vertical positions */
.hf--1 { top: calc(100% - 172px); }
.hf--2 { top: calc(100% - 90px);  padding-right: calc(min(100px, 40vw) - 10px); }
.hf--3 { top: calc(100% - 172px); }
.hf--4 { top: calc(100% - 90px);  padding-left: calc(min(100px, 40vw) - 10px); }

/* Label text */
.hf__label {
  font-family: var(--font-body);
  font-size: clamp(13px, 1.3vw, 17px);
  font-weight: 600;
  letter-spacing: .06em;
  text-transform: uppercase;
  color: rgb(0 142 207);
  line-height: 1.35;
  white-space: nowrap;
  flex-shrink: 0;
  transition: color 0.25s ease, letter-spacing 0.3s var(--ease-out);
}
.hf:hover .hf__label {
  color: #000;
  letter-spacing: .1em;
}
/* Flash lime al click */
.hf:active .hf__label { color: #000; }

.hf__label em {
  font-style: italic;
  color:#000;
  font-family: var(--font-serif);
  text-transform: none;
  letter-spacing: 0;
  font-size: 1.15em;
  transition: color 0.25s ease;
}
.hf:hover .hf__label em { color: #000; }

/* Horizontal line */
.hf__line {
  display: block;
  height: 1px;
  width: clamp(40px, 6vw, 80px);
  background: linear-gradient(90deg, rgba(129,236,241,.15), rgba(129,236,241,.55));
  flex-shrink: 0;
  margin: 0 10px;
  transition: width 0.35s var(--ease-out), opacity 0.25s ease;
}
.hf--right .hf__line {
  background: linear-gradient(90deg, rgba(129,236,241,.55), rgba(129,236,241,.15));
}
/* Linea si allunga al hover */
.hf:hover .hf__line {
  width: clamp(60px, 9vw, 120px);
  opacity: 1;
}

/* Terminal dot */
.hf__dot {
  display: block;
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: #008ecf;
  flex-shrink: 0;
  box-shadow: 0 0 8px 2px rgba(129,236,241,.6);
  transition: transform 0.3s var(--ease-out), box-shadow 0.3s ease;
  position: relative;
}
/* Ring espanso al hover */
.hf__dot::after {
  content: '';
  position: absolute;
  inset: -5px;
  border-radius: 50%;
  border: 1px solid rgba(129,236,241,.5);
  transform: scale(0);
  opacity: 0;
  transition: transform 0.35s var(--ease-out), opacity 0.35s ease;
}
.hf:hover .hf__dot {
  transform: scale(1.5);
  box-shadow: 0 0 14px 4px rgba(129,236,241,.8);
}
.hf:hover .hf__dot::after {
  transform: scale(1);
  opacity: 1;
}

/* Mobile: hide feature lines below 640px */
@media (max-width: 640px) {
  .hero__features { display: none; }
  .hero__water-sphere { top: 100%; width: min(420px, 100vw); height: min(420px, 100vw); }
  .hero__water-sphere canvas{
    transform: scale(2.5);
    
  }
}

.section__1{
  background: transparent;
  margin-bottom: -300px;
  position: relative;
  z-index: 10;
}

@media (max-width:767px) {

  .hero{
    min-height: 80vh;
  }

  .hero__water-sphere{ 
    top: 150vw;
  }

    /* Vertical positions */
  .hf--1 {     top: 100vw; }
  .hf--2 {     top: 110vw; }
  .hf--3 {     top: 100vw; }
  .hf--4 {     top: 110vw; }
 
  
}

/* =========================================================
   WHATSAPP FLOATING CTA
========================================================= */
.wa-float {
  position: fixed;
  bottom: 68px;
  right: 28px;
  z-index: 9999;
  display: flex;
  align-items: center;
  gap: 10px;
  background: #25D366;
  color: #fff;
  border-radius: var(--radius-pill);
  padding: 12px 20px 12px 14px;
  text-decoration: none;
  font-family: var(--font-body);
  font-size: 13px;
  font-weight: 700;
  letter-spacing: .02em;
  box-shadow: 0 4px 24px rgba(37,211,102,.45), 0 2px 8px rgba(0,0,0,.18);
  /* entrata */
  animation: wa-enter .6s var(--ease-out) 1.8s both;
  transition: transform .25s var(--ease-out), box-shadow .25s ease, padding .3s var(--ease-out);
  max-width: 340px;
}

@keyframes wa-enter {
  from { opacity: 0; transform: translateY(24px) scale(.9); }
  to   { opacity: 1; transform: none; }
}

.wa-float:hover {
  transform: translateY(-3px) scale(1.03);
  box-shadow: 0 8px 32px rgba(37,211,102,.55), 0 4px 12px rgba(0,0,0,.2);
}
.wa-float:active {
  transform: scale(.97);
}

.wa-float__icon {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  width: 32px;
  height: 32px;
  background: rgba(255,255,255,.18);
  border-radius: 50%;
  /* pulse continuo */
  animation: wa-pulse 2.4s ease-in-out infinite;
}

@keyframes wa-pulse {
  0%, 100% { box-shadow: 0 0 0 0 rgba(255,255,255,.4); }
  50%       { box-shadow: 0 0 0 7px rgba(255,255,255,0); }
}

.wa-float__label {
  line-height: 1.25;
  white-space: nowrap;
}

/* Su mobile: solo icona, label nascosta */
@media (max-width: 540px) {
  .wa-float {
    padding: 14px;
    bottom: 20px;
    right: 20px;
  }
  .wa-float__label { display: none; }
  .wa-float__icon  { width: 28px; height: 28px; background: none; }
  
}
