
:root{
  --black:#050505;--deep:#0d0d0c;--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;
  --orion:#171a30;--orion-l:#c8cdea;
  --luna:#3a3024;--luna-l:#e0c89a;
  --vega:#102417;--vega-l:#b5d8c5;
  --sirius:#171025;--sirius-l:#c5b8e8;
  --antares:#2b0f0f;--antares-l:#deb8b8;
  --polaris:#1a1a1a;--polaris-l:#d8d6d2;
}
*{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}

/* 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,.nav__links a.active{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,.nav__links a.active::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)}

/* BUTTONS */
.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)}

/* SECTIONS */
.section{padding:118px clamp(24px,4vw,58px)}
.inner{max-width:var(--max);margin:0 auto}
.section-title{font-size:clamp(54px,7vw,112px);margin-bottom:36px;line-height:1.08;overflow:visible}
.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)}
.paper .text{color:rgba(18,17,15,.58)}

/* ══ HERO ══ */
.orbita-hero{
  min-height:100svh;
  display:flex;align-items:center;
  position:relative;overflow:hidden;
  padding:116px clamp(24px,4vw,58px) 80px;
  background:#050505;
}

/* orbita di sfondo — canvas */
.orbita-hero__bg{position:absolute;inset:0;pointer-events:none;z-index:0;overflow:hidden}
#orbitaCanvas{position:absolute;inset:0;width:100%;height:100%;display:block}

.orbita-hero__inner{
  position:relative;z-index:2;
  max-width:var(--max);margin:0 auto;width:100%;
  display:grid;grid-template-columns:1fr 1fr;
  gap:80px;align-items:center;
}
.orbita-hero__copy .kicker{margin-bottom:28px}
.orbita-hero__copy h1{font-size:clamp(68px,7.5vw,124px);color:var(--cream);margin-bottom:32px;line-height:.9;overflow:visible}
.orbita-hero__copy .text{margin-bottom:44px}
.orbita-hero__copy .actions{display:flex;gap:20px;flex-wrap:wrap}

/* contatore lavori nell'hero */
.orbita-hero__stats{
  display:flex;flex-direction:column;gap:28px;
  justify-content:center;
}
.stat-item{
  display:flex;align-items:baseline;gap:16px;
  padding-bottom:28px;
  border-bottom:1px solid rgba(245,241,232,.08);
}
.stat-item:last-child{border-bottom:none;padding-bottom:0}
.stat-num{
  font-family:"Playfair Display",serif;
  font-size:clamp(52px,5.5vw,88px);
  font-weight:400;letter-spacing:-.04em;line-height:1;
  color:var(--cream);
}
.stat-label{
  font-size:10px;font-weight:500;letter-spacing:.26em;text-transform:uppercase;
  color:rgba(245,241,232,.38);
}

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

/* ══ FILTRI ══ */
.filtri-wrap{
  display:flex;align-items:center;justify-content:space-between;
  gap:20px;margin-bottom:52px;flex-wrap:wrap;
}
.filtri-bar{display:flex;gap:8px;flex-wrap:wrap}
.filtro{
  border:1px solid rgba(245,241,232,.12);border-radius:999px;
  padding:10px 20px;font-size:10px;font-weight:500;letter-spacing:.22em;text-transform:uppercase;
  color:rgba(245,241,232,.44);background:transparent;cursor:pointer;
  transition:border-color .28s var(--ease),color .28s var(--ease),background .28s var(--ease);
}
.filtro:hover{border-color:rgba(245,241,232,.40);color:rgba(245,241,232,.78)}
.filtro.active{border-color:rgba(245,241,232,.60);color:var(--cream);background:rgba(245,241,232,.06)}
.lavori-count{font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:rgba(245,241,232,.28)}

/* ══ GRIGLIA LAVORI ══ */
.works-masonry{
  display:grid;
  grid-template-columns:repeat(12,1fr);
  gap:18px;
}

/* card progetto */
.work-card{
  border-radius:24px;padding:36px;
  position:relative;overflow:hidden;
  display:flex;flex-direction:column;justify-content:space-between;
  background:#0d0d0c;
  transition:transform .48s var(--ease),box-shadow .48s var(--ease),filter .48s var(--ease);
  text-decoration:none;cursor:pointer;
}
.work-card:hover{transform:translateY(-8px);box-shadow:0 32px 80px rgba(0,0,0,.36);filter:brightness(1.08);z-index:2}

