
:root{
  --black:#050505;--cream:#f5f1e8;
  --muted:rgba(245,241,232,.62);--dim:rgba(245,241,232,.36);--line:rgba(245,241,232,.10);
  --paper:#f0e8dc;--ink:#12110f;--ease:cubic-bezier(.16,1,.3,1);--max:1360px;
  /* colore progetto — Orion/Branding */
  --pc:#171a30;--pc-l:#c8cdea;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;background:var(--black);scroll-padding-top:84px}
body{font-family:Inter,system-ui,sans-serif;background:#050505;color:var(--cream);overflow-x:hidden;line-height:1.65;-webkit-font-smoothing:antialiased;text-rendering:geometricPrecision;cursor:none;opacity:0;transition:opacity .75s var(--ease)}
body.is-ready{opacity:1}
a{text-decoration:none;color:inherit} svg{display:block} ::selection{background:#faf9f6;color:var(--black)}

/* CURSOR */
.cursor-light{position:fixed;width:360px;height:360px;border-radius:50%;pointer-events:none;z-index:5;opacity:0;background:radial-gradient(circle,rgba(245,241,232,.11),rgba(245,241,232,0) 65%);mix-blend-mode:screen;transform:translate(-50%,-50%);transition:opacity .35s var(--ease)}
.cursor-dot{position:fixed;left:0;top:0;width:8px;height:8px;border-radius:50%;background:#faf9f6;pointer-events:none;z-index:10001;transform:translate(-50%,-50%);mix-blend-mode:difference;opacity:.95}
.cursor-ring{position:fixed;left:0;top:0;width:42px;height:42px;border-radius:50%;border:1px solid rgba(245,241,232,.55);pointer-events:none;z-index:10000;transform:translate(-50%,-50%);mix-blend-mode:difference;opacity:.8;transition:width .28s var(--ease),height .28s var(--ease),border-color .28s var(--ease),opacity .28s var(--ease)}
body.cursor-hover .cursor-ring{width:68px;height:68px;border-color:rgba(245,241,232,.85);opacity:1}
body.cursor-hover .cursor-dot{transform:translate(-50%,-50%) scale(.65)}

/* TYPE */
.serif{font-family:"Playfair Display",Georgia,serif;font-weight:400;letter-spacing:-.045em;line-height:.94}
.italic{font-style:italic;letter-spacing:-.035em}
.kicker{font-size:10px;font-weight:500;letter-spacing:.32em;text-transform:uppercase;color:var(--dim)}
.text{font-size:clamp(16px,1.25vw,20px);font-weight:300;color:var(--muted);line-height:1.76;max-width:620px}

/* REVEAL */
.reveal{opacity:0;transform:translateY(34px);filter:blur(8px);transition:opacity 1s var(--ease),transform 1s var(--ease),filter 1s var(--ease)}
.reveal.visible{opacity:1;transform:none;filter:blur(0)}
.delay1{transition-delay:.10s}.delay2{transition-delay:.20s}.delay3{transition-delay:.32s}.delay4{transition-delay:.44s}

/* NAV */
.nav{position:fixed;top:0;left:0;right:0;height:78px;padding:0 clamp(24px,4vw,58px);display:flex;align-items:center;gap:34px;z-index:1000;color:var(--cream);background:linear-gradient(to bottom,rgba(7,7,7,.86),rgba(7,7,7,.15));transition:.35s var(--ease);transform:translateY(-14px);opacity:0}
body.is-ready .nav{transform:translateY(0);opacity:1}
.nav.small{height:62px;background:rgba(7,7,7,.82);backdrop-filter:blur(15px);border-bottom:1px solid var(--line)}
.logo{width:clamp(190px,14vw,240px);color:var(--cream);flex-shrink:0}
.nav__links{margin-left:auto;display:flex;align-items:center;gap:30px}
.nav__links a{font-size:10px;font-weight:500;letter-spacing:.25em;text-transform:uppercase;color:rgba(245,241,232,.52);transition:.25s var(--ease);position:relative}
.nav__links a:hover{color:var(--cream)}
.nav__links a::after{content:"";position:absolute;left:0;right:0;bottom:-8px;height:1px;background:currentColor;transform:scaleX(0);transform-origin:right;transition:transform .45s var(--ease);opacity:.7}
.nav__links a:hover::after{transform:scaleX(1);transform-origin:left}
.nav__cta{margin-left:14px;border:1px solid rgba(245,241,232,.18);border-radius:999px;padding:11px 22px;font-size:10px;font-weight:500;letter-spacing:.25em;text-transform:uppercase;color:var(--cream);transition:.35s var(--ease)}
.nav__cta:hover{background:#faf9f6;color:var(--black);border-color:var(--cream)}

/* BREADCRUMB */
.breadcrumb{position:fixed;top:78px;left:0;right:0;z-index:999;padding:0 clamp(24px,4vw,58px);height:38px;display:flex;align-items:center;background:rgba(7,7,7,.72);backdrop-filter:blur(12px);border-bottom:1px solid var(--line);transform:translateY(-14px);opacity:0;transition:.35s var(--ease)}
body.is-ready .breadcrumb{transform:translateY(0);opacity:1}
.breadcrumb nav{display:flex;align-items:center;gap:10px;font-size:10px;letter-spacing:.18em;text-transform:uppercase}
.breadcrumb a{color:rgba(245,241,232,.38);transition:.2s var(--ease)}
.breadcrumb a:hover{color:var(--cream)}
.breadcrumb span{color:rgba(245,241,232,.18)}
.breadcrumb strong{color:rgba(245,241,232,.72);font-weight:500}

/* SECTIONS */
.section{padding:118px clamp(24px,4vw,58px)}
.inner{max-width:var(--max);margin:0 auto}
.dark{background:radial-gradient(circle at 50% 38%,rgba(255,255,255,.04),transparent 42%),linear-gradient(180deg,#050505,#060606),repeating-linear-gradient(90deg,rgba(255,255,255,.014) 0px,rgba(255,255,255,.014) 1px,transparent 1px,transparent 4px);border-top:1px solid var(--line);position:relative}
.dark>.inner{position:relative;z-index:1}
.paper{background:var(--paper);color:var(--ink)}
.paper .kicker{color:rgba(18,17,15,.38)}

/* ══ HERO PROGETTO ══ */
.proj-hero{
  min-height:100svh;
  position:relative;overflow:hidden;
  display:flex;flex-direction:column;justify-content:flex-end;
  padding:0 clamp(24px,4vw,58px) 72px;
  background:linear-gradient(160deg,#090909 0%,var(--pc) 60%,#0a0a12 100%);
}

/* copertina visiva — SVG decorativo di sfondo */
.proj-hero__cover{
  position:absolute;inset:0;pointer-events:none;z-index:0;overflow:hidden;
}
.proj-hero__cover svg{width:100%;height:100%;object-fit:cover}

/* alone cromatico */
.proj-hero__glow{
  position:absolute;top:-10%;right:-5%;
  width:70vw;height:70vw;border-radius:50%;
  background:radial-gradient(circle,rgba(200,205,234,.08),transparent 60%);
  pointer-events:none;z-index:0;
  animation:glowPulse 10s ease-in-out infinite alternate;
}
@keyframes glowPulse{from{opacity:.5;transform:scale(1)}to{opacity:1;transform:scale(1.1)}}

.proj-hero__inner{
  position:relative;z-index:2;
  max-width:var(--max);margin:0 auto;width:100%;
  padding-top:140px;
}

/* badge costellazione */
.proj-badge{
  display:inline-flex;align-items:center;gap:10px;
  border:1px solid rgba(200,205,234,.24);border-radius:999px;
  padding:8px 18px;margin-bottom:32px;
  font-size:9px;font-weight:500;letter-spacing:.26em;text-transform:uppercase;
  color:var(--pc-l);background:rgba(200,205,234,.08);
}
.proj-badge i{width:5px;height:5px;border-radius:50%;background:var(--pc-l);flex-shrink:0}

.proj-hero__title{
  font-size:clamp(48px,6.5vw,108px);color:var(--cream);
  line-height:.92;overflow:visible;margin-bottom:36px;
  max-width:900px;
}

/* meta strip */
.proj-meta{
  display:flex;align-items:center;gap:0;
  border-top:1px solid rgba(245,241,232,.10);
  padding-top:32px;
  flex-wrap:wrap;
}
.proj-meta-item{
  display:flex;flex-direction:column;gap:4px;
  padding:0 36px 0 0;margin-right:36px;
  border-right:1px solid rgba(245,241,232,.10);
}
.proj-meta-item:last-child{border-right:none;margin-right:0;padding-right:0}
.pm-label{font-size:9px;font-weight:500;letter-spacing:.26em;text-transform:uppercase;color:rgba(245,241,232,.30)}
.pm-value{font-size:clamp(13px,1vw,16px);font-weight:300;color:rgba(245,241,232,.75)}

/* scroll hint */
.proj-scroll{
  position:absolute;right:clamp(28px,4vw,58px);bottom:72px;
  display:flex;align-items:flex-end;gap:16px;color:rgba(245,241,232,.32);z-index:3;
}
.proj-scroll span{font-size:9px;letter-spacing:.34em;text-transform:uppercase;writing-mode:vertical-rl}
.proj-scroll i{display:block;width:1px;height:64px;background:rgba(245,241,232,.15);position:relative;overflow:hidden}
.proj-scroll i::after{content:"";position:absolute;left:0;top:-40%;width:100%;height:40%;background:var(--pc-l);animation:scrollLine 1.8s ease-in-out infinite}
@keyframes scrollLine{to{top:120%}}

/* ══ INTRO BRIEF ══ */
.proj-brief{
  display:grid;grid-template-columns:1fr 1.6fr;
  gap:clamp(48px,8vw,120px);align-items:start;
}
.proj-brief__label .kicker{margin-bottom:20px}
.proj-brief__label h2{
  font-size:clamp(44px,5.2vw,84px);color:var(--ink);line-height:.96;
}
.proj-brief__label h2 .italic{color:rgba(18,17,15,.32)}

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

/* pull quote */
.pull-quote{
  font-family:"Playfair Display",serif;
  font-size:clamp(22px,2.2vw,36px);font-weight:400;font-style:italic;
  letter-spacing:-.03em;line-height:1.22;
  color:rgba(18,17,15,.65);
  padding:32px 0 32px 28px;
  border-left:2px solid rgba(18,17,15,.18);
  margin-bottom:32px;
}

.proj-body-text p{
  font-size:clamp(16px,1.2vw,20px);font-weight:300;color:rgba(18,17,15,.60);
  line-height:1.78;margin-bottom:24px;
}
.proj-body-text p:last-child{margin-bottom:0}
.proj-body-text strong{font-weight:500;color:rgba(18,17,15,.86)}

/* info laterale */
.proj-info-strip{
  display:flex;flex-direction:column;gap:0;
  border-top:1px solid rgba(18,17,15,.12);
  margin-top:40px;
}
.proj-info-row{
  display:grid;grid-template-columns:100px 1fr;
  gap:16px;padding:16px 0;
  border-bottom:1px solid rgba(18,17,15,.08);
  transition:padding-left .35s var(--ease);
}
.proj-info-row:last-child{border-bottom:none}
.proj-info-row:hover{padding-left:10px}
.pir-label{font-size:9px;font-weight:500;letter-spacing:.22em;text-transform:uppercase;color:rgba(18,17,15,.32);padding-top:2px}
.pir-value{font-size:14px;font-weight:300;color:rgba(18,17,15,.62);line-height:1.55}

/* ══ GALLERY IMMAGINI ══ */
.proj-gallery{
  display:grid;gap:18px;
}
.gallery-full{grid-template-columns:1fr}
.gallery-2{grid-template-columns:1fr 1fr}
.gallery-3{grid-template-columns:1.4fr 1fr}
.gallery-3 .gallery-col{display:flex;flex-direction:column;gap:18px}

.gallery-img{
  border-radius:16px;overflow:hidden;
  position:relative;background:rgba(245,241,232,.04);
  aspect-ratio:16/9;
  display:flex;align-items:center;justify-content:center;
  border:1px solid rgba(245,241,232,.06);
  transition:transform .45s var(--ease),box-shadow .45s var(--ease),filter .45s var(--ease);
}
.gallery-img:hover{transform:scale(1.015);box-shadow:0 24px 72px rgba(0,0,0,.32);filter:brightness(1.06);z-index:2}
.gallery-img.tall{aspect-ratio:3/4}
.gallery-img.square{aspect-ratio:1}
.gallery-img.wide{aspect-ratio:21/9}

/* placeholder visivo nei gallery slot */
.gallery-placeholder{
  position:absolute;inset:0;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:12px;
}
.gallery-placeholder svg{opacity:.18}
.gallery-placeholder span{
  font-size:9px;font-weight:500;letter-spacing:.22em;text-transform:uppercase;
  color:rgba(245,241,232,.22);
}

/* caption gallery */
.gallery-caption{
  font-size:11px;font-weight:300;color:rgba(245,241,232,.32);
  text-align:center;margin-top:12px;letter-spacing:.06em;
  font-style:italic;
}

/* ══ LA ROTTA ══ */
.proj-rotta{
  display:grid;grid-template-columns:1fr 1.5fr;
  gap:clamp(48px,7vw,108px);align-items:start;
}
.proj-rotta__label .kicker{margin-bottom:20px}
.proj-rotta__label h2{font-size:clamp(44px,5.2vw,84px);color:var(--cream);line-height:.96}
.proj-rotta__label h2 .italic{color:rgba(245,241,232,.38)}

.proj-steps{display:flex;flex-direction:column;gap:0;border-top:1px solid rgba(245,241,232,.08)}
.proj-step{
  display:flex;gap:24px;padding:28px 0;
  border-bottom:1px solid rgba(245,241,232,.08);
  position:relative;transition:padding-left .42s var(--ease);
}
.proj-step::before{content:"";position:absolute;left:0;top:0;bottom:0;width:2px;background:var(--pc-l);transform:scaleY(0);transform-origin:top;transition:transform .55s var(--ease);opacity:.6}
.proj-step:hover{padding-left:14px}
.proj-step:hover::before{transform:scaleY(1)}
.proj-step:last-child{border-bottom:none}
.ps-num{
  font-family:"Playfair Display",serif;font-size:38px;font-weight:400;
  letter-spacing:-.04em;color:rgba(245,241,232,.16);line-height:1;
  flex-shrink:0;width:56px;transition:color .38s var(--ease);
}
.proj-step:hover .ps-num{color:rgba(245,241,232,.35)}
.ps-body h3{
  font-family:"Playfair Display",serif;font-size:clamp(20px,1.8vw,28px);
  font-weight:400;letter-spacing:-.03em;color:var(--cream);margin-bottom:8px;
  transition:transform .38s var(--ease);
}
.proj-step:hover .ps-body h3{transform:translateY(-2px)}
.ps-body p{font-size:14px;font-weight:300;color:rgba(245,241,232,.48);line-height:1.68}

/* ══ RISULTATO ══ */
.proj-risultato{
  display:grid;grid-template-columns:1fr 1fr;
  gap:clamp(48px,7vw,108px);align-items:start;
}
.pr-copy .kicker{margin-bottom:20px}
.pr-copy h2{font-size:clamp(44px,5.2vw,84px);color:var(--ink);line-height:.96;margin-bottom:28px}
.pr-copy h2 .italic{color:rgba(18,17,15,.32)}
.pr-copy p{font-size:clamp(15px,1.1vw,18px);font-weight:300;color:rgba(18,17,15,.58);line-height:1.76;margin-bottom:20px}
.pr-copy p strong{font-weight:500;color:rgba(18,17,15,.86)}

/* metriche risultato */
.risultato-metrics{
  display:grid;grid-template-columns:1fr 1fr;
  gap:1px;background:rgba(18,17,15,.12);
  border:1px solid rgba(18,17,15,.12);
  margin-top:40px;
}
.metric-card{
  background:var(--paper);padding:36px 28px;
  transition:background .35s var(--ease),transform .42s var(--ease);
}
.metric-card:hover{background:#e8e0d4;transform:translateY(-4px);z-index:2;box-shadow:0 16px 48px rgba(18,17,15,.08)}
.metric-val{
  font-family:"Playfair Display",serif;font-size:clamp(48px,5vw,78px);
  font-weight:400;letter-spacing:-.04em;line-height:1;color:var(--ink);
  margin-bottom:8px;transition:transform .38s var(--ease);
}
.metric-card:hover .metric-val{transform:translateY(-3px)}
.metric-label{font-size:9px;font-weight:500;letter-spacing:.24em;text-transform:uppercase;color:rgba(18,17,15,.36)}
.metric-desc{font-size:13px;font-weight:300;color:rgba(18,17,15,.48);line-height:1.55;margin-top:8px}

/* ══ NAVIGAZIONE PROGETTI ══ */
.proj-nav{
  display:grid;grid-template-columns:1fr 1fr;
  gap:1px;background:var(--line);border-top:1px solid var(--line);
}
.proj-nav-card{
  padding:48px clamp(24px,4vw,58px);
  display:flex;flex-direction:column;gap:12px;
  background:#050505;
  transition:background .38s var(--ease);
  position:relative;overflow:hidden;
}
.proj-nav-card:hover{background:#0d0d0c}
.proj-nav-card::before{
  content:"";position:absolute;inset:0;
  background:linear-gradient(105deg,transparent 35%,rgba(255,255,255,.30) 47%,rgba(255,244,218,.10) 53%,transparent 65%);
  opacity:0;transform:translateX(-120%);pointer-events:none;mix-blend-mode:screen;
}
.proj-nav-card:hover::before{animation:navFlash .85s var(--ease) both}
@keyframes navFlash{0%{opacity:0;transform:translateX(-120%)}18%{opacity:.8}100%{opacity:0;transform:translateX(120%)}}

.proj-nav-card.next{text-align:right}
.pnc-dir{font-size:9px;font-weight:500;letter-spacing:.26em;text-transform:uppercase;color:rgba(245,241,232,.30)}
.pnc-badge{font-size:9px;font-weight:500;letter-spacing:.18em;text-transform:uppercase;color:rgba(245,241,232,.36);margin-bottom:4px}
.pnc-title{
  font-family:"Playfair Display",serif;font-size:clamp(22px,2.2vw,36px);
  font-weight:400;letter-spacing:-.04em;color:var(--cream);line-height:1.06;
  transition:transform .38s var(--ease);
}
.proj-nav-card:hover .pnc-title{transform:translateY(-3px)}
.pnc-arrow{
  font-size:20px;color:rgba(245,241,232,.28);margin-top:8px;
  transition:transform .38s var(--ease),color .38s var(--ease);
  display:block;
}
.proj-nav-card:hover .pnc-arrow{color:rgba(245,241,232,.65);transform:translateX(6px)}
.proj-nav-card.next:hover .pnc-arrow{transform:translateX(-6px)}

/* ══ CTA BAND ══ */
.cta-band{
  border-top:1px solid var(--line);padding:96px clamp(24px,4vw,58px);
  background:radial-gradient(circle at 55% 50%,rgba(245,241,232,.06),transparent 44%),
  linear-gradient(180deg,#050505,#060606);
}
.cta-band__inner{max-width:var(--max);margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:48px;flex-wrap:wrap}
.cta-band p{
  font-family:"Playfair Display",serif;
  font-size:clamp(32px,4vw,62px);font-weight:400;letter-spacing:-.045em;line-height:1.06;
  color:var(--cream);max-width:600px;
}
.cta-band p em{font-style:italic;color:rgba(245,241,232,.45)}
.btn{height:56px;display:inline-flex;align-items:center;justify-content:center;border-radius:999px;padding:0 32px;font-size:10px;font-weight:500;letter-spacing:.25em;text-transform:uppercase;transition:.35s var(--ease);position:relative;overflow:hidden;isolation:isolate}
.btn::before{content:"";position:absolute;inset:-1px;z-index:-1;background:linear-gradient(110deg,transparent,rgba(255,255,255,.28) 42%,transparent);transform:translateX(-125%);transition:transform .75s var(--ease)}
.btn:hover::before{transform:translateX(125%)}
.btn--light{background:#faf9f6;color:var(--black)}.btn--light:hover{transform:translateY(-3px);box-shadow:0 22px 70px rgba(245,241,232,.16)}
.btn--ghost{border:1px solid rgba(245,241,232,.18);color:rgba(245,241,232,.8)}.btn--ghost:hover{border-color:rgba(245,241,232,.48);color:var(--cream);transform:translateY(-3px)}
.cta-actions{display:flex;gap:16px;flex-wrap:wrap}

/* ══ FOOTER ══ */
.footer{border-top:1px solid var(--line);padding:76px clamp(24px,4vw,58px) 42px;background:radial-gradient(circle at 50% 38%,rgba(255,255,255,.04),transparent 42%),linear-gradient(180deg,#050505,#060606),repeating-linear-gradient(90deg,rgba(255,255,255,.014) 0px,rgba(255,255,255,.014) 1px,transparent 1px,transparent 4px)}
.footer-grid{max-width:var(--max);margin:0 auto;display:grid;grid-template-columns:1.2fr .7fr .7fr .7fr;gap:64px}
.footer-brand{margin-bottom:26px}
.footer p{color:rgba(245,241,232,.48);font-weight:300;max-width:340px}
.footer h4{font-size:10px;font-weight:500;letter-spacing:.3em;text-transform:uppercase;color:rgba(245,241,232,.42);margin-bottom:22px}
.footer a{display:block;color:rgba(245,241,232,.72);font-size:14px;margin-bottom:14px;transition:.25s}
.footer a:hover{color:var(--cream);transform:translateX(4px)}

/* ══ RESPONSIVE ══ */
@media(max-width:1080px){
  .nav__links{display:none}
  .breadcrumb{display:none}
  .proj-brief,.proj-rotta,.proj-risultato{grid-template-columns:1fr}
  .gallery-2,.gallery-3{grid-template-columns:1fr}
  .gallery-3 .gallery-col{gap:18px}
  .risultato-metrics{grid-template-columns:1fr 1fr}
  .footer-grid{grid-template-columns:1fr 1fr}
  .cta-band__inner{flex-direction:column;align-items:flex-start}
}
@media(max-width:680px){
  .nav{padding:0 24px}.logo{width:140px}.nav__cta{display:none}
  .proj-nav{grid-template-columns:1fr}
  .risultato-metrics{grid-template-columns:1fr}
  .proj-meta{gap:20px}
  .proj-meta-item{border-right:none;padding-right:0;margin-right:0}
  .footer-grid{grid-template-columns:1fr}
  .proj-scroll{display:none}
}
@media(prefers-reduced-motion:reduce){*,*::before,*::after{animation-duration:.001ms!important;transition-duration:.001ms!important}}

/* UPDATE — hero progetto più alta/pulita */
.proj-hero{
  justify-content:center!important;
  padding:118px clamp(24px,4vw,58px) 72px!important;
}

.proj-hero__inner{
  padding-top:40px!important;
  transform:translateY(-4vh);
}

.proj-badge{
  display:none!important;
}

.proj-hero__title{
  font-size:clamp(54px,7vw,118px)!important;
  margin-bottom:46px!important;
  max-width:940px!important;
}

.proj-meta{
  max-width:1040px;
}

.proj-hero__cover g[opacity=".055"]{
  opacity:.035!important;
  transform:translate(760px,120px) scale(1.8)!important;
}

@media(max-width:900px){
  .proj-hero{
    justify-content:flex-end!important;
    padding-top:116px!important;
  }
  .proj-hero__inner{
    transform:none;
    padding-top:0!important;
  }
}


/* SAFARI FIX — orbita progetto scroll dopo La Rotta */
@supports (-webkit-touch-callout: none) {
  html, body{
    overflow-x:hidden!important;
  }

  .section,
  .dark,
  .paper{
    contain:layout paint;
  }

  #visual-2,
  #risultato,
  #next{
    position:relative;
    overflow:hidden!important;
    min-height:auto!important;
  }

  #visual-2 .gallery-img,
  #visual-2 .proj-gallery,
  #risultato .gallery-img{
    transform:none!important;
    will-change:auto!important;
    backface-visibility:hidden;
    -webkit-transform:translateZ(0);
  }

  #visual-2 .gallery-img:hover,
  #risultato .gallery-img:hover{
    transform:none!important;
    box-shadow:none!important;
  }

  #visual-2 .reveal,
  #risultato .reveal{
    filter:none!important;
  }
}

/* fix generale leggero: evita ricalcoli infiniti su Safari con aspect-ratio + transform */
#visual-2 .gallery-img,
#risultato .gallery-img{
  min-height:1px;
  contain:layout paint;
}


/* HARD FIX — blocchi immagine stabili su Safari/Chrome */
.gallery-img{
  aspect-ratio:auto!important;
  height:clamp(260px,34vw,520px)!important;
  max-height:560px!important;
  min-height:220px!important;
  overflow:hidden!important;
  flex:0 0 auto!important;
}

.gallery-img.tall{
  height:clamp(420px,48vw,680px)!important;
  max-height:720px!important;
}

.gallery-img.square{
  height:clamp(280px,28vw,430px)!important;
  max-height:460px!important;
}

.gallery-img.wide{
  height:clamp(280px,32vw,470px)!important;
  max-height:500px!important;
}

.gallery-3{
  align-items:start!important;
}

.gallery-3 .gallery-col{
  min-height:0!important;
}

.gallery-placeholder{
  min-height:0!important;
  max-height:100%!important;
}

/* impedisce qualunque espansione infinita dei blocchi dopo la rotta */
#visual-2,
#visual-2 .inner,
#visual-2 .proj-gallery,
#visual-2 .gallery-col,
#visual-2 .gallery-img,
#risultato,
#risultato .inner,
#risultato .gallery-img{
  overflow:hidden!important;
  min-height:0!important;
}

/* Safari: toglie blur e trasformazioni dalle gallery che possono innescare repaint infiniti */
@supports (-webkit-touch-callout: none) {
  .gallery-img,
  .gallery-img:hover,
  .proj-gallery,
  .gallery-placeholder,
  #visual-2 *,
  #risultato *{
    transform:none!important;
    filter:none!important;
    backface-visibility:hidden!important;
    -webkit-backface-visibility:hidden!important;
  }

  .gallery-img{
    contain:strict!important;
  }
}


/* BLOCCO EDITORIALE — gallery applicazioni */
.gallery-applicazioni{
  grid-template-columns:1.4fr 1fr!important;
  align-items:start!important;
}

.gallery-applicazioni .gallery-col{
  display:flex!important;
  flex-direction:column!important;
  gap:18px!important;
  min-height:0!important;
}

.gallery-applicazioni .gallery-img.wide{
  height:clamp(260px,24vw,430px)!important;
}

.gallery-quote{
  min-height:clamp(320px,28vw,480px);
  border-radius:16px;
  border:1px solid rgba(245,241,232,.08);
  background:
    radial-gradient(circle at 22% 78%, rgba(200,205,234,.08), transparent 36%),
    linear-gradient(145deg, rgba(255,255,255,.025), rgba(255,255,255,.045));
  padding:42px;
  display:flex!important;
  flex-direction:column;
  justify-content:flex-end;
  overflow:hidden;
  position:relative;
}

.gallery-quote::before{
  content:"";
  position:absolute;
  inset:0;
  background:
    linear-gradient(90deg, rgba(245,241,232,.035) 1px, transparent 1px),
    linear-gradient(0deg, rgba(245,241,232,.025) 1px, transparent 1px);
  background-size:120px 120px;
  opacity:.34;
  pointer-events:none;
}

.gallery-quote span,
.gallery-quote h3,
.gallery-quote p{
  position:relative;
  z-index:1;
}

.gallery-quote span{
  font-size:10px;
  letter-spacing:.24em;
  text-transform:uppercase;
  color:rgba(245,241,232,.36);
  margin-bottom:18px;
}

.gallery-quote h3{
  font-family:"Playfair Display", serif;
  font-size:clamp(32px,3vw,56px);
  font-weight:400;
  line-height:1.02;
  letter-spacing:-.05em;
  color:rgba(245,241,232,.92);
  max-width:620px;
  margin-bottom:22px;
}

.gallery-quote p{
  max-width:560px;
  color:rgba(245,241,232,.58);
  line-height:1.72;
  font-weight:300;
}

@media(max-width:900px){
  .gallery-applicazioni{
    grid-template-columns:1fr!important;
  }
}


/* UPDATE — sezione applicazioni bilanciata */
.app-grid{
  display:grid;
  grid-template-columns:1.4fr 1fr;
  gap:18px;
  align-items:start;
}

.app-grid .gallery-img:nth-child(1),
.app-grid .gallery-img:nth-child(2){
  height:380px;
  min-height:380px;
}

.app-grid .gallery-img:nth-child(3),
.app-grid .gallery-img:nth-child(4){
  height:320px;
  min-height:320px;
}

@media(max-width:900px){
  .app-grid{
    grid-template-columns:1fr;
  }
}


/* FIX REALE — allineamento righe sezione Applicazioni */
#visual-2 .app-grid{
  display:grid!important;
  grid-template-columns:1.4fr 1fr!important;
  gap:18px!important;
  align-items:start!important;
}

#visual-2 .app-grid > .gallery-img{
  aspect-ratio:auto!important;
  max-height:none!important;
  min-height:0!important;
  height:auto!important;
}

#visual-2 .app-grid > .gallery-img:nth-child(1),
#visual-2 .app-grid > .gallery-img:nth-child(2){
  height:380px!important;
  min-height:380px!important;
  max-height:380px!important;
}

#visual-2 .app-grid > .gallery-img:nth-child(3),
#visual-2 .app-grid > .gallery-img:nth-child(4){
  height:320px!important;
  min-height:320px!important;
  max-height:320px!important;
}

#visual-2 .app-grid > .gallery-img .gallery-placeholder{
  height:100%!important;
}

@media(max-width:900px){
  #visual-2 .app-grid{
    grid-template-columns:1fr!important;
  }

  #visual-2 .app-grid > .gallery-img{
    height:320px!important;
    min-height:320px!important;
    max-height:320px!important;
  }
}


