/* ==========================================================================
   LUCA SPAGNOLI — Full Stack Content Creator
   Palette: #FFD000 (giallo) / #000000 (nero) / #00C2D1 (cyan) / #FCEFF9 (blush)
   ========================================================================== */

@font-face {
  font-family: 'Cako';
  src: url('../public/cako-thin.woff2') format('woff2');
  font-weight: 200;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: 'Cako';
  src: url('../public/cako-regular.woff2') format('woff2');
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: 'Cako';
  src: url('../public/cako-black.woff2') format('woff2');
  font-weight: 900;
  font-style: normal;
  font-display: swap;
}
/* Anton e Space Grotesk self-hosted (subset latin, gli stessi file che
   serviva Google Fonts): niente richieste esterne. Space Grotesk è un
   font variabile: un solo file copre tutti i pesi 400-700. */
@font-face {
  font-family: 'Anton';
  src: url('../public/anton-400.woff2') format('woff2');
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: 'Space Grotesk';
  src: url('../public/space-grotesk-var.woff2') format('woff2');
  font-weight: 400 700;
  font-style: normal;
  font-display: swap;
}

:root {
  --yellow: #FFD000;
  --black: #000000;
  --cyan: #00C2D1;
  /* cyan-inchiostro: testo/linee su fondi CHIARI (giallo/crema/blush ~4.3:1).
     Il cyan acceso resta solo su nero. Consolida il vecchio #008c98. */
  --cyan-ink: #006A74;
  --blush: #FCEFF9;
  /* crema/avorio: pausa neutra CALDA, distinta dal blush (rosato). Sfondo delle
     sezioni di contenuto al posto del giallo pieno, che resta solo su hero + casi. */
  --bg-warm: #FAF6EC;
  --white: #ffffff;

  /* Cako su tutti i titoli del sito (Anton resta solo come fallback) */
  --font-display: 'Cako', 'Anton', Impact, sans-serif;
  --font-hero: 'Cako', 'Anton', Impact, sans-serif;
  /* font precedente, usato di proposito in tutto maiuscolo su pochi elementi
     (stats hero, nomi/label case study, ticker CTA) */
  --font-anton: 'Anton', Impact, sans-serif;
  --font-body: 'Space Grotesk', 'Helvetica Neue', Arial, sans-serif;

  --container: 1240px;
  --pad: clamp(20px, 4vw, 48px);

  --ease-out: cubic-bezier(.22, 1, .36, 1);
  --ease-spring: cubic-bezier(.34, 1.56, .64, 1);
  /* equivalente CSS di expo.out: per le entrate "kinetic" della hero */
  --ease-expo: cubic-bezier(.16, 1, .3, 1);

  --radius-lg: 28px;
  --radius-md: 18px;
  --radius-sm: 12px;
}

/* ---------- Reset ---------- */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

html {
  scroll-behavior: smooth;
  -webkit-text-size-adjust: 100%;
}

body {
  font-family: var(--font-body);
  background: var(--yellow);
  color: var(--black);
  line-height: 1.55;
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
}

img, svg { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; }
ul { list-style: none; }
button { font: inherit; background: none; border: none; cursor: pointer; }

::selection { background: var(--black); color: var(--yellow); }

/* focus tastiera: cyan-ink su superfici chiare, cyan acceso su quelle scure */
:focus-visible {
  outline: 3px solid var(--cyan-ink);
  outline-offset: 3px;
}
.worlds :focus-visible,
.method :focus-visible,
.cta :focus-visible,
.footer :focus-visible,
.mobile-menu :focus-visible,
.case--black :focus-visible,
.offer--main :focus-visible,
.pain-card :focus-visible,
.srv-converge :focus-visible { outline-color: var(--cyan); }

.container {
  max-width: var(--container);
  margin-inline: auto;
  padding-inline: var(--pad);
}

/* ---------- Utility text accents ---------- */
.u-cyan { color: var(--cyan); }
.u-yellow { color: var(--yellow); }
.u-nowrap { white-space: nowrap; }

/* box evidenziatore invertito: nero pieno + testo giallo, per la parola chiave
   dei titoli su fondo chiaro (al posto della parola colorata, illeggibile su giallo) */
.u-box {
  background: var(--black);
  color: var(--yellow);
  padding: 0 .14em;
  border-radius: 2px;
  -webkit-box-decoration-break: clone;
  box-decoration-break: clone;
}

.u-underline {
  position: relative;
  white-space: nowrap;
  /* crea uno stacking context: senza, la riga con z-index -1 finisce
     dietro lo sfondo della sezione appena termina la transizione reveal */
  z-index: 0;
}
.u-underline::after {
  content: "";
  position: absolute;
  left: 0; right: 0; bottom: .04em;
  height: .14em;
  background: var(--cyan-ink);
  z-index: -1;
  transform: scaleX(0);
  transform-origin: left;
  transition: transform .8s var(--ease-out) .3s;
}
.is-visible .u-underline::after,
.u-underline.is-visible::after { transform: scaleX(1); }

/* ---------- Section eyebrow ---------- */
.section-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  font-size: 13px;
  font-weight: 700;
  letter-spacing: .18em;
  text-transform: uppercase;
  margin-bottom: 22px;
}
.section-eyebrow__bar {
  width: 34px;
  height: 3px;
  background: var(--black);
  display: inline-block;
}
.section-eyebrow--light { color: var(--blush); }
.section-eyebrow--light .section-eyebrow__bar { background: var(--cyan); }

/* ---------- Reveal animations ---------- */
.reveal {
  opacity: 0;
  transform: translateY(34px);
  transition:
    opacity .9s var(--ease-out) var(--delay, 0s),
    transform .9s var(--ease-out) var(--delay, 0s);
}
.reveal.is-visible { opacity: 1; transform: none; }

.reveal-line {
  display: block;
  overflow: hidden;
  padding: .12em 0 .06em;
  margin: -.12em 0 -.06em;
}
.reveal-line > span {
  display: block;
  transform: translateY(110%);
  transition: transform 1s var(--ease-out) var(--delay, 0s);
}
.reveal-line.is-visible > span { transform: none; }

@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  .intro { display: none !important; }
  .reveal, .reveal-line > span {
    opacity: 1 !important;
    transform: none !important;
    transition: none !important;
  }
  *, *::before, *::after { animation-duration: .01s !important; animation-delay: 0s !important; animation-iteration-count: 1 !important; }
}

/* ---------- Buttons ---------- */
.btn {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
  padding: 16px 28px;
  font-weight: 700;
  font-size: 16px;
  border-radius: 100px;
  overflow: hidden;
  isolation: isolate;
  transition: transform .35s var(--ease-spring), box-shadow .35s var(--ease-out);
  will-change: transform;
}
.btn__label { position: relative; z-index: 1; }
.btn__arrow {
  position: relative;
  z-index: 1;
  display: inline-block;
  transition: transform .35s var(--ease-spring);
}
.btn:hover { transform: translateY(-3px); }
.btn:active { transform: translateY(0) scale(.98); }
.btn:hover .btn__arrow { transform: translateX(5px); }
.btn:hover .btn__arrow--down { transform: translateY(5px); }

.btn::before {
  content: "";
  position: absolute;
  inset: 0;
  background: var(--cyan);
  border-radius: inherit;
  transform: translateY(101%);
  transition: transform .4s var(--ease-out);
  z-index: 0;
}
.btn:hover::before { transform: translateY(0); }

.btn--black { background: var(--black); color: var(--yellow); }
.btn--black:hover { color: var(--black); box-shadow: 0 14px 30px rgba(0,0,0,.22); }

.btn--yellow { background: var(--yellow); color: var(--black); }
/* la CTA gialla vive su fondi neri (offerte, CTA finale, menu): niente flash cyan,
   resta gialla "premium" e l'hover la fa sollevare invece di sbiadirla */
.btn--yellow::before { background: transparent; }
.btn--yellow:hover { box-shadow: 0 14px 30px rgba(0,0,0,.35); }

.btn--ghost {
  background: transparent;
  color: var(--black);
  box-shadow: inset 0 0 0 2px var(--black);
}
.btn--ghost::before { background: var(--black); }
.btn--ghost:hover { color: var(--yellow); }

.btn--lg { padding: 19px 34px; font-size: 17px; }
.btn--xl { padding: 23px 46px; font-size: 19px; }
.btn--full { width: 100%; }

/* ==========================================================================
   INTRO PRELOADER — arc reveal
   z-index: sopra header (100), burger mobile (101) e mobile-menu (99)
   ========================================================================== */
.intro {
  position: fixed;
  inset: 0;
  z-index: 999;
  display: none;
}
html.intro-pending .intro { display: block; }
html.intro-pending { overflow: hidden; } /* scroll lock pre-paint */

.intro__curtain {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
}
.intro__curtain-path { fill: var(--black); }

