/* ============================================================================
   agency.css · E-MIKE Apps, divisione digitale (CONCEPT v1, dark + audace)
   Direzione: tema scuro, tipografia gigante (Bricolage Grotesque self-hosted),
   COLORE PER SERVIZIO come elemento-firma. Dependency-free: nessuna CDN,
   nessun font esterno (Bricolage self-hosted in assets/fonts, OFL).
   File separato dal site.css attuale: serve a far approvare la direzione.
   ============================================================================ */

/* ---- Font display self-hosted (OFL, vedi assets/fonts/OFL.txt) ----------- */
@font-face{
  font-family:'Bricolage Grotesque'; font-style:normal; font-weight:600;
  font-display:swap; src:url('../fonts/bricolage-600.woff2') format('woff2');
}
@font-face{
  font-family:'Bricolage Grotesque'; font-style:normal; font-weight:700;
  font-display:swap; src:url('../fonts/bricolage-700.woff2') format('woff2');
}
@font-face{
  font-family:'Bricolage Grotesque'; font-style:normal; font-weight:800;
  font-display:swap; src:url('../fonts/bricolage-800.woff2') format('woff2');
}
/* Pacifico (font del titolo "La Sirenotta") NON è qui: è INCORPORATO in base64 dentro sirenotta.html
   (unica pagina che lo usa), così non serve caricare un file font separato. Il .woff2 resta in
   assets/fonts/ come sorgente. */

:root{
  /* superfici scure — neutri "Notte Assoluta" (preset d'archivio):
     nero neutro + bianco caldo, più sobrio del nero bluastro. */
  --bg:      #0A0A0A;      /* fondo (nero neutro) */
  --bg-2:    #121212;      /* fascia alternata */
  --bg-3:    #161616;      /* card */
  --bg-4:    #202020;      /* card hover / elevata */

  --ink:      #F4F2ED;     /* testo principale (bianco caldo) */
  --ink-soft: #B3B1A8;     /* testo secondario */
  --muted:    #807E75;     /* etichette */
  --line:      rgba(255,255,255,.10);
  --line-soft: rgba(255,255,255,.055);

  /* verde E-MIKE "di casa" (versione brillante per fondo scuro) */
  --accent:        #2FD27F;
  --accent-strong: #27BC70;
  --accent-tint:   rgba(47,210,127,.12);
  --accent-ink:    #04130B;   /* testo su pieno d'accento */

  --sans: system-ui, -apple-system, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
  --mono: ui-monospace, "SF Mono", "JetBrains Mono", Menlo, Consolas, monospace;
  --display: 'Bricolage Grotesque', var(--sans);

  --maxw: 1440px;                    /* box contenuto (come artwork ~1400) */
  --pad: clamp(18px, 3.5vw, 46px);   /* gutter laterali piu' piccoli: contenuto piu' largo */
  --head-h: 71px;                    /* altezza header sticky (70px + 1px bordo): SEMPRE da considerare */
  --radius: 16px;
  --radius-lg: 22px;
}

