/* =========================================================
   Fabrizio Palazzo — v3 "Copula-style"
   Color blocking: arancione · blu · crema · antracite
   Display condensato maiuscolo (Anton) + Inter
   ========================================================= */

:root{
  --cream:    #F1ECE1;
  --cream-2:  #FBF8F0;
  --ink:      #26231F;
  --ink-2:    #1C1A17;
  --orange:   #F5450A;
  --orange-d: #DC3D08;
  --blue:     #1E17E6;
  --blue-l:   #A9AEFF;
  --peri:     #A9AEFF;
  --ink-mut:  #6E675C;

  --line:      rgba(38,35,31,.16);
  --line-soft: rgba(38,35,31,.08);
  --oncol:     #F4F0E6;            /* testo su arancione/blu */
  --oncol-mut: rgba(244,240,230,.78);
  --line-col:  rgba(244,240,230,.28);

  --display: "Anton", "Impact", "Haettenschweiler", "Arial Narrow", sans-serif;
  --body: "Inter", system-ui, -apple-system, Segoe UI, Roboto, sans-serif;
  --mono: "Inter", sans-serif;

  --step--1: clamp(.74rem,.7rem + .18vw,.86rem);
  --step-0:  clamp(1rem,.96rem + .25vw,1.13rem);
  --step-1:  clamp(1.4rem,1.2rem + .8vw,2rem);
  --step-2:  clamp(2.2rem,1.6rem + 2.6vw,3.8rem);
  --step-3:  clamp(3rem,2rem + 5vw,7rem);
  --step-4:  clamp(3.8rem,2.2rem + 9vw,13rem);

  --container:1280px;
  --gutter:clamp(20px,5vw,76px);
  --radius:16px;
  --radius-lg:26px;
  --ease:cubic-bezier(.22,.61,.36,1);
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{margin:0;font-family:var(--body);font-size:var(--step-0);line-height:1.62;color:var(--ink);background:var(--cream);-webkit-font-smoothing:antialiased;overflow-x:clip}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer;border:none;background:none}
h1,h2,h3,h4{font-family:var(--display);font-weight:400;line-height:.94;margin:0;letter-spacing:.005em;text-transform:uppercase}
h1{font-size:var(--step-3)}h2{font-size:var(--step-2)}h3{font-size:var(--step-1)}
p{margin:0;text-wrap:pretty}
::selection{background:var(--blue);color:var(--cream)}
[hidden]{display:none!important}

/* Layout */
.container{max-width:var(--container);margin-inline:auto;padding-inline:var(--gutter)}
.section{padding-block:clamp(78px,11vw,150px)}
.section--tight{padding-block:clamp(56px,8vw,100px)}

.panel-light{background:var(--cream);color:var(--ink)}
.panel-dark{background:var(--orange);color:var(--oncol)}
.panel-ink2{background:var(--blue);color:var(--oncol)}
.muted{color:var(--ink-mut)}
.panel-dark .muted,.panel-ink2 .muted{color:var(--oncol-mut)}

/* shared text-color overrides for colored panels */
.panel-dark .lead,.panel-ink2 .lead{color:var(--oncol-mut)}
.panel-dark a.link-arrow,.panel-ink2 a.link-arrow{color:var(--cream)}

/* Eyebrow with flower bullet */
.eyebrow{font-family:var(--body);font-weight:700;font-size:var(--step--1);letter-spacing:.16em;text-transform:uppercase;display:inline-flex;align-items:center;gap:.55em;color:inherit}
.eyebrow::before{content:"\274B";color:var(--orange);font-size:1.15em;line-height:1}
.panel-dark .eyebrow::before{color:var(--blue-l)}
.panel-ink2 .eyebrow::before{color:var(--cream)}

/* Headings */
.h-xl{font-size:var(--step-4)}
.h-lg{font-size:var(--step-3)}
.h-md{font-size:var(--step-2)}
.h-sm{font-size:var(--step-1)}
.lead{font-size:var(--step-1);line-height:1.45;font-family:var(--body);font-weight:400;color:var(--ink-mut);text-transform:none}
.text-gold{color:var(--orange)}
.text-violet{color:var(--blue)}
.grad{color:var(--blue)}
.panel-dark .grad{color:var(--blue-l)}