.intro__words {
  position: absolute;
  inset: 0;
  display: grid;
  place-items: center;
  padding-inline: var(--pad);
}
.intro__word {
  grid-area: 1 / 1;
  font-family: var(--font-hero);
  font-weight: 900;
  font-size: clamp(48px, 10vw, 160px); /* scala della riga hero */
  line-height: 1;
  color: var(--yellow);
  opacity: 0; /* stato iniziale; WAAPI anima */
  will-change: transform, opacity, filter;
}

/* ==========================================================================
   HEADER
   ========================================================================== */
.header {
  position: fixed;
  top: 0; left: 0; right: 0;
  z-index: 100;
  padding: 18px var(--pad);
  transition: padding .4s var(--ease-out), background .4s var(--ease-out), box-shadow .4s var(--ease-out);
}
.header.is-scrolled {
  padding: 10px var(--pad);
  background: rgba(255, 208, 0, .9);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  box-shadow: 0 1px 0 rgba(0,0,0,.14);
}

.header__inner {
  max-width: var(--container);
  margin-inline: auto;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
}

.header__logo {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-weight: 700;
  font-size: 18px;
  letter-spacing: -.01em;
}
.header__logo-mark {
  display: grid;
  place-items: center;
  width: 38px;
  height: 38px;
  background: var(--black);
  color: var(--yellow);
  font-family: var(--font-display);
  font-weight: 900;
  font-size: 15px;
  letter-spacing: .02em;
  border-radius: 11px;
  transition: transform .4s var(--ease-spring), background .3s, color .3s;
}
.header__logo:hover .header__logo-mark {
  transform: rotate(-8deg) scale(1.06);
  background: var(--cyan);
  color: var(--black);
}

.header__nav {
  display: flex;
  align-items: center;
  gap: clamp(18px, 2.6vw, 36px);
}

.header__link {
  position: relative;
  font-weight: 600;
  font-size: 15px;
  overflow: hidden;
  display: inline-block;
  line-height: 1.3;
}
.header__link span {
  position: relative;
  display: inline-block;
  transition: transform .35s var(--ease-out);
}
.header__link span::after {
  content: attr(data-text);
  position: absolute;
  top: 100%; left: 0;
  /* su giallo il cyan acceso non si legge: nero + barra cyan-ink, come il body */
  color: var(--black);
  background: linear-gradient(transparent 82%, var(--cyan-ink) 82%);
  -webkit-text-stroke: 0;
}
.header__link:hover span { transform: translateY(-100%); }

.header__burger { display: none; }

/* Mobile menu */
.mobile-menu {
  position: fixed;
  inset: 0;
  z-index: 99;
  background: var(--black);
  color: var(--yellow);
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding: 100px var(--pad) 48px;
  clip-path: circle(0% at calc(100% - 44px) 38px);
  /* in chiusura la visibility scatta solo a cerchio richiuso: senza il ritardo
     il menu sparirebbe di colpo e l'animazione di chiusura non si vedrebbe mai */
  transition: clip-path .65s var(--ease-out), visibility 0s .65s;
  visibility: hidden;
}
.mobile-menu.is-open {
  clip-path: circle(150% at calc(100% - 44px) 38px);
  visibility: visible;
  transition: clip-path .65s var(--ease-out); /* in apertura visibile subito */
}

.mobile-menu__nav { display: flex; flex-direction: column; gap: 6px; }
.mobile-menu__link {
  font-family: var(--font-display);
  font-weight: 900;
  font-size: clamp(40px, 11vw, 64px);
  text-transform: none;
  line-height: 1.12;
  display: flex;
  align-items: baseline;
  gap: 16px;
  opacity: 0;
  transform: translateY(26px);
  transition: opacity .5s var(--ease-out), transform .5s var(--ease-out), color .25s;
}
.mobile-menu.is-open .mobile-menu__link { opacity: 1; transform: none; }
.mobile-menu.is-open .mobile-menu__link:nth-child(1) { transition-delay: .15s; }
.mobile-menu.is-open .mobile-menu__link:nth-child(2) { transition-delay: .22s; }
.mobile-menu.is-open .mobile-menu__link:nth-child(3) { transition-delay: .29s; }
.mobile-menu.is-open .mobile-menu__link:nth-child(4) { transition-delay: .36s; }
.mobile-menu__link:active { color: var(--cyan); }
.mobile-menu__num {
  font-family: var(--font-body);
  font-size: 14px;
  font-weight: 700;
  color: var(--cyan);
}
.mobile-menu__cta { margin-top: 40px; background: var(--yellow); color: var(--black); align-self: flex-start; }
.mobile-menu__footer {
  margin-top: auto;
  padding-top: 32px;
  font-size: 13px;
  color: var(--blush);
  opacity: .65;
}

/* Menu aperto: l'header resta sopra il menu (z-index 100 vs 99) — il logo
   passa ai colori del menu (su nero il riquadro nero e il testo nero
   sparivano) e l'header perde lo sfondo giallo dello stato scrolled */
.header__logo-text { transition: color .3s; }
body.menu-open .header {
  background: transparent;
  box-shadow: none;
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
}
body.menu-open .header__logo-mark { background: var(--yellow); color: var(--black); }
body.menu-open .header__logo-text { color: var(--yellow); }

/* ==========================================================================
   HERO
   ========================================================================== */
.hero {
  position: relative;
  display: flex;
  flex-direction: column;
  min-height: 100svh;
  background: var(--yellow);
  overflow: hidden;
}

/* ----- Grana pellicola: feTurbulence in data-URI, spostata a scatti ----- */
.hero::after {
  content: "";
  position: absolute;
  inset: -60px;
  z-index: 5;
  pointer-events: none;
  opacity: .06;
  mix-blend-mode: multiply;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='220' height='220'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  animation: grainShift 1.2s steps(4) infinite;
}
@keyframes grainShift {
  0%   { transform: translate(0, 0); }
  25%  { transform: translate(-24px, 16px); }
  50%  { transform: translate(18px, -20px); }
  75%  { transform: translate(-12px, -14px); }
  100% { transform: translate(0, 0); }
}
/* hero fuori viewport (classe dal JS): la grana smette di ridipingere */
.hero--offscreen::after { animation-play-state: paused; }

/* ----- Intro coreografata (~1.4s): il JS aggiunge .hero--intro prima del
   primo paint. Senza JS o con reduced-motion: tutto visibile subito. ----- */
@keyframes heroRise { from { transform: translateY(112%); } }
@keyframes heroFadeUp { from { opacity: 0; transform: translateY(26px); } }
@keyframes heroMarqueeUp { from { transform: translateY(101%); } }

.hero--intro .hero__line-inner { animation: heroRise .85s var(--ease-expo) backwards; }
.hero--intro .hero__line:nth-child(1) .hero__line-inner { animation-delay: .25s; }
.hero--intro .hero__line:nth-child(2) .hero__line-inner { animation-delay: .37s; }
.hero--intro .hero__line:nth-child(3) .hero__line-inner { animation-delay: .49s; }
.hero--intro .hero__eyebrow  { animation: heroFadeUp .6s var(--ease-expo) .05s backwards; }
.hero--intro .hero__subtitle { animation: heroFadeUp .6s var(--ease-expo) .8s backwards; }
.hero--intro .hero__actions  { animation: heroFadeUp .6s var(--ease-expo) .95s backwards; }
.hero--intro .hero__marquee  { animation: heroMarqueeUp .7s var(--ease-expo) 1.05s backwards; }

/* ----- Contenuto: colonna sinistra centrata in verticale ----- */
.hero__frame {
  position: relative;
  /* basis auto: il frame non scende mai sotto l'altezza del contenuto,
     così il centraggio non spilla sotto l'header sui viewport bassi */
  flex: 1 0 auto;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  justify-content: center;
  padding: clamp(96px, 10.5vh, 120px) var(--pad) clamp(24px, 3vh, 36px);
}
/* exit: parallasse + fade verso .worlds; il JS setta --hx (0→1) uscendo */
.hero--exit .hero__frame {
  transform: translateY(calc(var(--hx, 0) * -9vh));
  opacity: calc(1 - var(--hx, 0) * .65);
  will-change: transform, opacity;
}

.hero__eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-size: 13px;
  font-weight: 700;
  letter-spacing: .16em;
  text-transform: uppercase;
  background: var(--black);
  color: var(--yellow);
  padding: 9px 18px;
  border-radius: 100px;
  align-self: flex-start;
  margin-bottom: clamp(22px, 3.5vh, 36px);
}
.hero__eyebrow-dot {
  width: 8px; height: 8px;
  border-radius: 50%;
  background: var(--cyan);
  animation: pulse 2s ease-in-out infinite;
}
.hero__eyebrow-accent { color: var(--cyan); }
@keyframes pulse {
  0%, 100% { transform: scale(1); opacity: 1; }
  50% { transform: scale(1.5); opacity: .55; }
}

