
: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;
  /* Antares */
  --c:#2b0f0f;--c-light:#deb8b8;--c-mid:#c48080;
  --c-bg1:#130606;--c-bg2:#120707;
}
*{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(222,184,184,.13),rgba(200,205,234,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)}
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)}
.kicker-accent{color:var(--c-light);opacity:.72}
.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,.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--accent{background:var(--c-light);color:var(--c-bg1)}.btn--accent:hover{transform:translateY(-3px);box-shadow:0 22px 60px rgba(222,184,184,.22)}
.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)}

/* ══ 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(30,8,8,.72);backdrop-filter:blur(12px);
  border-bottom:1px solid rgba(222,184,184,.10);
  transition:transform .35s var(--ease),opacity .35s var(--ease);
  transform:translateY(-14px);opacity:0;
}
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(222,184,184,.45);transition:.2s var(--ease)}
.breadcrumb a:hover{color:var(--c-light)}
.breadcrumb span{color:rgba(222,184,184,.22)}
.breadcrumb strong{color:var(--c-light);font-weight:500}

/* ══ HERO ══ */
.svc-hero{
  min-height:100svh;
  display:flex;align-items:center;
  position:relative;overflow:hidden;
  padding:136px clamp(24px,4vw,58px) 80px;
  background:linear-gradient(145deg,var(--c-bg1) 0%,var(--c) 55%,var(--c-bg2) 100%);
}

/* sistema orbitale di sfondo */
.svc-hero__orbital{
  position:absolute;inset:0;pointer-events:none;z-index:0;
  overflow:hidden;
}
#orbitalCanvas{
  position:absolute;inset:0;
  width:100%;height:100%;
  display:block;
}

.svc-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;
}

.svc-hero__copy .kicker{margin-bottom:28px;color:var(--c-light);opacity:.65}
.svc-hero__copy h1{
  font-size:clamp(72px,8vw,130px);
  color:var(--cream);margin-bottom:32px;line-height:.92;overflow:visible;
}
.svc-hero__copy .text{margin-bottom:44px}
.svc-hero__copy .actions{display:flex;gap:20px;flex-wrap:wrap}

/* visual hero — mockup identità */
.svc-hero__visual{
  display:flex;justify-content:center;align-items:center;
  position:relative;min-height:460px;
}

/* scroll */
.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,.32)}
.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,.14);position:relative;overflow:hidden}
.scroll-ind i::after{content:"";position:absolute;left:0;top:-40%;width:100%;height:40%;background:var(--c-light);animation:scrollLine 1.8s ease-in-out infinite}
@keyframes scrollLine{to{top:120%}}

/* ══ COSA FACCIAMO ══ */
.cosa-grid{
  display:grid;grid-template-columns:1fr 1.3fr;
  gap:clamp(48px,7vw,108px);align-items:start;
}
.cosa-label{position:sticky;top:130px}
.cosa-label .kicker{margin-bottom:20px}
.cosa-label h2{font-size:clamp(44px,5.2vw,84px);color:var(--ink);line-height:.96}
.cosa-label h2 .italic{color:rgba(18,17,15,.32)}
.cosa-label p{margin-top:24px;font-size:clamp(15px,1.1vw,18px);font-weight:300;color:rgba(18,17,15,.55);line-height:1.72;max-width:380px}

.attivita-list{display:flex;flex-direction:column;gap:0;border-top:1px solid rgba(18,17,15,.12)}
.attivita{
  display:grid;grid-template-columns:52px 1fr;gap:20px;
  padding:30px 0;border-bottom:1px solid rgba(18,17,15,.12);
  position:relative;transition:padding-left .45s var(--ease);
}
.attivita::before{content:"";position:absolute;left:0;top:0;bottom:0;width:2px;background:var(--c);transform:scaleY(0);transform-origin:top;transition:transform .55s var(--ease)}
.attivita:hover{padding-left:14px}
.attivita:hover::before{transform:scaleY(1)}
.att-num{font-family:"Playfair Display",serif;font-size:36px;font-weight:400;letter-spacing:-.04em;color:rgba(18,17,15,.16);line-height:1;padding-top:4px;transition:color .38s var(--ease)}
.attivita:hover .att-num{color:rgba(18,17,15,.32)}
.att-body h3{font-family:"Playfair Display",serif;font-size:clamp(22px,1.9vw,30px);font-weight:400;letter-spacing:-.03em;color:var(--ink);margin-bottom:8px}
.att-body p{font-size:clamp(14px,1vw,16px);font-weight:300;color:rgba(18,17,15,.52);line-height:1.68}
.att-tags{display:flex;gap:6px;flex-wrap:wrap;margin-top:10px}
.att-tag{font-size:9px;font-weight:500;letter-spacing:.16em;text-transform:uppercase;border:1px solid rgba(18,17,15,.16);border-radius:999px;padding:4px 10px;color:rgba(18,17,15,.42)}

