/* ============================================================
   STORM X DIGITAL — OPERATOR / ENGINEERING-PAPER  v2 (LIGHT)
   Warm off-white background · charcoal type · electric orange accent
   ============================================================ */

:root {
  /* ---- Colour ---- */
  --c-bg-0: #F8F7F4;          /* warm off-white "paper" */
  --c-bg-1: #FFFFFF;          /* pure white surface */
  --c-bg-2: #EFEDE7;          /* elevated tinted surface */
  --c-bg-dark: #0F0F0F;       /* used in the rare full-bleed dark band */
  --c-line: #E0DDD5;          /* hairline border */
  --c-line-strong: #B8B4AB;   /* visible border */
  --c-text: #0F0F0F;          /* primary text — near-black */
  --c-text-mute: #5C5851;     /* secondary text */
  --c-text-faint: #908A7F;    /* tertiary / labels */
  --c-accent: #FF5500;        /* electric orange — used SPARINGLY */
  --c-accent-glow: rgba(255,85,0,0.18);
  --c-live: #16A34A;          /* live indicator — readable on white */

  /* ---- Typography ---- */
  --font-mono: 'JetBrains Mono', ui-monospace, 'SF Mono', Menlo, monospace;
  --font-display: 'Space Grotesk', system-ui, sans-serif;
  --font-serif: 'Instrument Serif', Georgia, serif;
  --font-body: 'Inter', system-ui, -apple-system, sans-serif;

  --t-mono-xs: 11px;
  --t-mono-sm: 12px;
  --t-mono-md: 13px;
  --t-body-sm: 14px;
  --t-body-md: 16px;
  --t-body-lg: 18px;
  --t-display-sm: 28px;
  --t-display-md: clamp(36px, 4vw, 56px);
  --t-display-lg: clamp(56px, 7vw, 110px);
  --t-display-xl: clamp(40px, 5.4vw, 72px);

  /* ---- Spacing (8px scale) ---- */
  --s-1: 4px; --s-2: 8px; --s-3: 16px; --s-4: 24px; --s-5: 32px;
  --s-6: 48px; --s-7: 64px; --s-8: 96px; --s-9: 128px;
  --gutter: clamp(16px, 4vw, 64px);

  /* ---- Motion ---- */
  --ease-snap: cubic-bezier(0.2, 0.8, 0.2, 1);
  --d-fast: 120ms;
  --d-med: 240ms;
  --d-slow: 480ms;
}

/* ---- Reset & base ---- */
*, *::before, *::after { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body {
  background: var(--c-bg-0);
  color: var(--c-text);
  font-family: var(--font-body);
  font-size: var(--t-body-md);
  line-height: 1.55;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  letter-spacing: -0.005em;
  overflow-x: hidden;

  /* Subtle paper-grain — dark fibers on warm white */
  background-image:
    url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0  0 0 0 0 0  0 0 0 0 0  0 0 0 0.06 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
}

a { color: inherit; text-decoration: none; }
button { font-family: inherit; cursor: pointer; }
img, svg { display: block; max-width: 100%; }
::selection { background: var(--c-accent); color: var(--c-bg-1); }

h1, h2, h3, h4 {
  font-family: var(--font-display);
  font-weight: 500;
  letter-spacing: -0.04em;
  line-height: 1.02;
  margin: 0;
}

/* (custom cursor removed per UX feedback — disorienta utenti 50+) */

/* ---- Layout primitives ---- */
.container {
  width: 100%;
  max-width: 1440px;
  margin: 0 auto;
  padding-left: var(--gutter);
  padding-right: var(--gutter);
}

.mono-label {
  font-family: var(--font-mono);
  font-size: var(--t-mono-xs);
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--c-text-faint);
  display: inline-flex;
  align-items: center;
  gap: var(--s-2);
}
.mono-label::before {
  content: '';
  width: 8px; height: 8px;
  border: 1px solid currentColor;
  display: inline-block;
}
.mono-label.is-live { color: var(--c-live); }
.mono-label.is-live::before {
  background: var(--c-live);
  border-color: var(--c-live);
  border-radius: 50%;
  animation: live-pulse 1.6s var(--ease-snap) infinite;
}
@keyframes live-pulse {
  0%, 100% { box-shadow: 0 0 0 0 rgba(22,163,74,0.5); }
  70%      { box-shadow: 0 0 0 6px rgba(22,163,74,0); }
}

.section { padding: var(--s-9) 0; position: relative; }
.section + .section { border-top: 1px solid var(--c-line); }
.section.is-dark {
  background: var(--c-bg-dark);
  color: var(--c-bg-0);
}
.section.is-dark .mono-label { color: rgba(248,247,244,0.55); }

.section-head {
  display: grid;
  grid-template-columns: 120px 1fr;
  gap: var(--s-4);
  margin-bottom: var(--s-7);
  align-items: baseline;
}
.section-head .num {
  font-family: var(--font-mono);
  font-size: var(--t-mono-sm);
  color: var(--c-text-faint);
  letter-spacing: 0.16em;
}
.section-head .title {
  font-size: var(--t-display-md);
  letter-spacing: -0.04em;
  max-width: 16ch;
}
@media (max-width: 720px) {
  .section-head { grid-template-columns: 1fr; gap: var(--s-3); margin-bottom: var(--s-6); }
  .section-head .title { max-width: none; font-size: clamp(28px, 8vw, 38px); }
}

/* ============== HEADER ============== */
.site-header {
  position: sticky; top: 0; z-index: 100;
  background: rgba(248,247,244,0.85);
  backdrop-filter: blur(18px) saturate(140%);
  -webkit-backdrop-filter: blur(18px) saturate(140%);
  border-bottom: 1px solid var(--c-line);
}
.header-inner {
  max-width: 1440px; margin: 0 auto;
  padding: 14px var(--gutter);
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: var(--s-4);
  align-items: center;
}
.header-logo {
  display: inline-flex; align-items: center;
  color: var(--c-text);
  text-decoration: none;
}
.header-logo .logo--primary { display: block; height: 32px; width: auto; }
.header-logo .logo--stacked { display: none; height: 44px; width: auto; }
/* Mantieni il logo orizzontale anche su mobile — più bello e riconoscibile */
@media (max-width: 540px) {
  .header-logo .logo--primary { display: block; height: 26px; }
}
.header-logo .dot { display: none; } /* legacy — rimosso dal markup nelle pagine v3.4+ */
.header-nav {
  display: flex; gap: var(--s-5);
  justify-content: center; align-items: center;
}
.nav-link, .nav-trigger {
  font-family: var(--font-mono);
  font-size: var(--t-mono-sm);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--c-text-mute);
  background: none; border: 0; padding: var(--s-2) 0;
  position: relative;
  transition: color var(--d-fast) var(--ease-snap);
}
.nav-link:hover, .nav-trigger:hover { color: var(--c-text); }
.nav-link.active::after, .nav-trigger:hover::after, .nav-link:hover::after {
  content: ''; position: absolute;
  left: 0; right: 0; bottom: -2px;
  height: 1px; background: var(--c-accent);
}
.nav-dropdown { position: relative; }
.nav-trigger::before { content: '['; margin-right: 2px; color: var(--c-text-faint); }
.nav-trigger::after { content: ']'; margin-left: 2px; color: var(--c-text-faint); }
.nav-panel {
  position: absolute; top: calc(100% + 8px); left: -8px;
  min-width: 280px;
  background: var(--c-bg-1);
  border: 1px solid var(--c-line-strong);
  padding: var(--s-2);
  opacity: 0; visibility: hidden;
  transform: translateY(-4px);
  transition: opacity var(--d-fast), visibility var(--d-fast), transform var(--d-fast);
  z-index: 50;
  box-shadow: 0 12px 40px rgba(15,15,15,0.08);
}
.nav-dropdown:hover .nav-panel,
.nav-dropdown:focus-within .nav-panel { opacity: 1; visibility: visible; transform: translateY(0); }
.nav-panel-item {
  display: flex; justify-content: space-between; align-items: center;
  padding: var(--s-3);
  font-size: var(--t-body-sm);
  color: var(--c-text);
  border-left: 2px solid transparent;
  transition: all var(--d-fast) var(--ease-snap);
}
.nav-panel-item .idx {
  font-family: var(--font-mono);
  font-size: var(--t-mono-xs);
  color: var(--c-text-faint);
  letter-spacing: 0.1em;
}
.nav-panel-item:hover {
  background: var(--c-bg-2);
  color: var(--c-accent);
  border-left-color: var(--c-accent);
}
.nav-panel-item:hover .idx { color: var(--c-accent); }
.header-right { display: flex; gap: var(--s-3); align-items: center; }
.header-lang {
  font-family: var(--font-mono);
  font-size: var(--t-mono-xs);
  font-weight: 700;
  letter-spacing: 0.12em;
  padding: 6px 10px;
  border: 1px solid var(--c-line-strong);
  color: var(--c-text-mute);
  transition: all var(--d-fast) var(--ease-snap);
}
.header-lang:hover { color: var(--c-accent); border-color: var(--c-accent); }
.header-cta {
  font-family: var(--font-mono);
  font-size: var(--t-mono-xs);
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  padding: 12px 18px;
  background: var(--c-text);
  color: var(--c-bg-0);
  position: relative;
  overflow: hidden;
  transition: transform var(--d-fast) var(--ease-snap);
}
.header-cta::after {
  content: '→'; margin-left: 8px;
  display: inline-block;
  transition: transform var(--d-med) var(--ease-snap);
}
.header-cta:hover { background: var(--c-accent); transform: translateY(-1px); }
.header-cta:hover::after { transform: translateX(4px); }
.mobile-menu-btn { display: none; background: none; border: 0; color: var(--c-text); padding: 4px; }
@media (max-width: 980px) {
  .header-nav { display: none; position: absolute; top: 100%; left: 0; right: 0;
    background: var(--c-bg-0); flex-direction: column; align-items: stretch;
    padding: var(--s-3); gap: var(--s-2); border-bottom: 1px solid var(--c-line);
    box-shadow: 0 12px 40px rgba(15,15,15,0.06);
    max-height: calc(100vh - 60px); overflow-y: auto; }
  .header-nav.open { display: flex; }
  .nav-link, .nav-trigger { padding: 12px 8px; text-align: left; }
  .nav-panel { position: static; opacity: 1; visibility: visible; transform: none;
    border: 0; padding: 0 0 0 var(--s-3); margin-top: var(--s-2); box-shadow: none; }
  /* Cloned CTA + lang inside the mobile nav overlay */
  .nav-mobile-actions { display: flex; flex-direction: column; gap: var(--s-2);
    margin-top: var(--s-3); padding-top: var(--s-3);
    border-top: 1px solid var(--c-line); }
  .nav-mobile-actions .header-cta { display: block; text-align: center;
    padding: 14px 18px; }
  .nav-mobile-actions .header-lang { display: inline-flex; width: fit-content;
    align-self: flex-start; }
  /* Hide the desktop CTA + lang from the header-right */
  .header-right > .header-cta,
  .header-right > .header-lang { display: none; }
  .mobile-menu-btn { display: block; margin-left: auto; }
}

