/* ============================================================
   APM — AI. DATA. SYSTEMS.
   Design system  ·  B/N cinematografico  ·  Raleway
   Palette: #FFFFFF · #B0B0B0 · #2B2B2B · #000000
   ============================================================ */

:root{
  --black:#000000;
  --ink:#FFFFFF;
  --mut:#FFFFFF;
  --line:#2B2B2B;
  --panel:#0A0A0C;
  --panel-2:#101013;

  --maxw:1240px;
  --pad-x:clamp(20px,5vw,64px);
  --pad-y:clamp(64px,12vw,150px);

  --fs-display:clamp(2.5rem,9vw,5.6rem);
  --fs-h2:clamp(1.7rem,5vw,3.1rem);
  --fs-h3:clamp(1.05rem,2.4vw,1.35rem);
  --fs-body:clamp(.95rem,1.4vw,1.05rem);
  --eyebrow:.72rem;

  --ease:cubic-bezier(.22,.61,.36,1);
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  background:var(--black);
  color:var(--ink);
  font-family:'Raleway',system-ui,sans-serif;
  font-weight:300;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer}
svg{display:block}

/* ---------- helper ---------- */
.wrap{max-width:var(--maxw);margin-inline:auto;padding-inline:var(--pad-x)}
.section{padding-block:var(--pad-y)}
.eyebrow{
  font-size:var(--eyebrow);font-weight:500;letter-spacing:.32em;
  text-transform:uppercase;color:var(--mut);
}
.rule{height:1px;background:var(--line);border:0}

/* reveal on scroll */
[data-reveal]{opacity:0;transform:translateY(22px);
  transition:opacity .9s var(--ease),transform .9s var(--ease)}
[data-reveal].in{opacity:1;transform:none}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:.6em;
  font-size:.74rem;font-weight:600;letter-spacing:.2em;text-transform:uppercase;
  padding:1.05em 1.8em;border:1px solid var(--ink);
  background:transparent;color:var(--ink);
  transition:background .35s var(--ease),color .35s var(--ease),border-color .35s var(--ease);
}
.btn:hover,.btn:focus-visible{background:var(--ink);color:var(--black)}
.btn--ghost{border-color:var(--line);color:var(--mut)}
.btn--ghost:hover,.btn--ghost:focus-visible{border-color:var(--ink);background:transparent;color:var(--ink)}
.link-more{
  font-size:.74rem;font-weight:600;letter-spacing:.2em;text-transform:uppercase;
  color:var(--ink);display:inline-flex;align-items:center;gap:.7em;
}
.link-more::after{content:"";width:30px;height:1px;background:currentColor;transition:width .35s var(--ease)}
.link-more:hover::after{width:48px}

/* ---------- brand mark (placeholder del logo) ---------- */
.brand{display:inline-flex;flex-direction:column;gap:.25em;line-height:1}
.brand__word{font-weight:700;font-size:1.45rem;letter-spacing:.14em}
.brand__tag{font-size:.52rem;font-weight:500;letter-spacing:.34em;color:var(--mut)}

/* ============================================================
   NAV
   ============================================================ */
.nav{
  position:fixed;inset:0 0 auto 0;z-index:100;
  display:flex;align-items:center;justify-content:flex-end;
  padding:1.1rem var(--pad-x);
  transition:background .4s var(--ease),border-color .4s var(--ease);
  border-bottom:1px solid transparent;
}
.nav.is-scrolled{background:rgba(0,0,0,.78);backdrop-filter:blur(10px);border-bottom-color:var(--line)}
.nav__logo{
  position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);
  display:flex;align-items:center;opacity:1;pointer-events:auto;
  transition:opacity .4s var(--ease);
}
.nav__logo img{height:17px;width:auto;display:block}
body.home .nav__logo{opacity:0;pointer-events:none}
body.home.moon-faded .nav__logo{opacity:1;pointer-events:auto}
.nav__menu{display:none}
.nav__links{display:flex;gap:1.6rem;list-style:none}
.nav__links a{
  font-size:.7rem;font-weight:500;letter-spacing:.18em;text-transform:uppercase;color:var(--mut);
  transition:color .3s var(--ease);
}
.nav__links a:hover{color:var(--ink)}
.nav__cta{display:none}
.nav__toggle{
  display:inline-flex;flex-direction:column;gap:5px;width:30px;
  background:none;border:0;padding:4px 0;
}
.nav__toggle span{height:1.5px;background:var(--ink);transition:transform .3s var(--ease),opacity .3s var(--ease)}
.nav.is-open .nav__toggle span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
.nav.is-open .nav__toggle span:nth-child(2){opacity:0}
.nav.is-open .nav__toggle span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}