/* dimensioni nella griglia 12 colonne */
.work-card.w-large{grid-column:span 7;min-height:480px}
.work-card.w-small{grid-column:span 5;min-height:480px}
.work-card.w-half{grid-column:span 6;min-height:380px}
.work-card.w-third{grid-column:span 4;min-height:340px}
.work-card.w-full{grid-column:span 12;min-height:320px}

/* gradients per costellazione */
.work-card.orion{background:linear-gradient(145deg,#090909,var(--orion))}
.work-card.luna{background:linear-gradient(145deg,#100d09,var(--luna))}
.work-card.vega{background:linear-gradient(145deg,#060e08,var(--vega))}
.work-card.sirius{background:linear-gradient(145deg,#070512,var(--sirius))}
.work-card.antares{background:linear-gradient(145deg,#0d0404,var(--antares))}
.work-card.polaris{background:linear-gradient(145deg,#0a0a0a,var(--polaris))}

/* alone radiale con colore costellazione */
.work-card::after{
  content:"";position:absolute;inset:0;
  background:radial-gradient(circle at 82% 14%,currentColor,transparent 38%);
  opacity:.07;transition:opacity .48s var(--ease),transform .48s var(--ease);pointer-events:none;
}
.work-card:hover::after{opacity:.18;transform:scale(1.1)}
.work-card.orion{color:var(--orion-l)}
.work-card.luna{color:var(--luna-l)}
.work-card.vega{color:var(--vega-l)}
.work-card.sirius{color:var(--sirius-l)}
.work-card.antares{color:var(--antares-l)}
.work-card.polaris{color:var(--polaris-l)}

/* flash di luce */
.work-card::before{
  content:"";position:absolute;inset:0;
  background:linear-gradient(105deg,transparent 0%,transparent 35%,rgba(255,255,255,.40) 47%,rgba(255,244,218,.14) 53%,transparent 65%,transparent 100%);
  opacity:0;transform:translateX(-120%);pointer-events:none;mix-blend-mode:screen;z-index:3;
}
.work-card:hover::before{animation:workFlash .88s var(--ease) both}
@keyframes workFlash{0%{opacity:0;transform:translateX(-120%)}18%{opacity:.9}100%{opacity:0;transform:translateX(120%)}}

/* contenuto card */
.wc-top{position:relative;z-index:1}
.wc-meta{
  display:flex;align-items:center;gap:12px;margin-bottom:20px;
}
.wc-badge{
  font-size:9px;font-weight:500;letter-spacing:.2em;text-transform:uppercase;
  border:1px solid currentColor;border-radius:999px;padding:4px 12px;
  color:currentColor;opacity:.55;transition:opacity .38s var(--ease);
}
.work-card:hover .wc-badge{opacity:.85}
.wc-year{font-size:9px;letter-spacing:.2em;color:rgba(245,241,232,.28)}
.wc-title{
  font-family:"Playfair Display",serif;
  font-size:clamp(30px,3.2vw,56px);font-weight:400;
  letter-spacing:-.04em;line-height:.98;
  color:var(--cream);max-width:520px;
  transition:transform .42s var(--ease);
}
.work-card:hover .wc-title{transform:translateY(-4px)}

.wc-bottom{position:relative;z-index:1}
.wc-desc{
  font-size:clamp(13px,.95vw,15px);font-weight:300;
  color:rgba(245,241,232,.48);line-height:1.62;max-width:420px;
  margin-bottom:20px;
  transition:color .38s var(--ease),transform .38s var(--ease);
}
.work-card:hover .wc-desc{color:rgba(245,241,232,.68);transform:translateY(-2px)}

.wc-tags{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:20px}
.wc-tag{
  font-size:9px;font-weight:500;letter-spacing:.16em;text-transform:uppercase;
  border:1px solid rgba(245,241,232,.14);border-radius:999px;padding:4px 10px;
  color:rgba(245,241,232,.38);transition:opacity .32s var(--ease);
}
.work-card:hover .wc-tag{opacity:.7;border-color:rgba(245,241,232,.28)}

.wc-cta{
  display:inline-flex;align-items:center;gap:8px;
  font-size:10px;font-weight:500;letter-spacing:.22em;text-transform:uppercase;
  color:currentColor;opacity:.5;border-bottom:1px solid currentColor;padding-bottom:5px;
  transition:opacity .32s var(--ease),gap .32s var(--ease);
}
.work-card:hover .wc-cta{opacity:1;gap:14px}

/* numero grande decorativo */
.wc-num{
  position:absolute;bottom:28px;right:32px;
  font-family:"Playfair Display",serif;font-size:96px;font-weight:400;
  letter-spacing:-.04em;line-height:1;
  color:currentColor;opacity:.06;z-index:0;
  transition:opacity .42s var(--ease),transform .42s var(--ease);
  pointer-events:none;
  user-select:none;
}
.work-card:hover .wc-num{opacity:.10;transform:translateY(-6px) scale(1.04)}

/* ══ SEZIONE COME LAVORIAMO ══ */
.orbita-process{
  display:grid;grid-template-columns:1fr 1fr;
  gap:clamp(48px,7vw,108px);align-items:center;
}
.orbita-process__copy .kicker{margin-bottom:20px}
.orbita-process__copy h2{font-size:clamp(44px,5.2vw,82px);color:var(--ink);line-height:.96;margin-bottom:28px}
.orbita-process__copy h2 .italic{color:rgba(18,17,15,.32)}
.orbita-process__copy p{font-size:clamp(15px,1.1vw,18px);font-weight:300;color:rgba(18,17,15,.55);line-height:1.76;max-width:480px}

.orbita-process__visual{
  display:flex;align-items:center;justify-content:center;
}

/* ══ CTA BAND ══ */
.cta-band{
  border-top:1px solid var(--line);
  padding:96px clamp(24px,4vw,58px);
  background:radial-gradient(circle at 60% 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:640px;
}
.cta-band p em{font-style:italic;color:rgba(245,241,232,.45)}
.cta-actions{display:flex;gap:16px;flex-shrink:0;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);position:relative}
.footer-grid{position:relative;z-index:1;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}
  .orbita-hero__inner{grid-template-columns:1fr}
  .orbita-hero__stats{flex-direction:row;gap:40px}
  .stat-item{border-bottom:none;border-right:1px solid rgba(245,241,232,.08);padding-right:40px;padding-bottom:0}
  .stat-item:last-child{border-right:none;padding-right:0}
  .works-masonry{grid-template-columns:1fr 1fr}
  .work-card.w-large,.work-card.w-small,.work-card.w-half,.work-card.w-third,.work-card.w-full{grid-column:auto;min-height:340px}
  .orbita-process{grid-template-columns: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}
  .orbita-hero{padding-top:100px}
  .orbita-hero__stats{flex-direction:column;gap:20px}
  .stat-item{border-right:none;border-bottom:1px solid rgba(245,241,232,.08);padding-bottom:20px;padding-right:0}
  .works-masonry{grid-template-columns:1fr}
  .scroll-ind{display:none}
  .footer-grid{grid-template-columns:1fr}
  .filtri-wrap{flex-direction:column;align-items:flex-start}
}
@media(prefers-reduced-motion:reduce){*,*::before,*::after{animation-duration:.001ms!important;transition-duration:.001ms!important}}

/* ORBITA — hover progetti più lento + fix frame quadrato */
.work-card{
  border-radius:24px;
  overflow:hidden;
  isolation:isolate;
  clip-path:inset(0 round 24px);
  -webkit-clip-path:inset(0 round 24px);
}

.work-card::before,
.work-card::after{
  border-radius:inherit;
  clip-path:inset(0 round 24px);
  -webkit-clip-path:inset(0 round 24px);
}

.work-card:hover::before{
  animation:workFlashSlow 1.22s cubic-bezier(.22,.61,.36,1) both!important;
}

@keyframes workFlashSlow{
  0%{
    opacity:0;
    transform:translateX(-135%);
  }
  16%{
    opacity:.72;
  }
  52%{
    opacity:.42;
  }
  100%{
    opacity:0;
    transform:translateX(135%);
  }
}


/* ORBITA — filtro con card nascoste davvero */
.work-card.is-filter-hidden{
  display:none!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;
  }
}