/* ============== HERO ============== */
.hero {
  position: relative;
  display: grid;
  grid-template-columns: 1fr 1.1fr;
  align-items: center;
  padding: var(--s-6) var(--gutter);
  border-bottom: 1px solid var(--c-line);
  gap: var(--s-6);
  min-height: clamp(540px, 72vh, 680px);
}
.hero-content { position: relative; z-index: 2; }
.hero-meta {
  display: flex; gap: var(--s-4); align-items: center;
  margin-bottom: var(--s-4);
  flex-wrap: wrap;
}
.hero-h1 {
  font-size: var(--t-display-xl);
  font-weight: 500;
  letter-spacing: -0.04em;
  line-height: 1;
  margin: 0 0 var(--s-4);
  max-width: 16ch;
  color: var(--c-text);
}
.hero-h1 em {
  font-family: var(--font-serif);
  font-style: italic;
  color: var(--c-accent);
  font-weight: 400;
  letter-spacing: -0.03em;
}
.hero-sub {
  font-size: var(--t-body-lg);
  color: var(--c-text-mute);
  max-width: 44ch;
  line-height: 1.5;
  margin: 0 0 var(--s-4);
}
.hero-sub strong { color: var(--c-text); font-weight: 600; }
.hero-sub em.guarantee {
  display: inline-block;
  font-style: normal;
  background: var(--c-text); color: var(--c-bg-0);
  padding: 2px 8px; font-weight: 600;
  font-family: var(--font-mono);
  font-size: 13px;
  letter-spacing: 0.04em;
}
.hero-actions {
  display: flex; gap: var(--s-3); align-items: center; flex-wrap: wrap;
}
.btn-primary {
  display: inline-flex; align-items: center; gap: var(--s-3);
  padding: 16px 24px;
  background: var(--c-accent); color: var(--c-bg-1);
  font-family: var(--font-mono);
  font-weight: 700;
  font-size: var(--t-mono-md);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  transition: transform var(--d-fast) var(--ease-snap);
}
.btn-primary::after {
  content: '→';
  transition: transform var(--d-med) var(--ease-snap);
}
.btn-primary:hover { transform: translateY(-2px); box-shadow: 0 12px 32px var(--c-accent-glow); }
.btn-primary:hover::after { transform: translateX(6px); }
.btn-ghost {
  display: inline-flex; align-items: center; gap: var(--s-3);
  padding: 16px 24px;
  background: transparent; color: var(--c-text);
  border: 1px solid var(--c-text);
  font-family: var(--font-mono);
  font-weight: 700;
  font-size: var(--t-mono-md);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  transition: all var(--d-fast) var(--ease-snap);
}
.btn-ghost:hover { background: var(--c-text); color: var(--c-bg-0); }

/* === Trust strip inline (under hero CTA) — 4 mini proof points === */
.trust-strip {
  display: grid; grid-template-columns: repeat(4, auto);
  gap: var(--s-5); margin-top: var(--s-5);
  padding-top: var(--s-4);
  border-top: 1px solid var(--c-line);
  align-items: center;
}
.trust-item {
  display: flex; flex-direction: column; gap: 2px;
  font-family: var(--font-mono);
  letter-spacing: 0.04em;
}
.trust-item .v {
  font-family: var(--font-display);
  font-size: 22px; font-weight: 600;
  color: var(--c-text); letter-spacing: -0.02em;
  line-height: 1;
}
.trust-item .v sup {
  font-family: var(--font-mono);
  font-size: 0.5em; color: var(--c-accent);
  font-weight: 400; vertical-align: top;
  margin-left: 2px;
}
.trust-item .l {
  font-size: 10px; color: var(--c-text-faint);
  text-transform: uppercase; letter-spacing: 0.14em;
  margin-top: 4px;
}
@media (max-width: 720px) {
  .trust-strip { grid-template-columns: repeat(2, 1fr); gap: var(--s-3) var(--s-4); }
}

/* === Hero visual: video player + frame === */
.hero-visual {
  position: relative;
  align-self: center;
  display: flex; align-items: center; justify-content: center;
  background: var(--c-bg-1);
  border: 1px solid var(--c-line);
  overflow: hidden;
  aspect-ratio: 16/10; /* matcha il video Veo 1920x1200 */
  width: 100%;
  max-width: 100%;
}
.hero-visual video,
.hero-visual img {
  width: 100%; height: 100%;
  object-fit: contain; /* video INTERO visibile, niente crop */
  position: absolute; inset: 0;
  background: var(--c-bg-1);
}
.hero-visual .corner {
  position: absolute; width: 14px; height: 14px;
  border: 1px solid var(--c-text);
  z-index: 2;
}
.hero-visual .corner.tl { top: 12px; left: 12px; border-right: 0; border-bottom: 0; }
.hero-visual .corner.tr { top: 12px; right: 12px; border-left: 0; border-bottom: 0; }
.hero-visual .corner.bl { bottom: 12px; left: 12px; border-right: 0; border-top: 0; }
.hero-visual .corner.br { bottom: 12px; right: 12px; border-left: 0; border-top: 0; }
.hero-visual .live-tag {
  position: absolute; top: 18px; right: 18px;
  font-family: var(--font-mono); font-size: 10px;
  letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--c-text); background: rgba(248,247,244,0.92);
  padding: 5px 9px; backdrop-filter: blur(4px);
  z-index: 2;
  display: inline-flex; align-items: center; gap: 6px;
}
.hero-visual .live-tag::before {
  content: ''; width: 6px; height: 6px; border-radius: 50%;
  background: var(--c-live); animation: live-pulse 1.6s var(--ease-snap) infinite;
}

@media (max-width: 980px) {
  .hero { grid-template-columns: 1fr; min-height: 0; padding-top: var(--s-5); }
  .hero-visual { aspect-ratio: 16/10; min-height: 280px; }
  .hero-h1 { max-width: 100%; }
}

/* === Logos strip (sotto hero, fascia client trust) === */
.logos-strip {
  background: var(--c-bg-1);
  border-bottom: 1px solid var(--c-line);
  padding: var(--s-5) var(--gutter);
}
.logos-inner {
  max-width: 1440px; margin: 0 auto;
  display: grid;
  grid-template-columns: 200px 1fr;
  gap: var(--s-5);
  align-items: center;
}
.logos-label {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--c-text-faint);
}
.logos-list {
  display: grid;
  grid-template-columns: repeat(9, 1fr);
  gap: var(--s-5);
  align-items: center;
}
.logos-list .logo-slot {
  height: 36px;
  display: flex; align-items: center; justify-content: center;
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--c-text-faint);
  border: 1px dashed var(--c-line);
  padding: 0 var(--s-2);
  opacity: 0.7;
  transition: opacity var(--d-fast);
}
.logos-list .logo-slot:hover { opacity: 1; color: var(--c-text); border-color: var(--c-line-strong); }
.logos-list img {
  max-height: 36px; width: auto;
  filter: grayscale(1) brightness(0.4);
  opacity: 0.7;
  transition: opacity var(--d-fast), filter var(--d-fast);
}
.logos-list a:hover img { opacity: 1; filter: grayscale(0) brightness(1); }
@media (max-width: 1280px) {
  .logos-list { grid-template-columns: repeat(5, 1fr); row-gap: var(--s-4); }
}
@media (max-width: 980px) {
  .logos-inner { grid-template-columns: 1fr; gap: var(--s-3); }
  .logos-list { grid-template-columns: repeat(3, 1fr); gap: var(--s-3); row-gap: var(--s-3); }
  .logos-list .logo-slot { display: none; }
}

/* ============== HERO STATS BAR (under hero) ============== */
.hero-stats-bar {
  display: grid; grid-template-columns: repeat(4, 1fr);
  border-top: 1px solid var(--c-line);
  border-bottom: 1px solid var(--c-line);
  background: var(--c-bg-1);
}
.hero-stat {
  padding: var(--s-5) var(--s-5);
  border-right: 1px solid var(--c-line);
  position: relative;
}
.hero-stat:last-child { border-right: 0; }
.hero-stat .label {
  font-family: var(--font-mono);
  font-size: var(--t-mono-xs);
  letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--c-text-faint);
  margin-bottom: var(--s-2);
}
.hero-stat .value {
  font-family: var(--font-display);
  font-size: clamp(32px, 3.6vw, 56px);
  font-weight: 500; letter-spacing: -0.04em;
  color: var(--c-text); line-height: 1;
}
.hero-stat .value sup {
  font-family: var(--font-mono);
  font-size: 0.32em; color: var(--c-accent);
  font-weight: 400; vertical-align: top;
  margin-left: 4px; letter-spacing: 0;
}
.hero-stat .delta {
  font-family: var(--font-mono);
  font-size: var(--t-mono-xs);
  color: var(--c-live);
  margin-top: var(--s-2);
  letter-spacing: 0.08em;
}
@media (max-width: 980px) {
  .hero-stats-bar { grid-template-columns: 1fr 1fr; }
  .hero-stat:nth-child(2) { border-right: 0; }
  .hero-stat:nth-child(1), .hero-stat:nth-child(2) { border-bottom: 1px solid var(--c-line); }
}

/* (ticker rimosso v3 — non utilizzato in nessuna pagina) */