.hero__title {
  font-family: var(--font-hero);
  /* XXL: "Comunica chiaro." (riga più lunga) deve stare su una riga sola;
     coefficiente vw tarato in preview su 768/1280/1920. Il termine in vh
     tiene titolo+CTA+marquee dentro la prima schermata sui 16:9 */
  font-size: clamp(48px, min(10.35vw, 17vh), 190px);
  font-weight: 900;
  line-height: .92;
  /* niente più stampatello: il testo mantiene l'iniziale maiuscola e il
     resto minuscolo così come scritto nell'HTML */
  text-transform: none;
  letter-spacing: .005em;
  text-align: left;
  margin-bottom: clamp(22px, 3.5vh, 40px);
}
/* maschera del reveal: la riga sale da dietro il bordo inferiore */
.hero__line {
  display: block;
  overflow: hidden;
  padding: .12em 0 .06em;
  margin: -.12em 0 -.06em;
}
.hero__line-inner {
  display: inline-block;
  white-space: nowrap;
}

.hero__line--accent .hero__line-inner {
  background: var(--black);
  color: var(--yellow);
  /* padding-top extra: l'accento di "più" sporge oltre la cap height
     e deve restare dentro il box nero per essere visibile */
  padding: .14em .18em .02em;
  margin-top: -.08em;
  -webkit-box-decoration-break: clone;
  box-decoration-break: clone;
}

.hero__subtitle {
  max-width: 32em;
  font-size: clamp(18px, 1.5vw, 22px);
  font-weight: 500;
  margin-bottom: clamp(26px, 4.5vh, 42px);
}
.hero__subtitle strong { background: linear-gradient(transparent 82%, var(--cyan-ink) 82%); }

.hero__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 14px;
}
/* gerarchia CTA hero: la primaria (nera piena) domina, la secondaria resta più tenue */
.hero__actions .btn--ghost {
  box-shadow: inset 0 0 0 1.5px rgba(0, 0, 0, .3);
  font-weight: 600;
}

/* ----- Marquee: striscia nera a filo del bordo basso della hero ----- */
.hero__marquee {
  position: relative;
  background: var(--black);
  color: var(--yellow);
  overflow: hidden;
  padding: clamp(10px, 1.4vh, 16px) 0;
}
.hero__marquee-track {
  display: flex;
  width: max-content;
  white-space: nowrap;
  font-family: var(--font-anton);
  font-size: clamp(16px, 2vw, 26px);
  letter-spacing: .08em;
  text-transform: uppercase;
  animation: ticker 26s linear infinite;
}

@keyframes ticker { to { transform: translateX(-50%); } }

/* ==========================================================================
   PROOF — microcopy + stats (ex-hero), fascia sotto il marquee
   ========================================================================== */
.proof {
  background: var(--yellow);
  padding: clamp(44px, 7vh, 80px) 0;
}
.proof__inner {
  display: flex;
  flex-direction: column;
  gap: clamp(28px, 4.5vh, 44px);
}
.proof__microcopy {
  font-size: 17.5px;
  max-width: 34em;
  opacity: .82;
  padding-left: 16px;
  border-left: 3px solid var(--black);
}
.proof__microcopy em { font-style: normal; font-weight: 700; }
.proof__stats {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: clamp(28px, 4.5vw, 72px);
}
.proof__stats-num {
  display: inline-block;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: .14em;
  background: var(--black);
  color: var(--yellow);
  border-radius: 100px;
  padding: 3px 11px;
  margin-bottom: 10px;
}
.proof__stats strong {
  display: block;
  font-family: var(--font-anton);
  font-weight: 400;
  font-size: clamp(22px, 2.3vw, 34px);
  text-transform: uppercase;
  line-height: 1;
  margin-bottom: 8px;
}
.proof__stats p { font-size: 16px; opacity: .82; }

/* ==========================================================================
   WORLDS (fascia visiva)
   ========================================================================== */
.worlds {
  background: var(--black);
  color: var(--blush);
  padding: clamp(70px, 11vh, 130px) 0 clamp(50px, 8vh, 90px);
  overflow: hidden;
}
.worlds__head { margin-bottom: clamp(36px, 5vh, 56px); }
.worlds__title {
  font-family: var(--font-display);
  font-weight: 900;
  font-size: clamp(34px, 4.6vw, 64px);
  line-height: 1.04;
  text-transform: none;
  color: var(--white);
  max-width: 16em;
  margin-bottom: 18px;
}
.worlds__sub { max-width: 44em; opacity: .75; font-size: 18px; }

.worlds__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: clamp(16px, 2vw, 26px);
  max-width: var(--container);
  margin-inline: auto;
  padding-inline: var(--pad);
}

.world-card {
  display: flex;
  flex-direction: column;
  background: #111;
  border: 1px solid rgba(252,239,249,.14);
  border-radius: var(--radius-lg);
  overflow: hidden;
  transition: transform .45s var(--ease-out), border-color .45s;
}
.world-card:hover {
  transform: translateY(-10px);
  border-color: var(--yellow);
}
.world-card__media {
  position: relative;
  aspect-ratio: 4 / 3.4;
  display: grid;
  place-items: center;
  background:
    radial-gradient(130% 110% at 20% 15%, var(--g1) 0%, transparent 58%),
    radial-gradient(120% 110% at 85% 90%, var(--g2) 0%, transparent 62%),
    #161616;
  transition: transform .6s var(--ease-out);
}
.world-card:hover .world-card__media { transform: scale(1.03); }
/* foto reale dietro l'icona: copre il gradiente placeholder. Se il file
   manca, l'<img> si rimuove da sola (onerror) e resta il gradiente. */
.world-card__photo {
  position: absolute;
  inset: 0;
  z-index: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
}
/* velatura leggera sopra la foto: profondità senza spegnere il lavoro */
.world-card__media:has(img.world-card__photo)::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 0;
  background: linear-gradient(180deg, rgba(0,0,0,.05), rgba(0,0,0,.35));
}
/* badge in angolo (come .srv__node): non copre volti e prodotti */
.world-card__icon {
  position: absolute;
  top: 14px; left: 14px;
  z-index: 1;
  width: 48px; height: 48px;
  display: grid;
  place-items: center;
  background: rgba(0,0,0,.82);
  color: var(--yellow);
  border-radius: 14px;
  transition: transform .45s var(--ease-spring), color .3s;
}
.world-card__icon svg { width: 24px; height: 24px; }
.world-card:hover .world-card__icon { transform: rotate(-6deg) scale(1.1); color: var(--cyan); }
.world-card__body { padding: 20px 22px 26px; }
.world-card__num {
  font-size: 12px;
  font-weight: 700;
  color: var(--cyan);
  letter-spacing: .14em;
}
.world-card__body h3 {
  font-family: var(--font-display);
  font-weight: 900;
  font-size: 25px;
  text-transform: none;
  color: var(--white);
  margin: 6px 0 8px;
}
.world-card__body p { font-size: 16.5px; opacity: .72; }

/* ==========================================================================
   PAIN
   ========================================================================== */
.pain {
  background: var(--bg-warm);
  padding: clamp(80px, 13vh, 150px) 0;
}
.pain__title {
  font-family: var(--font-display);
  font-weight: 900;
  font-size: clamp(36px, 5.6vw, 80px);
  line-height: 1.02;
  text-transform: none;
  margin-bottom: clamp(24px, 3.4vh, 36px);
}
.pain__title-accent > span {
  background: var(--black);
  color: var(--yellow);
  padding: 0 .18em;
  display: inline-block;
}
.pain__text {
  font-size: clamp(19px, 1.6vw, 22px);
  max-width: 36em;
  font-weight: 500;
  margin-bottom: clamp(40px, 6vh, 64px);
}

.pain__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: clamp(22px, 2.8vw, 40px);
}
.pain-card {
  position: relative;
  background: var(--black);
  color: var(--blush);
  border-radius: var(--radius-lg);
  padding: clamp(26px, 3vw, 38px);
  display: flex;
  gap: clamp(16px, 1.8vw, 26px);
  align-items: center;
  overflow: hidden;
  /* ombra dura offset (firma "sticker/print"): netta, colore pieno per riga */
  box-shadow: 7px 9px 0 var(--ps, var(--yellow));
  transition: transform .4s var(--ease-out), box-shadow .4s var(--ease-out);
}
.pain-card:nth-child(1) { --ps: var(--yellow); --pop: 0s;   --rot: -3deg; }
.pain-card:nth-child(2) { --ps: var(--cyan);   --pop: .09s; --rot:  3deg; }
.pain-card:nth-child(3) { --ps: var(--cyan);   --pop: .18s; --rot: -3deg; }
.pain-card::after {
  content: "";
  position: absolute;
  top: 0; right: 0;
  width: 130px; height: 130px;
  background: radial-gradient(circle at top right, rgba(0,194,209,.30), transparent 70%);
  opacity: 0;
  transition: opacity .4s;
  pointer-events: none;
}
/* hover: la card si solleva e l'ombra dura cresce (effetto "premuta") */
.pain-card:hover { transform: translateY(-6px); box-shadow: 11px 14px 0 var(--ps, var(--yellow)); }
.pain-card:hover::after { opacity: 1; }
.pain-card__num {
  font-family: var(--font-anton);
  font-weight: 400;
  font-size: clamp(38px, 4.4vw, 54px);
  line-height: .85;
  /* numero gigante a contorno: cyan acceso su nero (firma dei "numeri outline") */
  color: transparent;
  -webkit-text-stroke: 1.6px var(--cyan);
  flex-shrink: 0;
}
.pain-card p { font-size: clamp(18px, 1.5vw, 21px); }
.pain-card strong { color: var(--yellow); }