/* Buttons */
.btn{display:inline-flex;align-items:center;gap:.55em;padding:1.05em 1.7em;border-radius:100px;font-family:var(--body);font-weight:600;font-size:var(--step-0);letter-spacing:.01em;transition:transform .35s var(--ease),background .3s,color .3s,border-color .3s;will-change:transform}
.btn svg{width:1.05em;height:1.05em}
.btn--primary{background:var(--ink);color:var(--cream)}
.btn--primary:hover{transform:translateY(-3px);background:var(--blue);color:var(--cream)}
.panel-ink2 .btn--primary{background:var(--cream);color:var(--ink)}
.panel-ink2 .btn--primary:hover{background:var(--ink);color:var(--cream)}
.btn--ghost{border:1.5px solid currentColor;color:inherit}
.btn--ghost:hover{transform:translateY(-3px);background:currentColor}
.btn--ghost:hover{color:var(--cream)}
.panel-light .btn--ghost{color:var(--ink)}
.panel-light .btn--ghost:hover{background:var(--ink);color:var(--cream)}

.link-arrow{display:inline-flex;align-items:center;gap:.5em;font-weight:600;color:var(--blue)}
.link-arrow svg{width:1em;height:1em;transition:transform .3s var(--ease)}
.link-arrow:hover svg{transform:translateX(5px)}

/* NAV — cream over color at top, dark when scrolled on cream */
.nav{position:fixed;inset:0 0 auto 0;z-index:100;display:flex;align-items:center;justify-content:space-between;padding:20px var(--gutter);transition:background .4s,padding .4s,color .35s;color:var(--cream)}
.nav.scrolled{background:rgba(241,236,225,.97);padding-block:13px;color:var(--ink)}
.brand{display:flex;align-items:center;gap:.6em;font-family:var(--display);font-size:1.5rem;color:inherit;text-transform:lowercase;letter-spacing:.01em}
.brand .mark{width:38px;height:38px;border-radius:10px;display:grid;place-items:center;background:var(--blue);color:var(--cream);font-family:var(--body);font-weight:800;font-size:.9rem;letter-spacing:-.02em}
.brand small{display:block;font-family:var(--body);font-size:.58rem;letter-spacing:.16em;font-weight:600;text-transform:uppercase;opacity:.7}
.nav-links{display:flex;align-items:center;gap:clamp(14px,1.8vw,28px);list-style:none;margin:0;padding:0}
.nav-links a{font-size:.97rem;font-weight:600;color:inherit;opacity:.82;transition:opacity .25s;position:relative}
.nav-links a:hover,.nav-links a[aria-current="page"]{opacity:1}
.nav-links a::after{content:"";position:absolute;left:0;bottom:-6px;height:2px;width:0;background:currentColor;transition:width .3s var(--ease)}
.nav-links a:hover::after,.nav-links a[aria-current="page"]::after{width:100%}
.nav-cta{display:inline-flex}
.nav-links .btn--primary{display:none}
.nav-links .btn--primary::after{display:none}
.nav-cta.btn--primary{background:var(--ink);color:var(--cream)}
.nav.scrolled .nav-cta.btn--primary{background:var(--ink)}
.nav-cta.btn--primary:hover{background:var(--blue)}
.nav-toggle{display:none;flex-direction:column;gap:5px;padding:8px}
.nav-toggle span{width:24px;height:2px;background:currentColor;transition:.3s}

@media (max-width:980px){
  .nav-cta{display:none}
  .nav-toggle{display:flex}
  .nav-links{position:fixed;inset:0 0 0 auto;width:min(82vw,360px);flex-direction:column;align-items:flex-start;justify-content:center;gap:22px;padding:48px;background:var(--ink);transform:translateX(100%);transition:transform .45s var(--ease);color:var(--cream)}
  .nav-links.open{transform:translateX(0)}
  .nav-links a{font-size:1.7rem;font-family:var(--display);text-transform:uppercase;opacity:1}
  .nav-links a::after{background:var(--orange)}
  .nav-links .btn--primary{display:inline-flex;font-family:var(--body);background:var(--orange);color:var(--cream);margin-top:12px}
  .nav.menu-open{color:var(--cream)}
  .nav.menu-open .nav-toggle span{background:var(--cream)}
  .nav.menu-open .nav-toggle span:nth-child(1){transform:translateY(7px) rotate(45deg)}
  .nav.menu-open .nav-toggle span:nth-child(2){opacity:0}
  .nav.menu-open .nav-toggle span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
}