/* ============== SERVICES GRID ============== */
.services-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  border-top: 1px solid var(--c-line);
  border-left: 1px solid var(--c-line);
}
.service-card {
  display: flex; flex-direction: column;
  border-right: 1px solid var(--c-line);
  border-bottom: 1px solid var(--c-line);
  background: var(--c-bg-1);
  transition: background var(--d-med) var(--ease-snap);
  position: relative;
  overflow: hidden;
}
.service-card:hover { background: var(--c-bg-2); }
.service-card .img-wrap {
  aspect-ratio: 4/3;
  overflow: hidden;
  position: relative;
  background: var(--c-bg-0);
  border-bottom: 1px solid var(--c-line);
}
.service-card .img-wrap img {
  width: 100%; height: 100%; object-fit: cover;
  transition: transform var(--d-slow) var(--ease-snap);
}
.service-card:hover .img-wrap img { transform: scale(1.04); }
.service-card .body {
  padding: var(--s-5) var(--s-5) var(--s-6);
  display: flex; flex-direction: column;
  flex: 1;
}
.service-num {
  font-family: var(--font-mono);
  font-size: var(--t-mono-xs);
  color: var(--c-text-faint);
  letter-spacing: 0.16em;
  margin-bottom: var(--s-3);
  display: flex; justify-content: space-between;
}
.service-num .arrow {
  color: var(--c-accent); opacity: 0;
  transform: translateX(-6px);
  transition: all var(--d-med) var(--ease-snap);
}
.service-card:hover .service-num .arrow { opacity: 1; transform: translateX(0); }
.service-title {
  font-size: 22px;
  font-weight: 500;
  letter-spacing: -0.025em;
  margin-bottom: var(--s-3);
  line-height: 1.15;
}
.service-desc {
  color: var(--c-text-mute);
  font-size: var(--t-body-sm);
  margin-bottom: var(--s-4);
  line-height: 1.45;
}
.service-meta {
  font-family: var(--font-mono);
  font-size: var(--t-mono-xs);
  letter-spacing: 0.1em;
  color: var(--c-text-faint);
  text-transform: uppercase;
  margin-top: auto;
}
.service-meta span { margin-right: var(--s-3); }

@media (max-width: 980px) { .services-grid { grid-template-columns: 1fr; } }
@media (min-width: 981px) and (max-width: 1280px) { .services-grid { grid-template-columns: repeat(2, 1fr); } }

/* ============== KPI BLOCK ============== */
.kpi-row {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--s-5);
  padding: var(--s-7) 0;
  border-top: 1px solid var(--c-line);
  border-bottom: 1px solid var(--c-line);
}
.kpi { display: flex; flex-direction: column; gap: var(--s-2); }
.kpi .v {
  font-family: var(--font-display);
  font-size: clamp(40px, 5vw, 80px);
  font-weight: 500; letter-spacing: -0.05em;
  line-height: 0.95; color: var(--c-text);
}
.kpi .v sup {
  font-family: var(--font-mono);
  font-size: 0.32em; color: var(--c-accent);
  font-weight: 400; vertical-align: top;
  margin-left: 4px; letter-spacing: 0;
}
.kpi .l {
  font-family: var(--font-mono);
  font-size: var(--t-mono-xs);
  letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--c-text-faint);
}
@media (max-width: 980px) { .kpi-row { grid-template-columns: repeat(2, 1fr); } }

/* ============== PROCESS STEPS ============== */
.process {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--s-5);
  position: relative;
}
.process::before {
  content: ''; position: absolute;
  top: 60px; left: 24px; right: 24px; height: 1px;
  background-image: repeating-linear-gradient(to right, var(--c-line-strong) 0, var(--c-line-strong) 6px, transparent 6px, transparent 14px);
}
.step {
  position: relative;
  background: var(--c-bg-1);
  padding: var(--s-5);
  border: 1px solid var(--c-line);
  position: relative;
  z-index: 1;
}
.step .step-img {
  aspect-ratio: 4/3;
  background: var(--c-bg-0);
  border: 1px solid var(--c-line);
  margin-bottom: var(--s-4);
  overflow: hidden;
}
.step .step-img img { width: 100%; height: 100%; object-fit: cover; }
.step .step-marker {
  font-family: var(--font-mono);
  font-size: var(--t-mono-xs);
  letter-spacing: 0.16em;
  color: var(--c-text-faint);
  margin-bottom: var(--s-2);
  display: flex; gap: var(--s-3); align-items: center;
}
.step .step-marker .num {
  color: var(--c-accent); font-weight: 700;
}
.step h3 {
  font-size: 20px; letter-spacing: -0.02em;
  margin: 0 0 var(--s-3);
}
.step ul {
  list-style: none; padding: 0; margin: 0;
  font-size: var(--t-body-sm);
  color: var(--c-text-mute);
}
.step ul li {
  padding-left: var(--s-3); position: relative;
  margin-bottom: 6px;
}
.step ul li::before {
  content: '—'; position: absolute; left: 0; color: var(--c-text-faint);
}
@media (max-width: 980px) { .process { grid-template-columns: 1fr; } .process::before { display: none; } }

/* ============== EDITORIAL QUOTE ============== */
.editorial {
  position: relative;
  padding: var(--s-9) 0;
  background: var(--c-bg-1);
  overflow: hidden;
  border-top: 1px solid var(--c-line);
  border-bottom: 1px solid var(--c-line);
}
.editorial-bg {
  position: absolute; inset: 0;
  background-size: cover; background-position: center;
  opacity: 0.18;
  z-index: 0;
}
.editorial > .container { position: relative; z-index: 1; }
.editorial-quote {
  font-family: var(--font-serif);
  font-size: clamp(36px, 5vw, 84px);
  line-height: 1.05; letter-spacing: -0.02em;
  font-weight: 400;
  max-width: 22ch;
  color: var(--c-text);
}
.editorial-quote span { color: var(--c-accent); font-style: italic; }
.editorial-attr {
  font-family: var(--font-mono);
  font-size: var(--t-mono-sm);
  letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--c-text-faint);
  margin-top: var(--s-6);
  display: flex; align-items: center; gap: var(--s-3);
}
.editorial-attr::before {
  content: ''; width: 32px; height: 1px; background: var(--c-text-faint);
}

/* ============== CASE STUDIES ============== */
.case-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--s-5);
}
.case-card {
  background: var(--c-bg-1);
  border: 1px solid var(--c-line);
  display: flex; flex-direction: column;
  transition: all var(--d-med) var(--ease-snap);
  position: relative;
}
.case-card:hover { border-color: var(--c-text); transform: translateY(-2px); box-shadow: 0 16px 40px rgba(15,15,15,0.06); }
.case-card .cover {
  aspect-ratio: 4/3;
  background: var(--c-bg-0);
  border-bottom: 1px solid var(--c-line);
  overflow: hidden;
}
.case-card .cover img {
  object-fit: contain !important;
  background: var(--c-bg-0);
}
.case-card .cover img { width: 100%; height: 100%; object-fit: cover; }
.case-card .body { padding: var(--s-5); display: flex; flex-direction: column; flex: 1; }
.case-card .meta {
  font-family: var(--font-mono); font-size: var(--t-mono-xs);
  color: var(--c-text-faint); letter-spacing: 0.12em;
  margin-bottom: var(--s-3);
  display: flex; justify-content: space-between;
}
.case-card .headline {
  font-family: var(--font-display);
  font-size: 22px; line-height: 1.15;
  margin: 0 0 var(--s-3); letter-spacing: -0.02em;
  color: var(--c-text);
}
.case-card .pull {
  font-family: var(--font-serif);
  font-size: clamp(28px, 3vw, 40px);
  line-height: 1; letter-spacing: -0.02em;
  color: var(--c-accent);
  margin-bottom: var(--s-3);
}
.case-card .desc {
  color: var(--c-text-mute); font-size: var(--t-body-sm);
  margin: 0 0 var(--s-4);
}
.case-card .read {
  font-family: var(--font-mono); font-size: var(--t-mono-xs);
  color: var(--c-text); letter-spacing: 0.12em;
  margin-top: auto;
}
.case-card:hover .read { color: var(--c-accent); }
@media (max-width: 980px) { .case-grid { grid-template-columns: 1fr; } }

/* ============== FOOTER ============== */
.site-footer {
  background: var(--c-bg-dark);
  color: var(--c-bg-0);
  padding: var(--s-9) 0 var(--s-5);
}
.footer-grid {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr 1fr;
  gap: var(--s-6);
  margin-bottom: var(--s-7);
}
.footer-brand .footer-logo {
  display: inline-flex; align-items: center; margin-bottom: var(--s-3);
}
.footer-brand .footer-logo img {
  height: 36px; width: auto; display: block;
  /* niente filter hack: usiamo storm-x-mono.svg con bianco già nel SVG */
}
.footer-brand .footer-logo .dot { display: none; }
.footer-brand .tagline {
  font-family: var(--font-serif); font-size: 24px; line-height: 1.2;
  color: var(--c-bg-0); max-width: 28ch; margin-top: var(--s-3);
}
.footer-col h4 {
  font-family: var(--font-mono); font-size: var(--t-mono-xs);
  letter-spacing: 0.16em; text-transform: uppercase;
  color: rgba(248,247,244,0.5); margin-bottom: var(--s-4); font-weight: 500;
}
.footer-col ul { list-style: none; padding: 0; margin: 0; }
.footer-col li { margin-bottom: var(--s-2); }
.footer-col a {
  font-size: var(--t-body-sm); color: rgba(248,247,244,0.75);
  transition: color var(--d-fast);
}
.footer-col a:hover { color: var(--c-accent); }
.footer-meta {
  display: flex; justify-content: space-between; align-items: center;
  padding-top: var(--s-4); border-top: 1px solid rgba(248,247,244,0.12);
  font-family: var(--font-mono); font-size: var(--t-mono-xs);
  letter-spacing: 0.12em; color: rgba(248,247,244,0.5);
}
.footer-meta .live {
  display: inline-flex; align-items: center; gap: var(--s-2); color: var(--c-live);
}
.footer-meta .live::before {
  content: ''; width: 6px; height: 6px; border-radius: 50%; background: var(--c-live);
  animation: live-pulse 1.6s var(--ease-snap) infinite;
}
@media (max-width: 980px) { .footer-grid { grid-template-columns: 1fr 1fr; } }