/* ══ PROCESSO ORION ══ */
.processo-orion{
  display:grid;grid-template-columns:repeat(4,1fr);
  gap:1px;background:var(--line);border:1px solid var(--line);
  margin-top:64px;
}
.proc-step{
  background:linear-gradient(160deg,var(--c-bg1),var(--c));
  padding:40px 32px;
  display:flex;flex-direction:column;justify-content:space-between;
  min-height:320px;
  position:relative;overflow:hidden;
  transition:filter .38s var(--ease),transform .42s var(--ease);
}
.proc-step:hover{filter:brightness(1.12);transform:translateY(-6px);z-index:2;box-shadow:0 24px 70px rgba(0,0,0,.32)}
.proc-step::after{
  content:"";position:absolute;inset:0;
  background:radial-gradient(circle at 80% 20%,rgba(200,205,234,.18),transparent 44%);
  opacity:.5;transition:opacity .38s var(--ease);pointer-events:none;
}
.proc-step:hover::after{opacity:1}
.proc-arrow{
  font-family:"Playfair Display",serif;
  font-size:48px;font-weight:400;letter-spacing:-.04em;
  color:rgba(200,205,234,.18);line-height:1;
  transition:color .38s var(--ease),transform .42s var(--ease);
  position:relative;z-index:1;
}
.proc-step:hover .proc-arrow{color:rgba(200,205,234,.32);transform:translateY(-4px)}
.proc-body{position:relative;z-index:1}
.proc-body small{font-size:9px;letter-spacing:.28em;text-transform:uppercase;color:rgba(200,205,234,.42);display:block;margin-bottom:12px}
.proc-body h3{font-family:"Playfair Display",serif;font-size:clamp(24px,2vw,32px);font-weight:400;letter-spacing:-.04em;color:var(--cream);margin-bottom:10px;transition:transform .38s var(--ease)}
.proc-step:hover .proc-body h3{transform:translateY(-3px)}
.proc-body p{font-size:clamp(13px,.95vw,15px);font-weight:300;color:rgba(245,241,232,.52);line-height:1.62;transition:color .38s var(--ease)}
.proc-step:hover .proc-body p{color:rgba(245,241,232,.74)}

/* ══ CASE STUDY PREVIEW ══ */
.cases-head{
  display:grid;grid-template-columns:.8fr 1.2fr;
  gap:48px;align-items:end;margin-bottom:52px;
}
.cases-head h2{font-size:clamp(44px,5vw,82px);color:var(--cream);line-height:.96;overflow:visible}
.cases-head p{font-size:clamp(15px,1.1vw,18px);font-weight:300;color:rgba(245,241,232,.52);line-height:1.72}