/* HERO (orange) */
.hero{position:relative;min-height:100svh;display:flex;align-items:flex-end;overflow:hidden;padding-top:150px;padding-bottom:clamp(40px,6vw,80px)}
.aurora,.hero .grain{display:none}
.hero .container{position:relative;z-index:2;width:100%}
.hero-status{display:inline-flex;align-items:center;gap:.6em;font-family:var(--body);font-weight:600;font-size:var(--step--1);letter-spacing:.1em;text-transform:uppercase;color:var(--oncol-mut);margin-bottom:26px}
.dot{width:9px;height:9px;border-radius:50%;background:var(--blue-l);box-shadow:0 0 0 0 var(--blue-l);animation:pulse 2.4s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(169,174,255,.6)}70%{box-shadow:0 0 0 12px rgba(169,174,255,0)}100%{box-shadow:0 0 0 0 rgba(169,174,255,0)}}
.hero h1{font-size:var(--step-4);max-width:18ch;margin-bottom:.02em;line-height:.86;letter-spacing:.004em;color:var(--cream)}
.hero .lead{max-width:52ch;color:var(--oncol-mut);margin-top:28px}
.hero-actions{display:flex;flex-wrap:wrap;gap:14px;margin-top:36px;align-items:center}
.hero-stats{display:flex;flex-wrap:wrap;gap:clamp(28px,5vw,68px);margin-top:54px;padding-top:30px;border-top:1px solid var(--line-col)}
.stat .num{font-family:var(--display);font-size:var(--step-2);color:var(--cream);display:block;line-height:1}
.stat .lbl{font-size:var(--step--1);color:var(--oncol-mut);margin-top:8px;text-transform:uppercase;letter-spacing:.08em}