/* ============== ANIMATIONS ============== */
.reveal {
  opacity: 0; transform: translateY(16px);
  transition: opacity 800ms var(--ease-snap), transform 800ms var(--ease-snap);
}
.reveal.in { opacity: 1; transform: translateY(0); }
.reveal-stagger > * { opacity: 0; transform: translateY(12px); }
.reveal-stagger.in > * { opacity: 1; transform: translateY(0); transition: opacity 600ms var(--ease-snap), transform 600ms var(--ease-snap); }
.reveal-stagger.in > *:nth-child(1) { transition-delay: 0ms; }
.reveal-stagger.in > *:nth-child(2) { transition-delay: 80ms; }
.reveal-stagger.in > *:nth-child(3) { transition-delay: 160ms; }
.reveal-stagger.in > *:nth-child(4) { transition-delay: 240ms; }
.reveal-stagger.in > *:nth-child(5) { transition-delay: 320ms; }
.reveal-stagger.in > *:nth-child(6) { transition-delay: 400ms; }

/* ============== PAGE HEAD ============== */
.page-head {
  padding: var(--s-7) 0 var(--s-6);
  border-bottom: 1px solid var(--c-line);
}
.breadcrumb {
  font-family: var(--font-mono); font-size: var(--t-mono-xs);
  letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--c-text-faint); margin-bottom: var(--s-5);
}
.breadcrumb a { color: var(--c-text-mute); }
.breadcrumb a:hover { color: var(--c-accent); }
.breadcrumb .sep { color: var(--c-text-faint); margin: 0 var(--s-2); }
.page-title {
  font-size: var(--t-display-lg);
  letter-spacing: -0.05em; line-height: 0.95;
  max-width: 18ch; margin: 0; color: var(--c-text);
}
.page-title em { font-family: var(--font-serif); font-style: italic; color: var(--c-accent); font-weight: 400; }

/* Mobile: stack any 2-col inline grid in page-head to single column */
@media (max-width: 720px) {
  .page-head { padding: var(--s-6) 0 var(--s-5); }
  .page-head [style*="grid-template-columns"] {
    grid-template-columns: 1fr !important;
    gap: var(--s-5) !important;
    align-items: stretch !important;
  }
  .page-head .page-title { max-width: none; font-size: clamp(36px, 9vw, 56px); }
  .page-head .page-title em { display: inline; }
  /* Visual block (image/diagram) on mobile: cap height + add margin */
  .page-head [style*="aspect-ratio"] { max-height: 280px; }

  /* Also stack inline 2-col grids in content sections (case studies etc.) */
  .section > .container > [style*="grid-template-columns: 1fr 1fr"],
  .section > .container > [style*="grid-template-columns: 1.4fr 1fr"] {
    grid-template-columns: 1fr !important;
    gap: var(--s-5) !important;
    align-items: stretch !important;
  }
}

/* ============== SERVICE PAGE: TILE GRID ============== */
.tile-grid {
  display: grid; grid-template-columns: repeat(3, 1fr);
  border-top: 1px solid var(--c-line);
  border-left: 1px solid var(--c-line);
  background: var(--c-bg-1);
}
.tile {
  padding: var(--s-6);
  border-right: 1px solid var(--c-line);
  border-bottom: 1px solid var(--c-line);
}
.tile .tile-num {
  font-family: var(--font-mono); font-size: var(--t-mono-xs);
  letter-spacing: 0.16em; color: var(--c-accent);
  margin-bottom: var(--s-3);
}
.tile h3 { font-size: 20px; margin: 0 0 var(--s-2); letter-spacing: -0.02em; }
.tile p { color: var(--c-text-mute); font-size: var(--t-body-sm); margin: 0; }
@media (max-width: 980px) { .tile-grid { grid-template-columns: 1fr; } }
@media (min-width: 981px) and (max-width: 1280px) { .tile-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 720px) {
  .tile { padding: var(--s-4); border-right: 0; }
  .tile-grid { border-left: 0; }
  .tile h3 { font-size: 18px; }
}

/* ============== FAQ ============== */
.faq { display: grid; gap: var(--s-2); }
.faq details {
  border: 1px solid var(--c-line);
  background: var(--c-bg-1);
  padding: var(--s-4) var(--s-5);
}
.faq summary {
  font-family: var(--font-display);
  font-size: 20px;
  cursor: pointer; list-style: none;
  display: flex; justify-content: space-between; align-items: center;
  letter-spacing: -0.02em;
}
.faq summary::-webkit-details-marker { display: none; }
.faq summary::after { content: '+'; font-family: var(--font-mono); color: var(--c-accent); font-size: 24px; transition: transform var(--d-fast); }
.faq details[open] summary::after { transform: rotate(45deg); }
.faq p { color: var(--c-text-mute); font-size: var(--t-body-sm); margin: var(--s-3) 0 0; }

/* ============================================================
   PARADIGM SHIFT — sezione protagonist outbound multicanale
   Il servizio CORE, full-bleed, con i 4 canali coordinati
   ============================================================ */
.paradigm {
  background: var(--c-bg-dark);
  color: var(--c-bg-0);
  padding: var(--s-9) 0;
  position: relative;
  overflow: hidden;
  border-top: 1px solid var(--c-line);
  border-bottom: 1px solid var(--c-line);
}
.paradigm-inner {
  max-width: 1440px; margin: 0 auto;
  padding: 0 var(--gutter);
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--s-7);
  align-items: center;
}
.paradigm-content .num {
  font-family: var(--font-mono); font-size: var(--t-mono-sm);
  letter-spacing: 0.16em; color: var(--c-accent);
  margin-bottom: var(--s-4);
  display: inline-flex; align-items: center; gap: var(--s-2);
}
.paradigm-content .num::before {
  content: ''; width: 24px; height: 1px; background: var(--c-accent);
}
.paradigm-content h2 {
  font-size: clamp(36px, 4.5vw, 64px);
  letter-spacing: -0.04em; line-height: 1.02;
  margin: 0 0 var(--s-4); color: var(--c-bg-0);
  max-width: 16ch;
}
.paradigm-content h2 em {
  font-family: var(--font-serif); font-style: italic;
  color: var(--c-accent); font-weight: 400;
}
.paradigm-content .lede {
  font-size: var(--t-body-lg); line-height: 1.55;
  color: rgba(248,247,244,0.8);
  max-width: 50ch; margin: 0 0 var(--s-5);
}
.paradigm-content .lede strong { color: var(--c-bg-0); font-weight: 600; }

.paradigm-channels {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--s-3);
  margin-top: var(--s-5);
}
.channel {
  border: 1px solid rgba(248,247,244,0.18);
  padding: var(--s-4) var(--s-3);
  position: relative;
  transition: all var(--d-fast) var(--ease-snap);
}
.channel:hover {
  border-color: var(--c-accent);
  background: rgba(255,85,0,0.06);
}
.channel .ch-num {
  font-family: var(--font-mono); font-size: 10px;
  letter-spacing: 0.16em; color: var(--c-accent);
  margin-bottom: var(--s-2);
}
.channel h4 {
  font-family: var(--font-display); font-size: 17px;
  font-weight: 600; letter-spacing: -0.02em;
  color: var(--c-bg-0); margin: 0 0 6px;
}
.channel p {
  font-size: 12px; color: rgba(248,247,244,0.6);
  margin: 0; line-height: 1.4;
}
@media (max-width: 720px) {
  .paradigm-channels { grid-template-columns: repeat(2, 1fr); }
}

.paradigm-visual {
  position: relative;
  aspect-ratio: 1/1;
  background: rgba(248,247,244,0.02);
  border: 1px solid rgba(248,247,244,0.12);
  overflow: hidden;
  display: grid; place-items: center;
}
.paradigm-visual .corner {
  position: absolute; width: 14px; height: 14px;
  border: 1px solid var(--c-accent); z-index: 2;
}
.paradigm-visual .corner.tl { top: 12px; left: 12px; border-right: 0; border-bottom: 0; }
.paradigm-visual .corner.tr { top: 12px; right: 12px; border-left: 0; border-bottom: 0; }
.paradigm-visual .corner.bl { bottom: 12px; left: 12px; border-right: 0; border-top: 0; }
.paradigm-visual .corner.br { bottom: 12px; right: 12px; border-left: 0; border-top: 0; }
.paradigm-visual .schema-tag {
  position: absolute; bottom: 18px; left: 18px;
  font-family: var(--font-mono); font-size: 10px;
  letter-spacing: 0.16em; text-transform: uppercase;
  color: rgba(248,247,244,0.6);
  padding: 5px 9px;
}

/* === SVG diagram: 4 nodi (canali) → centro orange (TE) === */
.channel-diagram {
  width: 78%; height: 78%;
  position: relative;
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  grid-template-rows: 1fr 1fr 1fr;
  gap: 0;
}
.channel-diagram .node {
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  gap: 6px; position: relative; z-index: 2;
}
.channel-diagram .node .icon {
  width: 56px; height: 56px;
  border: 1px solid rgba(248,247,244,0.4);
  background: var(--c-bg-dark);
  display: grid; place-items: center;
  color: rgba(248,247,244,0.85);
  transition: all var(--d-fast) var(--ease-snap);
}
.channel-diagram .node .label {
  font-family: var(--font-mono); font-size: 10px;
  letter-spacing: 0.16em; text-transform: uppercase;
  color: rgba(248,247,244,0.55);
}
.channel-diagram .node:hover .icon {
  border-color: var(--c-accent);
  color: var(--c-accent);
  transform: scale(1.05);
}
.channel-diagram .node:hover .label { color: var(--c-accent); }
.channel-diagram .node.n-email { grid-column: 1; grid-row: 1; }
.channel-diagram .node.n-linkedin { grid-column: 3; grid-row: 1; }
.channel-diagram .node.n-whatsapp { grid-column: 1; grid-row: 3; }
.channel-diagram .node.n-phone { grid-column: 3; grid-row: 3; }
.channel-diagram .center {
  grid-column: 2; grid-row: 2;
  display: grid; place-items: center;
  position: relative; z-index: 3;
}
.channel-diagram .center .diamond {
  width: 84px; height: 84px;
  background: var(--c-accent);
  transform: rotate(45deg);
  display: grid; place-items: center;
  box-shadow: 0 0 60px rgba(255,85,0,0.5);
}
.channel-diagram .center .diamond span {
  transform: rotate(-45deg);
  font-family: var(--font-mono); font-size: 14px;
  font-weight: 700; letter-spacing: 0.1em;
  color: var(--c-bg-dark);
}
.channel-diagram .lines {
  position: absolute; inset: 0;
  z-index: 1; pointer-events: none;
}
.channel-diagram .lines line {
  stroke: rgba(248,247,244,0.25);
  stroke-width: 1;
  stroke-dasharray: 4 4;
  animation: dash-flow 6s linear infinite;
}
.channel-diagram .lines line.live {
  stroke: var(--c-accent);
  stroke-width: 1.5;
  stroke-dasharray: 6 4;
}
@keyframes dash-flow {
  to { stroke-dashoffset: -40; }
}

