/* Scala Core — Sistema Vivo (palette grafite fissa). Estratto da prototipi/3-sistema-vivo.html. */

:root{
    /* non-themed tokens */
    --mono:ui-monospace,"SF Mono",Menlo,monospace;
    --maxw:1180px;
    --ease:cubic-bezier(.22,.61,.36,1);
    /* node-rgb / node-dim-rgb : raw "r,g,b" triplets the canvas reads
       so JS can compose rgba() cleanly from the active theme accent */
  }

  /* ════════════════════════════════════════════════════════════
     THEMES — each theme overrides the full palette + a font pair.
     All CSS runs on these custom properties; the canvas reads
     --node-rgb / --node-dim-rgb at runtime. Default = Grafite freddo.
     ════════════════════════════════════════════════════════════ */

  /* 1 · GRAFITE FREDDO — neutral blue-black, cool white, steel/cyan (DEFAULT) */
  body, body[data-theme="grafite"]{
    --ink:#12151a; --ink-deep:#0d0f13; --ink-2:#1a1f27;
    --atmos-rgb:13,15,19;
    --on-ink:#e6eaef; --on-ink-dim:#8b96a6;
    --accent:#7fb4c4; --accent-light:#a7d2df; --accent-on-cream:#3a6c7c;
    --node-rgb:127,180,196; --node-dim-rgb:139,150,166;
    --line-ink:rgba(230,234,239,.10);
    --foot-bg:#7fb4c4; --foot-fg:#15201f; --foot-dim:#2f4a4d; --foot-accent:#1f3f49; --line-foot:rgba(16,28,30,.18);
    --sans:"Hanken Grotesk",system-ui,sans-serif;
  }

  *{box-sizing:border-box;margin:0;padding:0}
  html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
  body{
    background:var(--ink);
    color:var(--on-ink);
    font-family:var(--sans);
    font-weight:300;
    line-height:1.6;
    -webkit-font-smoothing:antialiased;
    text-rendering:optimizeLegibility;
    overflow-x:hidden;
  }

  /* ── Living field canvas ── */
  #field{
    position:fixed;
    inset:0;
    z-index:0;
    width:100%;
    height:100%;
    pointer-events:none;
  }

  /* atmosphere: subtle vignette pulling focus toward centre/text */
  .atmos{
    position:fixed;
    inset:0;
    z-index:1;
    pointer-events:none;
    background:
      radial-gradient(120% 90% at 50% 32%, transparent 0%, transparent 38%, rgba(var(--atmos-rgb),.55) 100%),
      linear-gradient(180deg, rgba(var(--atmos-rgb),.35) 0%, transparent 18%, transparent 82%, rgba(var(--atmos-rgb),.6) 100%);
  }

  /* film grain */
  .grain{position:fixed;inset:0;z-index:60;pointer-events:none;opacity:.035;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");}

  .shell{position:relative;z-index:5}

  /* ── Header ── */
  header{
    position:absolute;
    top:0;left:0;right:0;
    z-index:40;
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:2rem;
    padding:1.7rem clamp(1.2rem,4vw,3.2rem);
  }
  .brand{display:flex;align-items:center;gap:.9rem;text-decoration:none}
  .brand img{height:56px;width:auto;opacity:1;display:block}

  nav{display:flex;gap:2.1rem;align-items:center}
  nav a{
    color:var(--on-ink-dim);
    text-decoration:none;
    font-size:.82rem;
    text-transform:uppercase;
    letter-spacing:.13em;
    white-space:nowrap;
    position:relative;
    transition:color .35s var(--ease);
    padding:.2rem 0;
  }
  nav a::after{
    content:"";position:absolute;left:0;bottom:-2px;height:1px;width:0;
    background:var(--accent);
    transition:width .4s var(--ease);
  }
  nav a:hover{color:var(--on-ink)}
  nav a:hover::after{width:100%}
  nav a:focus-visible{outline:2px solid var(--accent);outline-offset:4px;border-radius:2px}

  .lang-sw{display:inline-flex;align-items:center;gap:.75rem}
  .lang-sw a.on{color:var(--on-ink)}
  .lang-sw .div{color:var(--on-ink-dim);opacity:.45;font-size:.7rem;line-height:1}

  .nav-toggle{display:none}

  /* ── Hero ── */
  .hero{
    position:relative;
    min-height:100svh;
    display:flex;
    flex-direction:column;
    justify-content:center;
    padding:9rem clamp(1.2rem,5vw,4rem) 5rem;
    max-width:var(--maxw);
    margin:0 auto;
  }
  .kicker{
    display:flex;align-items:center;gap:.85rem;
    font-family:var(--mono);
    font-size:.7rem;
    letter-spacing:.34em;
    text-transform:uppercase;
    color:var(--accent);
    margin-bottom:1.9rem;
    opacity:0;
    animation:fadeUp .9s var(--ease) .35s forwards;
  }
  .kicker .tick{
    width:2.4rem;height:1px;background:linear-gradient(90deg,var(--accent),transparent);
    display:inline-block;
  }
  h1{
    font-family:"Jost",system-ui,sans-serif;
    font-weight:200;
    text-transform:uppercase;
    font-size:clamp(1.9rem,4.6vw,3.5rem);
    line-height:1.16;
    letter-spacing:.06em;
    color:var(--on-ink);
    max-width:30ch;
    text-wrap:balance;
  }
  h1 .clause{display:block}
  h1 .clause-2{margin-top:.55rem;text-wrap:pretty}
  h1 .word{
    display:inline-block;
    opacity:0;
    transform:translateY(.5em);
    animation:wordUp 1.05s var(--ease) forwards;
  }
  h1 em{font-style:normal;color:var(--accent-light);font-weight:300}

  .scrollhint{
    margin-top:2.6rem;
    width:1px;height:46px;
    background:linear-gradient(180deg,var(--accent),transparent);
    opacity:0;
    animation:fadeUp 1s var(--ease) 1.9s forwards, drip 2.6s ease-in-out 2.5s infinite;
    transform-origin:top;
  }

  /* ── The mirror / readout ── */
  .mirror{
    position:relative;
    z-index:5;
    max-width:var(--maxw);
    margin:0 auto;
    padding:6rem clamp(1.2rem,5vw,4rem) 7rem;
  }

  .readout{display:flex;flex-direction:column;gap:0}

  .line{
    position:relative;
    padding:2rem 0;
    border-top:1px solid var(--line-ink);
    display:grid;
    grid-template-columns:1fr;
    gap:clamp(1.2rem,4vw,3.2rem);
    align-items:start;
  }
  .line:last-child{border-bottom:1px solid var(--line-ink)}

  .line .body{
    position:relative;
    font-family:"Jost",system-ui,sans-serif;
    font-weight:300;
    text-transform:uppercase;
    font-size:clamp(1.02rem,2.1vw,1.5rem);
    line-height:1.42;
    letter-spacing:.045em;
    color:var(--on-ink);
    opacity:0;
    transform:translateY(.6rem);
    transition:opacity .8s var(--ease), transform .8s var(--ease);
  }
  /* the traced detection underline */
  .line .body::after{
    content:"";
    position:absolute;
    left:0;
    bottom:-.55rem;
    height:1px;
    width:0;
    background:linear-gradient(90deg,var(--accent) 0%,var(--accent-light) 60%,transparent 100%);
    transition:width 1.1s var(--ease) .25s;
  }
  .line.seen .body{opacity:1;transform:none}
  .line.seen .body::after{width:min(100%,30rem)}

  /* scan node that rides the underline as it traces */
  .line .body .scan{
    position:absolute;
    bottom:-.55rem;
    left:0;
    width:5px;height:5px;
    border-radius:50%;
    background:var(--accent-light);
    box-shadow:0 0 8px 2px rgba(201,160,110,.45);
    opacity:0;
  }
  .line.seen .body .scan{
    animation:scanRide 1.35s var(--ease) .25s forwards;
  }

  /* ── Reveal allo scroll per le pagine interne.
     La classe .reveal la aggiunge il JS solo se reduce-motion è off,
     quindi qui non serve gestire prefers-reduced-motion. ── */
  .reveal{
    opacity:0;
    transform:translateY(1.4rem);
    transition:opacity .7s var(--ease), transform .7s var(--ease);
  }
  .reveal.seen{opacity:1;transform:none}

  /* ── The door / system state ── */
  .door-wrap{
    position:relative;
    z-index:5;
    padding:5rem clamp(1.2rem,5vw,4rem) 7rem;
  }
  .door{
    position:relative;
    max-width:var(--maxw);
    margin:0 auto;
    border:1px solid var(--line-ink);
    padding:clamp(2.4rem,5vw,4.6rem) clamp(1.6rem,4vw,4rem);
    background:
      linear-gradient(180deg, rgba(28,23,16,.5) 0%, rgba(16,13,9,.2) 100%);
    overflow:hidden;
  }
  /* HUD corner brackets */
  .door .corner{position:absolute;width:18px;height:18px;border:1px solid var(--accent);opacity:.55}
  .door .corner.tl{top:-1px;left:-1px;border-right:none;border-bottom:none}
  .door .corner.tr{top:-1px;right:-1px;border-left:none;border-bottom:none}
  .door .corner.bl{bottom:-1px;left:-1px;border-right:none;border-top:none}
  .door .corner.br{bottom:-1px;right:-1px;border-left:none;border-top:none}

  .door h2{
    font-family:"Jost",system-ui,sans-serif;
    font-weight:200;
    text-transform:uppercase;
    font-size:clamp(1.7rem,3.9vw,3rem);
    line-height:1.16;
    letter-spacing:.06em;
    color:var(--on-ink);
    margin-bottom:1.3rem;
    text-wrap:balance;
  }
  .door .sub{
    font-family:"Jost",system-ui,sans-serif;
    font-size:clamp(.9rem,1.7vw,1.05rem);
    text-transform:uppercase;
    letter-spacing:.07em;
    color:var(--on-ink-dim);
    max-width:46ch;
    margin-bottom:2.8rem;
    font-weight:300;
  }
  .cta{
    display:inline-flex;align-items:center;gap:.9rem;
    text-decoration:none;
    font-family:var(--mono);
    font-size:.78rem;
    letter-spacing:.12em;
    text-transform:uppercase;
    color:var(--ink);
    background:var(--accent);
    padding:1.05rem 1.8rem;
    transition:background .35s var(--ease), gap .35s var(--ease), transform .35s var(--ease);
    position:relative;
  }
  .cta:hover{background:var(--accent-light);gap:1.4rem;transform:translateY(-1px)}
  .cta:focus-visible{outline:2px solid var(--accent-light);outline-offset:4px}
  .cta .arr{transition:transform .35s var(--ease)}
  .cta:hover .arr{transform:translateX(3px)}

  /* ── Footer (cream breath) ── */
  footer{
    position:relative;
    z-index:5;
    background:var(--foot-bg);
    color:var(--foot-fg);
  }
  .foot-inner{
    max-width:var(--maxw);
    margin:0 auto;
    padding:clamp(2rem,3.5vw,3rem) clamp(1.2rem,5vw,4rem) 1.8rem;
  }
  .foot-tag{
    font-family:"Jost",system-ui,sans-serif;
    font-weight:300;
    text-transform:uppercase;
    font-size:clamp(1.15rem,2.7vw,1.85rem);
    line-height:1.32;
    letter-spacing:.05em;
    color:var(--foot-fg);
    max-width:42ch;
    margin-bottom:1.7rem;
  }
  .foot-grid{
    display:grid;
    grid-template-columns:1.4fr 1fr 1fr;
    gap:2.4rem;
    padding-top:2.6rem;
    border-top:1px solid var(--line-foot);
  }
  .foot-col h2{
    font-family:var(--mono);
    font-size:.6rem;
    letter-spacing:.2em;
    text-transform:uppercase;
    color:var(--foot-dim);
    font-weight:400;
    margin-bottom:1.1rem;
  }
  .foot-col ul{list-style:none}
  .foot-col li{margin-bottom:.55rem}
  .foot-col a, .foot-col .item{
    color:var(--foot-fg);
    text-decoration:none;
    font-size:.85rem;
    text-transform:uppercase;
    letter-spacing:.06em;
    transition:color .3s var(--ease);
  }
  .foot-col a:hover{color:var(--foot-accent)}
  .foot-col a.mail{color:var(--foot-accent)}
  .foot-col a:focus-visible{outline:2px solid var(--foot-accent);outline-offset:3px;border-radius:2px}

  .foot-bottom{
    display:flex;align-items:center;justify-content:space-between;
    flex-wrap:wrap;gap:1rem;
    margin-top:1.5rem;
    padding-top:1.3rem;
    border-top:1px solid var(--line-foot);
    font-size:.74rem;
    letter-spacing:.06em;
    text-transform:uppercase;
    color:var(--foot-dim);
  }
  .foot-bottom .note{
    font-family:var(--mono);
    font-size:.66rem;
    letter-spacing:.08em;
    text-transform:uppercase;
    color:var(--foot-dim);
    max-width:52ch;
  }
  .foot-bottom .cr{color:var(--foot-dim);white-space:nowrap}
  .foot-bottom .cr a{color:var(--foot-dim);text-decoration:none;transition:color .3s var(--ease)}
  .foot-bottom .cr a:hover{color:var(--foot-accent)}

  /* ════════════════════════════════════════════════════════════
     INTERIOR PAGES — page hero (uppercase Jost chrome) + long-form
     prose. Title/labels stay uppercase; the BODY reads sentence-case
     in the sans so long copy (the letter, descriptions) stays legible.
     ════════════════════════════════════════════════════════════ */
  .page-hero{
    position:relative;
    max-width:var(--maxw);
    margin:0 auto;
    padding:11rem clamp(1.2rem,5vw,4rem) 2.4rem;
  }
  .page-hero .kicker{margin-bottom:1.5rem}
  .page-hero h1{
    max-width:22ch;
    opacity:0;
    animation:fadeUp 1s var(--ease) .35s forwards;
  }

  .prose-wrap{
    position:relative;
    z-index:5;
    max-width:var(--maxw);
    margin:0 auto;
    padding:1.4rem clamp(1.2rem,5vw,4rem) 6.5rem;
  }
  .prose{
    max-width:62ch;
    opacity:0;
    animation:fadeUp 1s var(--ease) .6s forwards;
  }
  .prose p{
    font-family:var(--sans);
    font-weight:300;
    font-size:clamp(1.02rem,1.45vw,1.18rem);
    line-height:1.85;
    letter-spacing:.005em;
    color:var(--on-ink);
    margin-bottom:1.55rem;
  }
  .prose p.lead{
    font-size:clamp(1.16rem,1.9vw,1.42rem);
    line-height:1.68;
    color:var(--on-ink);
    margin-bottom:1.8rem;
  }
  .prose .sign{
    font-family:"Jost",system-ui,sans-serif;
    font-weight:300;
    text-transform:uppercase;
    letter-spacing:.13em;
    font-size:1.05rem;
    color:var(--accent-light);
    margin-top:2.6rem;
    margin-bottom:0;
  }
  .prose h2{
    font-family:"Jost",system-ui,sans-serif;
    font-weight:200;text-transform:uppercase;letter-spacing:.06em;
    font-size:clamp(1.12rem,2vw,1.45rem);color:var(--on-ink);
    margin:2.8rem 0 1rem;
  }
  .prose ul{list-style:none;margin:0 0 1.55rem;padding:0;display:flex;flex-direction:column;gap:.7rem}
  .prose li{
    position:relative;padding-left:1.4rem;
    font-family:var(--sans);font-weight:300;
    font-size:clamp(1rem,1.4vw,1.12rem);line-height:1.7;color:var(--on-ink);
  }
  .prose li::before{content:"";position:absolute;left:1px;top:.62em;width:6px;height:6px;background:var(--accent);transform:rotate(45deg)}
  .prose .meta-note{font-family:var(--mono);font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:var(--on-ink-dim);margin-bottom:2rem}
  .prose-cta{margin-top:2.4rem}
  .prose-cta a, a.link-ink{
    font-family:var(--mono);
    font-size:.8rem;
    letter-spacing:.12em;
    text-transform:uppercase;
    color:var(--accent);
    text-decoration:none;
    border-bottom:1px solid transparent;
    transition:color .3s var(--ease), border-color .3s var(--ease);
  }
  .prose-cta a:hover, a.link-ink:hover{color:var(--accent-light);border-color:var(--accent-light)}
  .prose-cta a:focus-visible, a.link-ink:focus-visible{outline:2px solid var(--accent);outline-offset:4px;border-radius:2px}

  @media (max-width:480px){
    .page-hero{padding-top:8.5rem}
  }

  /* page lede (under hero h1, sans, dim) */
  .page-lede{
    font-family:var(--sans);
    font-weight:300;
    font-size:clamp(1.02rem,1.7vw,1.25rem);
    line-height:1.6;
    color:var(--on-ink-dim);
    max-width:46ch;
    margin-top:1.5rem;
    opacity:0;
    animation:fadeUp 1s var(--ease) .55s forwards;
  }

  /* shared inline accent link (used in prose + body copy) */
  a.link-ink{
    color:var(--accent);
    text-decoration:none;
    border-bottom:1px solid rgba(127,180,196,.4);
    transition:color .3s var(--ease), border-color .3s var(--ease);
  }
  a.link-ink:hover{color:var(--accent-light);border-color:var(--accent-light)}

  /* ════════════════════════════════════════════════════════════
     SERVIZI — livelli as a "deliverable readout": mono index,
     uppercase Jost name, sentence-case sans copy, sample in a
     HUD panel (same language as the home's door).
     ════════════════════════════════════════════════════════════ */
  .livelli-wrap{
    position:relative;z-index:5;
    max-width:var(--maxw);margin:0 auto;
    padding:1.6rem clamp(1.2rem,5vw,4rem) 3rem;
  }
  .livelli{display:flex;flex-direction:column}
  .lv{
    display:grid;
    grid-template-columns:1fr;
    gap:clamp(1.4rem,4vw,3.4rem);
    padding:3rem 0;
    border-top:1px solid var(--line-ink);
    align-items:start;
  }
  .lv:last-child{border-bottom:1px solid var(--line-ink)}
  .lv-body{min-width:0}
  .lv-name{
    font-family:"Jost",system-ui,sans-serif;
    font-weight:200;text-transform:uppercase;
    font-size:clamp(1.5rem,3vw,2.2rem);
    letter-spacing:.06em;line-height:1.15;
    color:var(--on-ink);margin-bottom:.9rem;
  }
  .lv-lede{
    font-family:var(--sans);font-weight:300;
    font-size:clamp(1rem,1.5vw,1.18rem);
    line-height:1.7;color:var(--on-ink);
    max-width:52ch;margin-bottom:1.8rem;
  }
  .lbl{
    display:block;
    font-family:var(--mono);
    font-size:.62rem;letter-spacing:.22em;text-transform:uppercase;
    color:var(--accent);margin-bottom:.75rem;
  }
  .forma-dettaglio{
    margin-top:1.2rem;padding-top:1.1rem;border-top:1px solid var(--line-ink);
    font-family:var(--sans);font-weight:300;font-size:.95rem;line-height:1.6;color:var(--on-ink-dim);
  }

  /* nota listino — accent callout */
  .nota-listino{
    border-left:2px solid var(--accent);
    padding:.2rem 0 .2rem 1.6rem;max-width:60ch;margin-bottom:2rem;
  }
  .nota-listino .h{
    font-family:"Jost",system-ui,sans-serif;font-weight:300;text-transform:uppercase;
    letter-spacing:.08em;font-size:clamp(1.1rem,1.9vw,1.4rem);
    color:var(--on-ink);margin-bottom:.7rem;
  }
  .nota-listino p:not(.h){
    font-family:var(--sans);font-weight:300;font-size:clamp(.98rem,1.4vw,1.08rem);
    line-height:1.75;color:var(--on-ink-dim);
  }

  @media (max-width:860px){
    .lv{grid-template-columns:1fr;gap:1rem}
  }

  /* ════════════════════════════════════════════════════════════
     LE FORME — verticali as HUD product cards in a grid.
     ════════════════════════════════════════════════════════════ */
  .forme-grid{
    display:grid;
    grid-template-columns:repeat(3,1fr);
    gap:1.4rem;
    margin-top:.5rem;
  }
  .form-card{
    position:relative;
    display:flex;flex-direction:column;
    border:1px solid var(--line-ink);
    background:linear-gradient(180deg, rgba(127,180,196,.035) 0%, rgba(13,15,19,.28) 100%);
    padding:clamp(1.5rem,2.4vw,2rem);
    transition:border-color .4s var(--ease), transform .4s var(--ease);
  }
  .form-card:not(.soon):hover{border-color:rgba(127,180,196,.4);transform:translateY(-2px)}
  .form-card.soon{opacity:.74}
  .form-who{
    font-family:var(--mono);
    font-size:.6rem;letter-spacing:.2em;text-transform:uppercase;
    color:var(--accent);margin-bottom:1rem;
  }
  .form-name{
    font-family:"Jost",system-ui,sans-serif;
    font-weight:200;text-transform:uppercase;
    font-size:clamp(1.35rem,2.4vw,1.8rem);
    letter-spacing:.05em;line-height:1.12;
    color:var(--on-ink);margin-bottom:.9rem;
  }
  .form-desc{
    font-family:var(--sans);font-weight:400;
    font-size:clamp(1rem,1.4vw,1.1rem);line-height:1.55;
    color:var(--on-ink);margin-bottom:1rem;
    text-wrap:balance;
  }
  .form-card .forma-dettaglio{
    margin-top:0;padding-top:0;border-top:none;
    flex:1 1 auto;margin-bottom:1.6rem;
  }
  .form-go{
    align-self:flex-start;
    font-family:var(--mono);
    font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;
    color:var(--accent);text-decoration:none;
    border:1px solid rgba(127,180,196,.4);
    padding:.7rem 1.1rem;
    transition:background .35s var(--ease), color .35s var(--ease);
  }
  .form-go:hover{background:var(--accent);color:var(--ink)}
  .form-go:focus-visible{outline:2px solid var(--accent);outline-offset:3px}
  .form-soon-tag{
    align-self:flex-start;
    font-family:var(--mono);
    font-size:.62rem;letter-spacing:.18em;text-transform:uppercase;
    color:var(--on-ink-dim);
    border:1px dashed var(--line-ink);
    padding:.55rem .9rem;
  }

  @media (max-width:860px){
    .forme-grid{grid-template-columns:1fr;gap:1.1rem}
    .form-card .forma-dettaglio{flex:0 1 auto}
  }

  /* ════════════════════════════════════════════════════════════
     COME LA PENSIAMO — convinzioni: roman index + claim + esempio.
     ════════════════════════════════════════════════════════════ */
  .convinzioni{display:flex;flex-direction:column;margin-top:.5rem}
  .conv{
    display:grid;grid-template-columns:auto 1fr;
    gap:clamp(1.4rem,4vw,3.2rem);
    padding:2.6rem 0;
    border-top:1px solid var(--line-ink);
    align-items:start;
  }
  .conv:last-child{border-bottom:1px solid var(--line-ink)}
  .conv-num{
    font-family:"Jost",system-ui,sans-serif;
    font-weight:200;font-size:clamp(1.6rem,3vw,2.4rem);
    letter-spacing:.04em;color:var(--accent-light);
    padding-top:.1rem;white-space:nowrap;
  }
  .conv-body{min-width:0;max-width:58ch}
  .conv-claim{
    font-family:var(--sans);font-weight:500;
    font-size:clamp(1.18rem,2vw,1.5rem);line-height:1.4;
    color:var(--on-ink);margin-bottom:.9rem;
    text-wrap:balance;
  }
  .conv-sub{
    font-family:var(--sans);font-weight:300;
    font-size:clamp(1rem,1.4vw,1.1rem);line-height:1.7;
    color:var(--on-ink-dim);margin-bottom:1.2rem;
  }
  .conv-esempio{
    font-family:var(--sans);font-weight:300;
    font-size:clamp(.95rem,1.35vw,1.04rem);line-height:1.7;
    color:var(--on-ink-dim);
    border-left:2px solid rgba(127,180,196,.35);
    padding-left:1.2rem;
  }

  @media (max-width:860px){
    .conv{grid-template-columns:1fr;gap:.6rem}
    .conv-num{font-size:1.4rem}
  }

  /* ════════════════════════════════════════════════════════════
     CONTATTI — form on ink + "cosa succede dopo".
     ════════════════════════════════════════════════════════════ */
  .form-contatto{
    display:flex;flex-direction:column;gap:1.5rem;
    max-width:48rem;margin-top:2.4rem;
  }
  .form-contatto label{
    display:block;
    font-family:var(--mono);
    font-size:.62rem;letter-spacing:.2em;text-transform:uppercase;
    color:var(--accent);margin-bottom:.65rem;
  }
  .form-contatto input,
  .form-contatto textarea{
    width:100%;
    background:rgba(230,234,239,.035);
    border:1px solid var(--line-ink);
    color:var(--on-ink);
    font-family:var(--sans);font-weight:300;font-size:1.02rem;
    padding:.95rem 1.1rem;
    transition:border-color .3s var(--ease), background .3s var(--ease);
  }
  .form-contatto textarea{min-height:9rem;resize:vertical;line-height:1.6}
  .form-contatto input:focus,
  .form-contatto textarea:focus{
    outline:none;
    border-color:var(--accent);
    background:rgba(230,234,239,.06);
  }
  .form-contatto input::placeholder,
  .form-contatto textarea::placeholder{color:var(--on-ink-dim)}
  .form-actions{display:flex;align-items:center;gap:1.4rem;flex-wrap:wrap;margin-top:.4rem}
  .cta-pill{
    font-family:var(--mono);
    font-size:.78rem;letter-spacing:.12em;text-transform:uppercase;
    color:var(--ink);background:var(--accent);
    border:none;cursor:pointer;
    padding:1.05rem 2.2rem;
    transition:background .35s var(--ease), transform .35s var(--ease);
  }
  .cta-pill:hover{background:var(--accent-light);transform:translateY(-1px)}
  .cta-pill:focus-visible{outline:2px solid var(--accent-light);outline-offset:4px}
  .form-actions .alt{
    font-family:var(--sans);font-weight:300;font-size:.95rem;color:var(--on-ink-dim);
  }
  .form-actions .alt a{color:var(--accent);text-decoration:none;border-bottom:1px solid rgba(127,180,196,.4)}
  .form-actions .alt a:hover{color:var(--accent-light)}
  /* consenso: label sobria, niente uppercase/mono delle label di campo */
  .form-contatto .form-consent{
    display:flex;align-items:flex-start;gap:.7rem;margin:0;cursor:pointer;
    font-family:var(--sans);font-weight:300;font-size:.92rem;line-height:1.5;
    letter-spacing:normal;text-transform:none;color:var(--on-ink-dim);
  }
  .form-contatto .form-consent input{
    width:auto;flex:none;margin-top:.18em;padding:0;accent-color:var(--accent);
  }
  .form-feedback{
    font-family:var(--sans);font-weight:300;font-size:.95rem;line-height:1.5;
    margin-top:.2rem;min-height:1.2em;
  }
  .form-feedback.is-ok{color:var(--accent-light)}
  .form-feedback.is-err{color:#e0a3a3}
  .form-feedback a{color:var(--accent);border-bottom:1px solid rgba(127,180,196,.4)}

  .contatto-dopo{margin-top:4rem;max-width:54rem}
  .contatto-dopo h2{
    font-family:"Jost",system-ui,sans-serif;
    font-weight:200;text-transform:uppercase;
    font-size:clamp(1.3rem,2.4vw,1.8rem);letter-spacing:.06em;
    color:var(--on-ink);margin-bottom:1.6rem;
  }
  .dopo-list{list-style:none;display:flex;flex-direction:column;gap:1.1rem}
  .dopo-list li{
    position:relative;padding-left:1.4rem;
    font-family:var(--sans);font-weight:300;
    font-size:clamp(.98rem,1.4vw,1.08rem);line-height:1.65;color:var(--on-ink-dim);
  }
  .dopo-list li::before{
    content:"";position:absolute;left:1px;top:.55em;
    width:6px;height:6px;background:var(--accent);transform:rotate(45deg);
  }
  .dopo-list li strong{color:var(--on-ink);font-weight:500}

  /* ── Animations ── */
  @keyframes fadeUp{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:none}}
  @keyframes wordUp{from{opacity:0;transform:translateY(.5em)}to{opacity:1;transform:none}}
  @keyframes pulse{
    0%,100%{box-shadow:0 0 0 0 rgba(var(--node-rgb),.45)}
    50%{box-shadow:0 0 0 5px rgba(var(--node-rgb),0)}
  }
  @keyframes drip{
    0%,100%{transform:scaleY(.4);opacity:.5}
    50%{transform:scaleY(1);opacity:1}
  }
  @keyframes scanRide{
    0%{opacity:1;left:0}
    85%{opacity:1}
    100%{opacity:0;left:min(100%,30rem)}
  }

  /* ── Responsive ── */
  /* Nav -> hamburger gia' a 1024px: prima che le voci lunghe (IT) vadano a capo. */
  @media (max-width:1024px){
    nav{
      position:fixed;inset:0;
      flex-direction:column;justify-content:center;
      background:rgba(16,13,9,.97);
      backdrop-filter:blur(8px);
      gap:2.2rem;
      transform:translateX(100%);
      transition:transform .45s var(--ease);
      z-index:45;
    }
    nav.open{transform:none}
    nav a{font-size:1.3rem;color:var(--on-ink)}
    .nav-toggle{
      display:flex;flex-direction:column;gap:5px;
      background:none;border:none;cursor:pointer;
      z-index:50;padding:.4rem;
    }
    .nav-toggle span{width:24px;height:1.5px;background:var(--on-ink);transition:.35s var(--ease)}
    .nav-toggle.open span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
    .nav-toggle.open span:nth-child(2){opacity:0}
    .nav-toggle.open span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}
  }

  @media (max-width:860px){
    .line{grid-template-columns:1fr;gap:.7rem}
    .line .body::after{bottom:-.4rem}
    .line .body .scan{bottom:-.4rem}
    .foot-grid{grid-template-columns:1fr;gap:2rem}
  }

  @media (max-width:480px){
    .hero{padding-top:7.5rem}
    h1{font-size:clamp(2.1rem,9vw,3rem)}
  }

  /* ── Reduced motion ── */
  @media (prefers-reduced-motion:reduce){
    *,*::before,*::after{
      animation:none !important;
      transition:none !important;
    }
    html{scroll-behavior:auto}
    .kicker,.scrollhint{opacity:1}
    h1 .word{opacity:1;transform:none}
    .scrollhint{display:none}
    .line .body{opacity:1;transform:none}
    .line .body::after{width:min(100%,30rem)}
    .line .body .scan{display:none}
  }

  /* ── A-capo automatici, responsive ───────────────────────────────
     pretty = niente parole orfane sull'ultima riga dei testi;
     balance = righe bilanciate sui titoli (i titoli grandi h1/.door h2/
     .conv-claim hanno gia' balance piu' su). Vale a ogni larghezza,
     niente <br> a mano. ponytail: se un punto preciso resta brutto,
     si rifinisce li' con &nbsp; o <br>, non si torna indietro su questo. */
  p, li{ text-wrap:pretty; }
  h2, .page-lede, .form-name, .nota-listino .h{ text-wrap:balance; }