.cases-grid{display:grid;grid-template-columns:1.4fr 1fr;gap:18px}
.case-card{
  border-radius:24px;overflow:hidden;
  position:relative;padding:42px 36px;
  min-height:380px;
  display:flex;flex-direction:column;justify-content:space-between;
  transition:transform .45s var(--ease),box-shadow .45s var(--ease),filter .45s var(--ease);
  cursor:pointer;
}
.case-card:hover{transform:translateY(-7px);box-shadow:0 28px 72px rgba(0,0,0,.32);filter:brightness(1.08)}
.case-card.primary{background:linear-gradient(145deg,#0c0e20,var(--c),#111525)}
.case-card.secondary{background:linear-gradient(145deg,#0e0f1a,#1c2040,#0c0d18)}
.case-card::before{
  content:"";position:absolute;inset:0;
  background:linear-gradient(105deg,transparent 30%,rgba(255,255,255,.38) 47%,rgba(200,205,234,.14) 53%,transparent 65%);
  opacity:0;transform:translateX(-120%);pointer-events:none;mix-blend-mode:screen;
}
.case-card:hover::before{animation:caseFlash .85s var(--ease) both}
@keyframes caseFlash{0%{opacity:0;transform:translateX(-120%)}18%{opacity:.9}100%{opacity:0;transform:translateX(120%)}}
.case-card small{font-size:10px;letter-spacing:.24em;text-transform:uppercase;color:rgba(222,184,184,.45);position:relative;z-index:1}
.case-card h3{font-family:"Playfair Display",serif;font-size:clamp(32px,3.2vw,54px);font-weight:400;letter-spacing:-.04em;line-height:.98;color:var(--cream);position:relative;z-index:1;transition:transform .42s var(--ease)}
.case-card:hover h3{transform:translateY(-4px)}
.case-card p{font-size:clamp(14px,1vw,16px);font-weight:300;color:rgba(245,241,232,.50);position:relative;z-index:1}
.case-cta{
  display:inline-flex;align-items:center;gap:8px;
  font-size:10px;font-weight:500;letter-spacing:.22em;text-transform:uppercase;
  color:var(--c-light);opacity:.65;border-bottom:1px solid var(--c-light);padding-bottom:5px;
  position:relative;z-index:1;transition:opacity .3s var(--ease),gap .3s var(--ease);
}
.case-card:hover .case-cta{opacity:1;gap:14px}

/* placeholder visual nei case */
.case-visual{
  position:absolute;bottom:0;right:0;
  width:55%;height:60%;opacity:.12;
  background:linear-gradient(145deg,transparent,var(--c-light));
  clip-path:polygon(20% 0%,100% 0%,100% 100%,0% 100%);
}

/* ══ CTA CONTATTO ══ */
.svc-cta{
  background:linear-gradient(145deg,var(--c-bg1),var(--c),var(--c-bg2));
  border-top:1px solid rgba(222,184,184,.10);
  padding:100px clamp(24px,4vw,58px);
}
.svc-cta__inner{
  max-width:var(--max);margin:0 auto;
  display:grid;grid-template-columns:1fr 1fr;
  gap:80px;align-items:center;
}
.svc-cta__copy p{
  font-family:"Playfair Display",serif;
  font-size:clamp(36px,4.5vw,72px);font-weight:400;
  letter-spacing:-.045em;line-height:1.02;
  color:var(--cream);margin-bottom:28px;
}
.svc-cta__copy p em{font-style:italic;color:var(--c-light)}
.svc-cta__copy .sub{
  font-size:clamp(15px,1.1vw,18px);font-weight:300;
  color:rgba(245,241,232,.50);line-height:1.72;max-width:480px;
}

/* mini form nel CTA */
.svc-mini-form{
  background:rgba(245,241,232,.04);
  border:1px solid rgba(200,205,234,.12);
  border-radius:24px;padding:40px;
  display:flex;flex-direction:column;gap:14px;
}
.svc-mini-form p{
  font-size:10px;font-weight:500;letter-spacing:.22em;text-transform:uppercase;
  color:var(--c-light);opacity:.6;margin-bottom:4px;
}
.field{
  width:100%;background:rgba(245,241,232,.05);
  border:1px solid rgba(200,205,234,.14);border-radius:14px;
  color:var(--cream);padding:16px 18px;outline:0;font:inherit;
  transition:border-color .28s var(--ease);
}
.field:focus{border-color:rgba(200,205,234,.35)}
.field::placeholder{color:rgba(245,241,232,.28)}
.field-select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' fill='none'%3E%3Cpath d='M1 1l5 5 5-5' stroke='rgba(222,184,184,.45)' stroke-width='1.5' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 18px center;background-size:12px;padding-right:42px;cursor:pointer}
.field-select option{background:#1a1d30;color:var(--cream)}
textarea.field{min-height:100px;resize:vertical}
.svc-submit{
  height:52px;border-radius:999px;border:0;
  background:var(--c-light);color:var(--c-bg1);
  font-size:10px;letter-spacing:.24em;text-transform:uppercase;
  font-weight:600;cursor:pointer;
  transition:.32s var(--ease);
}
.svc-submit:hover{transform:translateY(-3px);box-shadow:0 16px 48px rgba(200,205,234,.24)}

/* ══ NAV SERVIZI ══ */
.svc-nav-strip{
  background:rgba(7,7,7,.85);backdrop-filter:blur(14px);
  border-top:1px solid var(--line);border-bottom:1px solid var(--line);
  padding:0 clamp(24px,4vw,58px);
  overflow-x:auto;scrollbar-width:none;
}
.svc-nav-strip::-webkit-scrollbar{display:none}
.svc-nav-inner{
  max-width:var(--max);margin:0 auto;
  display:flex;align-items:center;gap:0;
  height:56px;white-space:nowrap;
}
.svc-nav-item{
  display:inline-flex;align-items:center;gap:8px;
  height:100%;padding:0 22px;
  font-size:10px;font-weight:500;letter-spacing:.22em;text-transform:uppercase;
  color:rgba(245,241,232,.38);border-right:1px solid var(--line);
  transition:.25s var(--ease);
}
.svc-nav-item:hover{color:rgba(245,241,232,.72);background:rgba(245,241,232,.03)}
.svc-nav-item.active{color:var(--c-light);background:rgba(200,205,234,.05)}
.svc-nav-item i{width:6px;height:6px;border-radius:50%;background:currentColor;flex-shrink:0}

/* ══ 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}
  .svc-hero__inner{grid-template-columns:1fr}
  .svc-hero__visual{display:none}
  .cosa-grid{grid-template-columns:1fr}
  .cosa-label{position:static}
  .processo-orion{grid-template-columns:1fr 1fr}
  .cases-grid{grid-template-columns:1fr}
  .cases-head{grid-template-columns:1fr}
  .svc-cta__inner{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr 1fr}
  .breadcrumb{display:none}
}
@media(max-width:680px){
  .nav{padding:0 24px}.logo{width:140px}.nav__cta{display:none}
  .svc-hero{padding-top:106px}
  .processo-orion{grid-template-columns:1fr}
  .scroll-ind{display:none}
  .footer-grid{grid-template-columns:1fr}
  .svc-nav-strip{display:none}
}
@media(prefers-reduced-motion:reduce){*,*::before,*::after{animation-duration:.001ms!important;transition-duration:.001ms!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;
  }
}