.paradigm-quote {
  font-family: var(--font-serif);
  font-size: clamp(22px, 2.4vw, 32px);
  line-height: 1.3; letter-spacing: -0.01em;
  color: var(--c-bg-0);
  margin-top: var(--s-7);
  padding-top: var(--s-5);
  border-top: 1px solid rgba(248,247,244,0.15);
  max-width: 60ch;
}
.paradigm-quote .author {
  display: block; margin-top: var(--s-3);
  font-family: var(--font-mono); font-size: var(--t-mono-sm);
  letter-spacing: 0.12em; text-transform: uppercase;
  color: rgba(248,247,244,0.55); font-style: normal;
}

@media (max-width: 980px) {
  .paradigm-inner { grid-template-columns: 1fr; }
}

/* ============================================================
   COMPLEMENTARY SERVICES — quando outbound è il protagonista
   ============================================================ */
.complementary-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  border-top: 1px solid var(--c-line);
  border-left: 1px solid var(--c-line);
}
.complementary-card {
  background: var(--c-bg-1);
  border-right: 1px solid var(--c-line);
  border-bottom: 1px solid var(--c-line);
  padding: var(--s-5);
  display: flex; flex-direction: column;
  transition: background var(--d-med) var(--ease-snap);
}
.complementary-card:hover { background: var(--c-bg-2); }
.complementary-card .icon-frame {
  aspect-ratio: 1/1;
  background: var(--c-bg-0);
  border: 1px solid var(--c-line);
  margin-bottom: var(--s-4);
  overflow: hidden;
}
.complementary-card .icon-frame img {
  width: 100%; height: 100%; object-fit: contain; padding: 8px;
}
.complementary-card .num {
  font-family: var(--font-mono); font-size: 10px;
  letter-spacing: 0.16em; color: var(--c-text-faint);
  margin-bottom: var(--s-2);
}
.complementary-card h3 {
  font-size: 17px; font-weight: 600;
  letter-spacing: -0.02em; margin: 0 0 var(--s-2);
}
.complementary-card p {
  color: var(--c-text-mute); font-size: 13px;
  line-height: 1.45; margin: 0;
}
@media (max-width: 980px) { .complementary-grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 540px) { .complementary-grid { grid-template-columns: 1fr; } }

/* ============================================================
   LOGOS strip — supporto immagini reali (oltre al placeholder)
   ============================================================ */
.logos-list a {
  display: flex; align-items: center; justify-content: center;
  height: 36px; padding: 0 var(--s-2);
  text-decoration: none;
}

/* ============================================================
   TEAM SECTION — "L'Infrastruttura Umana"
   4 senior, foto B&N che diventano colore in hover, superpower in reveal
   ============================================================ */
.team {
  padding: var(--s-9) 0;
  border-top: 1px solid var(--c-line);
}
.team-head {
  display: grid;
  grid-template-columns: 120px 1fr;
  gap: var(--s-4);
  margin-bottom: var(--s-7);
  align-items: end;
  padding: 0 var(--gutter);
  max-width: 1440px; margin-left: auto; margin-right: auto;
}
.team-head .num {
  font-family: var(--font-mono); font-size: var(--t-mono-sm);
  letter-spacing: 0.16em; color: var(--c-text-faint);
}
.team-head .heading h2 {
  font-size: var(--t-display-md);
  letter-spacing: -0.04em;
  margin: 0 0 var(--s-3);
  max-width: 14ch;
}
.team-head .heading p {
  font-size: var(--t-body-lg);
  color: var(--c-text-mute);
  margin: 0;
  max-width: 60ch;
}
.team-head .heading p strong { color: var(--c-text); font-weight: 600; }

.team-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--s-4);
  padding: 0 var(--gutter);
  max-width: 1440px; margin: 0 auto;
}
.team-card {
  position: relative;
  display: flex; flex-direction: column;
}
.team-card .portrait {
  aspect-ratio: 1/1;
  background: var(--c-bg-2);
  border: 1px solid var(--c-line);
  overflow: hidden;
  position: relative;
  margin-bottom: var(--s-4);
  transition: border-color var(--d-med) var(--ease-snap);
}
.team-card:hover .portrait { border-color: var(--c-accent); }
.team-card .portrait img {
  width: 100%; height: 100%; object-fit: cover;
  filter: grayscale(100%);
  transition: filter var(--d-slow) var(--ease-snap), transform var(--d-slow) var(--ease-snap);
}
.team-card:hover .portrait img {
  filter: grayscale(0%);
  transform: scale(1.03);
}
.team-card .portrait::after {
  content: ''; position: absolute; inset: 0;
  background: linear-gradient(180deg, transparent 60%, rgba(15,15,15,0.6) 100%);
  opacity: 0;
  transition: opacity var(--d-med) var(--ease-snap);
}
.team-card:hover .portrait::after { opacity: 1; }

.team-card .portrait .linkedin-cta {
  position: absolute; bottom: 12px; right: 12px;
  width: 36px; height: 36px;
  background: var(--c-accent); color: var(--c-bg-1);
  display: grid; place-items: center;
  opacity: 0; transform: translateY(8px);
  transition: opacity var(--d-med) var(--ease-snap), transform var(--d-med) var(--ease-snap);
  z-index: 2;
}
.team-card:hover .linkedin-cta { opacity: 1; transform: translateY(0); }
.team-card .linkedin-cta svg { width: 18px; height: 18px; }

.team-card h3 {
  font-family: var(--font-display);
  font-size: 19px; font-weight: 600;
  letter-spacing: -0.02em;
  margin: 0 0 4px;
  color: var(--c-text);
  transition: color var(--d-fast);
}
.team-card:hover h3 { color: var(--c-accent); }
.team-card .role {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--c-accent);
  font-weight: 600;
  margin: 0 0 var(--s-3);
}
.team-card .superpower {
  font-size: 13px;
  color: var(--c-text-mute);
  line-height: 1.5;
  margin: 0;
}

@media (max-width: 980px) {
  .team-grid { grid-template-columns: repeat(2, 1fr); }
  .team-head { grid-template-columns: 1fr; }
}
@media (max-width: 540px) {
  .team-grid { grid-template-columns: 1fr; }
}

/* ============================================================
   WHATSAPP PROTOCOL — sezione approfondimento outbound
   Replica fedele del chat mockup del sito di produzione
   ============================================================ */
.whatsapp-protocol {
  background: var(--c-bg-dark);
  color: var(--c-bg-0);
  padding: var(--s-9) 0;
  position: relative;
  overflow: hidden;
}
.wp-inner {
  max-width: 1440px; margin: 0 auto;
  padding: 0 var(--gutter);
  display: grid;
  grid-template-columns: 1.1fr 1fr;
  gap: var(--s-7);
  align-items: center;
}
.wp-content .num {
  font-family: var(--font-mono); font-size: var(--t-mono-sm);
  letter-spacing: 0.16em; color: var(--c-accent);
  margin-bottom: var(--s-4);
  display: inline-flex; align-items: center; gap: var(--s-2);
}
.wp-content .num::before {
  content: ''; width: 24px; height: 1px; background: var(--c-accent);
}
.wp-content h2 {
  font-size: clamp(36px, 4.5vw, 60px);
  letter-spacing: -0.04em; line-height: 1.02;
  margin: 0 0 var(--s-3); color: var(--c-bg-0);
  max-width: 16ch;
}
.wp-content h2 em {
  font-family: var(--font-serif); font-style: italic;
  color: var(--c-accent); font-weight: 400;
}
.wp-content .lede {
  font-family: var(--font-serif);
  font-size: 22px; line-height: 1.4;
  color: rgba(248,247,244,0.75);
  font-style: italic;
  margin: 0 0 var(--s-6); max-width: 50ch;
}

.wp-pillars {
  display: grid; gap: var(--s-4);
  margin-top: var(--s-5);
}
.wp-pillar {
  display: grid;
  grid-template-columns: 40px 1fr;
  gap: var(--s-3);
  padding: var(--s-3) 0;
  border-top: 1px solid rgba(248,247,244,0.12);
}
.wp-pillar:last-child { border-bottom: 1px solid rgba(248,247,244,0.12); }
.wp-pillar .ico {
  width: 32px; height: 32px;
  border: 1px solid var(--c-accent);
  display: grid; place-items: center;
  color: var(--c-accent);
  margin-top: 4px;
}
.wp-pillar h4 {
  font-family: var(--font-display);
  font-size: 16px; font-weight: 600;
  letter-spacing: -0.01em;
  color: var(--c-bg-0); margin: 0 0 4px;
}
.wp-pillar p {
  font-size: 13px; line-height: 1.5;
  color: rgba(248,247,244,0.6); margin: 0;
}

/* === iPhone mockup === */
.iphone-frame {
  width: 100%; max-width: 360px;
  margin: 0 auto;
  aspect-ratio: 9/19;
  background: #000;
  border-radius: 44px;
  padding: 12px;
  position: relative;
  box-shadow: 0 30px 80px rgba(0,0,0,0.6), 0 0 0 1px rgba(248,247,244,0.1) inset;
}
.iphone-screen {
  width: 100%; height: 100%;
  background: #0B141A;  /* WhatsApp dark mode bg */
  border-radius: 32px;
  overflow: hidden;
  position: relative;
  display: flex;
  flex-direction: column;
}
.iphone-frame::before {
  /* Notch */
  content: '';
  position: absolute;
  top: 12px; left: 50%; transform: translateX(-50%);
  width: 110px; height: 28px;
  background: #000;
  border-radius: 20px;
  z-index: 10;
}