/* entrata "a comparsa" aggressiva, in cascata: ogni card scatta con overshoot
   (spring) quando la sezione entra in viewport. Sostituisce il reveal generico
   solo per queste card; il delay --pop crea l'effetto uno-dopo-l'altro. */
.pain-card.reveal { opacity: 0; }
.pain-card.reveal.is-visible {
  opacity: 1;
  animation: painPop .6s var(--ease-spring) var(--pop, 0s) backwards;
}
@keyframes painPop {
  from { opacity: 0; transform: translateY(46px) scale(.82) rotate(var(--rot, -3deg)); }
  to   { opacity: 1; transform: translateY(0) scale(1) rotate(0); }
}

/* ==========================================================================
   SERVICES
   ========================================================================== */
.services {
  background: var(--blush);
  padding: clamp(56px, 8vh, 96px) 0;
}
.services__title {
  font-family: var(--font-display);
  font-weight: 900;
  font-size: clamp(36px, 5vw, 70px);
  line-height: 1.04;
  text-transform: none;
  margin-bottom: clamp(32px, 5vh, 56px);
}

/* 3 servizi come card affiancate; la barra-CTA nera sotto è il punto
   in cui i tre strumenti convergono (resa di "una sola direzione") */
.services__flow {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: clamp(18px, 2vw, 32px);
  align-items: stretch;
}

.srv {
  position: relative;
  display: flex;
  flex-direction: column;
  background: var(--white);
  border: 2px solid var(--black);
  border-radius: var(--radius-lg);
  overflow: hidden;
  box-shadow: 8px 10px 0 var(--sh, var(--black));
  transition: transform .4s var(--ease-out), box-shadow .4s var(--ease-out);
}
.srv:nth-child(1) { --sh: var(--yellow); }
.srv:nth-child(2) { --sh: var(--cyan); }
.srv:hover { transform: translateY(-5px); box-shadow: 12px 15px 0 var(--sh, var(--black)); }

/* fascia grafica in cima alla card (order la porta sopra il corpo testo):
   tinta piatta del servizio + numero gigante in outline, la stessa firma
   dei numeroni di pain e metodo — niente gradient, come il resto del sito */
.srv__media {
  order: -1;
  position: relative;
  aspect-ratio: 16 / 10;
  max-height: 240px;
  background: var(--acc);
  display: grid;
  place-items: center;
  overflow: hidden;
  border-bottom: 2px solid var(--black);
}
.srv__num {
  font-family: var(--font-anton);
  font-size: clamp(96px, 9vw, 150px);
  line-height: 1;
  color: transparent;
  -webkit-text-stroke: 2.5px var(--icon, var(--black));
  user-select: none;
  transition: color .35s var(--ease-out);
}
/* hover: il numero si riempie, eco del "pop" delle card pain */
.srv:hover .srv__num { color: var(--icon, var(--black)); }

/* badge sull'angolo della fascia: ora ospita l'icona del servizio */
.srv__node {
  position: absolute;
  top: 14px; left: 14px;
  z-index: 2;
  width: 46px; height: 46px;
  display: grid;
  place-items: center;
  background: var(--acc, var(--yellow));
  color: var(--node-c, var(--black));
  border: 2px solid var(--black);
  border-radius: 50%;
  transition: transform .4s var(--ease-spring);
}
.srv__node svg { width: 22px; height: 22px; }
.srv:hover .srv__node { transform: rotate(-8deg) scale(1.1); }

.srv__body {
  display: flex;
  flex-direction: column;
  flex: 1;
  padding: clamp(20px, 1.8vw, 28px);
}
.srv__tag {
  align-self: flex-start;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: .16em;
  text-transform: uppercase;
  padding: 6px 14px;
  border-radius: 100px;
  border: 1.5px solid var(--black);
  margin-bottom: 14px;
  transition: background .3s, color .3s;
}
.srv:hover .srv__tag { background: var(--black); color: var(--node-c, var(--acc, var(--yellow))); }

.srv__title {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: clamp(21px, 1.6vw, 27px);
  line-height: 1.1;
  margin-bottom: 12px;
}
.srv__text { font-size: 17px; opacity: .82; margin-bottom: 18px; }
.srv__list { display: flex; flex-direction: column; gap: 9px; margin-top: auto; }
.srv__list li {
  position: relative;
  font-size: 16.5px;
  font-weight: 600;
  padding-left: 20px;
}
.srv__list li::before {
  content: "✦";
  position: absolute;
  left: 0;
  top: 3px;
  color: var(--cyan-ink);
  font-size: 11px;
}

/* barra-CTA nera a tutta larghezza: il punto di convergenza + ponte alle offerte */
.srv-converge { grid-column: 1 / -1; margin-top: clamp(6px, 1vh, 14px); }
.srv-converge__panel {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 18px 28px;
  background: var(--black);
  color: var(--blush);
  border: 2px solid var(--black);
  border-radius: var(--radius-lg);
  padding: clamp(22px, 2.6vw, 32px) clamp(24px, 3vw, 40px);
}
.srv-converge__title {
  font-family: var(--font-display);
  font-size: clamp(22px, 2.4vw, 32px);
  line-height: 1.1;
}

/* ==========================================================================
   OFFERS
   ========================================================================== */
.offers {
  background: var(--bg-warm);
  padding: clamp(80px, 13vh, 150px) 0;
}
.offers__title {
  font-family: var(--font-display);
  font-weight: 900;
  font-size: clamp(36px, 5vw, 70px);
  line-height: 1.04;
  text-transform: none;
  margin-bottom: clamp(40px, 6vh, 64px);
}
.offers__title-sub { font-weight: 400; color: transparent; -webkit-text-stroke: 1.5px var(--black); }

.offers__grid {
  display: grid;
  grid-template-columns: 1.08fr .92fr;
  gap: clamp(18px, 2.2vw, 28px);
  align-items: stretch;
}

.offer {
  position: relative;
  border-radius: var(--radius-lg);
  padding: clamp(30px, 3.4vw, 48px);
  display: flex;
  flex-direction: column;
  transition: transform .45s var(--ease-out), box-shadow .45s var(--ease-out);
}
.offer:hover { transform: translateY(-8px); }

.offer--main {
  background: var(--black);
  color: var(--blush);
}
.offer--main:hover { box-shadow: 10px 12px 0 var(--cyan); }

.offer--alt {
  background: rgba(0,0,0,.045);
  border: 2px solid var(--black);
  color: var(--black);
}
.offer--alt:hover { box-shadow: 10px 12px 0 var(--black); }
.offer--alt .offer__text,
.offer--alt .offer__ideal { opacity: .85; }

.offer__badge {
  position: absolute;
  top: -14px;
  left: clamp(30px, 3.4vw, 48px);
  font-size: 12px;
  font-weight: 700;
  letter-spacing: .12em;
  text-transform: uppercase;
  background: var(--cyan);
  color: var(--black);
  padding: 7px 16px;
  border-radius: 100px;
}
.offer__badge--alt { background: var(--blush); border: 2px solid var(--black); }

.offer__title {
  font-family: var(--font-display);
  font-weight: 900;
  font-size: clamp(28px, 2.8vw, 42px);
  text-transform: none;
  margin: 10px 0 6px;
}
.offer--main .offer__title { color: var(--yellow); }
.offer__sub { font-weight: 700; font-size: 16px; margin-bottom: 16px; }
.offer--main .offer__sub { color: var(--cyan); }

/* fascia di specifiche: dati concreti che separano le due offerte a colpo d'occhio */
.offer__specs {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 18px;
}
.offer__specs li {
  font-size: 12.5px;
  font-weight: 700;
  letter-spacing: .02em;
  padding: 5px 12px;
  border-radius: 100px;
  border: 1.5px solid currentColor;
  opacity: .85;
}
.offer__text { font-size: 17.5px; margin-bottom: 14px; opacity: .88; }
.offer__ideal { font-size: 16.5px; margin-bottom: 24px; opacity: .8; }