/* hero headline reveal — no clipping */
.reveal-line{display:block;overflow:visible}
.reveal-line > span{display:block;transform:translateY(.4em);opacity:0;transition:transform .85s var(--ease),opacity .85s var(--ease)}
.hero.loaded .reveal-line > span{transform:none;opacity:1}
.hero.loaded .reveal-line:nth-child(2) > span{transition-delay:.08s}
.hero.loaded .reveal-line:nth-child(3) > span{transition-delay:.16s}
.fade-up{opacity:0;transform:translateY(20px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
.hero.loaded .fade-up{opacity:1;transform:none}
.hero.loaded .d1{transition-delay:.3s}.hero.loaded .d2{transition-delay:.44s}.hero.loaded .d3{transition-delay:.58s}

/* Flower / asterisk */
.flower{display:inline-block;color:var(--blue);animation:spin 14s linear infinite;transform-origin:50% 50%}
.flower.slow{animation-duration:22s}
.panel-dark .flower{color:var(--blue)}
@keyframes spin{to{transform:rotate(360deg)}}

/* Blob seal */
.seal{position:relative;width:clamp(120px,14vw,168px);aspect-ratio:1;display:grid;place-items:center;background:var(--blue);color:var(--cream);text-align:center;border-radius:46% 54% 52% 48%/52% 46% 54% 48%;animation:morph 8s ease-in-out infinite,spinslow 26s linear infinite;font-family:var(--display);text-transform:uppercase;line-height:.92;font-size:clamp(.95rem,1.4vw,1.2rem);padding:18px;transition:transform .3s}
.seal:hover{transform:scale(1.06)}
.seal.orange{background:var(--orange)}
@media (max-width:980px){.hero .seal{display:none}}
@keyframes morph{0%,100%{border-radius:46% 54% 52% 48%/52% 46% 54% 48%}50%{border-radius:54% 46% 48% 52%/46% 54% 48% 52%}}
@keyframes spinslow{to{transform:rotate(360deg)}}
.seal .seal-in{display:block;animation:spinback 26s linear infinite}
@keyframes spinback{to{transform:rotate(-360deg)}}

/* tilt utils */
.tilt-l{transform:rotate(-4deg)}
.tilt-r{transform:rotate(3.5deg)}

/* MARQUEE (blue band) */
.marquee{overflow:hidden;background:var(--blue);padding-block:24px}
.marquee-track{display:flex;gap:0;white-space:nowrap;width:max-content;animation:scroll-x 32s linear infinite}
.marquee:hover .marquee-track{animation-play-state:paused}
.marquee-track span{font-family:var(--display);text-transform:uppercase;font-size:clamp(1.5rem,3.4vw,2.6rem);color:var(--cream);padding-inline:.5em;display:inline-flex;align-items:center;letter-spacing:.01em}
.marquee-track span::after{content:"\274B";color:var(--orange);margin-left:.8em;font-size:.5em}
.marquee-track span.is-mut{color:transparent;-webkit-text-stroke:1.4px rgba(244,240,230,.6)}
@keyframes scroll-x{to{transform:translateX(-50%)}}

/* Section head */
.sec-head{margin-bottom:clamp(40px,6vw,76px)}
.sec-head .eyebrow{margin-bottom:20px}
.sec-head p{margin-top:20px;max-width:60ch}
.sec-head .lead{max-width:60ch}

/* Cards */
.grid{display:grid;gap:18px}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-2{grid-template-columns:repeat(2,1fr)}
@media (max-width:900px){.grid-3{grid-template-columns:1fr 1fr}}
@media (max-width:620px){.grid-3,.grid-2{grid-template-columns:1fr}}

.card{position:relative;border-radius:var(--radius-lg);padding:32px;background:var(--cream-2);color:var(--ink);border:1px solid var(--line);overflow:hidden;display:flex;flex-direction:column;transition:transform .4s var(--ease),box-shadow .4s}
.panel-dark .card,.panel-ink2 .card{background:var(--cream);border-color:transparent}
.card::before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:var(--orange);transform:scaleX(0);transform-origin:left;transition:transform .4s var(--ease)}
.card:hover{transform:translateY(-6px);box-shadow:0 28px 56px -30px rgba(38,35,31,.45)}
.card:hover::before{transform:scaleX(1)}
.card .ix{font-family:var(--display);font-size:1.3rem;color:var(--orange);margin-bottom:16px}
.card h3{font-size:var(--step-1);margin-bottom:12px;line-height:1;color:var(--ink)}
.card p{color:var(--ink-mut);font-size:var(--step-0);flex:1;text-transform:none}
.card .tags{display:flex;flex-wrap:wrap;gap:8px;margin-top:22px}
.tag{font-family:var(--body);font-weight:600;font-size:.72rem;letter-spacing:.03em;text-transform:uppercase;padding:5px 11px;border-radius:100px;border:1px solid var(--line);color:var(--ink-mut)}
.card .more{margin-top:24px}
.card.is-new::after{content:"Novità";position:absolute;top:24px;right:24px;font-family:var(--body);font-weight:700;font-size:.64rem;letter-spacing:.08em;text-transform:uppercase;padding:5px 11px;border-radius:100px;background:var(--blue);color:var(--cream)}

/* Quote cards */
.card.quote{padding-top:52px}
.card.quote p{color:var(--ink);font-family:var(--body);font-weight:500;font-size:var(--step-1);line-height:1.34;flex:0 0 auto;text-transform:none}
.card.quote::before{transform:scaleX(1);height:5px;width:46px;left:32px;right:auto;border-radius:4px;top:30px;background:var(--blue)}
.card.quote figcaption{margin-top:24px;display:flex;flex-direction:column;gap:2px}
.qname{font-weight:700;color:var(--ink)}
.qrole{font-size:var(--step--1);color:var(--ink-mut)}

/* Horizontal scroll */
.hscroll{display:flex;gap:18px;overflow-x:auto;padding-bottom:14px;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;scrollbar-width:thin}
.hscroll > *{flex:0 0 min(86vw,380px);scroll-snap-align:start}
.hscroll-hint{font-family:var(--body);font-weight:600;font-size:var(--step--1);letter-spacing:.1em;text-transform:uppercase;opacity:.7;margin-bottom:18px;display:flex;align-items:center;gap:.5em}
.hscroll-hint svg{width:1.1em;height:1.1em}

/* Pillars */
.pillars{border-top:1px solid var(--line)}
.panel-dark .pillars,.panel-ink2 .pillars{border-color:var(--line-col)}
.pillar{display:grid;grid-template-columns:auto 1fr auto;gap:clamp(16px,4vw,72px);align-items:start;padding:clamp(28px,4.2vw,56px) clamp(0px,2vw,26px);border-bottom:1px solid var(--line);transition:background .4s var(--ease),padding-left .4s var(--ease);border-radius:18px}
.panel-dark .pillar,.panel-ink2 .pillar{border-color:var(--line-col)}
.pillar:hover{background:var(--cream-2)}
.panel-dark .pillar:hover,.panel-ink2 .pillar:hover{background:rgba(244,240,230,.1)}
.pillar .pno{font-family:var(--display);color:var(--orange);font-size:1.5rem;padding-top:.2em}
.panel-dark .pillar .pno{color:var(--blue)}
.pillar .pmain{max-width:60ch}
.pillar h3{font-size:clamp(2.1rem,1.2rem + 3.4vw,4.4rem);line-height:.92;margin-bottom:16px;transition:color .3s}
.pillar:hover h3{color:var(--orange)}
.panel-dark .pillar:hover h3{color:var(--blue)}
.pillar p{color:var(--ink-mut);margin-bottom:20px;font-size:var(--step-0);max-width:52ch;text-transform:none}
.panel-dark .pillar p,.panel-ink2 .pillar p{color:var(--oncol-mut)}
.pillar .plist{display:flex;flex-wrap:wrap;gap:9px}
.pillar .plist a{font-family:var(--body);font-weight:600;font-size:.82rem;letter-spacing:.01em;padding:8px 15px;border:1px solid var(--line);border-radius:100px;color:inherit;transition:background .25s,color .25s,border-color .25s}
.pillar .plist a:hover{background:var(--ink);color:var(--cream);border-color:var(--ink)}
.panel-dark .pillar .plist a,.panel-ink2 .pillar .plist a{border-color:var(--line-col)}
.panel-dark .pillar .plist a:hover,.panel-ink2 .pillar .plist a:hover{background:var(--cream);color:var(--ink);border-color:var(--cream)}
.pillar .parrow{align-self:center;color:var(--orange);width:54px;height:54px;border-radius:50%;border:1.5px solid var(--line);display:grid;place-items:center;transition:background .3s,color .3s,border-color .3s,transform .3s}
.pillar .parrow svg{width:22px;height:22px}
.pillar:hover .parrow{background:var(--orange);color:var(--cream);border-color:var(--orange);transform:rotate(-45deg)}
.panel-dark .pillar .parrow{color:var(--blue);border-color:var(--line-col)}
.panel-dark .pillar:hover .parrow{background:var(--blue);color:var(--cream);border-color:var(--blue)}
@media (max-width:760px){.pillar{grid-template-columns:auto 1fr;gap:14px 18px}.pillar .parrow{display:none}}

/* Statement / manifesto */
.statement{font-family:var(--display);text-transform:uppercase;font-size:clamp(2.2rem,1.2rem + 4.4vw,5.2rem);line-height:.92;max-width:20ch}
.statement .accent{color:var(--orange)}
.panel-dark .statement .accent,.panel-ink2 .statement .accent{color:var(--blue-l)}
.statement-meta{font-family:var(--body);font-weight:700;font-size:var(--step--1);letter-spacing:.14em;text-transform:uppercase;color:var(--ink-mut)}
.panel-dark .statement-meta,.panel-ink2 .statement-meta{color:var(--oncol-mut)}

/* Word stack */
.wordstack{font-family:var(--display);text-transform:uppercase;line-height:.9;font-size:clamp(2.6rem,1.4rem + 6vw,7.5rem);display:flex;flex-wrap:wrap;gap:0 .3em}
.wordstack span{display:inline-block}
.wordstack .mut{color:transparent;-webkit-text-stroke:1.5px currentColor}
.wordstack .accent{color:var(--orange)}
.panel-ink2 .wordstack .accent{color:var(--blue-l)}

/* Steps */
.steps{display:grid;gap:0;border-top:1px solid var(--line)}
.panel-dark .steps,.panel-ink2 .steps{border-color:var(--line-col)}
.step{display:grid;grid-template-columns:110px 1fr;gap:24px;padding:34px 0;border-bottom:1px solid var(--line);align-items:start}
.panel-dark .step,.panel-ink2 .step{border-color:var(--line-col)}
.step .n{font-family:var(--display);font-size:var(--step-2);color:var(--orange);line-height:1}
.panel-ink2 .step .n{color:var(--blue-l)}
.step h3{font-size:var(--step-1);margin-bottom:8px}
.step p{color:var(--ink-mut);text-transform:none}
.panel-dark .step p,.panel-ink2 .step p{color:var(--oncol-mut)}
@media (max-width:560px){.step{grid-template-columns:1fr;gap:8px}}

/* Checks */
.checks{list-style:none;margin:0;padding:0;display:grid;gap:15px}
.checks li{display:flex;gap:13px;align-items:flex-start}
.checks span{text-transform:none}
.checks svg{flex:none;width:22px;height:22px;margin-top:3px;color:var(--orange)}
.panel-dark .checks svg{color:var(--blue)}
.panel-ink2 .checks svg{color:var(--blue-l)}

/* Band stats */
.band{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
@media (max-width:760px){.band{grid-template-columns:1fr 1fr}}
.band .stat{padding:28px;border-radius:var(--radius);background:var(--cream-2);border:1px solid var(--line)}
.panel-dark .band .stat,.panel-ink2 .band .stat{background:var(--cream);border-color:transparent}
.band .stat .num{color:var(--orange)}
.band .stat .lbl{color:var(--ink-mut)}

/* Split */
.split{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(38px,6vw,88px);align-items:center}
.split>*{min-width:0}
@media (max-width:860px){.split{grid-template-columns:1fr}}

/* Portrait (tilted block) */
.portrait{position:relative;border-radius:var(--radius-lg);overflow:hidden;aspect-ratio:4/5;background:var(--blue);display:grid;place-items:center}
.portrait .frame{position:absolute;inset:18px;border:1px solid var(--line-col);border-radius:calc(var(--radius-lg) - 12px);z-index:2;pointer-events:none}
.portrait picture{display:contents}
.portrait img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:1}
.portrait .big{font-family:var(--display);font-size:clamp(4rem,16vw,9rem);line-height:.85;text-align:center;color:var(--cream)}
.portrait .cap{position:absolute;bottom:24px;left:24px;font-family:var(--body);font-weight:600;font-size:.74rem;letter-spacing:.1em;text-transform:uppercase;color:var(--oncol-mut)}

/* CTA band (blue block) */
.cta-band{position:relative;border-radius:var(--radius-lg);overflow:hidden;padding:clamp(44px,7vw,92px);background:var(--blue);color:var(--oncol)}
.cta-band .eyebrow{color:var(--cream)}
.cta-band .eyebrow::before{color:var(--cream)}
.cta-band h2{color:var(--cream)}
.cta-band .muted,.cta-band .lead{color:var(--oncol-mut)}
.cta-band .btn--primary{background:var(--cream);color:var(--ink)}
.cta-band .btn--primary:hover{background:var(--orange);color:var(--cream)}
.cta-band .btn--ghost{border-color:var(--line-col);color:var(--cream)}
.cta-band .btn--ghost:hover{background:var(--cream);color:var(--ink);border-color:var(--cream)}
.cta-seal{position:absolute;right:clamp(20px,5vw,70px);top:50%;transform:translateY(-50%);display:none}
@media(min-width:1000px){.cta-seal{display:grid}}

/* FAQ */
.faq{border-top:1px solid var(--line)}
.panel-dark .faq,.panel-ink2 .faq{border-color:var(--line-col)}
.faq details{border-bottom:1px solid var(--line)}
.panel-dark .faq details,.panel-ink2 .faq details{border-color:var(--line-col)}
.faq summary{list-style:none;cursor:pointer;padding:26px 0;display:flex;justify-content:space-between;gap:20px;align-items:center;font-family:var(--body);font-weight:700;font-size:var(--step-1);line-height:1.2;text-transform:none}
.faq summary::-webkit-details-marker{display:none}
.faq summary .ic{flex:none;width:32px;height:32px;border-radius:50%;border:1.5px solid currentColor;display:grid;place-items:center;transition:transform .35s var(--ease),background .3s,color .3s}
.faq summary .ic::before{content:"+";font-family:var(--body);font-size:1.35rem;line-height:1}
.faq details[open] summary .ic{transform:rotate(45deg);background:var(--orange);color:var(--cream);border-color:var(--orange)}
.faq details p{padding:0 0 28px;color:var(--ink-mut);max-width:72ch;text-transform:none}
.panel-dark .faq details p,.panel-ink2 .faq details p{color:var(--oncol-mut)}

/* Page hero (orange) */
.page-hero{position:relative;padding-top:180px;padding-bottom:clamp(52px,7vw,104px);overflow:hidden;background:var(--orange);color:var(--oncol)}
.page-hero .glow{display:none}
.page-hero h1{font-size:var(--step-3);max-width:20ch;margin-bottom:.06em;line-height:.92;color:var(--cream)}
.page-hero .lead{max-width:60ch;color:var(--oncol-mut)}
.crumb{font-family:var(--body);font-weight:600;font-size:var(--step--1);letter-spacing:.1em;text-transform:uppercase;color:var(--oncol-mut);margin-bottom:24px;display:flex;flex-wrap:wrap;gap:.6em;align-items:center}
.crumb a{color:var(--cream)}

/* Form — underline inputs */
.form{display:grid;gap:22px}
.form .row{display:grid;grid-template-columns:1fr 1fr;gap:22px}
@media (max-width:600px){.form .row{grid-template-columns:1fr}}
.field{display:flex;flex-direction:column;gap:8px}
.field label{font-family:var(--body);font-weight:600;font-size:.8rem;letter-spacing:.04em;color:var(--ink)}
.field input,.field select,.field textarea{font:inherit;color:var(--ink);background:transparent;border:0;border-bottom:2px solid var(--line);border-radius:0;padding:12px 2px;transition:border-color .3s}
.field textarea{min-height:120px;resize:vertical}
.field input::placeholder,.field textarea::placeholder{color:var(--ink-mut);opacity:.7}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--orange)}