/* iOS status bar */
.ios-status {
  height: 44px;
  display: flex; justify-content: space-between; align-items: center;
  padding: 0 22px 0 26px;
  font-family: -apple-system, 'SF Pro Text', system-ui, sans-serif;
  font-size: 15px;
  font-weight: 600;
  color: white;
  position: relative;
  z-index: 5;
}
.ios-status .ios-time { letter-spacing: -0.02em; }
.ios-status .ios-icons {
  display: flex; gap: 6px; align-items: center;
}
.ios-status .ios-icons svg { width: 16px; height: 16px; fill: white; }
.ios-status .battery {
  width: 24px; height: 11px;
  border: 1px solid rgba(255,255,255,0.6);
  border-radius: 3px; padding: 1px;
  position: relative;
}
.ios-status .battery::after {
  content: '';
  position: absolute; right: -3px; top: 3px;
  width: 2px; height: 5px; background: rgba(255,255,255,0.6);
  border-radius: 0 1px 1px 0;
}
.ios-status .battery span {
  display: block;
  width: 75%; height: 100%;
  background: white;
  border-radius: 1px;
}

/* WhatsApp chat header */
.wa-header {
  background: #1F2C34;
  padding: 8px 14px 10px;
  display: flex; align-items: center; gap: 10px;
  border-bottom: 1px solid rgba(255,255,255,0.05);
}
.wa-header .back {
  color: #00A884; font-size: 22px; line-height: 1; padding-right: 4px;
}
.wa-header .avatar {
  width: 36px; height: 36px; border-radius: 50%;
  background: var(--c-accent);
  flex-shrink: 0;
  overflow: hidden;
  display: grid; place-items: center;
}
.wa-header .avatar img {
  width: 100%; height: 100%; object-fit: cover;
}
.wa-header .who {
  flex: 1;
  font-family: -apple-system, 'SF Pro Text', system-ui, sans-serif;
  color: white;
  min-width: 0;
}
.wa-header .name {
  font-size: 15px; font-weight: 600;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.wa-header .status {
  font-size: 12px; color: rgba(255,255,255,0.5);
  margin-top: 1px;
}
.wa-header .actions {
  display: flex; gap: 18px;
  color: white;
  font-size: 18px;
}

/* Chat body */
.wa-body {
  flex: 1;
  background: #0B141A;
  padding: 12px 8px 8px;
  display: flex; flex-direction: column; gap: 6px;
  overflow: hidden;
  position: relative;
}
.wa-body::before {
  /* Subtle WhatsApp pattern */
  content: '';
  position: absolute; inset: 0;
  background-image:
    radial-gradient(circle at 20% 30%, rgba(255,255,255,0.015) 1px, transparent 1px),
    radial-gradient(circle at 80% 70%, rgba(255,255,255,0.015) 1px, transparent 1px);
  background-size: 60px 60px;
  pointer-events: none;
}
.wa-body > * { position: relative; z-index: 1; }

.wa-date {
  align-self: center;
  background: #1F2C34;
  color: rgba(255,255,255,0.7);
  font-family: -apple-system, system-ui, sans-serif;
  font-size: 11px;
  padding: 4px 10px;
  border-radius: 8px;
  margin-bottom: 4px;
  font-weight: 500;
}
.wa-encryption {
  align-self: center;
  text-align: center;
  background: #1A2730;
  color: rgba(255,213,79,0.85);
  font-family: -apple-system, system-ui, sans-serif;
  font-size: 10px;
  line-height: 1.3;
  padding: 6px 14px;
  border-radius: 6px;
  max-width: 80%;
  margin-bottom: 4px;
}

/* Bubbles */
.wa-bubble {
  font-family: -apple-system, 'SF Pro Text', system-ui, sans-serif;
  font-size: 13px;
  line-height: 1.35;
  padding: 6px 9px 4px;
  border-radius: 7px;
  max-width: 78%;
  position: relative;
  word-wrap: break-word;
  opacity: 0;
  transform: translateY(8px);
  animation: bubble-in 0.4s var(--ease-snap) forwards;
}
.wa-bubble.in {
  background: #202C33;
  color: white;
  align-self: flex-start;
  border-top-left-radius: 0;
  animation-delay: var(--delay, 0.5s);
}
.wa-bubble.in::before {
  content: ''; position: absolute; left: -6px; top: 0;
  width: 0; height: 0;
  border-top: 8px solid #202C33;
  border-left: 7px solid transparent;
}
.wa-bubble.out {
  background: #005C4B;
  color: white;
  align-self: flex-end;
  border-top-right-radius: 0;
  animation-delay: var(--delay, 2.5s);
}
.wa-bubble.out::before {
  content: ''; position: absolute; right: -6px; top: 0;
  width: 0; height: 0;
  border-top: 8px solid #005C4B;
  border-right: 7px solid transparent;
}
.wa-bubble .meta {
  font-size: 10px;
  color: rgba(255,255,255,0.5);
  text-align: right;
  margin-top: 1px;
  display: inline-block;
  margin-left: 8px;
  float: right;
}
.wa-bubble .meta .check { color: #53BDEB; margin-left: 2px; }

/* Voice note */
.wa-voice {
  background: #202C33;
  align-self: flex-start;
  border-top-left-radius: 0;
  border-radius: 7px;
  padding: 8px 12px;
  display: flex; align-items: center; gap: 8px;
  max-width: 78%;
  position: relative;
  opacity: 0;
  transform: translateY(8px);
  animation: bubble-in 0.4s var(--ease-snap) forwards;
  animation-delay: var(--delay, 1.5s);
}
.wa-voice::before {
  content: ''; position: absolute; left: -6px; top: 0;
  width: 0; height: 0;
  border-top: 8px solid #202C33;
  border-left: 7px solid transparent;
}
.wa-voice .play {
  width: 26px; height: 26px;
  background: rgba(255,255,255,0.1);
  border-radius: 50%;
  display: grid; place-items: center;
  color: white;
  font-size: 11px;
  flex-shrink: 0;
}
.wa-voice .waveform {
  flex: 1;
  height: 22px;
  display: flex; align-items: center; gap: 1.5px;
}
.wa-voice .waveform span {
  width: 1.5px; background: rgba(255,255,255,0.4);
  border-radius: 1px;
}
.wa-voice .waveform span.played { background: var(--c-accent); }
.wa-voice .duration {
  font-family: -apple-system, system-ui, sans-serif;
  font-size: 10px;
  color: rgba(255,255,255,0.6);
  white-space: nowrap;
}
.wa-voice .pulse {
  position: absolute; right: -4px; top: -4px;
  width: 8px; height: 8px;
  background: var(--c-accent);
  border-radius: 50%;
  box-shadow: 0 0 0 0 rgba(255,85,0,0.5);
  animation: live-pulse 1.6s var(--ease-snap) infinite;
}

/* Typing indicator (compare prima del primo messaggio) */
.wa-typing {
  background: #202C33;
  border-radius: 7px;
  border-top-left-radius: 0;
  padding: 8px 12px;
  align-self: flex-start;
  display: inline-flex; gap: 4px;
  position: relative;
  animation: typing-show-hide 1.5s ease-in-out forwards;
  animation-delay: 0.1s;
  opacity: 0;
}
.wa-typing::before {
  content: ''; position: absolute; left: -6px; top: 0;
  width: 0; height: 0;
  border-top: 8px solid #202C33;
  border-left: 7px solid transparent;
}
.wa-typing span {
  width: 6px; height: 6px;
  border-radius: 50%;
  background: rgba(255,255,255,0.4);
  animation: typing-dot 1.4s ease-in-out infinite;
}
.wa-typing span:nth-child(2) { animation-delay: 0.2s; }
.wa-typing span:nth-child(3) { animation-delay: 0.4s; }

/* Input bar */
.wa-input {
  background: #1F2C34;
  padding: 8px 12px;
  display: flex; gap: 6px; align-items: center;
  border-top: 1px solid rgba(255,255,255,0.05);
}
.wa-input .pill {
  flex: 1;
  background: #2A3942;
  border-radius: 18px;
  padding: 6px 12px;
  color: rgba(255,255,255,0.4);
  font-family: -apple-system, system-ui, sans-serif;
  font-size: 13px;
}
.wa-input .send {
  width: 32px; height: 32px;
  background: #00A884;
  border-radius: 50%;
  display: grid; place-items: center;
  color: white;
  font-size: 14px;
}

/* Animations */
@keyframes bubble-in {
  to { opacity: 1; transform: translateY(0); }
}
@keyframes typing-show-hide {
  0%   { opacity: 0; }
  20%  { opacity: 1; }
  80%  { opacity: 1; }
  100% { opacity: 0; }
}
@keyframes typing-dot {
  0%, 60%, 100% { transform: translateY(0); opacity: 0.4; }
  30% { transform: translateY(-4px); opacity: 1; }
}

@media (max-width: 980px) {
  .wp-inner { grid-template-columns: 1fr; gap: var(--s-6); }
  .iphone-frame { max-width: 320px; }
}

/* ============================================================
   FLOW SECTION — "Il flusso completo: dal dato al meeting"
   Timeline 5 step con mockup realistici per ogni fase
   ============================================================ */
.flow {
  padding: var(--s-9) 0;
  border-top: 1px solid var(--c-line);
  border-bottom: 1px solid var(--c-line);
  background: var(--c-bg-0);
}
.flow-head {
  max-width: 1440px; margin: 0 auto var(--s-7);
  padding: 0 var(--gutter);
  display: grid; grid-template-columns: 120px 1fr; gap: var(--s-4);
  align-items: end;
}
.flow-head .num {
  font-family: var(--font-mono); font-size: var(--t-mono-sm);
  letter-spacing: 0.16em; color: var(--c-text-faint);
}
.flow-head .heading h2 {
  font-size: var(--t-display-md); letter-spacing: -0.04em; line-height: 1.02;
  margin: 0 0 var(--s-3); max-width: 18ch;
}
.flow-head .heading h2 em {
  font-family: var(--font-serif); font-style: italic;
  color: var(--c-accent); font-weight: 400;
}
.flow-head .heading p {
  color: var(--c-text-mute); font-size: var(--t-body-lg);
  line-height: 1.5; margin: 0; max-width: 60ch;
}

.flow-timeline {
  max-width: 1440px; margin: 0 auto;
  padding: 0 var(--gutter);
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 0;
  position: relative;
}
.flow-timeline::before {
  /* dashed connecting line */
  content: ''; position: absolute;
  top: 28px; left: calc(var(--gutter) + 60px); right: calc(var(--gutter) + 60px);
  height: 1px;
  background-image: repeating-linear-gradient(to right, var(--c-line-strong) 0, var(--c-line-strong) 8px, transparent 8px, transparent 16px);
  z-index: 0;
}

.flow-step {
  position: relative; z-index: 1;
  padding: 0 var(--s-3);
  display: flex; flex-direction: column;
}
.flow-step .marker {
  width: 56px; height: 56px;
  border: 1px solid var(--c-line-strong);
  background: var(--c-bg-0);
  display: grid; place-items: center;
  font-family: var(--font-mono);
  font-size: var(--t-mono-md); font-weight: 700;
  letter-spacing: 0.08em; color: var(--c-text-faint);
  margin-bottom: var(--s-4);
  transition: all var(--d-fast) var(--ease-snap);
}
.flow-step:nth-child(5) .marker {
  /* ultimo step → meeting confermato → highlight orange */
  border-color: var(--c-accent);
  color: var(--c-accent);
  background: rgba(255,85,0,0.05);
}
.flow-step .step-label {
  font-family: var(--font-mono); font-size: var(--t-mono-xs);
  letter-spacing: 0.16em; color: var(--c-text-faint);
  text-transform: uppercase; margin: 0 0 var(--s-2);
}
.flow-step h3 {
  font-family: var(--font-display);
  font-size: 19px; font-weight: 600;
  letter-spacing: -0.025em; line-height: 1.15;
  margin: 0 0 var(--s-2);
  color: var(--c-text);
}
.flow-step p.flow-desc {
  color: var(--c-text-mute);
  font-size: 13px; line-height: 1.5;
  margin: 0 0 var(--s-4);
}

/* === Mockup containers === */
.flow-mockup {
  background: var(--c-bg-1);
  border: 1px solid var(--c-line);
  padding: var(--s-3);
  font-family: var(--font-mono); font-size: 10px;
  letter-spacing: 0.04em;
  color: var(--c-text);
  line-height: 1.4;
  position: relative;
  overflow: hidden;
}

/* === STEP 01: Database aziende === */
.mock-database .table-rows {
  display: grid; gap: 4px; margin-bottom: 8px;
}
.mock-database .row {
  display: grid; grid-template-columns: 1fr auto;
  font-size: 9.5px;
  padding: 4px 6px;
  background: var(--c-bg-0);
  border-left: 2px solid var(--c-line-strong);
  align-items: center;
}
.mock-database .row.match {
  border-left-color: var(--c-accent);
  background: rgba(255,85,0,0.05);
}
.mock-database .row .sect {
  color: var(--c-text);
}
.mock-database .row .meta {
  color: var(--c-text-faint);
  font-size: 9px;
}
.mock-database .counter {
  display: flex; justify-content: space-between; align-items: center;
  padding: 6px 6px 0;
  border-top: 1px solid var(--c-line);
  margin-top: 6px;
  font-size: 9.5px;
}
.mock-database .counter .num {
  color: var(--c-accent); font-weight: 700;
}

/* === STEP 02: Card decisore === */
.mock-contact {
  display: grid;
  grid-template-columns: 36px 1fr;
  gap: 10px;
  align-items: center;
}
.mock-contact .avatar {
  width: 36px; height: 36px;
  background: var(--c-bg-2);
  border: 1px solid var(--c-line-strong);
  display: grid; place-items: center;
  color: var(--c-text-faint);
  font-size: 12px; font-weight: 700;
}
.mock-contact .info {
  font-family: var(--font-body);
  font-size: 11px;
  line-height: 1.35;
}
.mock-contact .info .name {
  color: var(--c-text);
  font-weight: 600;
  font-size: 12px;
  margin-bottom: 1px;
}
.mock-contact .info .role {
  color: var(--c-accent);
  font-family: var(--font-mono);
  font-size: 9px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  margin-bottom: 6px;
}
.mock-contact .info .ch {
  color: var(--c-text-mute);
  font-family: var(--font-mono);
  font-size: 9.5px;
  display: block;
  padding: 2px 0;
}
.mock-contact .info .ch::before {
  content: '✓ ';
  color: var(--c-live);
  font-weight: 700;
}

/* === STEP 03: 4 touchpoint mini-card === */
.mock-touch {
  display: grid; gap: 4px;
}
.mock-touch .tp {
  background: var(--c-bg-0);
  border-left: 2px solid var(--c-line-strong);
  padding: 4px 6px;
  font-size: 9.5px;
  display: grid; grid-template-columns: 14px 1fr;
  gap: 6px;
  align-items: start;
}
.mock-touch .tp .ico {
  color: var(--c-text-faint); font-size: 11px; line-height: 1; padding-top: 1px;
}
.mock-touch .tp .body {
  font-family: var(--font-body); color: var(--c-text); line-height: 1.3;
}
.mock-touch .tp .body .from {
  color: var(--c-text-faint); font-family: var(--font-mono); font-size: 8.5px;
  letter-spacing: 0.08em; text-transform: uppercase; margin-bottom: 2px;
}

/* === STEP 04: Sequenza giorni === */
.mock-sequence {
  font-family: var(--font-mono);
  font-size: 9px;
}
.mock-sequence .days {
  display: grid;
  grid-template-columns: repeat(14, 1fr);
  gap: 1px;
  margin-bottom: 6px;
}
.mock-sequence .days .day {
  height: 14px;
  background: var(--c-bg-0);
  border: 1px solid var(--c-line);
  position: relative;
  display: grid; place-items: center;
}
.mock-sequence .days .day.touchpoint {
  background: var(--c-accent);
  border-color: var(--c-accent);
}
.mock-sequence .days .day.today {
  border-color: var(--c-text);
}
.mock-sequence .legend {
  display: flex; gap: 8px;
  font-size: 8.5px; color: var(--c-text-faint);
  letter-spacing: 0.04em;
  margin-top: 4px;
}
.mock-sequence .legend span {
  display: flex; align-items: center; gap: 4px;
}
.mock-sequence .legend span::before {
  content: ''; width: 8px; height: 8px;
  background: var(--c-accent);
}

/* === STEP 05: Meeting confermato === */
.mock-calendar {
  font-family: var(--font-body);
}
.mock-calendar .week {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 2px;
  margin-bottom: 6px;
  font-size: 9px;
  text-align: center;
  font-family: var(--font-mono);
  color: var(--c-text-faint);
  letter-spacing: 0.06em;
  text-transform: uppercase;
}
.mock-calendar .slots {
  display: grid; gap: 3px;
}
.mock-calendar .slot {
  background: var(--c-bg-0);
  border-left: 2px solid var(--c-line);
  padding: 4px 6px;
  font-size: 10px;
  display: grid; grid-template-columns: 36px 1fr;
  gap: 6px;
  font-family: var(--font-mono);
}
.mock-calendar .slot.confirmed {
  border-left-color: var(--c-accent);
  background: rgba(255,85,0,0.06);
  position: relative;
}
.mock-calendar .slot.confirmed::after {
  content: '✓ CONFIRMED';
  position: absolute; top: 50%; right: 6px; transform: translateY(-50%);
  font-size: 8px; color: var(--c-accent);
  letter-spacing: 0.1em;
  font-weight: 700;
}
.mock-calendar .slot .time {
  color: var(--c-text-faint);
  font-size: 9.5px;
}
.mock-calendar .slot .who {
  color: var(--c-text);
  font-family: var(--font-body);
  font-size: 10px;
}
.mock-calendar .slot.confirmed .who {
  font-weight: 600;
}
.mock-calendar .slot.empty .who {
  color: var(--c-text-faint);
  font-style: italic;
}

@media (max-width: 980px) {
  .flow-timeline { grid-template-columns: 1fr; gap: var(--s-5); }
  .flow-timeline::before { display: none; }
  .flow-head { grid-template-columns: 1fr; }
}

/* ============================================================
   COOKIE BANNER + PREFERENCE MODAL
   GDPR-compliant, Consent Mode v2, Meta + Google Ads ready
   ============================================================ */
.cookie-banner {
  position: fixed; bottom: 0; left: 0; right: 0;
  background: var(--c-bg-dark);
  color: var(--c-bg-0);
  z-index: 9000;
  border-top: 1px solid rgba(255,85,0,0.4);
  box-shadow: 0 -10px 40px rgba(0,0,0,0.3);
  padding: var(--s-4) var(--gutter);
  transform: translateY(100%);
  transition: transform 0.4s var(--ease-snap);
}
.cookie-banner.show { transform: translateY(0); }
.cookie-banner-inner {
  max-width: 1440px; margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr auto;
  gap: var(--s-5);
  align-items: center;
}
.cookie-banner .copy {
  display: flex; flex-direction: column; gap: 4px;
}
.cookie-banner .label {
  font-family: var(--font-mono); font-size: 10px;
  letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--c-accent);
  display: inline-flex; align-items: center; gap: var(--s-2);
}
.cookie-banner .label::before {
  content: ''; width: 8px; height: 8px;
  background: var(--c-accent); border-radius: 50%;
  display: inline-block;
}
.cookie-banner h3 {
  font-family: var(--font-display);
  font-size: 17px; font-weight: 600;
  letter-spacing: -0.02em;
  color: var(--c-bg-0); margin: 0;
}
.cookie-banner p {
  font-size: 13px; line-height: 1.45;
  color: rgba(248,247,244,0.7);
  margin: 0; max-width: 70ch;
}
.cookie-banner p a {
  color: var(--c-accent); border-bottom: 1px solid currentColor;
}
.cookie-banner .actions {
  display: flex; gap: var(--s-2); align-items: center;
}
.cookie-btn {
  font-family: var(--font-mono);
  font-size: 11px; font-weight: 700;
  letter-spacing: 0.12em; text-transform: uppercase;
  padding: 12px 18px;
  cursor: pointer;
  border: 1px solid transparent;
  background: transparent;
  color: rgba(248,247,244,0.8);
  transition: all var(--d-fast) var(--ease-snap);
  white-space: nowrap;
}
.cookie-btn:hover { color: var(--c-bg-0); }
.cookie-btn.btn-customize {
  border-color: rgba(248,247,244,0.3);
}
.cookie-btn.btn-customize:hover { border-color: var(--c-bg-0); }
.cookie-btn.btn-reject {
  border-color: rgba(248,247,244,0.2);
}
.cookie-btn.btn-accept {
  background: var(--c-accent); color: var(--c-bg-0);
}
.cookie-btn.btn-accept:hover { background: white; color: var(--c-bg-dark); }

/* Cookie modal preferences */
.cookie-modal {
  position: fixed; inset: 0;
  background: rgba(15,15,15,0.85);
  z-index: 9100;
  display: none;
  align-items: center; justify-content: center;
  padding: var(--s-4);
  backdrop-filter: blur(8px);
}
.cookie-modal.show { display: flex; }
.cookie-modal-box {
  background: var(--c-bg-dark);
  color: var(--c-bg-0);
  width: 100%; max-width: 560px;
  border: 1px solid rgba(248,247,244,0.15);
  max-height: 90vh; overflow-y: auto;
}
.cookie-modal-head {
  padding: var(--s-5);
  border-bottom: 1px solid rgba(248,247,244,0.1);
}
.cookie-modal-head h2 {
  font-family: var(--font-display); font-size: 22px;
  letter-spacing: -0.02em; margin: 0 0 var(--s-2);
  color: var(--c-bg-0);
}
.cookie-modal-head p {
  font-size: 13px; color: rgba(248,247,244,0.65); margin: 0; line-height: 1.5;
}
.cookie-cat {
  padding: var(--s-4) var(--s-5);
  border-bottom: 1px solid rgba(248,247,244,0.08);
  display: grid;
  grid-template-columns: 1fr auto;
  gap: var(--s-4);
  align-items: start;
}
.cookie-cat .info h4 {
  font-family: var(--font-display); font-size: 15px; font-weight: 600;
  letter-spacing: -0.01em; color: var(--c-bg-0);
  margin: 0 0 4px;
}
.cookie-cat .info p {
  font-size: 12px; line-height: 1.5;
  color: rgba(248,247,244,0.55); margin: 0;
}
.cookie-cat .info .always {
  font-family: var(--font-mono); font-size: 9px;
  letter-spacing: 0.16em; color: var(--c-live);
  text-transform: uppercase; margin-top: 4px; display: inline-block;
}

/* Toggle switch */
.cookie-toggle {
  position: relative;
  width: 40px; height: 22px;
  flex-shrink: 0;
  margin-top: 2px;
}
.cookie-toggle input { opacity: 0; width: 0; height: 0; position: absolute; }
.cookie-toggle .slider {
  position: absolute; inset: 0;
  background: rgba(248,247,244,0.2);
  cursor: pointer;
  transition: background var(--d-fast);
  border-radius: 22px;
}
.cookie-toggle .slider::before {
  content: '';
  position: absolute; top: 3px; left: 3px;
  width: 16px; height: 16px;
  background: var(--c-bg-0);
  transition: transform var(--d-fast);
  border-radius: 50%;
}
.cookie-toggle input:checked + .slider { background: var(--c-accent); }
.cookie-toggle input:checked + .slider::before { transform: translateX(18px); }
.cookie-toggle input:disabled + .slider {
  background: rgba(22,163,74,0.6);
  cursor: not-allowed;
}
.cookie-toggle input:disabled + .slider::before { transform: translateX(18px); }

.cookie-modal-foot {
  padding: var(--s-4) var(--s-5);
  display: flex; gap: var(--s-2); justify-content: flex-end;
  border-top: 1px solid rgba(248,247,244,0.1);
  flex-wrap: wrap;
}

@media (max-width: 720px) {
  .cookie-banner { padding: var(--s-3) var(--gutter); }
  .cookie-banner-inner { grid-template-columns: 1fr; gap: var(--s-3); }
  .cookie-banner h3 { font-size: 15px; }
  .cookie-banner p { font-size: 12px; }
  .cookie-banner .actions { flex-wrap: wrap; gap: 8px; }
  .cookie-btn { flex: 1 1 100%; min-width: 0; padding: 12px 14px; font-size: 11px; letter-spacing: 0.08em; }
  .cookie-btn.btn-customize { order: 3; }
  .cookie-btn.btn-reject { order: 2; flex: 1 1 calc(50% - 4px); }
  .cookie-btn.btn-accept { order: 1; flex: 1 1 calc(50% - 4px); }
  .cookie-modal-box { max-height: 95vh; }
  .cookie-modal-foot { flex-direction: column-reverse; gap: 8px; }
  .cookie-modal-foot .cookie-btn { width: 100%; flex: none; }
}

/* ============================================================
   PRENOTA · FORMSPREE CONTACT FORM
   Editorial-style inputs · honeypot hidden · success/error states
   ============================================================ */
.section-prenota {
  background: var(--c-bg-1);
  border-top: 1px solid var(--c-line);
}
.prenota-head {
  text-align: center;
  max-width: 760px;
  margin: 0 auto var(--s-7);
}
.prenota-title {
  font-family: var(--font-display);
  font-size: clamp(40px, 6vw, 72px);
  letter-spacing: -0.045em;
  line-height: 0.98;
  margin: 0 0 var(--s-4);
  color: var(--c-text);
}
.prenota-title em {
  font-family: var(--font-serif);
  font-style: italic;
  color: var(--c-accent);
  font-weight: 400;
}
.prenota-lede {
  color: var(--c-text-mute);
  font-size: var(--t-body-lg);
  max-width: 56ch;
  margin: 0 auto;
  line-height: 1.5;
}

.prenota-form {
  display: flex;
  flex-direction: column;
  gap: var(--s-5);
  background: var(--c-bg-0);
  border: 1px solid var(--c-line);
  padding: clamp(24px, 4vw, 48px);
}

/* Honeypot — hidden but NOT display:none (bots skip display:none) */
.prenota-form .hp {
  position: absolute;
  left: -9999px;
  width: 1px;
  height: 1px;
  opacity: 0;
  pointer-events: none;
}

.form-row {
  display: flex;
  flex-direction: column;
  gap: var(--s-2);
}
.form-row label {
  font-family: var(--font-mono);
  font-size: var(--t-mono-sm);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--c-text);
  font-weight: 500;
  display: flex;
  align-items: baseline;
  gap: 8px;
}
.form-row label .l-num {
  color: var(--c-accent);
  font-weight: 700;
}
.form-row input,
.form-row textarea {
  font-family: var(--font-display);
  font-size: 18px;
  color: var(--c-text);
  background: var(--c-bg-1);
  border: 1px solid var(--c-line);
  padding: 14px 16px;
  border-radius: 0;
  -webkit-appearance: none;
  appearance: none;
  transition: border-color var(--d-fast) var(--ease-snap),
              background var(--d-fast) var(--ease-snap);
  width: 100%;
  box-sizing: border-box;
}
.form-row input::placeholder,
.form-row textarea::placeholder {
  color: var(--c-text-faint);
  font-family: var(--font-display);
  opacity: 1;
}
.form-row input:focus,
.form-row textarea:focus {
  outline: none;
  border-color: var(--c-accent);
  background: var(--c-bg-0);
  box-shadow: 0 0 0 3px rgba(255, 85, 0, 0.1);
}
.form-row textarea {
  resize: vertical;
  min-height: 88px;
  line-height: 1.5;
}
.form-row input:invalid:not(:placeholder-shown),
.form-row textarea:invalid:not(:placeholder-shown) {
  border-color: rgba(201, 60, 60, 0.6);
}
.form-row .hint {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.04em;
  color: var(--c-text-faint);
  line-height: 1.5;
}