.offer__list {
  display: flex;
  flex-direction: column;
  gap: 11px;
  margin-bottom: 30px;
}
.offer__list li {
  position: relative;
  padding-left: 30px;
  font-size: 17.5px;
  font-weight: 600;
}
.offer__list li::before {
  content: "✓";
  position: absolute;
  left: 0; top: 1px;
  width: 20px; height: 20px;
  display: grid;
  place-items: center;
  font-size: 11px;
  font-weight: 700;
  border-radius: 50%;
  background: var(--yellow);
  color: var(--black);
}
.offer--alt .offer__list li::before { background: var(--black); color: var(--yellow); }

/* variante a fasi: il progetto è un percorso con un traguardo, non un canone
   di servizi — numeri 01→04 al posto delle spunte */
.offer__list--steps { counter-reset: step; list-style: none; }
.offer__list--steps li { counter-increment: step; padding-left: 34px; }
.offer__list--steps li::before,
.offer--alt .offer__list--steps li::before {
  content: counter(step, decimal-leading-zero);
  width: auto; height: auto;
  background: transparent;
  border-radius: 0;
  font-size: 13px;
  font-weight: 900;
  letter-spacing: .04em;
  color: var(--black);
  opacity: .55;
  top: 2px;
}

.offer .btn { margin-top: auto; }

/* bussola di scelta: rende esplicito il "uno solo è quello giusto per te" */
.offers__compass {
  max-width: 720px;
  margin: clamp(28px, 4vh, 44px) auto 0;
  text-align: center;
  font-size: 17.5px;
  font-weight: 600;
  opacity: .9;
}
.offers__compass strong { font-weight: 800; white-space: nowrap; }

/* ==========================================================================
   METHOD
   ========================================================================== */
.method {
  background: var(--black);
  color: var(--blush);
  padding: clamp(80px, 13vh, 150px) 0;
}
.method__title {
  font-family: var(--font-display);
  font-weight: 900;
  font-size: clamp(34px, 4.8vw, 66px);
  line-height: 1.05;
  text-transform: none;
  color: var(--white);
  max-width: 18em;
  margin-bottom: clamp(46px, 7vh, 72px);
}

/* ----- Le tre fasi (fallback: impilate in verticale) ----- */
.mstep {
  position: relative;
  display: grid;
  grid-template-columns: minmax(0, .95fr) minmax(0, 1.05fr);
  gap: clamp(24px, 4vw, 64px);
  align-items: center;
  padding: clamp(28px, 4vh, 44px) 0;
}
.mstep + .mstep { border-top: 1px solid rgba(252, 239, 249, .14); }

.mstep__phase {
  font-size: 12px;
  font-weight: 700;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--cyan);
  margin-bottom: 14px;
}
.mstep__title {
  font-family: var(--font-display);
  font-weight: 900;
  font-size: clamp(28px, 3.2vw, 50px);
  line-height: 1.05;
  color: var(--white);
  margin-bottom: 16px;
}
.mstep__lead {
  font-size: clamp(17px, 1.4vw, 20px);
  opacity: .85;
  max-width: 32em;
}
.mstep__points {
  display: flex;
  flex-direction: column;
  gap: 13px;
  margin-bottom: 20px;
}
.mstep__points li {
  position: relative;
  font-size: 17.5px;
  padding-left: 24px;
  opacity: .9;
  max-width: 36em;
}
.mstep__points li::before {
  content: "✦";
  position: absolute;
  left: 0;
  top: 4px;
  color: var(--cyan);
  font-size: 12px;
}
.mstep__result { font-size: 17.5px; opacity: .95; }
.mstep__result strong { color: var(--yellow); }

.mstep__bignum {
  position: absolute;
  right: -2%;
  top: 50%;
  transform: translateY(-50%);
  font-family: var(--font-anton);
  font-size: clamp(160px, 26vw, 420px);
  line-height: 1;
  color: transparent;
  -webkit-text-stroke: 2px rgba(252, 239, 249, .14);
  pointer-events: none;
  user-select: none;
  z-index: 0;
}
.mstep__info, .mstep__detail { position: relative; z-index: 1; }

/* barra di avanzamento: visibile solo in modalità scrub */
.method__progress { display: none; }

/* ----- Modalità scrub: il pin ferma lo scroll e fa passare le tre fasi -----
   Il JS aggiunge .method--scrub e aggiorna --mp (0→1). Senza JS o con
   reduced-motion restano le tre fasi impilate qui sopra.
   Solo su viewport abbastanza grandi: sugli schermi piccoli il contenuto
   di una fase è più alto dello spazio disponibile nel frame pinnato e
   finirebbe sotto la barra di avanzamento — lì restano le fasi impilate. */
@media (min-width: 761px) and (min-height: 640px) {
  .method--scrub {
    height: 360vh;
    padding: 0;
  }
  .method--scrub .method__sticky {
    position: sticky;
    top: 0;
    height: 100svh;
    overflow: hidden;
    display: flex;
    align-items: stretch;
  }
  .method--scrub .method__frame {
    width: 100%;
    display: flex;
    flex-direction: column;
    padding-top: clamp(76px, 10vh, 120px);
    padding-bottom: clamp(24px, 4vh, 40px);
  }
  .method--scrub .method__title { margin-bottom: clamp(20px, 3vh, 36px); }
  .method--scrub .method__stage {
    position: relative;
    flex: 1;
    min-height: 0;
    display: grid;
    align-items: center;
  }
  .method--scrub .mstep {
    grid-area: 1 / 1;
    padding: 0;
    pointer-events: none;
    transition: none;
    --ti: clamp(0, (var(--mp, 0) - var(--in, 0)) / .12, 1);
    --to: clamp(0, (var(--mp, 0) - var(--out, 1)) / .12, 1);
    opacity: calc(var(--ti) * (1 - var(--to)));
    filter: blur(calc((1 - var(--ti)) * 12px + var(--to) * 12px));
    transform: translateY(calc((1 - var(--ti)) * 28px - var(--to) * 28px));
  }
  .method--scrub .mstep + .mstep { border-top: none; }
  .method--scrub .mstep:nth-child(1) { --in: -.12; --out: .30; }
  .method--scrub .mstep:nth-child(2) { --in: .34; --out: .62; }
  .method--scrub .mstep:nth-child(3) { --in: .66; --out: 2; }

  .method--scrub .method__progress {
    display: flex;
    align-items: center;
    gap: 14px;
    margin-top: clamp(16px, 2.5vh, 28px);
  }
  .method__progress-num {
    width: 40px; height: 40px;
    display: grid;
    place-items: center;
    border-radius: 50%;
    border: 1.5px solid rgba(252, 239, 249, .35);
    font-family: var(--font-anton);
    font-size: 16px;
    --t: clamp(0, (var(--mp, 0) - var(--at, 0)) / .04, 1);
    background: color-mix(in srgb, var(--yellow) calc(var(--t) * 100%), transparent);
    color: color-mix(in srgb, var(--black) calc(var(--t) * 100%), var(--blush));
  }
  .method__progress-bar {
    flex: 1;
    height: 2px;
    background: rgba(252, 239, 249, .18);
    overflow: hidden;
  }
  .method__progress-bar i {
    display: block;
    height: 100%;
    background: var(--yellow);
    transform-origin: left;
    transform: scaleX(var(--fill, 0));
  }
  .method--scrub .method__progress > .method__progress-bar:nth-child(2) i {
    --fill: clamp(0, var(--mp, 0) / .34, 1);
  }
  .method--scrub .method__progress > .method__progress-bar:nth-child(4) i {
    --fill: clamp(0, (var(--mp, 0) - .34) / .32, 1);
  }
}

/* ==========================================================================
   CLIENTI (fascia loghi)
   ========================================================================== */
.clients {
  /* accento giallo centrale sull'intera sezione: ampio e morbido, niente stacchi */
  background:
    radial-gradient(55% 85% at 50% 58%, rgba(255, 208, 0, .24), transparent 70%),
    var(--blush);
  padding: clamp(56px, 8vh, 96px) 0;
  overflow: hidden;
}
.clients__head { margin-bottom: clamp(28px, 4vh, 46px); }
.clients__title {
  font-family: var(--font-display);
  font-weight: 900;
  font-size: clamp(28px, 3.4vw, 52px);
  line-height: 1.05;
}