/* mobile menu panel */
.nav__panel{
  position:fixed;inset:0;z-index:99;background:var(--black);
  display:flex;flex-direction:column;justify-content:center;gap:.4rem;
  padding:var(--pad-x);
  transform:translateY(-100%);opacity:0;pointer-events:none;
  transition:transform .5s var(--ease),opacity .5s var(--ease);
}
.nav__panel.is-open{transform:none;opacity:1;pointer-events:auto}
.nav__panel a{
  font-size:1.4rem;font-weight:300;letter-spacing:.12em;text-transform:uppercase;
  padding:.5rem 0;border-bottom:1px solid var(--line);color:var(--ink);
}
.nav__panel .btn{margin-top:1.6rem;align-self:flex-start}

/* ============================================================
   HERO
   ============================================================ */
.hero{position:relative;background:#000}
.hero__img{width:100%;display:block;background:#000}
.hero__inner{
  position:relative;z-index:2;max-width:var(--maxw);margin-inline:auto;
  padding-inline:var(--pad-x);
  margin-top:clamp(-30px,-5vw,-6px);          /* claim attaccato alla luna */
  padding-bottom:clamp(48px,9vw,96px);
}
.hero h1{
  font-size:var(--fs-display);font-weight:200;line-height:1.02;letter-spacing:.01em;
  margin-bottom:1.4rem;
}
.hero h1 span{display:block}
.hero__motto{
  font-size:clamp(1.05rem,2.2vw,1.5rem);font-weight:300;letter-spacing:.02em;
  color:var(--ink);margin-bottom:2.4rem;
}

/* ============================================================
   SERVIZI (4 card)
   ============================================================ */
.services{border-top:1px solid var(--line)}
.services__grid{
  display:grid;grid-template-columns:1fr;gap:0;
}
.scard{
  padding:clamp(28px,5vw,44px) 0;border-bottom:1px solid var(--line);
}
.scard__ic{width:34px;height:34px;color:var(--ink);margin-bottom:1.6rem}
.scard h3{font-size:var(--fs-h3);font-weight:500;letter-spacing:.04em;text-transform:uppercase;margin-bottom:.7rem}
.scard p{color:var(--mut);font-size:.95rem;max-width:30ch}

/* ============================================================
   FEATURE (gufo)
   ============================================================ */
.feature{position:relative;border-top:1px solid var(--line)}
.feature__media{
  position:relative;min-height:54vh;
  background:
    radial-gradient(80% 90% at 70% 30%, rgba(180,180,180,.16), transparent 55%),
    linear-gradient(180deg,#0c0c0f,#000);
  display:flex;align-items:flex-end;
}
.feature__media .slot{
  margin:auto auto 1.4rem;font-size:.6rem;letter-spacing:.3em;text-transform:uppercase;color:#3a3a3c;
}
.feature__media--ai{
  background:
    linear-gradient(180deg,rgba(0,0,0,.12),rgba(0,0,0,.40)),
    url('../assets/ai-consulting.jpg') center/cover no-repeat;
}
.feature__body{padding-block:clamp(40px,8vw,90px)}
.feature__body h2{font-size:var(--fs-h2);font-weight:200;line-height:1.1;margin-bottom:1.5rem}
.feature__body p{color:var(--mut);max-width:46ch;margin-bottom:2rem}

/* ============================================================
   FRONTIERE
   ============================================================ */
.frontier{
  position:relative;border-top:1px solid var(--line);
  min-height:62vh;display:flex;align-items:center;
  background:
    radial-gradient(100% 120% at 50% 120%, rgba(140,140,140,.18), transparent 60%),
    linear-gradient(180deg,#000,#0a0a0c);
  overflow:hidden;
}
.frontier h2{
  font-size:var(--fs-h2);font-weight:200;line-height:1.12;text-align:center;
  width:100%;letter-spacing:.02em;
}
.frontier h2 .dim{color:var(--mut)}

/* ============================================================
   PROCESSO 01–05
   ============================================================ */
.process{border-top:1px solid var(--line)}
.process__head{margin-bottom:clamp(36px,6vw,64px)}
.process__head h2{font-size:var(--fs-h2);font-weight:200;margin-top:.8rem}
.steps{display:grid;grid-template-columns:1fr;gap:0}
.step{
  display:grid;grid-template-columns:auto 1fr;gap:1.4rem;align-items:start;
  padding:1.7rem 0;border-top:1px solid var(--line);
}
.step:last-child{border-bottom:1px solid var(--line)}
.step__num{font-size:.72rem;font-weight:600;letter-spacing:.2em;color:var(--mut);padding-top:.3rem}
.step__ic{width:30px;height:30px;color:var(--ink);margin-bottom:.9rem}
.step h3{font-size:1rem;font-weight:500;letter-spacing:.06em;text-transform:uppercase;margin-bottom:.45rem}
.step p{color:var(--mut);font-size:.92rem;max-width:42ch}

/* ============================================================
   FOOTER
   ============================================================ */
.footer{border-top:1px solid var(--line);background:var(--panel)}
.footer__top{
  display:grid;grid-template-columns:1fr;gap:clamp(32px,6vw,56px);
  padding-block:clamp(48px,8vw,88px);
}
.footer__claim{font-size:clamp(1.2rem,3.2vw,1.8rem);font-weight:200;line-height:1.25;max-width:24ch}
.footer__cols{display:grid;grid-template-columns:repeat(2,1fr);gap:2rem}
.footer__col h4{font-size:.66rem;font-weight:600;letter-spacing:.24em;text-transform:uppercase;color:var(--mut);margin-bottom:1rem}
.footer__col a{display:block;font-size:.86rem;color:var(--ink);padding:.28rem 0;opacity:.8;transition:opacity .3s var(--ease)}
.footer__col a:hover{opacity:1}
.footer__bar{
  display:flex;flex-direction:column;gap:1rem;
  padding-block:1.6rem;border-top:1px solid var(--line);
  font-size:.66rem;letter-spacing:.14em;text-transform:uppercase;color:var(--mut);
}

/* ============================================================
   DESKTOP
   ============================================================ */
@media(min-width:760px){
  .footer__top{grid-template-columns:1.3fr 1fr}
  .footer__cols{grid-template-columns:repeat(3,1fr)}
  .footer__bar{flex-direction:row;justify-content:space-between;align-items:center}
  .services__grid{grid-template-columns:repeat(2,1fr);column-gap:clamp(24px,4vw,56px)}
  .scard{border-bottom:1px solid var(--line)}
  .steps{grid-template-columns:repeat(5,1fr);gap:0}
  .step{
    grid-template-columns:1fr;border-top:0;border-left:1px solid var(--line);
    padding:0 clamp(14px,2vw,26px);min-height:200px;
  }
  .step:first-child{border-left:0;padding-left:0}
  .step:last-child{border-bottom:0}
  .feature{display:grid;grid-template-columns:1fr 1fr;align-items:stretch}
  .feature__media{min-height:100%}
  .feature__body{display:flex;flex-direction:column;justify-content:center;padding-inline:clamp(36px,5vw,72px)}
}
@media(min-width:980px){
  .nav__menu{display:flex;align-items:center;gap:2.4rem}
  .nav__cta{display:inline-flex}
  .nav__toggle{display:none}
}

@media(prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  [data-reveal]{opacity:1;transform:none;transition:none}
}

/* ============================================================
   PAGINA CHI SIAMO
   ============================================================ */
.about-hero{padding-top:clamp(96px,15vh,140px);padding-bottom:clamp(28px,6vw,56px)}
.about-grid{display:grid;grid-template-columns:1fr;gap:clamp(28px,5vw,56px);align-items:center}
.about__photo{
  position:relative;width:100%;max-width:360px;aspect-ratio:18/19;overflow:hidden;
  border:1px solid var(--line);background:linear-gradient(180deg,#0c0c0f,#000);
  display:flex;align-items:center;justify-content:center;
  color:#3a3a3c;font-size:.6rem;letter-spacing:.3em;text-transform:uppercase;
}
.about__photo img{position:absolute;inset:0;width:100%;height:100%;object-fit:contain}
.about__role{font-size:.76rem;font-weight:500;letter-spacing:.2em;text-transform:uppercase;color:var(--mut);margin-bottom:.4rem}
.about__intro h1{font-size:clamp(2rem,6vw,3.4rem);font-weight:200;line-height:1.04;margin:.4rem 0 1.2rem}
.about__intro p{color:var(--mut);max-width:50ch}
@media(min-width:760px){.about-grid{grid-template-columns:360px 1fr;align-items:start;gap:clamp(22px,3vw,42px)}}
.about-section{padding-block:clamp(40px,7vw,80px);border-top:1px solid var(--line)}
.about-section > .eyebrow{display:block;margin-bottom:clamp(22px,4vw,40px)}

.tl__item{display:grid;grid-template-columns:auto 1fr;gap:1.3rem;padding:1.5rem 0;border-top:1px solid var(--line)}
.tl__item:last-child{border-bottom:1px solid var(--line)}
.tl__yr{font-size:.74rem;font-weight:600;letter-spacing:.12em;color:var(--mut);white-space:nowrap;padding-top:.2rem}
.tl__b h3{font-size:1.05rem;font-weight:500;letter-spacing:.03em;margin-bottom:.4rem}
.tl__b p{color:var(--mut);font-size:.92rem;max-width:56ch}

.cols3{display:grid;grid-template-columns:1fr;gap:clamp(26px,4vw,44px)}
.cgrp h3{font-size:.72rem;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:var(--mut);margin-bottom:1rem}
.cgrp ul{list-style:none}
.cgrp li{padding:.5rem 0;border-bottom:1px solid var(--line);font-size:.92rem;color:var(--ink)}

.proj{display:grid;grid-template-columns:1fr;gap:1.4rem}
.pcard{border:1px solid var(--line);padding:clamp(22px,4vw,34px)}
.pcard h3{font-size:1.1rem;font-weight:500;margin-bottom:.55rem;letter-spacing:.02em}
.pcard p{color:var(--mut);font-size:.92rem}

.about-cta{padding-block:clamp(48px,8vw,90px);border-top:1px solid var(--line);text-align:center}
.about-cta h2{font-size:var(--fs-h2);font-weight:200;margin-bottom:1.8rem}

@media(min-width:760px){
  .about-grid{grid-template-columns:.82fr 1.18fr}
  .cols3{grid-template-columns:repeat(3,1fr)}
  .proj{grid-template-columns:repeat(2,1fr)}
}

/* ============================================================
   SERVIZIO IN EVIDENZA — Consulenza AI & Innovazione (con foto)
   ============================================================ */
.feat{
  display:grid;grid-template-columns:1fr;
  border:1px solid var(--line);overflow:hidden;
  margin:clamp(28px,5vw,52px) 0 clamp(20px,4vw,36px);
}
.feat__media{
  min-height:56vw;max-height:380px;
  background:linear-gradient(180deg,rgba(0,0,0,.10),rgba(0,0,0,.42)),
    url('../assets/ai-consulting.jpg') center/cover no-repeat;
}
.feat__body{
  padding:clamp(26px,5vw,46px);
  display:flex;flex-direction:column;justify-content:center;
}
.feat__body .scard__ic{margin-bottom:1.1rem}
.feat__body h3{
  font-size:var(--fs-h3);font-weight:500;letter-spacing:.05em;
  text-transform:uppercase;margin-bottom:.7rem;
}
.feat__body p{color:var(--mut);max-width:46ch;margin-bottom:1.5rem}

@media(min-width:760px){
  .feat{grid-template-columns:1.05fr 1fr}
  .feat__media{min-height:100%}
  .services__grid--3{grid-template-columns:repeat(3,1fr)}
}

/* ============================================================
   PAGINA CONFORMITÀ & AI ACT
   ============================================================ */
.lead{font-size:clamp(1rem,2.4vw,1.18rem);color:var(--mut);max-width:58ch;margin-top:1.3rem;line-height:1.6}
.pcard__tag{display:inline-block;margin-top:1rem;font-size:.68rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--mut)}
.disclaimer{padding-block:clamp(26px,5vw,46px);border-top:1px solid var(--line)}
.disclaimer p{color:var(--mut);font-size:.78rem;max-width:74ch;opacity:.78;line-height:1.6}
@media(min-width:760px){ .frame4{grid-template-columns:repeat(2,1fr)} }

/* ============================================================
   PAGINA APM PER HOTEL + DEMO SOFIA
   ============================================================ */
.hsec-hero{padding-top:clamp(96px,15vh,140px);padding-bottom:clamp(28px,6vw,56px)}
.hsec-hero h1{font-size:clamp(2rem,6.4vw,3.6rem);font-weight:200;line-height:1.06;margin:.6rem 0 1.2rem;max-width:20ch}
.hsec-hero .lead{max-width:54ch}
.hsec-hero .cta-row{display:flex;flex-wrap:wrap;gap:.8rem;margin-top:1.8rem}

.plist{list-style:none;max-width:62ch;margin-top:.4rem}
.plist li{padding:.75rem 0;border-top:1px solid var(--line);color:var(--mut);font-size:.95rem;display:flex;gap:.8rem;line-height:1.5}
.plist li::before{content:"—";color:var(--mut);flex:none}

.benefits{display:grid;grid-template-columns:1fr;gap:0}
.benefits .b{padding:1.35rem 0;border-top:1px solid var(--line)}
.benefits .b:last-child{border-bottom:1px solid var(--line)}
.benefits h3{font-size:1.02rem;font-weight:500;letter-spacing:.02em;margin-bottom:.4rem}
.benefits p{color:var(--mut);font-size:.92rem;max-width:58ch}

.signal{max-width:62ch;color:var(--mut);font-size:clamp(1rem,2.2vw,1.12rem);line-height:1.6}
.signal a{color:var(--ink);text-decoration:none;border-bottom:1px solid var(--line)}

/* --- DEMO WIDGET --- */
.demo{border:1px solid var(--line);max-width:640px;margin:clamp(24px,4vw,40px) auto 0;background:var(--panel);display:flex;flex-direction:column;overflow:hidden}
.demo__bar{display:flex;align-items:center;gap:.6rem;padding:.85rem 1.1rem;border-bottom:1px solid var(--line)}
.demo__dot{width:9px;height:9px;border-radius:50%;background:#666;flex:none;transition:background .3s}
.demo[data-state="online"]  .demo__dot{background:#3ad07a;box-shadow:0 0 0 3px rgba(58,208,122,.16)}
.demo[data-state="offline"] .demo__dot{background:#777}
.demo[data-state="checking"].demo .demo__dot,.demo[data-state="checking"] .demo__dot{background:#caa23a}
.demo__title{font-size:.82rem;letter-spacing:.05em;font-weight:500}
.demo__state{margin-left:auto;font-size:.66rem;letter-spacing:.14em;text-transform:uppercase;color:var(--mut)}
.demo__log{min-height:240px;max-height:380px;overflow-y:auto;padding:1.1rem;display:flex;flex-direction:column;gap:.7rem;font-size:.92rem}
.msg{max-width:84%;padding:.62rem .85rem;border:1px solid var(--line);line-height:1.45;white-space:pre-wrap;word-wrap:break-word}
.msg--u{align-self:flex-end;background:var(--panel-2);border-color:#26262b}
.msg--a{align-self:flex-start;background:transparent}
.msg--sys{align-self:center;color:var(--mut);font-size:.78rem;border:0;text-align:center;max-width:100%;padding:.2rem}
.demo__chips{display:flex;flex-wrap:wrap;gap:.5rem;padding:0 1.1rem .9rem}
.chip{font:inherit;font-size:.78rem;color:var(--ink);background:transparent;border:1px solid var(--line);padding:.42rem .72rem;cursor:pointer;transition:border-color .2s,background .2s}
.chip:hover{border-color:#3a3a40;background:#141417}
.chip:disabled{opacity:.4;cursor:not-allowed}
.demo__input{display:flex;gap:.5rem;padding:.85rem 1.1rem;border-top:1px solid var(--line)}
.demo__input input{flex:1;font:inherit;font-size:.9rem;color:var(--ink);background:var(--panel-2);border:1px solid var(--line);padding:.62rem .8rem;outline:none}
.demo__input input:focus{border-color:#3a3a40}
.demo__input button{font:inherit;font-size:.8rem;letter-spacing:.06em;text-transform:uppercase;color:#000;background:var(--ink);border:0;padding:.62rem 1.1rem;cursor:pointer}
.demo__input button:disabled{opacity:.4;cursor:not-allowed}
.demo__offline{padding:1.5rem 1.1rem 1.7rem;text-align:center;border-top:1px solid var(--line)}
.demo__offline p{color:var(--mut);font-size:.88rem;margin:0 auto 1rem;max-width:44ch;line-height:1.55}
.demo__note{max-width:640px;margin:1rem auto 0;color:var(--mut);font-size:.78rem;line-height:1.6;text-align:center;opacity:.82}
.demo__note strong{color:var(--ink);font-weight:500}

/* ============================================================
   SFONDO LUNA FISSO + VELO  (v3)
   ============================================================ */
.moon-bg{position:fixed;inset:0;z-index:0;pointer-events:none;will-change:filter;
  background:#000 url('../assets/hero-moon.png') top center / min(1180px,165%) auto no-repeat;}
.moon-veil{position:fixed;inset:0;z-index:0;pointer-events:none;background:#000;opacity:.45;}
body:not(.home) .moon-bg{filter:blur(15px);transform:scale(1.06)}
body:not(.home) .moon-veil{opacity:.8}
.nav{z-index:100}
main{position:relative;z-index:1}
.hero,.footer{background:transparent}

/* nav: logo a sinistra, niente overlap col menu */
.nav__logo{left:var(--pad-x);top:50%;transform:translateY(-50%)}
.nav__logo img{height:20px}
.brand__logo{height:28px;width:auto;display:block}

/* hero: claim fin sotto la luna, leggera sovrapposizione */
.hero{min-height:auto;display:block;
  padding-top:calc(min(1180px,165vw)/2.55);
  padding-bottom:clamp(40px,8vh,96px)}
.hero .hero__inner{margin-top:-2.2em;padding-bottom:0}
.hero h1{text-shadow:0 2px 34px rgba(0,0,0,.55)}
.hero__motto{text-shadow:0 1px 20px rgba(0,0,0,.5)}

/* ============================================================
   CAROSELLO · IN CANTIERE
   ============================================================ */
.cantiere__head{display:flex;align-items:flex-end;justify-content:space-between;gap:1rem;flex-wrap:wrap;margin-bottom:clamp(22px,4vw,40px)}
.cantiere__head h2{font-size:var(--fs-h2);font-weight:200;margin-top:.4rem}
.cantiere__nav{display:flex;gap:.5rem}
.cnav{font:inherit;font-size:1rem;color:var(--ink);background:transparent;border:1px solid var(--line);width:42px;height:42px;cursor:pointer;transition:border-color .2s,background .2s}
.cnav:hover{border-color:#3a3a40;background:#141417}
.track{display:flex;gap:1rem;overflow-x:auto;scroll-snap-type:x mandatory;padding-bottom:.6rem;scrollbar-width:thin}
.track::-webkit-scrollbar{height:5px}
.track::-webkit-scrollbar-thumb{background:#2b2b2b}
.pslide{flex:0 0 84%;max-width:520px;scroll-snap-align:start;border:1px solid var(--line);background:var(--panel);
  min-height:300px;padding:clamp(22px,4vw,34px);display:flex;flex-direction:column;justify-content:flex-end;gap:.5rem;
  text-decoration:none;color:var(--ink);transition:border-color .3s var(--ease),transform .3s var(--ease)}
a.pslide:hover{border-color:#4a4a52;transform:translateY(-3px)}
.pslide__tag{font-size:.68rem;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--mut)}
.pslide h3{font-size:1.5rem;font-weight:300;letter-spacing:.02em}
.pslide p{color:var(--mut);font-size:.92rem;max-width:42ch}
.pslide__cta{margin-top:.4rem;font-size:.8rem;letter-spacing:.1em;text-transform:uppercase}
.pslide--soon{border-style:dashed;opacity:.7}
@media(min-width:760px){ .pslide{flex-basis:40%} }

/* ============================================================
   SPOTLIGHT · blocco Contatti in fondo
   ============================================================ */
@keyframes spotPulse{
  0%{box-shadow:0 0 0 0 rgba(255,255,255,0);background:transparent}
  18%{box-shadow:0 0 0 2px rgba(255,255,255,.92),0 0 46px rgba(255,255,255,.22);background:rgba(255,255,255,.07)}
  100%{box-shadow:0 0 0 0 rgba(255,255,255,0);background:transparent}
}
#foot-contatti.spotlight{animation:spotPulse 1.9s var(--ease) forwards;padding:14px;margin:-14px}

/* ===== HERO HOTEL CON FOTO DI SFONDO ===== */
.hsec-hero--photo{position:relative;background:#000;overflow:hidden;
  padding:clamp(118px,18vh,180px) 0 clamp(56px,10vh,104px)}
.hsec-hero--photo::before{content:"";position:absolute;inset:0;z-index:0;
  background:url('../assets/hotel-hero.jpg') center 38%/cover no-repeat;opacity:1}
.hsec-hero--photo::after{content:"";position:absolute;inset:0;z-index:0;background:transparent}
.hsec-hero--photo > .wrap{position:relative;z-index:1}
.hsec-hero--photo h1{text-shadow:0 2px 6px rgba(0,0,0,.7),0 1px 24px rgba(0,0,0,.5)}
.hsec-hero--photo .lead{color:#ffffff;text-shadow:0 1px 4px rgba(0,0,0,.85),0 1px 14px rgba(0,0,0,.5)}
.hsec-hero--photo .about__role{text-shadow:0 1px 4px rgba(0,0,0,.85)}
.hsec-hero--conf::before{background:url('../assets/conformita-hero.jpg') center/cover no-repeat;opacity:1}
.hsec-hero--conf::after{background:
  linear-gradient(90deg,rgba(0,0,0,.66) 0%,rgba(0,0,0,.42) 38%,rgba(0,0,0,.10) 64%,rgba(0,0,0,0) 100%),
  linear-gradient(180deg,rgba(0,0,0,.08) 0%,rgba(0,0,0,.30) 100%)}

/* ===== CARD "Sofia per Hotel" · sfondo tulipani (testo nero sx, fiori liberi dx) ===== */
.pslide--sofia{position:relative;overflow:hidden;color:#161616;border-color:#e6e6e6;
  background-color:#ffffff;
  background-image:url('../assets/sofia-bg.jpg');
  background-repeat:no-repeat;background-position:right center;background-size:cover}
.pslide--sofia::before{content:"";position:absolute;inset:0;z-index:0;
  background:linear-gradient(90deg,#fff 0%,rgba(255,255,255,.94) 38%,rgba(255,255,255,.45) 64%,rgba(255,255,255,0) 86%),
            linear-gradient(0deg,rgba(255,255,255,.9) 0%,rgba(255,255,255,0) 42%)}
.pslide--sofia > *{position:relative;z-index:1}
.pslide--sofia .pslide__tag{color:#5c5c5c}
.pslide--sofia h3{color:#141414}
.pslide--sofia p{color:#3a3a3a}
.pslide--sofia .pslide__cta{color:#141414}
a.pslide--sofia:hover{border-color:#bdbdbd;transform:translateY(-3px)}

/* leggibilità card Ausonia: testo nero in grassetto */
.pslide--sofia .pslide__tag{color:#3d3d3d;font-weight:700}
.pslide--sofia h3{color:#0e0e0e;font-weight:600}
.pslide--sofia p{color:#242424;font-weight:600;font-size:.96rem}
.pslide--sofia .pslide__cta{color:#0e0e0e;font-weight:700}

/* slide CTA del carosello */
.pslide--cta{background:var(--panel-2);border-color:#2f2f36}
a.pslide--cta:hover{border-color:#5a5a64;transform:translateY(-3px)}
.pslide--cta .pslide__cta{color:#fff}

/* gli anchor non finiscono sotto la nav fissa; hero un filo più compatto su mobile */
html{scroll-padding-top:78px}
@media(max-width:680px){ .hero{min-height:auto} .hero .hero__inner{padding-bottom:clamp(8px,2vh,20px)} }

/* ===== CARD "Ring" · gufo vigile (progetto simulato) ===== */
.pslide--ring{position:relative;overflow:hidden;color:#161616;border-color:#e6e6e6;min-height:360px;
  background-color:#ffffff;background-image:url('../assets/ring-owl.jpg');
  background-repeat:no-repeat;background-position:center top;background-size:cover}
.pslide--ring::before{content:"";position:absolute;inset:0;z-index:0;
  background:linear-gradient(0deg,#fff 0%,#fff 24%,rgba(255,255,255,.35) 46%,rgba(255,255,255,0) 64%)}
.pslide--ring > *{position:relative;z-index:1}
.pslide--ring .pslide__tag{color:#3d3d3d;font-weight:700}
.pslide--ring h3{color:#0e0e0e;font-weight:600}
.pslide--ring p{color:#242424;font-weight:600}

/* ===== CARD "APM Robots" · copertina + video 9:16 in-place ===== */
.pslide--robots{position:relative;overflow:hidden;min-height:clamp(340px,46vw,420px);
  padding-bottom:clamp(84px,9vw,94px);
  background-color:#0a0a0c;background-image:url('../assets/robots-cover.jpg');
  background-repeat:no-repeat;background-position:center;background-size:cover}
.pslide--robots::before{content:"";position:absolute;inset:0;z-index:0;
  background:linear-gradient(0deg,rgba(0,0,0,.86) 0%,rgba(0,0,0,.34) 46%,rgba(0,0,0,.04) 76%)}
.pslide--robots > *{position:relative;z-index:1}
a.pslide--robots:hover{border-color:#4a4a52;transform:translateY(-3px)}
.pslide__play{position:absolute;left:clamp(16px,3vw,24px);bottom:clamp(16px,3vw,24px);z-index:3;
  width:48px;height:48px;border-radius:50%;border:1px solid rgba(255,255,255,.55);
  background:rgba(255,255,255,.15);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);
  color:#fff;font-size:.95rem;padding-left:3px;display:flex;align-items:center;justify-content:center;
  cursor:pointer;transition:background .25s var(--ease),transform .25s var(--ease)}
.pslide__play:hover{background:rgba(255,255,255,.30);transform:scale(1.07)}
/* lightbox video: si espande dalla posizione della slide fino al 9:16, oscurando il sito */
.vlightbox[hidden]{display:none}
.vlightbox{position:fixed;inset:0;z-index:1000}
.vlightbox__backdrop{position:absolute;inset:0;background:rgba(0,0,0,.93);opacity:0;
  transition:opacity .45s var(--ease);cursor:pointer}
.vlightbox.is-open .vlightbox__backdrop{opacity:1}
.vlightbox__player{position:fixed;overflow:hidden;background:#000;border-radius:4px;
  box-shadow:0 30px 90px rgba(0,0,0,.65);
  transition:left .5s var(--ease),top .5s var(--ease),width .5s var(--ease),height .5s var(--ease)}
.vlightbox__player video{width:100%;height:100%;object-fit:cover;display:block;background:#000}
.vlightbox__close{position:absolute;top:8px;right:8px;z-index:2;width:36px;height:36px;border-radius:50%;
  border:1px solid rgba(255,255,255,.45);background:rgba(0,0,0,.5);backdrop-filter:blur(4px);
  -webkit-backdrop-filter:blur(4px);color:#fff;cursor:pointer;display:flex;align-items:center;
  justify-content:center;font-size:1rem;line-height:1;opacity:0;transition:opacity .3s .15s}
.vlightbox.is-open .vlightbox__close{opacity:1}

/* luna nitida (home, in cima) = NESSUN velo; compare solo scrollando */
body.home .moon-veil{opacity:0}

/* header "In cantiere": titolo raggruppato; su mobile le frecce vanno SOTTO */
.cantiere__title .eyebrow{margin-bottom:.45rem}
.cantiere__title h2{margin-top:0}
@media(max-width:680px){
  .cantiere__head{flex-direction:column;align-items:flex-start;gap:1.1rem}
  .cantiere__nav{order:2}
}

/* chiudo il buco tra l'hero (pulsante) e "In cantiere" */
.hero{padding-bottom:clamp(14px,2.5vh,34px)}
.cantiere.section{padding-top:clamp(6px,1.6vw,22px)}