/* Footer (charcoal) */
.footer{background:var(--ink-2);color:var(--cream);padding-block:72px 32px}
.footer-cta{padding-bottom:clamp(40px,6vw,72px);margin-bottom:clamp(40px,5vw,56px);border-bottom:1px solid var(--line-col)}
.footer-cta .fc-sub{font-family:var(--body);font-weight:600;font-size:var(--step--1);letter-spacing:.14em;text-transform:uppercase;color:var(--oncol-mut);margin-bottom:22px;display:flex;align-items:center;gap:.55em}
.footer-cta .fc-sub::before{content:"\274B";color:var(--orange)}
.footer-cta .fc-link{display:inline-flex;align-items:center;gap:.2em;font-family:var(--display);text-transform:uppercase;font-size:clamp(2.8rem,1.6rem + 6vw,8rem);line-height:.86;color:var(--cream);transition:color .3s}
.footer-cta .fc-link:hover{color:var(--orange)}
.footer-cta .fc-link svg{width:.66em;height:.66em;transition:transform .35s var(--ease)}
.footer-cta .fc-link:hover svg{transform:translateX(.12em) rotate(-45deg)}
.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr;gap:42px}
@media (max-width:760px){.footer-grid{grid-template-columns:1fr;gap:32px}}
.footer h4{font-family:var(--body);font-weight:600;font-size:.74rem;letter-spacing:.14em;text-transform:uppercase;color:var(--oncol-mut);margin-bottom:18px}
.footer ul{list-style:none;margin:0;padding:0;display:grid;gap:12px}
.footer ul a{color:var(--oncol-mut);transition:color .25s}
.footer ul a:hover{color:var(--orange)}
.footer .muted{color:var(--oncol-mut)}
.footer .big-cta{font-family:var(--display);text-transform:uppercase;font-size:var(--step-2);max-width:16ch;line-height:.92}
.footer .big-cta a{color:var(--cream)}
.footer .big-cta a:hover{color:var(--orange)}
.footer-bottom{display:flex;flex-wrap:wrap;justify-content:space-between;gap:16px;margin-top:58px;padding-top:26px;border-top:1px solid var(--line-col);font-size:var(--step--1);color:var(--oncol-mut)}