.clients__marquee {
  position: relative;
  overflow: hidden;
  padding-block: clamp(18px, 3vh, 34px);
  -webkit-mask-image: linear-gradient(90deg, transparent, #000 8%, #000 92%, transparent);
  mask-image: linear-gradient(90deg, transparent, #000 8%, #000 92%, transparent);
}
/* fuoco radiale: il clone sfocato della fila è visibile solo ai lati,
   il centro resta sulla fila nitida sottostante */
.clients__bluroverlay {
  position: absolute;
  inset: 0;
  padding-block: clamp(18px, 3vh, 34px); /* come la marquee: allinea le file */
  overflow: hidden;
  pointer-events: none;
  z-index: 2;
  -webkit-mask-image: linear-gradient(90deg, #000 0%, #000 16%, transparent 38%, transparent 62%, #000 84%, #000 100%);
  mask-image: linear-gradient(90deg, #000 0%, #000 16%, transparent 38%, transparent 62%, #000 84%, #000 100%);
}
.clients__track--blur { filter: blur(7px); }
.clients__track {
  display: flex;
  width: max-content;
  animation: clientsScroll 32s linear infinite;
}
.clients__marquee:hover .clients__track { animation-play-state: paused; }

.clients__group {
  display: flex;
  align-items: center;
  gap: clamp(48px, 6vw, 110px);
  padding-right: clamp(48px, 6vw, 110px);
}
.clients__group img {
  height: clamp(38px, 4.4vw, 64px);
  width: auto;
  max-width: 220px;
  object-fit: contain;
  opacity: .85;
  transition: opacity .3s, transform .3s var(--ease-out);
}
.clients__group img:hover { opacity: 1; transform: scale(1.07); }
/* compensi per pari peso visivo: i quadrati crescono, i pesanti calano */
.clients__group img[src*="antonioli"] { height: clamp(56px, 6.2vw, 92px); }
.clients__group img[src*="mgm"] { height: clamp(66px, 7.8vw, 118px); }
.clients__group img[src*="borgosesia"] { height: clamp(50px, 5.8vw, 88px); }
.clients__group img[src*="la-colombera"] { height: clamp(48px, 5.4vw, 80px); }
.clients__group img[src*="mai-extreme"] { height: clamp(28px, 3.2vw, 46px); }

/* tre gruppi identici: il loop scatta a un terzo della larghezza */
@keyframes clientsScroll { to { transform: translateX(calc(-100% / 3)); } }

/* ----- Modalità scrub: mini pin con titolo che attraversa il frame -----
   Il JS aggiunge .clients--scrub e aggiorna --cp (0→1). Senza JS o con
   reduced-motion resta la fascia compatta qui sopra. */
.clients__title { width: fit-content; }

/* niente pin: la sezione resta compatta, sempre alla sua altezza naturale;
   il titolo attraversa il frame mentre la sezione attraversa il viewport */
.clients--scrub .clients__title {
  /* --tt: corsa in px misurata dal JS (larghezza utile - larghezza titolo) */
  transform: translateX(calc(var(--cp, 0) * var(--tt, 0px)));
}
@media (prefers-reduced-motion: reduce) {
  .clients__track { animation: none; width: auto; flex-wrap: wrap; gap: 28px; padding-inline: var(--pad); }
  .clients__group { flex-wrap: wrap; }
  .clients__group[aria-hidden="true"] { display: none; }
  .clients__marquee { mask-image: none; -webkit-mask-image: none; }
  .clients__bluroverlay { display: none; }
}

/* ==========================================================================
   CASES
   ========================================================================== */
.cases { background: var(--yellow); }
.cases > .container { padding-top: clamp(80px, 13vh, 150px); padding-bottom: clamp(46px, 7vh, 72px); }
.cases__title {
  font-family: var(--font-display);
  font-weight: 900;
  font-size: clamp(34px, 4.8vw, 66px);
  line-height: 1.05;
  text-transform: none;
  max-width: 18em;
}

.case { padding: clamp(60px, 9vh, 110px) 0; }
.case--yellow { background: var(--yellow); padding-top: 0; }
.case--blush { background: var(--blush); }
.case--black { background: var(--black); color: var(--blush); }

.case__inner {
  display: grid;
  grid-template-columns: minmax(0, .92fr) minmax(0, 1.08fr);
  gap: clamp(32px, 5vw, 80px);
  align-items: center;
}
.case__inner--flip .case__media { order: 2; }
.case__inner--flip .case__body { order: 1; }

.case__media { position: relative; max-width: 760px; }
.case__img {
  position: relative;
  aspect-ratio: 4 / 4.6;
  border-radius: var(--radius-lg);
  overflow: hidden;
  display: grid;
  place-items: center;
  /* ombra dura offset come il resto del sistema: qui era l'unica sfumata */
  box-shadow: 12px 14px 0 var(--case-sh, var(--black));
  transition: transform .55s var(--ease-out);
}
.case--blush .case__img { --case-sh: var(--cyan); }
.case--black .case__img { --case-sh: var(--yellow); }
.case__media:hover .case__img { transform: scale(1.02) rotate(-.6deg); }
.case__img-label {
  position: relative;
  z-index: 2;
  font-family: var(--font-anton);
  font-weight: 400;
  font-size: clamp(44px, 4.8vw, 70px);
  line-height: 1;
  text-align: center;
  text-transform: uppercase;
}

/* foto reale del case study: copre il placeholder grafico mantenendo gli
   angoli arrotondati (il box ha overflow:hidden). Se il file manca, l'<img>
   si rimuove da sola (onerror) e resta il placeholder. */
.case__img-photo {
  position: absolute;
  inset: 0;
  z-index: 1;
  width: 100%;
  height: 100%;
  object-fit: cover;
}
/* leggero zoom: il collage ha un filo bianco sul bordo, lo portiamo fuori dal riquadro */
.case__img--eventi .case__img-photo { transform: scale(1.025); }
/* con la foto presente, nascondo scritta e decorazioni del placeholder */
.case__img:has(img.case__img-photo) .case__img-label,
.case__img:has(img.case__img-photo) .case__img-stripes,
.case__img:has(img.case__img-photo) .case__img-grid,
.case__img:has(img.case__img-photo) .case__img-dots { display: none; }

.case__img--mai {
  background:
    radial-gradient(120% 100% at 18% 12%, #1a1a1a 0%, transparent 50%),
    linear-gradient(160deg, #000 0%, #222 55%, #000 100%);
  color: var(--yellow);
}
.case__img-stripes {
  position: absolute;
  inset: 0;
  display: flex;
  justify-content: space-around;
  transform: skewX(-18deg) scaleX(1.4);
}
.case__img-stripes i { width: 10%; background: rgba(255,208,0,.12); }
.case__img-stripes i:nth-child(2) { background: rgba(0,194,209,.14); }
.case__img-stripes i:nth-child(3) { background: rgba(252,239,249,.07); }

.case__img--antonioli {
  background: linear-gradient(150deg, #111 0%, #2a2a2a 100%);
  color: var(--blush);
}
.case__img-grid {
  position: absolute;
  inset: 14%;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
  opacity: .85;
}
.case__img-grid i { border: 2.5px solid rgba(255,208,0,.5); border-radius: 14px; }
.case__img-grid i:nth-child(2) { border-color: rgba(0,194,209,.55); }
.case__img-grid i:nth-child(3) { border-color: rgba(252,239,249,.3); }
.case__img-grid i:nth-child(4) { background: rgba(255,208,0,.16); border-color: transparent; }

.case__img--eventi {
  background:
    radial-gradient(100% 90% at 75% 20%, rgba(0,194,209,.5) 0%, transparent 55%),
    radial-gradient(110% 100% at 20% 85%, rgba(255,208,0,.6) 0%, transparent 60%),
    #0c0c0c;
  color: var(--white);
}
.case__img-dots {
  position: absolute;
  inset: 0;
  background-image: radial-gradient(rgba(252,239,249,.35) 1.5px, transparent 1.5px);
  background-size: 26px 26px;
}

.case__index {
  position: absolute;
  top: -26px;
  right: -8px;
  z-index: 3;
  font-family: var(--font-display);
  font-size: clamp(70px, 8vw, 120px);
  line-height: 1;
  color: transparent;
  -webkit-text-stroke: 2px currentColor;
  opacity: .55;
  pointer-events: none;
}

.case__kicker {
  display: inline-block;
  font-size: 12.5px;
  font-weight: 700;
  letter-spacing: .16em;
  text-transform: uppercase;
  color: var(--cyan);
  background: rgba(0,0,0,.85);
  padding: 7px 15px;
  border-radius: 100px;
  margin-bottom: 18px;
}
.case--black .case__kicker { background: rgba(252,239,249,.1); }

.case__name {
  font-family: var(--font-anton);
  font-weight: 400;
  font-size: clamp(34px, 4vw, 56px);
  line-height: 1.04;
  text-transform: uppercase;
  margin-bottom: 10px;
}
.case--black .case__name { color: var(--yellow); }
.case__headline {
  font-size: clamp(18px, 1.6vw, 22px);
  font-weight: 700;
  margin-bottom: 16px;
}
.case__text { font-size: 18px; opacity: .85; margin-bottom: 26px; max-width: 40em; }

.case__meta {
  display: grid;
  gap: 16px;
  margin-bottom: 26px;
}
.case__meta dt {
  font-size: 12px;
  font-weight: 700;
  letter-spacing: .16em;
  text-transform: uppercase;
  margin-bottom: 4px;
  color: var(--cyan);
}
.case--yellow .case__meta dt,
.case--blush .case__meta dt { color: var(--cyan-ink); }
.case__meta dd { font-size: 17px; opacity: .85; max-width: 50em; }

/* ----- Striscia media "Dal progetto" sotto ogni caso ----- */
.case__strip { margin-top: clamp(36px, 6vh, 60px); }

.case__strip-head {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 16px;
}
.case__strip-label {
  font-size: 12px;
  font-weight: 700;
  letter-spacing: .18em;
  text-transform: uppercase;
}
.case__strip-label span { color: var(--cyan); }
/* su casi chiari (giallo/blush) il ✦ usa il cyan-inchiostro leggibile */
.case--yellow .case__strip-label span,
.case--blush .case__strip-label span { color: var(--cyan-ink); }
.case--black .case__strip-label span { color: var(--yellow); }
.case__strip-cue { font-size: 12px; font-weight: 700; letter-spacing: .08em; opacity: .55; }

.case__strip-track {
  display: flex;
  gap: clamp(16px, 2.2vw, 28px);
  overflow-x: auto;
  /* overflow-y esplicito: senza, il browser lo calcola comunque "auto" (regola
     CSS: se un asse è visible e l'altro no, quello visible diventa auto), e i
     pixel che sporgono per inclinazione/hover dei frame trasformano la striscia
     in un contenitore scrollabile in verticale, catturando la rotellina del
     mouse invece di far scrollare la pagina. */
  overflow-y: hidden;
  /* niente scroll-snap: la striscia resta dove la lasci dopo il trascinamento */
  /* aria sopra e sotto per inclinazioni e ombre dure */
  padding-top: 12px;
  padding-bottom: 20px;
  scrollbar-width: none;
}
.case__strip-track::-webkit-scrollbar { display: none; }
.case__strip-track { cursor: grab; }
.case__strip-track.is-dragging {
  cursor: grabbing;
  user-select: none;
}
/* gli eventi del mouse restano sulla striscia: niente drag nativo delle immagini */
.strip-item__media { pointer-events: none; }

.strip-item {
  flex: 0 0 auto;
}
/* gap ampio: l'ombra dura dei riquadri inclinati non deve toccare la didascalia */
.strip-item figure { display: flex; flex-direction: column; gap: 18px; }

.strip-item__frame {
  position: relative;
  height: clamp(300px, 36vh, 400px);
  border: 2px solid var(--black);
  border-radius: var(--radius-md);
  background: linear-gradient(135deg, var(--sg1, #fff), var(--sg2, #ffe9a8));
  display: grid;
  place-items: center;
  overflow: hidden;
  transform: rotate(var(--tilt, 1.4deg));
  box-shadow: 7px 9px 0 var(--ssh, var(--black));
  transition: transform .4s var(--ease-out), box-shadow .4s var(--ease-out);
}
.strip-item--photo .strip-item__frame { aspect-ratio: 4 / 5; }
.strip-item--reel .strip-item__frame { aspect-ratio: 9 / 16; }
/* scatti orizzontali (es. panoramiche): stessa cornice, proporzione più larga
   invece del ritaglio verticale forzato che rovinerebbe l'inquadratura */
.strip-item--wide .strip-item__frame { aspect-ratio: 16 / 9; }
.strip-item:nth-child(even) .strip-item__frame { --tilt: -1.4deg; }
.strip-item:hover .strip-item__frame {
  transform: rotate(0) translateY(-6px);
  box-shadow: 10px 13px 0 var(--ssh, var(--black));
}

.strip-item__media {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.strip-item__icon { width: 44px; height: 44px; color: rgba(0, 0, 0, .5); }
.strip-item__icon svg { width: 100%; height: 100%; }

/* accenti per caso: ombra e placeholder seguono la palette della sezione */
.case--blush .strip-item { --ssh: var(--cyan); }
.case--blush .strip-item__frame { --sg1: #ffffff; --sg2: #cfeef1; }
.case--black .strip-item { --ssh: var(--yellow); }
.case--black .strip-item__frame { --sg1: #2b2b2b; --sg2: #111111; border-color: var(--blush); }
.case--black .strip-item__icon { color: rgba(252, 239, 249, .6); }

/* ==========================================================================
   CTA FINALE
   ========================================================================== */
.cta {
  position: relative;
  background: var(--black);
  color: var(--blush);
  padding: clamp(90px, 15vh, 170px) 0 clamp(80px, 12vh, 140px);
  overflow: hidden;
  text-align: center;
}
.cta__marquee {
  position: absolute;
  top: 26px;
  left: 0; right: 0;
  overflow: hidden;
  opacity: .14;
  pointer-events: none;
}
.cta__marquee-track {
  display: flex;
  width: max-content;
  animation: ticker 20s linear infinite;
  font-family: var(--font-anton);
  font-size: clamp(48px, 7vw, 100px);
  text-transform: uppercase;
  color: var(--yellow);
  white-space: nowrap;
}

.cta__inner {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
}
.cta__title {
  font-family: var(--font-display);
  font-weight: 900;
  font-size: clamp(40px, 6.4vw, 96px);
  line-height: 1;
  text-transform: none;
  color: var(--white);
  margin-bottom: clamp(24px, 4vh, 38px);
}
.cta__title-accent > span {
  background: var(--yellow);
  color: var(--black);
  padding: 0 .18em;
  display: inline-block;
}
.cta__text {
  font-size: clamp(16px, 1.5vw, 20px);
  max-width: 38em;
  opacity: .85;
  margin-bottom: clamp(32px, 5vh, 48px);
}
.cta__microcopy {
  margin-top: 22px;
  font-size: 14px;
  opacity: .6;
}

/* ---------- Form di contatto ---------- */
.cta__form {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 20px;
  width: 100%;
  max-width: 560px;
  text-align: left;
}
.cta__form-row {
  display: flex;
  flex-wrap: wrap;
  gap: 16px;
  width: 100%;
}
.cta__field {
  display: flex;
  flex-direction: column;
  gap: 8px;
  width: 100%;
}
.cta__form-row .cta__field { flex: 1 1 220px; }
.cta__field label {
  font-size: 12.5px;
  font-weight: 700;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--blush);
  opacity: .65;
}
.cta__field input,
.cta__field textarea {
  width: 100%;
  padding: 14px 18px;
  font-family: var(--font-body);
  font-size: 16px;
  color: var(--blush);
  background: rgba(252, 239, 249, .05);
  border: 1px solid rgba(252, 239, 249, .18);
  border-radius: var(--radius-sm);
  transition: border-color .25s var(--ease-out), background .25s var(--ease-out);
}
.cta__field textarea { resize: vertical; min-height: 110px; }
.cta__field input::placeholder,
.cta__field textarea::placeholder { color: rgba(252, 239, 249, .4); }
.cta__field input:focus,
.cta__field textarea:focus {
  background: rgba(252, 239, 249, .09);
  border-color: var(--cyan);
}
.cta__submit { margin-top: 4px; }
/* esito dell'invio: conferma (cyan) o errore (giallo) sotto il pulsante */
.cta__form-status {
  width: 100%;
  margin-top: -4px;
  text-align: center;
  font-size: 15px;
  font-weight: 600;
}
.cta__form-status.is-ok { color: var(--cyan); }
.cta__form-status.is-error { color: var(--yellow); }
/* invio in corso: il pulsante non risponde e si spegne un po' */
.btn:disabled { opacity: .55; pointer-events: none; }
/* alternativa sempre visibile al form: l'email in chiaro */
.cta__form-note {
  width: 100%;
  margin-top: -8px;
  text-align: center;
  font-size: 13.5px;
  opacity: .6;
}
.cta__form-note a {
  font-weight: 700;
  text-decoration: underline;
  text-underline-offset: 3px;
}
.cta__form-note a:hover { color: var(--cyan); }

/* ==========================================================================
   FOOTER
   ========================================================================== */
.footer {
  background: var(--black);
  color: var(--blush);
  border-top: 1px solid rgba(252,239,249,.12);
  overflow: hidden;
}
.footer__inner {
  display: grid;
  grid-template-columns: 1.4fr 1fr 1fr;
  gap: clamp(28px, 4vw, 60px);
  padding-top: clamp(50px, 8vh, 80px);
  padding-bottom: clamp(36px, 6vh, 60px);
}
.footer__name {
  font-family: var(--font-display);
  font-weight: 900;
  font-size: 28px;
  text-transform: none;
  color: var(--yellow);
}
.footer__role {
  font-size: 13px;
  font-weight: 700;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--cyan);
  margin: 4px 0 14px;
}
.footer__label {
  font-size: 12px;
  font-weight: 700;
  letter-spacing: .18em;
  text-transform: uppercase;
  opacity: .5;
  margin-bottom: 16px;
}
.footer__contacts ul, .footer__nav ul {
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.footer__link {
  position: relative;
  font-size: 17px;
  font-weight: 600;
  width: fit-content;
  transition: color .25s;
}
.footer__link::after {
  content: "";
  position: absolute;
  left: 0; bottom: -3px;
  width: 100%; height: 1.5px;
  background: var(--cyan);
  transform: scaleX(0);
  transform-origin: right;
  transition: transform .35s var(--ease-out);
}
.footer__link:hover { color: var(--yellow); }
.footer__link:hover::after { transform: scaleX(1); transform-origin: left; }
.footer__place { font-size: 17px; opacity: .65; }

.footer__big {
  font-family: var(--font-display);
  font-weight: 900;
  /* minimo basso: sotto i ~480px il vecchio minimo di 60px superava la
     larghezza dello schermo e la scritta usciva tagliata ("Mostrati meg").
     12.2vw invece di 12.5: a 12.5 il testo sforava dell'~1% a ogni larghezza */
  font-size: clamp(36px, 12.2vw, 190px);
  line-height: .9;
  text-align: center;
  /* maiuscolo solo sulle iniziali: il testo nell'HTML è "Luca Spagnoli" */
  text-transform: none;
  white-space: nowrap;
  color: var(--yellow);
  user-select: none;
  pointer-events: none;
  padding-bottom: clamp(14px, 2.4vh, 26px);
}

.footer__bottom {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding-block: 22px;
  border-top: 1px solid rgba(252,239,249,.1);
  font-size: 13px;
  opacity: .75;
}
.footer__top { font-weight: 700; transition: color .25s; }
.footer__top:hover { color: var(--cyan); }
/* link alla privacy policy (documento LegalBlink, si apre in nuova scheda) */
.footer__policy {
  text-decoration: underline;
  text-underline-offset: 3px;
  transition: color .25s;
}
.footer__policy:hover { color: var(--cyan); }

/* ==========================================================================
   LIGHTBOX — anteprima grande dei contenuti delle strisce
   ========================================================================== */
.lightbox {
  border: none;
  padding: 0;
  background: transparent;
  max-width: none;
  max-height: none;
  overflow: visible;
  /* il reset universale azzera il margin: auto del dialog, che lo centra */
  margin: auto;
}
.lightbox::backdrop { background: rgba(0, 0, 0, .84); }

.lightbox__figure {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 16px;
}
.lightbox__stage video,
.lightbox__stage img {
  display: block;
  border: 2px solid var(--black);
  border-radius: var(--radius-md);
  box-shadow: 10px 13px 0 var(--yellow);
  background: var(--black);
}
/* niente aspect-ratio/object-fit forzati: i reel non sono tutti 9:16 (alcuni
   sono orizzontali o in altri formati) e non vanno mai ritagliati — qui il
   video prende sempre la sua proporzione reale, vincolata solo in ingombro */
.lightbox__stage video,
.lightbox__stage img {
  width: auto;
  height: auto;
  max-width: min(92vw, 860px);
  max-height: 80vh;
}
.lightbox__close {
  position: fixed;
  top: 18px;
  right: 18px;
  z-index: 2;
  width: 52px;
  height: 52px;
  display: grid;
  place-items: center;
  font-size: 20px;
  font-weight: 700;
  background: var(--yellow);
  color: var(--black);
  border: 2px solid var(--black);
  border-radius: 50%;
  cursor: pointer;
  transition: transform .35s var(--ease-spring), background .25s;
}
.lightbox__close:hover { transform: rotate(-8deg) scale(1.08); background: var(--cyan); }

@media (prefers-reduced-motion: no-preference) {
  .lightbox[open] .lightbox__figure { animation: lightboxIn .45s var(--ease-out) backwards; }
  @keyframes lightboxIn {
    from { opacity: 0; transform: translateY(22px) scale(.96); }
  }
}

/* i riquadri delle strisce diventano cliccabili (il JS li rende attivabili) */
.strip-item__frame { cursor: zoom-in; }
.case__strip-track.is-dragging .strip-item__frame { cursor: grabbing; }
body.lightbox-open { overflow: hidden; }

/* ==========================================================================
   RESPONSIVE
   ========================================================================== */

/* Schermi larghi: il sito occupa tutto il frame, non un blocco centrato.
   Il padding cresce con il viewport così i bordi respirano comunque. */
@media (min-width: 1440px) {
  :root {
    /* nessun tetto: le sezioni si allineano alla hero, che è sempre full width */
    --container: 100%;
    --pad: clamp(56px, 5vw, 128px);
  }
  .strip-item__frame { height: clamp(320px, 40vh, 480px); }
}

@media (max-width: 1024px) {
  .worlds__grid { grid-template-columns: 1fr 1fr; }
  .services__flow { grid-template-columns: 1fr; }
  .offers__grid { grid-template-columns: 1fr; }
  .mstep { grid-template-columns: 1fr; gap: 18px; align-items: start; }
  .mstep__bignum { font-size: clamp(120px, 30vw, 220px); right: 0; top: 0; transform: none; }
  .case__inner { grid-template-columns: 1fr; gap: 40px; }
  .case__inner--flip .case__media { order: 0; }
  .case__inner--flip .case__body { order: 1; }
  .case__img { max-width: 480px; aspect-ratio: 4/3.4; }
  .footer__inner { grid-template-columns: 1fr 1fr; }
  .footer__brand { grid-column: 1 / -1; }
}

@media (max-width: 760px) {
  .header__nav { display: none; }
  .header__burger {
    position: relative;
    z-index: 101;
    display: flex;
    flex-direction: column;
    justify-content: center;
    gap: 6px;
    width: 46px; height: 46px;
    padding: 11px;
    background: var(--black);
    border-radius: 12px;
  }
  .header__burger span {
    display: block;
    height: 2.5px;
    background: var(--yellow);
    border-radius: 2px;
    transition: transform .35s var(--ease-out), opacity .25s, width .35s var(--ease-out);
  }
  .header__burger span:nth-child(2) { width: 70%; }
  .header__burger.is-open span:nth-child(1) { transform: translateY(8.5px) rotate(45deg); }
  .header__burger.is-open span:nth-child(2) { opacity: 0; }
  .header__burger.is-open span:nth-child(3) { transform: translateY(-8.5px) rotate(-45deg); }

  body.menu-open { overflow: hidden; }

  /* su mobile la grana resta ma statica e la fila loghi sfocata sparisce:
     sono i due paint più costosi della pagina */
  .hero::after { animation: none; }
  .clients__bluroverlay { display: none; }

  .hero__frame { padding-top: 92px; }
  /* mobile: le due parole di ogni frase vanno a capo → righe impilate XXL */
  .hero__title { font-size: clamp(52px, 16.5vw, 76px); line-height: .95; }
  .hero__line-inner { white-space: normal; }
  .hero__actions { align-self: stretch; }
  .hero__actions .btn { width: 100%; }
  .proof__stats { grid-template-columns: 1fr; gap: 20px; }
  .proof__stats strong { font-size: 22px; }

  .worlds__grid { grid-template-columns: 1fr; }
  .pain__grid { grid-template-columns: 1fr; }

  .offer__badge { left: 24px; }

  .case__index { font-size: 64px; top: -18px; right: 0; }

  .strip-item__frame { height: clamp(240px, 32vh, 320px); }

  .mstep__lead { font-size: 17px; }
  .mstep__points li { font-size: 16.5px; }
  .mstep__title { font-size: clamp(24px, 7vw, 32px); }

  .srv-converge__panel { flex-direction: column; align-items: stretch; text-align: center; }
  .srv-converge__panel .btn { width: 100%; justify-content: center; }

  .cta__inner .btn--xl { width: 100%; padding: 20px 28px; font-size: 17px; }

  .footer__inner { grid-template-columns: 1fr; gap: 34px; }
  .footer__bottom { flex-direction: column; text-align: center; }
}

/* Sotto i ~520px il badge della hero non sta su una riga: i suoi elementi
   flex andavano ciascuno per conto proprio — qui il wrap diventa ordinato
   (nome sulla prima riga, ruolo sulla seconda) */
@media (max-width: 520px) {
  .hero__eyebrow {
    flex-wrap: wrap;
    row-gap: 2px;
    font-size: 11.5px;
  }
  /* "una sola direzione." è sottolineato e non può andare a capo: sotto i
     ~370px al minimo fisso di 36px sforava lo schermo — qui scala col viewport */
  .services__title { font-size: clamp(24px, 9.2vw, 36px); }
}