/* colore PER SERVIZIO: si attiva con data-accent su una sezione/card */
[data-accent="sitiweb"]    { --accent:#5C8BFF; --accent-strong:#4D7CFF; --accent-tint:rgba(92,139,255,.14); --accent-ink:#050a1c; }
[data-accent="app"]        { --accent:#2FD27F; --accent-strong:#27BC70; --accent-tint:rgba(47,210,127,.14); --accent-ink:#04130b; }
[data-accent="preventivi"] { --accent:#2FD27F; --accent-strong:#27BC70; --accent-tint:rgba(47,210,127,.14); --accent-ink:#04130b; }
[data-accent="costochef"]  { --accent:#FF8A3D; --accent-strong:#F2761F; --accent-tint:rgba(255,138,61,.14); --accent-ink:#1c0a02; }
[data-accent="seo"]        { --accent:#FFB23E; --accent-strong:#F59E1F; --accent-tint:rgba(255,178,62,.14); --accent-ink:#1c1303; }
[data-accent="social"]     { --accent:#FF5CA8; --accent-strong:#F5409A; --accent-tint:rgba(255,92,168,.14); --accent-ink:#1c0512; }

*{ box-sizing:border-box; }
html{ -webkit-text-size-adjust:100%; scroll-behavior:smooth; }
@media (prefers-reduced-motion: reduce){ html{ scroll-behavior:auto; } }

body{
  margin:0; background:var(--bg); color:var(--ink);
  font-family:var(--sans); font-size:17px; line-height:1.6; font-weight:400;
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
a{ color:inherit; text-decoration:none; }
img{ max-width:100%; display:block; }
::selection{ background:var(--accent); color:var(--accent-ink); }
:focus-visible{ outline:2px solid var(--accent); outline-offset:3px; border-radius:4px; }

/* ---- Wordmark E-MIKE (font di brand Inversionz) -------------------------- */
.wordmark{ font-family:'Inversionz', var(--mono); letter-spacing:.12em; line-height:1; text-transform:lowercase; }

/* ---- Layout -------------------------------------------------------------- */
.wrap{ max-width:var(--maxw); margin:0 auto; padding-left:var(--pad); padding-right:var(--pad); }
.section{ padding:clamp(56px,7.5vw,104px) 0; position:relative; }
.section--line{ border-top:1px solid var(--line); }
.section--alt{ background:var(--bg-2); }

/* etichetta "engineered": eyebrow mono con indice + lineetta */
.eyebrow{
  display:inline-flex; align-items:center; gap:11px;
  font-family:var(--mono); font-size:12.5px; letter-spacing:.18em; text-transform:uppercase;
  color:var(--muted); margin:0 0 22px;
}
.eyebrow .idx{ color:var(--accent); font-weight:600; }
.eyebrow .bar{ width:28px; height:1px; background:var(--line); }

/* ---- Tipografia: display Bricolage per i titoli -------------------------- */
h1,h2,h3,h4{ font-family:var(--display); font-weight:700; letter-spacing:-0.02em; line-height:1.02; margin:0; color:#fff; text-wrap:balance; }
/* text-wrap:balance bilancia le righe dei titoli invece di riempirle a forza:
   niente pi&ugrave; "a capo a caso", su titoli con la virgola spezza al punto naturale.
   (Ignorato dai browser vecchi, quindi nessun rischio.) */
.display,.h2,.h3{ text-wrap:balance; }
.lead,p{ text-wrap:pretty; } /* evita la parola orfana sull'ultima riga dei testi */
.display{ font-size:clamp(46px,8.4vw,108px); font-weight:800; letter-spacing:-0.04em; line-height:.95; }
.h2{ font-size:clamp(32px,5vw,60px); font-weight:700; letter-spacing:-0.03em; }
.h3{ font-size:clamp(24px,3vw,34px); font-weight:600; letter-spacing:-0.02em; }
.lead{ font-family:var(--sans); font-size:clamp(18px,2.2vw,23px); color:var(--ink-soft); line-height:1.55; max-width:46ch; }
.muted{ color:var(--muted); }
.mono{ font-family:var(--mono); }

/* ---- Header -------------------------------------------------------------- */
.site-head{
  position:sticky; top:0; z-index:50;
  background:color-mix(in srgb, var(--bg) 78%, transparent);
  -webkit-backdrop-filter:blur(12px); backdrop-filter:blur(12px);
  border-bottom:1px solid var(--line);
}
.site-head .wrap{ display:flex; align-items:center; justify-content:space-between; height:70px; }
.brand{ display:inline-flex; align-items:baseline; gap:10px; }
.brand .wordmark{ font-size:24px; color:#fff; }
.brand .tag{
  font-family:var(--mono); font-size:11px; letter-spacing:.16em; text-transform:uppercase;
  color:var(--accent-ink); background:var(--accent); padding:3px 7px; border-radius:5px; transform:translateY(-2px);
}
.nav{ display:flex; align-items:center; gap:26px; }
.nav__item{ position:relative; display:inline-flex; align-items:center; gap:4px; }
/* link di primo livello (porta all'hub) */
.nav > a, .nav__item > a{ font-size:15px; color:var(--ink-soft); position:relative; padding:4px 0; white-space:nowrap; }
.nav > a::after, .nav__item > a::after{ content:""; position:absolute; left:0; right:100%; bottom:0; height:1.5px; background:var(--accent); transition:right .25s ease; }
.nav > a:hover, .nav__item > a:hover{ color:#fff; }
.nav > a:hover::after, .nav__item > a:hover::after{ right:0; }
.nav .btn{ padding:9px 16px; color:var(--accent-ink); }
.nav .btn::after{ display:none; }

/* freccia + bottone che apre il sottomenu */
.nav__sub-toggle{ background:none; border:0; padding:6px 2px; margin:0; cursor:pointer; display:inline-flex; align-items:center; color:var(--muted); }
.nav__sub-toggle::before{ content:""; width:7px; height:7px; border-right:1.5px solid currentColor; border-bottom:1.5px solid currentColor; transform:rotate(45deg); transition:transform .2s ease, color .2s ease; position:relative; top:-1px; }
.nav__item:hover .nav__sub-toggle, .nav__item:focus-within .nav__sub-toggle{ color:#fff; }

/* dropdown */
.submenu{ position:absolute; top:calc(100% + 12px); left:-14px; min-width:230px; padding:8px;
  background:var(--bg-3); border:1px solid var(--line); border-radius:14px; box-shadow:0 18px 40px rgba(0,0,0,.45);
  display:flex; flex-direction:column; gap:2px; z-index:60;
  opacity:0; visibility:hidden; transform:translateY(6px); transition:opacity .18s ease, transform .18s ease, visibility .18s; }
.submenu::before{ content:""; position:absolute; top:-12px; left:0; right:0; height:12px; } /* ponte: non perde l'hover nel gap */
.nav__item:hover .submenu, .nav__item:focus-within .submenu, .submenu.open{ opacity:1; visibility:visible; transform:none; }
.submenu a{ display:block; padding:10px 12px; border-radius:9px; font-size:14.5px; color:var(--ink-soft); white-space:nowrap; }
.submenu a::after{ display:none; }
.submenu a:hover{ background:var(--bg-4); color:#fff; }
.submenu .soon{ font-family:var(--mono); font-size:10px; letter-spacing:.1em; text-transform:uppercase; color:var(--muted); margin-left:8px; }
.nav-toggle{ display:none; }

/* ---- Buttons ------------------------------------------------------------- */
.btn{
  display:inline-flex; align-items:center; gap:9px; cursor:pointer;
  font-family:var(--sans); font-size:15px; font-weight:600; line-height:1;
  padding:14px 24px; border-radius:999px; border:1px solid transparent;
  background:var(--accent); color:var(--accent-ink);
  transition:transform .15s ease, background .2s ease, border-color .2s ease, color .2s ease;
}
.btn:hover{ transform:translateY(-2px); background:var(--accent-strong); }
.btn--ghost{ background:transparent; color:var(--ink); border-color:var(--line); }
.btn--ghost:hover{ background:transparent; border-color:#fff; }
.btn .arrow{ transition:transform .2s ease; }
.btn:hover .arrow{ transform:translateX(3px); }
.btn-row{ display:flex; flex-wrap:wrap; gap:14px; align-items:center; }

/* ============================================================================
   HERO — la tesi: tipografia gigante + colore per servizio + griglia tecnica
   ============================================================================ */
.hero{ position:relative; overflow:hidden; padding:clamp(calc(var(--head-h) + 22px),11vw,150px) 0 clamp(40px,6vw,76px); }
.hero::before{ /* griglia tecnica sottile, sfumata */
  content:""; position:absolute; inset:0; pointer-events:none;
  background-image:
    linear-gradient(rgba(255,255,255,.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.04) 1px, transparent 1px);
  background-size:64px 64px;
  -webkit-mask-image:radial-gradient(120% 90% at 15% -8%, #000 28%, transparent 74%);
          mask-image:radial-gradient(120% 90% at 15% -8%, #000 28%, transparent 74%);
}
/* (Rimosso il blob "aurora" multicolore: era un segnale tipico da sito generato
   dall'AI e contraddiceva la regola "niente gradienti decorativi". Il colore ora
   vive negli accenti per-sezione e nella lista servizi, non in una nuvola sfocata.) */
.hero .wrap{ position:relative; z-index:1; }
.hero__eyebrow{ font-family:var(--mono); font-size:12.5px; letter-spacing:.2em; text-transform:uppercase; color:var(--muted); margin:0 0 26px; }
.hero h1{ max-width:15ch; }
/* Colori parola dell'hero SMORZATI: meno "neon su nero" (segnale da sito AI),
   tinte più sobrie e di luminanza simile, così sembrano una palette voluta.
   Gli accenti pieni restano nelle card/sezioni, dove funzionano. */
.hero h1 .w-siti{ color:#7E97D6; }
.hero h1 .w-app{ color:#57C08A; }
.hero h1 .w-seo{ color:#D7A14F; }
.hero h1 .w-social{ color:#D982B0; }
/* Parole hero animate (glitch in site.js): nascoste finche' il JS non le rivela,
   ma SOLO se il JS e' attivo (flag html.js). Senza JS restano visibili. */
.hero h1 .hw{ white-space:nowrap; }
.hero h1 .hw .hl{ display:inline-block; }
html.js .hero h1 .hw{ visibility:hidden; }
@media (prefers-reduced-motion: reduce){ html.js .hero h1 .hw{ visibility:visible; } }

/* Banda mostri di Ci.Bo' Run (canvas a tutta larghezza, disegno reale del gioco) */
.game-band{ display:block; width:100%; height:clamp(190px,26vw,300px); background:#0A0A0A;
  border-top:1px solid rgba(255,255,255,.08); border-bottom:1px solid rgba(255,255,255,.08); }

/* Split-flap (tabellone Solari) su un titolo corto: le lettere appaiono lettera
   dopo lettera dalla prima (JS in site.js). Nascosto via html.js finche' non parte. */
.flap-title .flword{ white-space:nowrap; }
.flap-title .fl{ display:inline-block; color:rgba(255,255,255,.5); }
.flap-title .fl.locked{ color:#fff; animation:flaplock .12s ease; }
@keyframes flaplock{ from{ transform:translateY(-2px); } to{ transform:none; } }
html.js .flap-title{ visibility:hidden; }
@media (prefers-reduced-motion: reduce){ html.js .flap-title{ visibility:visible; } }
.hero .lead{ margin:30px 0 36px; max-width:52ch; font-size:clamp(18px,2.2vw,23px); }

/* marquee dei servizi sotto l'hero (movimento con un senso: dice cosa facciamo) */
.ticker{ position:relative; z-index:1; margin-top:clamp(40px,6vw,72px); border-top:1px solid var(--line); border-bottom:1px solid var(--line); overflow:hidden; }
.ticker__track{ display:flex; width:max-content; gap:0; padding:18px 0; animation:ticker 64s linear infinite; }
.ticker__track span{ font-family:var(--display); font-weight:700; font-size:clamp(20px,2.4vw,28px); letter-spacing:-.02em; color:var(--ink); padding:0 28px; display:inline-flex; align-items:center; gap:28px; white-space:nowrap; }
.ticker__track span::before{ content:""; width:9px; height:9px; border-radius:2px; background:var(--c,#2FD27F); }
.ticker:hover .ticker__track{ animation-play-state:paused; }
@keyframes ticker{ to{ transform:translateX(-50%); } }
@media (prefers-reduced-motion: reduce){ .ticker__track{ animation:none; } }

/* ---- Tag pill (lista etichette, usata nella vetrina software in home) ----- */
.svc__tags{ display:flex; flex-wrap:wrap; gap:7px; margin:0 0 20px; padding:0; list-style:none; }
.svc__tags li{ font-family:var(--mono); font-size:11.5px; color:var(--ink-soft); border:1px solid var(--line); border-radius:999px; padding:5px 11px; }

/* ---- Banda credibilità (fatti veri, niente numeri gonfiati) -------------- */
.facts{ display:grid; grid-template-columns:repeat(4,1fr); gap:1px; background:var(--line); border:1px solid var(--line); border-radius:var(--radius); overflow:hidden; }
.facts > div{ background:var(--bg-2); padding:clamp(24px,3vw,34px); }
.facts .big{ font-family:var(--display); font-weight:800; font-size:clamp(34px,5vw,56px); letter-spacing:-.03em; color:#fff; line-height:1; }
.facts .lab{ color:var(--ink-soft); font-size:15px; margin-top:10px; }
.facts .lab b{ color:var(--accent); font-weight:600; }

.badge{ font-family:var(--mono); font-size:10.5px; letter-spacing:.12em; text-transform:uppercase; padding:4px 9px; border-radius:999px; border:1px solid var(--line); color:var(--ink-soft); display:inline-flex; align-items:center; gap:7px; }
.badge .dot{ width:7px; height:7px; border-radius:50%; background:var(--accent); }
.badge--live{ color:var(--accent); border-color:color-mix(in srgb, var(--accent) 45%, transparent); background:var(--accent-tint); }
.badge--soon .dot{ background:var(--muted); }

/* ---- Approccio: passi numerati (la struttura è informazione) ------------- */
.steps{ list-style:none; margin:clamp(34px,4vw,52px) 0 0; padding:0; display:grid; }
.steps li{ display:grid; grid-template-columns:clamp(60px,8vw,108px) 1fr; gap:clamp(18px,3vw,40px); padding:clamp(26px,3.4vw,40px) 0; border-top:1px solid var(--line); align-items:start; }
.steps li:last-child{ border-bottom:1px solid var(--line); }
.steps .n{ font-family:var(--display); font-weight:800; font-size:clamp(34px,5vw,64px); color:var(--accent); line-height:.9; letter-spacing:-.03em; }
.steps h3{ font-size:clamp(20px,2.4vw,26px); margin-bottom:10px; }
.steps p{ color:var(--ink-soft); margin:0; max-width:60ch; }

/* ---- Studio / azienda ---------------------------------------------------- */
.split{ display:grid; grid-template-columns:minmax(0,.85fr) minmax(0,1.15fr); gap:clamp(28px,6vw,80px); align-items:start; }
.stack > * + *{ margin-top:18px; }

/* ---- CTA ----------------------------------------------------------------- */
.cta .display{ max-width:16ch; }
.cta .lead{ margin:26px 0 34px; }

/* ---- Footer -------------------------------------------------------------- */
.site-foot{ background:var(--bg-2); border-top:1px solid var(--line); padding:clamp(48px,6vw,76px) 0 40px; color:var(--ink-soft); }
.family{ display:grid; grid-template-columns:repeat(auto-fit,minmax(150px,1fr)); gap:1px; background:var(--line); border:1px solid var(--line); border-radius:var(--radius); overflow:hidden; margin-bottom:40px; }
.family a, .family span{ background:var(--bg-3); padding:18px 20px; display:block; transition:background .2s ease; }
.family a:hover{ background:var(--bg-4); }
.family .lab{ font-family:var(--mono); font-size:11px; letter-spacing:.12em; text-transform:uppercase; color:var(--muted); margin-bottom:6px; }
.family .nm{ font-size:16px; color:var(--ink); }
.family .here .nm{ color:var(--accent); font-weight:600; }
.foot-bottom{ display:flex; flex-wrap:wrap; justify-content:space-between; gap:16px; font-size:14px; color:var(--muted); }
.foot-bottom .wordmark{ font-size:17px; color:#fff; }

/* ---- Reveal -------------------------------------------------------------- */
.reveal{ opacity:0; transform:translateY(20px); transition:opacity .7s cubic-bezier(.2,.7,.2,1), transform .7s cubic-bezier(.2,.7,.2,1); }
.reveal.in{ opacity:1; transform:none; }
@media (prefers-reduced-motion: reduce){ .reveal{ opacity:1; transform:none; transition:none; } }

/* ---- Responsive ---------------------------------------------------------- */
@media (max-width:980px){
  .facts{ grid-template-columns:repeat(2,1fr); }
  .split{ grid-template-columns:1fr; gap:32px; }
}
@media (max-width:680px){
  body{ font-size:17px; }
  .nav{ position:fixed; inset:var(--head-h) 0 auto 0; flex-direction:column; align-items:stretch; gap:0;
    background:var(--bg-2); border-bottom:1px solid var(--line); padding:8px var(--pad) 20px;
    transform:translateY(-135%); transition:transform .28s ease; }
  .nav.open{ transform:none; }
  .nav > a, .nav__item{ border-top:1px solid var(--line-soft); }
  .nav__item{ flex-wrap:wrap; align-items:center; }
  .nav > a, .nav__item > a{ padding:15px 0; display:block; flex:1; }
  .nav > a::after, .nav__item > a::after{ display:none; }
  .nav__sub-toggle{ padding:15px 10px; color:var(--ink-soft); }
  .nav__sub-toggle::before{ top:0; }
  .nav__sub-toggle[aria-expanded="true"]::before{ transform:rotate(-135deg); }
  /* su mobile il sottomenu &egrave; a fisarmonica: chiuso di default, si apre col toggle */
  .submenu{ position:static; transform:none; box-shadow:none; border:0; background:transparent;
    padding:0 0 10px 14px; min-width:0; width:100%; display:none; }
  .submenu::before{ display:none; }
  .submenu.open{ display:flex; }
  .submenu a{ padding:11px 0; }
  .nav .btn{ margin-top:12px; justify-content:center; }
  .nav-toggle{ display:inline-flex; flex-direction:column; gap:5px; background:none; border:0; padding:8px; cursor:pointer; }
  .nav-toggle span{ width:24px; height:2px; background:var(--ink); border-radius:2px; transition:transform .25s, opacity .2s; }
  .nav-toggle.open span:nth-child(1){ transform:translateY(7px) rotate(45deg); }
  .nav-toggle.open span:nth-child(2){ opacity:0; }
  .nav-toggle.open span:nth-child(3){ transform:translateY(-7px) rotate(-45deg); }
  .facts{ grid-template-columns:1fr 1fr; }
  .steps li{ grid-template-columns:1fr; gap:6px; }
}

/* ============================================================================
   AGGIUNTE SCHELETRO (giugno 2026) · correzioni anti-AI + moduli pagine interne
   - freccia in puro CSS (.cta-arrow) ripresa dal trattamento di artworkstudios
   - lista servizi verticale (.svc-list) al posto della griglia di card 2x2
   - mockup dispositivo, griglia progetti, hero di pagina interna, prose
   ============================================================================ */

/* ---- Freccia minimale in CSS (dettaglio "engineered", non emoji) ---------- */
.cta-arrow{ position:relative; width:9px; height:9px; display:inline-block; flex:none;
  border-top:1.5px solid currentColor; border-right:1.5px solid currentColor;
  transform:rotate(45deg); transition:transform .2s ease; }
a:hover > .cta-arrow, .lnk:hover .cta-arrow{ transform:rotate(45deg) translate(2px,-2px); }

/* link testuale d'accento con freccia */
.lnk{ display:inline-flex; align-items:center; gap:11px; font-weight:600; font-size:15px; color:var(--accent); }
.lnk .cta-arrow{ color:var(--accent); }

/* ---- Hero di pagina interna (più sobrio della home) ---------------------- */
.page-hero{ padding:clamp(calc(var(--head-h) + 22px),11vw,140px) 0 clamp(34px,5vw,60px); border-bottom:1px solid var(--line); position:relative; }
.page-hero .kicker{ font-family:var(--mono); font-size:12.5px; letter-spacing:.2em; text-transform:uppercase; color:var(--muted); margin:0 0 22px; display:inline-flex; gap:11px; align-items:center; }
.page-hero .kicker::before{ content:""; width:10px; height:10px; border-radius:3px; background:var(--accent); box-shadow:0 0 0 5px var(--accent-tint); }
.page-hero h1{ font-family:var(--display); font-weight:800; font-size:clamp(40px,7vw,84px); letter-spacing:-.035em; line-height:.98; max-width:16ch; }
.page-hero .lead{ margin-top:26px; }

/* ---- LISTA SERVIZI (creative list) · 2 colonne, hairline, immagine a lato -- */
.svc-list{ display:grid; grid-template-columns:1.05fr .95fr; gap:clamp(28px,5vw,64px); align-items:stretch; margin-top:clamp(34px,4vw,52px); }
.svc-list__items{ list-style:none; margin:0; padding:0; display:flex; flex-direction:column; justify-content:center; }
.svc-list__row{ border-top:1px solid var(--line); }
.svc-list__row:last-child{ border-bottom:1px solid var(--line); }
.svc-list__a{ display:grid; grid-template-columns:auto 1fr auto; align-items:center; gap:18px; padding:clamp(22px,3vw,34px) 4px; }
.svc-list__num{ font-family:var(--mono); font-size:12.5px; color:var(--muted); letter-spacing:.08em; }
.svc-list__t{ font-family:var(--display); font-weight:700; font-size:clamp(24px,3vw,34px); letter-spacing:-.02em; line-height:1; color:var(--ink); transition:color .25s ease; }
.svc-list__a:hover .svc-list__t, .svc-list__a:focus-visible .svc-list__t, .svc-list__a.is-active .svc-list__t{ color:var(--accent); }
.svc-list__d{ display:block; color:var(--ink-soft); font-size:15px; margin-top:8px; max-width:48ch; }
.svc-list__arrow{ width:9px; height:9px; border-top:1.5px solid var(--muted); border-right:1.5px solid var(--muted); transform:rotate(45deg); transition:transform .25s ease, border-color .25s ease; }
.svc-list__a:hover .svc-list__arrow, .svc-list__a.is-active .svc-list__arrow{ border-color:var(--accent); transform:rotate(45deg) translate(3px,-3px); }
/* pannello immagine che cambia secondo la voce attiva */
.svc-list__media{ position:relative; border:1px solid var(--line); border-radius:var(--radius-lg); overflow:hidden; background:var(--bg-3); min-height:340px; }
.svc-list__fig{ position:absolute; inset:0; opacity:0; transition:opacity .35s ease; display:flex; align-items:center; justify-content:center; text-align:center; padding:26px;
  background:linear-gradient(0deg,var(--accent-tint),var(--accent-tint)),var(--bg-4); }
.svc-list__fig.is-active{ opacity:1; }
.svc-list__fig span{ font-family:var(--mono); font-size:12px; color:var(--ink-soft); line-height:1.6; }
@media (max-width:880px){
  .svc-list{ grid-template-columns:1fr; }
  .svc-list__media{ display:none; } /* su mobile la lista basta da sola */
  .svc-list__d{ display:block; }
}

/* ---- Mockup / screenshot (cornici) --------------------------------------- */
.shot{ position:relative; border:1px solid var(--line); border-radius:var(--radius); overflow:hidden;
  background:linear-gradient(0deg,var(--accent-tint),var(--accent-tint)),var(--bg-4); }
.shot[data-label]::after{ content:attr(data-label); position:absolute; inset:0; display:flex; align-items:center; justify-content:center; text-align:center; padding:22px; font-family:var(--mono); font-size:12px; color:var(--ink-soft); line-height:1.6; }
.shot--desktop{ aspect-ratio:16/10; }
.shot--a4{ aspect-ratio:1/1.414; }
.shot--phone{ aspect-ratio:1/2; max-width:300px; margin-inline:auto; border-radius:30px; border-width:8px; border-color:#161616; box-shadow:0 0 0 1px var(--line); }
.media-pair{ display:grid; grid-template-columns:1.6fr .9fr; gap:clamp(16px,2.5vw,28px); align-items:center; margin-top:clamp(28px,4vw,44px); }
@media (max-width:760px){ .media-pair{ grid-template-columns:1fr; } }

/* ---- Showcase software (testo + screenshot grande) ----------------------- */
.showcase{ display:grid; grid-template-columns:.9fr 1.1fr; gap:clamp(28px,5vw,64px); align-items:start; }
.showcase--flip{ grid-template-columns:1.1fr .9fr; }
.showcase--flip .showcase__txt{ order:2; }
@media (max-width:860px){ .showcase, .showcase--flip{ grid-template-columns:1fr; } .showcase--flip .showcase__txt{ order:0; } }

/* ---- Griglia progetti / lavori (con etichetta) --------------------------- */
.proj-grid{ display:grid; grid-template-columns:repeat(auto-fill,minmax(300px,1fr)); gap:clamp(16px,2vw,24px); margin-top:clamp(34px,4vw,52px); }
.proj{ display:flex; flex-direction:column; border:1px solid var(--line); border-radius:var(--radius); overflow:hidden; background:var(--bg-3); transition:border-color .25s ease, transform .2s ease; }
.proj:hover{ border-color:color-mix(in srgb, var(--accent) 50%, var(--line)); transform:translateY(-4px); }
.proj__cover{ aspect-ratio:16/10; border-bottom:1px solid var(--line); }
.proj__b{ padding:clamp(18px,2.2vw,26px); display:flex; flex-direction:column; gap:8px; flex:1; }
.proj__tag{ font-family:var(--mono); font-size:11px; letter-spacing:.12em; text-transform:uppercase; color:var(--muted); }
.proj h3{ font-size:clamp(20px,2.4vw,26px); }
.proj p{ color:var(--ink-soft); font-size:15px; margin:0; flex:1; }

/* ---- Elenco "cosa puoi gestire / caratteristiche" (raggiera) ------------- */
.feat-grid{ display:grid; grid-template-columns:repeat(auto-fit,minmax(240px,1fr)); gap:1px; background:var(--line); border:1px solid var(--line); border-radius:var(--radius); overflow:hidden; margin-top:clamp(28px,4vw,44px); }
.feat{ background:var(--bg-2); padding:clamp(22px,2.6vw,30px); }
.feat .n{ font-family:var(--mono); font-size:12px; color:var(--accent); letter-spacing:.08em; }
.feat h3{ font-size:clamp(20px,2.4vw,26px); margin:12px 0 8px; }
.feat p{ color:var(--ink-soft); font-size:15px; margin:0; }

/* ---- Variante "righe spec": stessi .feat resi a tutta larghezza con hairline.
   Serve a spezzare due griglie a card vicine (anti-AI: variazione voluta) e a
   dare respiro ai blocchi con pochi item o testi lunghi. Richiede lo .n. ----- */
.feat-grid--rows{ display:block; background:transparent; border:0; border-radius:0;
  overflow:visible; }
.feat-grid--rows .feat{ display:grid; grid-template-columns:minmax(34px,auto) 1fr;
  column-gap:clamp(18px,3vw,44px); align-items:baseline;
  background:transparent; padding:clamp(22px,3vw,32px) 0; border-top:1px solid var(--line); }
.feat-grid--rows .feat:last-child{ border-bottom:1px solid var(--line); }
.feat-grid--rows .feat .n{ grid-column:1; grid-row:1 / span 20; font-size:13px; }
.feat-grid--rows .feat > :not(.n){ grid-column:2; }
.feat-grid--rows .feat h3{ margin:0 0 6px; }
.feat-grid--rows .feat .feat__claim{ margin:0 0 6px; }
@media (max-width:600px){
  .feat-grid--rows .feat{ grid-template-columns:1fr; row-gap:5px; }
  .feat-grid--rows .feat .n{ grid-row:auto; }
}

/* ---- "Cosa non è" / nota onesta ------------------------------------------ */
.note{ border:1px dashed var(--line); border-radius:var(--radius); padding:clamp(22px,3vw,32px); background:var(--bg-2); }
.note h3{ font-size:clamp(20px,2.4vw,26px); margin-bottom:14px; }
.note ul{ margin:0; padding-left:20px; color:var(--ink-soft); }
.note li{ margin:7px 0; }

/* ---- Prose / blocchi di testo -------------------------------------------- */
.prose{ max-width:62ch; }
.prose p{ color:var(--ink-soft); margin:0 0 18px; }
.grid-2{ display:grid; grid-template-columns:repeat(2,1fr); gap:clamp(20px,3vw,40px); }
@media (max-width:760px){ .grid-2{ grid-template-columns:1fr; } }
/* nelle 2 colonne le card DEVONO riempire la colonna (il cap 62ch di .prose le lasciava
   più strette del pannello titolo, sia qui sia su cibo-run). Il testo resta comodo perché
   la colonna è già ~metà larghezza. */
.grid-2 > .prose{ max-width:none; }

/* ---- Breadcrumb leggero -------------------------------------------------- */
.crumbs{ font-family:var(--mono); font-size:12px; letter-spacing:.06em; color:var(--muted); margin:0 0 18px; }
.crumbs a{ color:var(--muted); } .crumbs a:hover{ color:var(--ink); }

/* ---- Card .feat a 3 livelli: titolo + claim in grassetto + paragrafo ------ */
.feat__claim{ font-weight:700; color:var(--ink); font-size:15px; margin:6px 0 9px; }

/* ---- CTA "panel" scura con mockup dispositivo (ripresa da artwork) -------- */
.cta-panel{ display:grid; grid-template-columns:1.05fr .95fr; gap:clamp(26px,4vw,56px); align-items:center;
  background:linear-gradient(180deg, var(--bg-3), var(--bg-2)); border:1px solid var(--line);
  border-radius:var(--radius-lg); padding:clamp(28px,4vw,56px); overflow:hidden; }
.cta-panel__media .shot{ width:100%; }
.cta-panel .lead{ max-width:46ch; }
@media (max-width:780px){ .cta-panel{ grid-template-columns:1fr; } }

/* ---- Footer mega-strutturato (colonne + divisioni + barra) ---------------- */
.foot-cols{ display:grid; grid-template-columns:1.5fr 1fr 1fr 1.3fr; gap:clamp(24px,4vw,56px);
  padding-bottom:clamp(30px,4vw,46px); border-bottom:1px solid var(--line); }
.foot-col{ display:flex; flex-direction:column; align-items:flex-start; gap:10px; }
.foot-col .wordmark{ font-size:20px; color:#fff; margin-bottom:2px; }
.foot-col > p{ color:var(--muted); font-size:14px; line-height:1.6; margin:0; max-width:34ch; }
.foot-h{ font-family:var(--mono); font-size:11px; letter-spacing:.16em; text-transform:uppercase; color:var(--muted); margin:0 0 3px; font-weight:400; }
.foot-col a{ color:var(--ink-soft); font-size:14.5px; }
.foot-col a:hover{ color:#fff; }
.foot-col address{ color:var(--muted); font-size:14px; line-height:1.6; font-style:normal; }
@media (max-width:860px){ .foot-cols{ grid-template-columns:1fr 1fr; gap:30px 24px; } }
@media (max-width:520px){ .foot-cols{ grid-template-columns:1fr; } }
.site-foot .family{ margin-top:clamp(30px,4vw,46px); }

/* La home non rivela l'hero (niente fade uniforme anche lì): l'hero è subito
   pieno, i reveal restano solo per le sezioni sotto. */
.hero .reveal{ opacity:1; transform:none; }

/* ---- Rifinitura spaziatura/showcase (audit giugno 2026) ------------------ */
/* Stringe il vuoto quando una sezione segue subito l'hero di pagina interna. */
.page-hero + .section{ padding-top:clamp(28px,4vw,52px); }
/* Showcase: la coppia immagine NON va affiancata dentro la colonna stretta
   (il telefono diventava una scheggia su desktop): si impila e resta leggibile. */
.showcase .media-pair{ grid-template-columns:1fr; gap:clamp(14px,2vw,20px); }
/* il desktop riempie la colonna (stretch di default); solo il telefono è
   limitato e allineato a sinistra con justify-self (NON justify-items, che
   azzerava la larghezza dello screenshot desktop). */
.showcase .media-pair .shot--desktop{ width:100%; }
/* il telefono ha aspect-ratio ma serve una larghezza ESPLICITA, altrimenti in
   griglia collassa a una scheggia: width fissa, allineato a sinistra. */
.showcase .media-pair .shot--phone{ width:180px; max-width:100%; justify-self:start; margin-inline:0; }
/* Utility: tiene unite parole che non devono spezzarsi a fine riga (es. E-MIKE). */
.nowrap{ white-space:nowrap; }

/* feat-grid a 3 colonne: per griglie da 6 voci (evita celle vuote dell'auto-fit). */
.feat-grid--3{ grid-template-columns:repeat(3,1fr); }
@media (max-width:860px){ .feat-grid--3{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:560px){ .feat-grid--3{ grid-template-columns:1fr; } }

/* ============================================================================
   TEMA CHIARO IBRIDO (in produzione, giugno 2026) — override finale dei token.
   Parte alta SCURA (header + hero/page-hero), CORPO CHIARO, fasce e footer scuri.
   Sostituisce la vecchia base tutta-dark. Le sezioni scure usano .section--dark.
   ============================================================================ */
:root{
  --bg:#FFFFFF; --bg-2:#F3F5F8; --bg-3:#FFFFFF; --bg-4:#EDF0F4;
  --ink:#15181B; --ink-soft:#474C53; --muted:#7B818A;
  --line:rgba(16,20,26,.12); --line-soft:rgba(16,20,26,.07);
  --accent:#16996A; --accent-strong:#12805A; --accent-tint:rgba(22,153,106,.10); --accent-ink:#ffffff;
}
[data-accent="sitiweb"]{ --accent:#2B59C3; --accent-strong:#234CAB; --accent-tint:rgba(43,89,195,.10); --accent-ink:#fff; }
[data-accent="app"],[data-accent="preventivi"]{ --accent:#16996A; --accent-strong:#12805A; --accent-tint:rgba(22,153,106,.10); --accent-ink:#fff; }
[data-accent="seo"]{ --accent:#BD7510; --accent-strong:#A2630B; --accent-tint:rgba(189,117,16,.12); --accent-ink:#fff; }
[data-accent="social"]{ --accent:#CC3A86; --accent-strong:#B22F73; --accent-tint:rgba(204,58,134,.10); --accent-ink:#fff; }
[data-accent="costochef"]{ --accent:#E2611B; --accent-strong:#C9520F; --accent-tint:rgba(226,97,27,.10); --accent-ink:#fff; }

h1,h2,h3,h4,.display,.h2,.h3{ color:var(--ink); }
.proj,.cta-panel{ box-shadow:0 1px 2px rgba(16,20,26,.04), 0 10px 28px rgba(16,20,26,.06); }
.proj:hover{ box-shadow:0 2px 6px rgba(16,20,26,.07), 0 18px 44px rgba(16,20,26,.10); }

/* --- parte alta scura: header + hero + page-hero (poi corpo chiaro) -------- */
.site-head{ background:color-mix(in srgb, #0A0A0A 80%, transparent); border-bottom-color:rgba(255,255,255,.10);
  --ink:#F4F2ED; --ink-soft:#B3B1A8; --muted:#827F76; --line:rgba(255,255,255,.10); --bg-3:#161616; --bg-4:#202020; }
.hero, .page-hero{ background:#0A0A0A; color:#F4F2ED;
  --ink:#F4F2ED; --ink-soft:#B3B1A8; --muted:#827F76; --line:rgba(255,255,255,.10); }
.hero h1, .page-hero h1{ color:#fff; }
.page-hero{ border-bottom-color:rgba(255,255,255,.10); }

/* --- fasce scure di ritmo (classe .section--dark) ------------------------- */
.section--dark{ background:#0A0A0A; color:#F4F2ED;
  --ink:#F4F2ED; --ink-soft:#B3B1A8; --muted:#827F76; --line:rgba(255,255,255,.10); --bg-2:#141414; }
.section--dark h1,.section--dark h2,.section--dark h3,.section--dark .h2,.section--dark .display{ color:#fff; }
.section--dark .facts{ background:rgba(255,255,255,.10); border-color:rgba(255,255,255,.10); }
.section--dark .facts > div{ background:#141414; }

/* CTA panel e footer scuri sul corpo chiaro */
.cta-panel{ background:#0A0A0A; border-color:rgba(255,255,255,.10);
  --ink:#F4F2ED; --ink-soft:#B3B1A8; --muted:#827F76; --line:rgba(255,255,255,.12); --bg-4:#202020; }
.cta-panel h2,.cta-panel .h2,.cta-panel .display{ color:#fff; }
.site-foot{ background:#0A0A0A; color:#B3B1A8;
  --ink:#F4F2ED; --ink-soft:#B3B1A8; --muted:#827F76; --line:rgba(255,255,255,.10); --line-soft:rgba(255,255,255,.06);
  --bg-3:#161616; --bg-4:#202020; }
.site-foot .wordmark{ color:#fff; }

/* ---- card .feat cliccabile (griglia "aspetti" / tipi) + ancore sotto header */
a.feat{ transition:background .2s ease, box-shadow .2s ease; }
a.feat:hover{ background:var(--bg-4); }
a.feat .lnk{ margin-top:12px; }
[id]{ scroll-margin-top:calc(var(--head-h) + 20px); }

/* ============================================================================
   MOCKUP GRANDI + ANIMAZIONI (giugno 2026) · direzione "immagini grandi che
   riempiono, sito dinamico". Niente librerie: solo CSS + IntersectionObserver.
   ============================================================================ */

/* ---- Mockup "finestra browser" per screenshot grandi e realistici -------- */
.browser{ border:1px solid var(--line); border-radius:14px; overflow:hidden; background:var(--bg-3);
  box-shadow:0 26px 64px rgba(16,20,26,.16); }
.browser__bar{ display:flex; align-items:center; gap:7px; padding:11px 14px; background:var(--bg-4);
  border-bottom:1px solid var(--line); }
.browser__bar i{ width:11px; height:11px; border-radius:50%; background:var(--muted); opacity:.45; }
.browser__bar span{ margin-left:12px; font-family:var(--mono); font-size:12px; color:var(--muted); }
.browser .shot{ border:0; border-radius:0; box-shadow:none; }

/* ---- Composizione laptop/browser + telefono sovrapposto (riempie) -------- */
.device-stack{ position:relative; }
.device-stack > .browser{ width:100%; }
.device-stack__phone{ position:absolute; right:-5%; bottom:-12%; width:30%; min-width:120px; max-width:190px; }
.device-stack__phone .shot--phone{ width:100%; margin:0; box-shadow:0 22px 48px rgba(16,20,26,.28); }
@media (max-width:760px){
  .device-stack__phone{ position:static; width:150px; margin:18px auto 0; right:auto; bottom:auto; }
}

/* ---- Animazioni d'entrata (varianti, non tutte uguali) ------------------- */
.reveal--zoom{ opacity:0; transform:scale(.96); transition:opacity .8s cubic-bezier(.2,.7,.2,1), transform .8s cubic-bezier(.2,.7,.2,1); }
.reveal--zoom.in{ opacity:1; transform:none; }
.reveal--right{ opacity:0; transform:translateX(30px); transition:opacity .7s ease, transform .7s cubic-bezier(.2,.7,.2,1); }
.reveal--right.in{ opacity:1; transform:none; }

/* card a cascata: i figli di una griglia .reveal entrano sfalsati (dinamismo) */
.feat-grid.reveal, .proj-grid.reveal{ opacity:1; transform:none; transition:none; }
.feat-grid.reveal > *, .proj-grid.reveal > *{ opacity:0; transform:translateY(18px);
  transition:opacity .55s ease, transform .55s cubic-bezier(.2,.7,.2,1); }
.feat-grid.reveal.in > *, .proj-grid.reveal.in > *{ opacity:1; transform:none; }
.feat-grid.reveal.in > *:nth-child(2), .proj-grid.reveal.in > *:nth-child(2){ transition-delay:.06s; }
.feat-grid.reveal.in > *:nth-child(3), .proj-grid.reveal.in > *:nth-child(3){ transition-delay:.12s; }
.feat-grid.reveal.in > *:nth-child(4), .proj-grid.reveal.in > *:nth-child(4){ transition-delay:.18s; }
.feat-grid.reveal.in > *:nth-child(5), .proj-grid.reveal.in > *:nth-child(5){ transition-delay:.24s; }
.feat-grid.reveal.in > *:nth-child(6), .proj-grid.reveal.in > *:nth-child(6){ transition-delay:.30s; }

@media (prefers-reduced-motion: reduce){
  .reveal--zoom, .reveal--right{ opacity:1; transform:none; transition:none; }
  .feat-grid.reveal > *, .proj-grid.reveal > *{ opacity:1; transform:none; transition:none; }
}

/* Su schermi molto larghi il box cresce a 1500px (come artwork sopra i 1600px) */
@media (min-width:1600px){ :root{ --maxw:1500px; } }

/* ---- Ogni screenshot DESKTOP assume l'aspetto di una finestra browser ----
   Mockup automatico su tutto il sito (barra + 3 pallini), senza HTML per ogni shot.
   Dentro .browser la barra c'e' gia' in HTML, quindi la sopprimiamo. */
.shot--desktop::before{
  content:""; position:absolute; top:0; left:0; right:0; height:30px; z-index:1;
  border-bottom:1px solid var(--line);
  background:
    radial-gradient(circle 4px at 18px 15px, rgba(128,128,128,.55) 98%, transparent 100%),
    radial-gradient(circle 4px at 35px 15px, rgba(128,128,128,.55) 98%, transparent 100%),
    radial-gradient(circle 4px at 52px 15px, rgba(128,128,128,.55) 98%, transparent 100%),
    var(--bg-4);
}
.shot--desktop[data-label]::after{ padding-top:30px; }
.browser .shot--desktop::before{ display:none; }

/* ============================================================================
   ZOOM-HERO · hero "alla Apple" a 3 fasi (sticky + progresso scroll -> --p 0..1):
   1) il titolo sfuma, la finestra del sito SALE e CRESCE fino a quasi tutto schermo
   2) la finestra si FERMA, dai lati entrano elementi che si SOVRAPPONGONO
   3) tutto SALE INSIEME e si rilascia nella pagina.
   BASE = hero normale (mobile + reduced-motion): nessun blocco, finestra ferma.
   L'effetto si attiva SOLO da >=861px e con motion consentito (media query).
   ============================================================================ */
.zoom-hero{ position:relative; background:#0A0A0A; color:#F4F2ED;
  --ink:#F4F2ED; --ink-soft:#B3B1A8; --muted:#827F76; --line:rgba(255,255,255,.10);
  --bg-3:#161616; --bg-4:#202020; }
.zoom-hero__stage{ display:flex; flex-direction:column; align-items:center; justify-content:center;
  gap:clamp(22px,4vh,46px); text-align:center;
  padding:clamp(92px,13vh,150px) var(--pad) clamp(40px,8vh,80px); }
.zoom-hero__intro{ max-width:760px; }
.zoom-hero__intro .kicker{ justify-content:center; }
.zoom-hero__intro h1{ font-family:var(--display); font-weight:800; color:#fff; text-wrap:balance;
  font-size:clamp(38px,6.4vw,76px); letter-spacing:-.035em; line-height:1.0; margin:0; }
.zoom-hero__intro .lead{ margin:20px auto 0; max-width:48ch; }
.zoom-hero__scene{ position:relative; width:100%; display:flex; justify-content:center; }
.zoom-hero__device{ width:min(880px,92vw); }
.zoom-hero__device .browser{ box-shadow:0 30px 80px rgba(0,0,0,.45); }
.zoom-hero__hint{ font-family:var(--mono); font-size:12px; letter-spacing:.16em; text-transform:uppercase;
  color:var(--muted); display:inline-flex; align-items:center; gap:9px; }
.zoom-hero__hint::after{ content:""; width:9px; height:9px; border-right:1.5px solid var(--muted);
  border-bottom:1.5px solid var(--muted); transform:rotate(45deg); }
/* elementi laterali: nascosti senza animazione (compaiono solo nella scena scroll) */
.zoom-hero__side, .zoom-hero__chip{ display:none; }
.zoom-hero__chip{ font-family:var(--mono); font-size:13px; letter-spacing:.06em; text-transform:uppercase;
  color:#F4F2ED; background:rgba(18,18,18,.72); border:1px solid rgba(255,255,255,.16);
  border-radius:999px; padding:11px 17px; -webkit-backdrop-filter:blur(6px); backdrop-filter:blur(6px); white-space:nowrap; }
.zoom-hero__side--phone{ width:clamp(120px,15vw,200px); }
.zoom-hero__side--phone .shot--phone{ width:100%; margin:0; box-shadow:0 22px 48px rgba(0,0,0,.45); }

@media (prefers-reduced-motion: no-preference) and (min-width:861px){
  /* Sezione alta: finale lungo -> la ripresa dello scroll resta morbida.
     Le fasi --fade/--grow/--enter/--lift le calcola site.js gia' ammorbidite (smoothstep). */
  .zoom-hero{ height:330vh; }
  .zoom-hero__stage{ position:sticky; top:var(--head-h); height:calc(100vh - var(--head-h)); overflow:hidden;
    display:block; padding:0; gap:0; }
  .zoom-hero__intro{ position:absolute; left:50%; top:13vh; width:760px; max-width:92vw;
    opacity:calc(1 - var(--fade,0)); transform:translate(-50%, calc(var(--grow,0) * -9vh));
    will-change:opacity, transform; }
  /* Fase finale: la finestra si alza solo di poco (poco nero sotto), il resto
     della salita lo fa la ripresa naturale dello scroll con la sezione sotto dietro. */
  .zoom-hero__scene{ position:absolute; inset:0; align-items:center;
    transform:translateY(calc((1 - var(--grow,0)) * 46vh - var(--lift,0) * 16vh));
    opacity:calc(1 - var(--lift,0) * .22); will-change:transform, opacity; }
  .zoom-hero__device{ width:64vw; max-width:none; transform:scale(calc(.9 + var(--grow,0) * .58));
    transform-origin:center; will-change:transform; }
  .zoom-hero__side, .zoom-hero__chip{ display:block; position:absolute; opacity:var(--enter,0);
    will-change:transform, opacity; }
  .zoom-hero__side--phone{ right:7vw; bottom:9vh;
    transform:translateX(calc((1 - var(--enter,0)) * 42vw)) rotate(7deg); }
  .zoom-hero__chip--l{ left:6vw; top:26vh; transform:translateX(calc((1 - var(--enter,0)) * -38vw)); }
  .zoom-hero__chip--r{ right:8vw; top:33vh; transform:translateX(calc((1 - var(--enter,0)) * 38vw)); }
}

/* ============================================================================
   AMBIENTE DI GIOCO (solo pagina cibo-run, body.game-env): lo scenario REALE di
   Ci.Bo' Run (cibo-scena.js) è lo SFONDO fisso; hero/card/testi galleggiano sopra
   come pannelli leggibili. Niente grafiche inventate: lo sfondo è codice del gioco.
   ============================================================================ */
body.game-env{ background:#9fd0e8; }                    /* azzurro cielo: niente lampo dietro al canvas */
#cibo-world{ position:fixed; inset:0; width:100vw; height:100vh; height:100dvh; z-index:-2; pointer-events:none; }
body.game-env main > section{ background:transparent; } /* lo scenario si vede attraverso le sezioni */
body.game-env .page-hero{ border-bottom:0; }            /* niente hairline sopra lo scenario */
body.game-env .section--line{ border-top:0; }
/* hero e CTA: pannello scuro translucido, largo come il contenuto (= card bianche) */
body.game-env .game-panel{ background:rgba(11,15,21,.58); -webkit-backdrop-filter:blur(7px); backdrop-filter:blur(7px);
  border:1px solid rgba(255,255,255,.12); border-radius:20px; padding:clamp(22px,3.2vw,44px); }
body.game-env .cta h2, body.game-env .cta .lead{ color:#fff; }
/* breadcrumb + kicker dell'hero: più chiari, leggibili sul pannello scuro */
body.game-env .page-hero .crumbs, body.game-env .page-hero .crumbs a,
body.game-env .page-hero .kicker{ color:rgba(255,255,255,.82); }
/* blocchi di testo lunghi: pannello chiaro translucido */
body.game-env .prose{ background:rgba(255,255,255,.86); -webkit-backdrop-filter:blur(5px); backdrop-filter:blur(5px);
  border-radius:14px; padding:clamp(18px,2.4vw,28px); }
/* occhielli "01 IL PROGETTO" come chip scuro leggibile sopra lo scenario */
body.game-env .section .eyebrow{ display:inline-flex; align-items:center; background:rgba(11,15,21,.6); color:#eef2f5;
  padding:7px 13px; border-radius:999px; -webkit-backdrop-filter:blur(4px); backdrop-filter:blur(4px); }
body.game-env .section .eyebrow .bar{ background:rgba(255,255,255,.4); }
body.game-env .section .eyebrow .idx{ color:color-mix(in srgb, var(--accent) 42%, #ffffff); } /* numero più chiaro sul chip */
/* titoli "nudi" sopra il cielo: alone chiaro per leggibilità (NON tocca i titoli nei pannelli scuri) */
body.game-env .section > .wrap > h2.h2{ text-shadow:0 1px 0 rgba(255,255,255,.7), 0 3px 16px rgba(255,255,255,.55); }
/* footer appena trasparente: lascia intravedere lo scenario */
body.game-env .site-foot{ background:rgba(12,14,16,.9); -webkit-backdrop-filter:blur(6px); backdrop-filter:blur(6px);
  margin-top:clamp(44px,6vh,68px); }  /* stacco dalla sezione sopra: il mostro cammina sul bordo alto e sporgeva */

/* ---- Telefono "in mano" con dentro la demo del gioco (cibo-run) -------------
   L'immagine PNG (mani + telefono) ha lo SCHERMO TRASPARENTE: sta SOPRA, l'iframe
   del gioco sta DIETRO, posizionato sul rettangolo dello schermo (%, da tarare). */
/* touch-action: pan-x pan-y = consenti lo scroll ma blocca il PINCH-ZOOM sulla demo.
   Zoomare un iframe scalato via transform con canvas animato fa crashare Safari mobile
   (rirasterizza a risoluzione enorme). La pagina fuori dalla demo resta zoomabile. */
.phone-demo{ position:relative; max-width:1320px; margin-inline:auto; touch-action:pan-x pan-y;
  transform:translateX(-1.25%); }  /* lo SCHERMO nella PNG e' 15px (1.25%) a dx del centro: ricentra */
.phone-demo__frame{ display:block; width:100%; height:auto; position:relative; z-index:2; pointer-events:none; }
/* rettangolo dello SCHERMO, misurato sul canale alfa della PNG (mani-telefono.png,
   1200x920): la finestra trasparente va L=332..898 T=98..355 px. Lo teniamo LEGGERMENTE
   piu' grande del foro (~0.7% per lato) cosi' copre sempre il bordo: l'eccesso e' nascosto
   dietro la cornice opaca dell'immagine (niente pixel scoperti sul lato sinistro). */
.phone-demo__screen{ position:absolute; z-index:1; overflow:hidden; background:#000;
  left:26.9%; top:10.1%; width:48.6%; height:28.9%; border-radius:8px; }
/* l'iframe gira a dimensione logica FISSA (~1080px) e viene scalato via transform da
   giochi.js (initPhoneDemoScale) per riempire il rettangolo: cos&igrave; scala INSIEME l'HUD
   HTML (font in px) e il canvas. Dentro, il gioco misura via documentElement.clientWidth. */
.phone-demo__game{ position:absolute; top:0; left:0; border:0; background:#000;
  transform-origin:top left; pointer-events:none; }

/* PRIMO SCHERMO di cibo-run (.cibo-hero): titolo + mani-telefono sopra lo scenario.
   Su SCROLL (desktop) il telefono zooma e si dissolve, e la sezione 01 sale da sotto.
   Le sezioni interne restano trasparenti (lo scenario passa). */
body.game-env .cibo-hero .page-hero,
body.game-env .cibo-hero__phone,
body.game-env .cibo-after > section{ background:transparent; }
body.game-env .cibo-hero .phone-demo{ width:min(1080px,90vw); max-width:none; margin-inline:auto; }
/* MOBILE / flusso normale: spazi stretti, NESSUN effetto (palco statico, contenuto a flusso) */
body.game-env .cibo-hero__stage > .page-hero{ padding:clamp(16px,5vw,30px) 0 clamp(16px,4vw,26px); }
body.game-env .cibo-hero__phone{ padding:0; }
body.game-env .cibo-hero__phone .phone-demo{ margin-top:clamp(2px,2vw,12px); }
body.game-env .cibo-hero + .cibo-after > .section:first-child{ padding-top:clamp(22px,4vw,46px); }
/* Più RESPIRO nel flusso statico (tablet/mobile, cioè ogni device SENZA puntatore fine): il titolo non
   deve stare attaccato alle mani e la sez.01 non deve incollarsi sopra. Complemento del gate desktop:
   (max-width:860px) OPPURE nessun hover OPPURE puntatore grosso (touch). Il desktop-effetto non è toccato. */
@media (max-width:860px), (hover:none), (pointer:coarse){
  body.game-env .cibo-hero__phone .phone-demo{ margin-top:clamp(14px,4.5vw,44px); }              /* stacco titolo -> mani */
  body.game-env .cibo-hero + .cibo-after > .section:first-child{ padding-top:clamp(30px,6vw,66px); } /* stacco mani -> sez.01 */
  /* Vita su mobile/tablet (dove la cinematica desktop è spenta): le mani-telefono ENTRANO una volta
     all'apertura, con fade + risalita e un filo di zoom. Eco mobile della cinematica. Solo con motion. */
  @media (prefers-reduced-motion: no-preference){
    body.game-env .cibo-hero__phone{ animation:ciboPhoneIn 1.05s cubic-bezier(.2,.75,.2,1) .12s both; }
  }
}
@keyframes ciboPhoneIn{ from{ opacity:0; transform:translateY(52px) scale(.88); } to{ opacity:1; transform:none; } }

/* DESKTOP + motion: palco sticky. Titolo fisso in alto, mani in basso; scorrendo il telefono
   ZOOMA e si DISSOLVE, e il blocco contenuto (.cibo-after) sale COMPATTO da sotto le mani. */
/* GATE = solo computer con PUNTATORE FINE (mouse/trackpad) e hover: (hover:hover) and (pointer:fine).
   L'aspect-ratio NON bastava: i tablet Samsung/Android in landscape sono 16:10 (=1.6), indistinguibili
   da un laptop. Il puntatore invece separa netto: i tablet touch (iPad, Galaxy Tab in modalità tablet)
   hanno pointer:coarse e restano al flusso statico; qui il palco corto rompeva l'overlap col titolo.
   NB: un tablet in modalità desktop CON trackpad può riportare pointer:fine (caso limite, DeX). */
@media (prefers-reduced-motion: no-preference) and (min-width:861px) and (hover:hover) and (pointer:fine){
  .cibo-hero{ height:220vh; position:relative; }   /* binario di scroll LUNGO: l'animazione dura di più (più smooth) */
  .cibo-hero__stage{ position:sticky; top:var(--head-h); height:calc(100vh - var(--head-h));
    overflow:hidden; display:flex; flex-direction:column; z-index:2; }
  /* il TITOLO resta FISSO (non si dissolve con le mani): il contenuto gli sale sotto e poi
     scorrono via insieme alla fine del pin. */
  body.game-env .cibo-hero__stage > .page-hero{
    flex:1 0 auto; display:flex; align-items:center;
    padding:clamp(22px,3.2vh,52px) 0 clamp(16px,2.4vh,36px);
  }
  body.game-env .cibo-hero__stage > .page-hero > .wrap{ width:100%; }
  body.game-env .cibo-hero__phone{
    flex:0 0 auto; display:flex; padding:0;
    opacity:calc(1 - var(--cfade,0));
    transform:translateY(calc(var(--cgrow,0) * -13vh)) scale(calc(1 + var(--cgrow,0) * 1.4));
    transform-origin:center 62%; will-change:opacity,transform;
  }
  body.game-env .cibo-hero__phone > .wrap{ width:100%; display:flex; justify-content:center; align-items:flex-end; }
  body.game-env .cibo-hero__phone .phone-demo{ margin-top:0; }
  /* BLOCCO CONTENUTO (.cibo-after = sez.01 + 02 + CTA, compatte insieme): parte da sotto
     (overlap via margin-top) e sale VELOCE con translateY(--crise) mentre le mani si
     dissolvono; arriva sotto al titolo e poi scorrono via insieme. A riposo translateY=0. */
  body.game-env .cibo-hero + .cibo-after{
    margin-top:calc((100vh - var(--head-h)) * -.58);   /* posiziona il riposo: gap dal titolo ~ uguale a 01->02 */
    position:relative; z-index:1; will-change:transform;   /* il translateY lo guida site.js (rise + hold) */
  }
  /* RETE DI SICUREZZA overlap su VIEWPORT BASSI (<=880px alt.): lì il palco è corto, il titolo lo riempie
     e con l'overlap pieno (-.58) la sez.01 finiva SOPRA il titolo. Riduciamo l'overlap così resta SOTTO.
     I desktop normali sono più alti (MacBook ~982) → non toccati. Protegge i device che sfuggono al gate
     (es. tablet in desktop-mode col trackpad, pointer:fine). Verificato: a 768px alt. la 01 resta sotto. */
  @media (max-height:880px){
    body.game-env .cibo-hero + .cibo-after{ margin-top:calc((100vh - var(--head-h)) * -.16); }
  }
  /* spazi più stretti tra 01, 02 e CTA (richiesta owner): il gap title->01 deve eguagliare questo */
  body.game-env .cibo-after > .section{ padding-top:clamp(20px,3.4vh,44px); padding-bottom:clamp(20px,3.4vh,44px); }
  /* SOLO la sez.01: mentre sale parte rimpicciolita (60%) e si allarga fino al 100%,
     centrata; la 02 resta a dimensione piena. Top ancorato così non spinge sul titolo. */
  body.game-env .cibo-after > .section:first-child{
    transform:scale(calc(.6 + var(--crise,0) * .4)); transform-origin:center top; will-change:transform;
  }
}

/* ============================================================================
   LA SIRENOTTA (sirenotta.html) · titolo gioco in Pacifico + sfondo marino
   ============================================================================ */
/* titolo gioco (Pacifico giallo come l'app). Specificità `.page-hero h1.game-title` per BATTERE
   `.page-hero h1` (che imporrebbe font display + colore bianco). Alone dorato TOLTO (su fondo chiaro
   non serviva), solo ombra morbida per stacco; leggero bob. */
.page-hero h1.game-title{ font-family:'Pacifico',cursive; font-weight:400; line-height:1.05;
  letter-spacing:.01em; font-size:clamp(52px,9vw,108px); max-width:none; color:#ffe08a;
  margin:0; text-wrap:balance; text-shadow:0 3px 12px rgba(0,0,0,.4);
  animation:gameTitleBob 2.4s ease-in-out infinite; }
@keyframes gameTitleBob{ 0%,100%{ transform:translateY(0); } 50%{ transform:translateY(-6px); } }
@media (prefers-reduced-motion: reduce){ .page-hero h1.game-title{ animation:none; } }
/* sfondo pagina = mare (placeholder finché non arriva la scena animata del gioco, come cibo-scena.js).
   Il canvas #sirenotta-world (quando pronto) ci disegnerà sopra l'ambientazione che scorre. */
body.game-env.sea-env{ background:linear-gradient(#bfe3f2 0%, #86c4de 34%, #3a90b4 62%, #1a6787 82%, #0e4c66 100%); }
#sirenotta-world{ position:fixed; inset:0; width:100%; height:100%; z-index:-2; display:block; pointer-events:none; }