/* Scroll reveal */
[data-reveal]{opacity:0;transform:translateY(26px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
[data-reveal].in{opacity:1;transform:none}
[data-reveal-delay="1"]{transition-delay:.08s}
[data-reveal-delay="2"]{transition-delay:.16s}
[data-reveal-delay="3"]{transition-delay:.24s}
[data-reveal-delay="4"]{transition-delay:.32s}
[data-reveal-delay="5"]{transition-delay:.4s}
.tilt-l[data-reveal].in{transform:rotate(-4deg)}
.tilt-r[data-reveal].in{transform:rotate(3.5deg)}

/* Misc */
.center{text-align:center}
.mt-l{margin-top:clamp(36px,5vw,56px)}
.mb-m{margin-bottom:24px}
.maxw{max-width:60ch}
.divider{height:1px;background:var(--line);border:0;margin:0}
.skip{position:absolute;left:-999px;top:0;background:var(--orange);color:var(--cream);padding:10px 16px;z-index:200;border-radius:0 0 8px 0}
.skip:focus{left:0}
:focus-visible{outline:2px solid var(--blue);outline-offset:3px;border-radius:4px}

/* progress + whatsapp + cursor */
.progress{position:fixed;top:0;left:0;height:3px;width:0;z-index:200;background:var(--blue)}
.btn--wa{background:#25D366;color:#06351c}
.btn--wa:hover{transform:translateY(-3px);background:#1eb858;color:#fff}
.wa-float{position:fixed;right:18px;bottom:18px;z-index:90;width:60px;height:60px;border-radius:50%;display:grid;place-items:center;background:#25D366;color:#fff;box-shadow:0 14px 32px -8px rgba(0,0,0,.35);transition:transform .3s var(--ease)}
.wa-float:hover{transform:scale(1.08) translateY(-2px)}
.wa-float svg{width:32px;height:32px}
.wa-float::after{content:"Scrivimi su WhatsApp";position:absolute;right:72px;white-space:nowrap;background:var(--ink-2);color:var(--cream);font-size:.82rem;padding:8px 13px;border-radius:10px;opacity:0;transform:translateX(8px);pointer-events:none;transition:opacity .3s,transform .3s}
.wa-float:hover::after{opacity:1;transform:translateX(0)}
@media (max-width:600px){.wa-float{width:54px;height:54px}.wa-float::after{display:none}}

.cursor{position:fixed;top:0;left:0;width:16px;height:16px;border-radius:50%;background:var(--peri);pointer-events:none;z-index:300;transform:translate(-50%,-50%);transition:width .25s var(--ease),height .25s var(--ease),background .25s,opacity .3s;opacity:0;mix-blend-mode:normal}
.cursor.on{opacity:.9}
.cursor.big{width:54px;height:54px;background:rgba(169,174,255,.45)}
@media (pointer:coarse){.cursor{display:none}}

/* hide horizontal scrollbars (auto-scroll handles movement) */
.hscroll{scrollbar-width:none;cursor:grab}
.hscroll::-webkit-scrollbar{display:none;height:0;width:0}
.hscroll.dragging{cursor:grabbing;scroll-snap-type:none;user-select:none}
.hscroll.dragging a{pointer-events:none}

/* ===== NAV as side slide panel on ALL sizes ===== */
.nav{z-index:120}
.nav-cta{display:none!important}
.nav-toggle{display:flex!important;width:50px;height:50px;border-radius:50%;border:1.5px solid currentColor;align-items:center;justify-content:center;gap:5px;padding:0;transition:background .3s,color .3s,border-color .3s}
.nav.scrolled .nav-toggle:hover{background:var(--ink);color:var(--cream);border-color:var(--ink)}
.nav-toggle span{width:18px;height:2px;background:currentColor}
.nav-links{position:fixed;inset:0 0 0 auto;width:min(94vw,480px);flex-direction:column;align-items:flex-start;justify-content:center;gap:clamp(8px,1.4vw,16px);padding:clamp(30px,6vw,68px);background:var(--ink-2);color:var(--cream);transform:translateX(100%);transition:transform .55s var(--ease);z-index:110;overflow-y:auto;box-shadow:-30px 0 80px -30px rgba(0,0,0,.6)}
.nav-links.open{transform:translateX(0)}
.nav-links::before{content:"\274B";position:absolute;top:30px;left:clamp(30px,6vw,68px);color:var(--orange);font-size:1.6rem;animation:spin 16s linear infinite}
.nav-links li{width:100%}
.nav-links a{font-family:var(--display)!important;text-transform:uppercase;font-size:clamp(2.1rem,1.2rem + 3.4vw,3.6rem)!important;line-height:0.8;font-weight:400;color:var(--cream);opacity:1;padding:4px 0;display:inline-block}
.nav-links a::after{height:3px;background:var(--orange);bottom:2px}
.nav-links a:hover{color:var(--orange)}
.nav-links .btn--primary{display:inline-flex!important;font-family:var(--body)!important;font-size:1rem!important;text-transform:none;letter-spacing:.01em;background:var(--orange);color:var(--cream);margin-top:20px;padding:1em 1.6em}
.nav-links .btn--primary::after{display:none}
.nav.menu-open{color:var(--cream)}
.nav.menu-open .nav-toggle{border-color:var(--cream)}
.nav.menu-open .nav-toggle span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav.menu-open .nav-toggle span:nth-child(2){opacity:0}
.nav.menu-open .nav-toggle span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
/* backdrop */
.nav-backdrop{position:fixed;inset:0;background:rgba(20,18,14,.5);opacity:0;visibility:hidden;transition:opacity .4s,visibility .4s;z-index:105}
.nav-backdrop.show{opacity:1;visibility:visible}

/* ===== Horizontal pinned gallery (whole panels) ===== */
.hsection{position:relative;height:400vh;background:var(--cream)}
.hsticky{position:sticky;top:0;height:100vh;overflow:hidden}
.hstrip{display:flex;height:100%;width:max-content;will-change:transform}
.hpanel{flex:0 0 100vw;height:100%;display:flex;align-items:center;padding-block:120px}
.hpanel .container{width:100%}
.hpanel .pk{font-family:var(--display);font-size:clamp(4rem,3rem + 6vw,11rem);line-height:.8;color:currentColor;opacity:.22}
.hpanel h2{font-size:clamp(2.4rem,1.5rem + 4.5vw,6rem);margin:.1em 0 .3em;max-width:18ch}
.hpanel p{max-width:52ch;font-size:var(--step-1)}
.hprogress{position:absolute;left:var(--gutter);right:var(--gutter);bottom:38px;height:3px;background:rgba(38,35,31,.16);z-index:3}
.hpanel.panel-dark ~ .hprogress,.hsection .hprogress i{display:block}
.hprogress i{position:absolute;left:0;top:0;height:100%;width:25%;background:var(--ink);transition:transform .2s linear}
.hscroll-cue{position:absolute;right:var(--gutter);bottom:54px;z-index:3;font-family:var(--body);font-weight:600;font-size:var(--step--1);letter-spacing:.12em;text-transform:uppercase;display:flex;align-items:center;gap:.5em}
.hscroll-cue svg{width:1.2em;height:1.2em;animation:nudge 1.4s ease-in-out infinite}
@keyframes nudge{0%,100%{transform:translateX(0)}50%{transform:translateX(5px)}}
@media (max-width:760px){
  .hsection{height:auto}
  .hsticky{position:static;height:auto;overflow:visible}
  .hstrip{flex-direction:column;width:auto}
  .hpanel{flex-basis:auto;height:auto;min-height:78vh;padding-block:90px}
  .hprogress,.hscroll-cue{display:none}
}

@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important;scroll-behavior:auto!important}
  .reveal-line > span{transform:none!important;opacity:1!important}
  [data-reveal]{opacity:1!important;transform:none!important}
  .fade-up{opacity:1!important;transform:none!important}
  .marquee-track,.flower,.seal{animation:none}
  .cursor{display:none!important}
  .nav-links::before{animation:none}
  .hsection{height:auto}
  .hsticky{position:static;height:auto;overflow:visible}
  .hstrip{flex-direction:column;width:auto;transform:none!important}
  .hpanel{flex-basis:auto;height:auto;min-height:auto}
  .hprogress,.hscroll-cue{display:none}
  .tilt-l[data-reveal].in{transform:rotate(-4deg)!important}
  .tilt-r[data-reveal].in{transform:rotate(3.5deg)!important}
}