/* MOBILE FIX — hero progetto più alta */
@media(max-width:680px){
  .proj-hero{
    min-height:92svh!important;
    justify-content:center!important;
    padding:118px 24px 56px!important;
  }

  .proj-hero__inner{
    transform:translateY(-7vh)!important;
    padding-top:0!important;
  }

  .proj-hero__title{
    font-size:clamp(48px,15vw,72px)!important;
    line-height:.92!important;
    margin-bottom:34px!important;
  }

  .proj-meta{
    padding-top:24px!important;
  }
}

@media(max-width:430px){
  .proj-hero__inner{
    transform:translateY(-9vh)!important;
  }
}


/* MOBILE FIX — elimina fascia bianca finale */
html,
body{
  background:#050505!important;
}

@media(max-width:680px){
  body{
    overflow-x:hidden!important;
    background:#050505!important;
  }

  .page-wrap,
  main,
  .site-main{
    background:#050505!important;
  }

  .proj-hero{
    min-height:100svh!important;
    padding-bottom:120px!important;
  }

  footer{
    margin-top:0!important;
  }
}


/* MOBILE REFINEMENT — menu grande, footer compatto, hero allineate */
.mobile-menu-toggle,
.mobile-menu-panel{
  display:none;
}

@media(max-width:1080px){
  body{
    cursor:auto!important;
  }

  .cursor-light,
  .cursor-ring,
  .cursor-dot{
    display:none!important;
  }

  .nav{
    height:72px!important;
    padding:0 24px!important;
    background:linear-gradient(to bottom,rgba(7,7,7,.94),rgba(7,7,7,.42))!important;
    backdrop-filter:blur(14px)!important;
  }

  .nav.small{
    height:64px!important;
  }

  .nav__links,
  .nav__cta{
    display:none!important;
  }

  .logo{
    width:clamp(142px,38vw,180px)!important;
  }

  .mobile-menu-toggle{
    margin-left:auto;
    width:48px;
    height:48px;
    border-radius:999px;
    border:1px solid rgba(245,241,232,.20);
    background:rgba(245,241,232,.035);
    color:var(--cream);
    display:flex!important;
    align-items:center;
    justify-content:center;
    flex-direction:column;
    gap:5px;
    padding:0;
    cursor:pointer;
    z-index:1302;
  }

  .mobile-menu-toggle span{
    width:18px;
    height:1px;
    display:block;
    background:currentColor;
    transform-origin:center;
    transition:transform .36s var(--ease), opacity .24s var(--ease);
  }

  body.mobile-menu-open .mobile-menu-toggle span:nth-child(1){
    transform:translateY(6px) rotate(45deg);
  }

  body.mobile-menu-open .mobile-menu-toggle span:nth-child(2){
    opacity:0;
  }

  body.mobile-menu-open .mobile-menu-toggle span:nth-child(3){
    transform:translateY(-6px) rotate(-45deg);
  }

  .mobile-menu-panel{
    position:fixed;
    inset:0;
    z-index:1300;
    display:block!important;
    overflow:auto;
    padding:104px 24px 36px;
    color:var(--cream);
    background:
      radial-gradient(circle at 72% 24%, rgba(245,241,232,.09), transparent 30%),
      radial-gradient(circle at 24% 72%, rgba(245,241,232,.045), transparent 32%),
      linear-gradient(180deg,#050505,#060606);
    transform:translateY(-100%);
    transition:transform .68s cubic-bezier(.22,.61,.36,1);
  }

  body.mobile-menu-open{
    overflow:hidden!important;
  }

  body.mobile-menu-open .mobile-menu-panel{
    transform:translateY(0);
  }

  .mobile-menu-panel nav{
    display:flex;
    flex-direction:column;
    gap:0;
  }

  .mobile-menu-panel a{
    display:flex;
    align-items:baseline;
    gap:16px;
    padding:15px 0;
    border-bottom:1px solid rgba(245,241,232,.085);
    color:rgba(245,241,232,.92);
    font-family:"Playfair Display",Georgia,serif;
    font-size:clamp(44px,14vw,82px);
    line-height:.92;
    letter-spacing:-.06em;
  }

  .mobile-menu-panel a span{
    min-width:28px;
    font-family:Inter,system-ui,sans-serif;
    font-size:10px;
    font-weight:500;
    letter-spacing:.28em;
    color:rgba(245,241,232,.35);
  }

  .mobile-menu-panel .mobile-menu-cta{
    margin-top:32px;
    height:56px;
    border-radius:999px;
    border:1px solid rgba(245,241,232,.22);
    display:flex;
    align-items:center;
    justify-content:center;
    font-family:Inter,system-ui,sans-serif;
    font-size:10px;
    font-weight:500;
    letter-spacing:.25em;
    text-transform:uppercase;
    color:var(--cream);
  }

  .mobile-menu-foot{
    margin-top:34px;
    padding-top:22px;
    border-top:1px solid rgba(245,241,232,.08);
    color:rgba(245,241,232,.42);
    font-size:13px;
    font-weight:300;
  }

  /* Footer mobile compatto */
  .footer{
    padding:50px 24px 28px!important;
  }

  .footer-grid{
    display:block!important;
    max-width:none!important;
    margin:0 auto!important;
  }

  .footer-grid > div:first-child{
    padding-bottom:26px!important;
    margin-bottom:8px!important;
    border-bottom:1px solid rgba(245,241,232,.08)!important;
  }

  .footer-brand{
    margin-bottom:14px!important;
  }

  .footer p{
    max-width:320px!important;
    font-size:14px!important;
    line-height:1.6!important;
  }

  .footer-grid > div:not(:first-child):not(:last-child){
    margin:0!important;
  }

  .footer h4{
    margin:0!important;
    padding:17px 0!important;
    border-bottom:1px solid rgba(245,241,232,.075)!important;
    position:relative;
    cursor:pointer;
  }

  .footer h4::after{
    content:"+";
    position:absolute;
    right:0;
    top:17px;
    color:rgba(245,241,232,.42);
  }

  .footer .footer-mobile-open h4::after{
    content:"−";
  }

  .footer-grid > div:not(:first-child):not(:last-child) a{
    display:none!important;
  }

  .footer-grid > div.footer-mobile-open a{
    display:block!important;
  }

  .footer a{
    font-size:13px!important;
    margin-bottom:12px!important;
  }

  .footer-grid > div[style*="grid-column"]{
    display:flex!important;
    flex-direction:column!important;
    align-items:flex-start!important;
    gap:10px!important;
    margin-top:22px!important;
    padding-top:18px!important;
  }

  .footer-grid > div[style*="grid-column"] div{
    display:flex!important;
    gap:18px!important;
    flex-wrap:wrap!important;
  }
}

@media(max-width:680px){
  /* Hero mobile: allineamento coerente a Sistema */
  .hero,
  .luce-hero,
  .cost-hero,
  .costellazioni-hero,
  .constellazioni-hero,
  .sistema-hero,
  .orbita-hero,
  .rotta-hero,
  .proj-hero,
  .page-hero{
    min-height:100svh!important;
    align-items:flex-start!important;
    padding-top:112px!important;
    padding-left:24px!important;
    padding-right:24px!important;
    padding-bottom:58px!important;
  }

  .hero__inner,
  .luce-hero__inner,
  .cost-hero__inner,
  .sistema-hero__inner,
  .orbita-hero__inner,
  .rotta-hero__inner,
  .proj-hero__inner,
  .page-hero .inner{
    padding-top:0!important;
    transform:none!important;
    align-items:start!important;
  }

  .hero__copy,
  .luce-hero__copy,
  .cost-hero__copy,
  .sistema-hero__copy,
  .orbita-hero__copy,
  .rotta-hero__copy{
    padding-top:0!important;
    padding-bottom:0!important;
  }

  .hero .kicker,
  .luce-hero .kicker,
  .cost-hero .kicker,
  .sistema-hero .kicker,
  .orbita-hero .kicker,
  .rotta-hero .kicker,
  .proj-hero .kicker{
    margin-bottom:24px!important;
  }

  .hero h1,
  .luce-hero h1,
  .cost-hero h1,
  .sistema-hero h1,
  .orbita-hero h1,
  .rotta-hero h1,
  .proj-hero__title{
    margin-top:0!important;
  }

  .btn,
  .btn--light,
  .btn--ghost,
  .btn--ink{
    width:100%;
    max-width:100%;
  }

  .actions,
  .cta-actions,
  .cta-btns{
    width:100%;
    gap:12px!important;
  }
}


/* MOBILE FOOTER ACCORDION FIX */
@media(max-width:1080px){
  .footer .footer-grid > div[data-mobile-accordion="true"] a{
    display:none!important;
  }

  .footer .footer-grid > div[data-mobile-accordion="true"].footer-mobile-open a{
    display:block!important;
  }

  .footer .footer-grid > div[data-mobile-accordion="true"] h4{
    cursor:pointer!important;
    user-select:none;
  }

  .footer .footer-grid > div[data-mobile-accordion="true"] h4::after{
    content:"+";
    position:absolute;
    right:0;
    top:17px;
    color:rgba(245,241,232,.42);
  }

  .footer .footer-grid > div[data-mobile-accordion="true"].footer-mobile-open h4::after{
    content:"−";
  }
}


/* MOBILE FOOTER ACCORDION DEFINITIVO */
@media(max-width:1080px){
  .footer .footer-mobile-links{
    display:none!important;
    padding:2px 0 14px!important;
  }

  .footer .footer-mobile-links a{
    display:block!important;
  }

  .footer .footer-mobile-group.footer-mobile-open .footer-mobile-links{
    display:block!important;
  }

  .footer .footer-mobile-group h4{
    cursor:pointer!important;
    user-select:none!important;
    position:relative!important;
    padding-right:34px!important;
  }

  .footer .footer-mobile-group h4::after{
    content:"+";
    position:absolute;
    right:0;
    top:17px;
    color:rgba(245,241,232,.42);
  }

  .footer .footer-mobile-group.footer-mobile-open h4::after{
    content:"−";
  }

  /* neutralizza le vecchie regole che nascondevano direttamente gli <a> */
  .footer-grid > div.footer-mobile-group:not(:first-child):not(:last-child) a{
    display:block!important;
  }
}




/* MOBILE FOOTER ACCORDION + MENU CLOSE + 404 CURSOR FIX */
@media(max-width:1080px){
  .footer .footer-grid > div.footer-mobile-group .footer-mobile-links{
    display:none!important;
    padding:4px 0 18px!important;
  }

  .footer .footer-grid > div.footer-mobile-group.footer-mobile-open .footer-mobile-links{
    display:block!important;
  }

  .footer .footer-grid > div.footer-mobile-group .footer-mobile-links a{
    display:block!important;
    margin-bottom:13px!important;
  }

  .footer .footer-grid > div.footer-mobile-group h4{
    cursor:pointer!important;
    user-select:none!important;
    position:relative!important;
    padding:18px 34px 18px 0!important;
    margin:0!important;
    border-bottom:1px solid rgba(245,241,232,.075)!important;
  }

  .footer .footer-grid > div.footer-mobile-group h4::after{
    content:"+";
    position:absolute;
    right:0;
    top:18px;
    color:rgba(245,241,232,.55);
    font-size:18px;
    line-height:1;
  }

  .footer .footer-grid > div.footer-mobile-group.footer-mobile-open h4::after{
    content:"−";
  }

  .footer-grid > div.footer-mobile-group:not(:first-child):not(:last-child) > a{
    display:none!important;
  }

  .footer-grid > div.footer-mobile-group.footer-mobile-open:not(:first-child):not(:last-child) > a{
    display:none!important;
  }

  .mobile-menu-panel{
    padding-top:96px!important;
  }

  .mobile-menu-close{
    position:fixed;
    right:24px;
    top:18px;
    width:48px;
    height:48px;
    border-radius:999px;
    border:1px solid rgba(245,241,232,.22);
    background:rgba(245,241,232,.04);
    color:var(--cream);
    display:flex;
    align-items:center;
    justify-content:center;
    font-size:28px;
    line-height:1;
    z-index:1400;
    cursor:pointer;
  }

  .mobile-menu-back{
    margin-top:26px;
    width:100%;
    height:54px;
    border-radius:999px;
    border:1px solid rgba(245,241,232,.18);
    background:transparent;
    color:rgba(245,241,232,.82);
    font-size:10px;
    letter-spacing:.25em;
    text-transform:uppercase;
    cursor:pointer;
  }
}

body.error404,
body.error404 *,
.error404,
.error404 *{
  cursor:auto!important;
}

body.error404 .cursor-light,
body.error404 .cursor-ring,
body.error404 .cursor-dot{
  display:none!important;
  opacity:0!important;
  visibility:hidden!important;
  pointer-events:none!important;
}




/* FOOTER WORDPRESS FINAL FIX — no bullets + mobile accordion */
.footer ul,
.footer li{
  list-style:none!important;
  margin:0!important;
  padding:0!important;
}

.footer li::marker{
  content:""!important;
}

.footer li a,
.footer a{
  text-decoration:none!important;
}

@media(max-width:1080px){
  .footer .footer-grid{
    display:block!important;
  }

  .footer .footer-mobile-group{
    display:block!important;
  }

  .footer .footer-mobile-group .footer-mobile-links{
    display:none!important;
    overflow:hidden!important;
    padding:4px 0 18px!important;
  }

  .footer .footer-mobile-group.footer-mobile-open .footer-mobile-links{
    display:block!important;
  }

  .footer .footer-mobile-group .footer-mobile-links a{
    display:block!important;
    margin:0 0 13px!important;
    padding:0!important;
  }

  .footer .footer-mobile-group h4{
    display:block!important;
    cursor:pointer!important;
    user-select:none!important;
    position:relative!important;
    padding:18px 34px 18px 0!important;
    margin:0!important;
    border-bottom:1px solid rgba(245,241,232,.075)!important;
  }

  .footer .footer-mobile-group h4::after{
    content:"+";
    position:absolute;
    right:0;
    top:18px;
    color:rgba(245,241,232,.55);
    font-size:18px;
    line-height:1;
  }

  .footer .footer-mobile-group.footer-mobile-open h4::after{
    content:"−";
  }
}




/* LOGO GOLD MOON + NAV BULLET FIX */
.nav__links,
.nav__links li,
.footer ul,
.footer li{
  list-style:none!important;
}

.nav__links li::marker,
.footer li::marker{
  content:""!important;
  font-size:0!important;
}

.nav__links li{
  margin:0!important;
  padding:0!important;
  display:flex!important;
  align-items:center!important;
}

.nav__links a::before,
.nav__links li::before{
  content:none!important;
  display:none!important;
}

.logo .logo-gold-crescent,
.logo use .logo-gold-crescent{
  fill:url(#comoonicaMoonGold)!important;
  filter:
    drop-shadow(0 0 3px rgba(244,223,155,.20))
    drop-shadow(0 0 11px rgba(198,154,62,.18));
  animation:comoonicaGoldLamina 5.8s ease-in-out infinite;
  transform-box:fill-box;
  transform-origin:center;
}

@keyframes comoonicaGoldLamina{
  0%,100%{
    opacity:.90;
    filter:
      drop-shadow(0 0 3px rgba(244,223,155,.18))
      drop-shadow(0 0 10px rgba(198,154,62,.14));
  }
  45%{
    opacity:1;
    filter:
      drop-shadow(0 0 5px rgba(255,242,191,.34))
      drop-shadow(0 0 16px rgba(216,173,75,.26));
  }
  58%{
    opacity:.96;
  }
}