.form-actions {
  display: flex;
  flex-direction: column;
  gap: var(--s-3);
  margin-top: var(--s-2);
  align-items: flex-start;
}
.btn-submit {
  position: relative;
  min-width: 280px;
  padding: 20px 32px;
  cursor: pointer;
  font-family: var(--font-mono);
  border: 0;
  font-size: var(--t-body-sm);
  letter-spacing: 0.08em;
}
.btn-submit .btn-loading { display: none; }
.btn-submit[aria-busy="true"] { opacity: 0.7; cursor: wait; }
.btn-submit[aria-busy="true"] .btn-label { display: none; }
.btn-submit[aria-busy="true"] .btn-loading { display: inline; }
.btn-submit:disabled { opacity: 0.5; cursor: not-allowed; transform: none !important; }

.form-footnote {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.08em;
  color: var(--c-text-faint);
  line-height: 1.6;
  margin: 0;
  max-width: 60ch;
}
.form-footnote a { color: var(--c-text-mute); border-bottom: 1px solid currentColor; }
.form-footnote a:hover { color: var(--c-accent); }

/* Success state */
.prenota-success {
  background: var(--c-bg-0);
  border: 1px solid var(--c-line);
  border-left: 4px solid var(--c-accent);
  padding: clamp(32px, 5vw, 64px);
  text-align: center;
  animation: prenotaFadeIn 480ms var(--ease-snap);
}
.prenota-success .success-mark {
  color: var(--c-accent);
  margin: 0 auto var(--s-4);
  display: inline-block;
}
.prenota-success h3 {
  font-family: var(--font-display);
  font-size: clamp(28px, 4vw, 42px);
  letter-spacing: -0.03em;
  margin: 0 0 var(--s-3);
  color: var(--c-text);
}
.prenota-success p {
  color: var(--c-text-mute);
  font-size: var(--t-body-lg);
  margin: 0 auto var(--s-3);
  max-width: 52ch;
  line-height: 1.5;
}
.prenota-success .mono-note {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.16em;
  color: var(--c-text-faint);
  text-transform: uppercase;
  margin-top: var(--s-4);
}
@keyframes prenotaFadeIn {
  from { opacity: 0; transform: translateY(12px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* Error state */
.prenota-error {
  background: rgba(201, 60, 60, 0.06);
  border: 1px solid rgba(201, 60, 60, 0.3);
  padding: var(--s-4);
  margin-top: var(--s-3);
}
.prenota-error p {
  color: var(--c-text);
  font-size: var(--t-body-sm);
  margin: 0;
  line-height: 1.5;
}
.prenota-error a { color: var(--c-accent); border-bottom: 1px solid currentColor; }

/* Mobile adjustments */
@media (max-width: 720px) {
  .prenota-form { padding: var(--s-4); gap: var(--s-4); }
  .form-row input,
  .form-row textarea { font-size: 16px; /* iOS no-zoom */ padding: 12px 14px; }
  .btn-submit { width: 100%; min-width: 0; padding: 18px 20px; }
  .form-actions { align-items: stretch; }
  .prenota-success { padding: var(--s-5) var(--s-4); }
}
