
: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;
}
*{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,.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)}
.btn--ink{height:56px;display:inline-flex;align-items:center;justify-content:center;border-radius:999px;padding:0 30px;font-size:10px;font-weight:500;letter-spacing:.25em;text-transform:uppercase;border:1px solid rgba(18,17,15,.28);color:var(--ink);transition:.35s var(--ease)}
.btn--ink:hover{background:var(--ink);color:var(--paper);border-color:var(--ink);transform:translateY(-3px)}
.btn--ink-solid{background:var(--ink);color:var(--paper);border-color:var(--ink)}.btn--ink-solid:hover{background:rgba(18,17,15,.82);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 ══ */
.rotta-hero{
  min-height:100svh;
  display:flex;align-items:center;
  position:relative;overflow:hidden;
  padding:116px clamp(24px,4vw,58px) 80px;
  background:#050505;
}
.rotta-hero__bg{position:absolute;inset:0;pointer-events:none;z-index:0;overflow:hidden}
#rottaCanvas{position:absolute;inset:0;width:100%;height:100%;display:block}

.rotta-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;
}
.rotta-hero__copy .kicker{margin-bottom:28px}
.rotta-hero__copy h1{font-size:clamp(68px,7.5vw,124px);color:var(--cream);margin-bottom:0;line-height:.9;overflow:visible}
.rotta-hero__copy h1 .line2{display:block;color:rgba(245,241,232,.55);margin-top:.08em}
.rotta-hero__copy h1 .line3{display:block;margin-top:.08em}
.rotta-hero__copy .sub{
  font-size:clamp(17px,1.35vw,22px);font-weight:300;
  color:rgba(245,241,232,.48);line-height:1.72;
  max-width:480px;margin-top:32px;margin-bottom:44px;
}
.rotta-hero__copy .actions{display:flex;gap:20px;flex-wrap:wrap}

/* numeri step nell'hero */
.rotta-hero__steps{
  display:flex;flex-direction:column;gap:0;
}
.hero-step{
  display:flex;align-items:center;gap:20px;
  padding:22px 0;border-bottom:1px solid rgba(245,241,232,.08);
  transition:padding-left .45s var(--ease);
  position:relative;
}
.hero-step::before{content:"";position:absolute;left:0;top:0;bottom:0;width:2px;background:rgba(245,241,232,.30);transform:scaleY(0);transform-origin:top;transition:transform .55s var(--ease)}
.hero-step:hover{padding-left:14px}
.hero-step:hover::before{transform:scaleY(1)}
.hero-step:last-child{border-bottom:none}
.hs-num{
  font-family:"Playfair Display",serif;font-size:48px;font-weight:400;
  letter-spacing:-.04em;color:rgba(245,241,232,.16);line-height:1;
  flex-shrink:0;width:68px;transition:color .38s var(--ease);
}
.hero-step:hover .hs-num{color:rgba(245,241,232,.36)}
.hs-content h3{
  font-family:"Playfair Display",serif;font-size:clamp(24px,2.2vw,34px);
  font-weight:400;letter-spacing:-.04em;color:var(--cream);
  margin-bottom:4px;transition:transform .38s var(--ease);
}
.hero-step:hover .hs-content h3{transform:translateY(-2px)}
.hs-content p{font-size:13px;font-weight:300;color:rgba(245,241,232,.40);line-height:1.55}

.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%}}

/* ══ 4 STEP ESTESI ══ */
.step-full{
  display:grid;grid-template-columns:1fr 1.5fr;
  gap:clamp(48px,7vw,108px);
  align-items:start;
  padding:80px 0;
  border-bottom:1px solid rgba(18,17,15,.12);
}
.step-full:last-child{border-bottom:none}
.step-full.reverse{grid-template-columns:1.5fr 1fr;direction:rtl}
.step-full.reverse>*{direction:ltr}

.sf-label .step-num-big{
  font-family:"Playfair Display",serif;
  font-size:clamp(96px,12vw,180px);font-weight:400;letter-spacing:-.04em;
  color:rgba(18,17,15,.09);line-height:.88;
  margin-bottom:8px;
  transition:color .55s var(--ease);
}
.step-full:hover .sf-label .step-num-big{color:rgba(18,17,15,.16)}
.sf-label .kicker{margin-bottom:16px}
.sf-label h2{
  font-family:"Playfair Display",serif;
  font-size:clamp(36px,4vw,68px);font-weight:400;letter-spacing:-.04em;
  line-height:.98;color:var(--ink);
}
.sf-label h2 .italic{color:rgba(18,17,15,.32)}

.sf-body{
  display:flex;flex-direction:column;gap:24px;
  padding-top:clamp(12px,2.5vw,48px);
}
.sf-body p{
  font-size:clamp(16px,1.2vw,20px);font-weight:300;
  color:rgba(18,17,15,.60);line-height:1.78;
}
.sf-body p strong{font-weight:500;color:rgba(18,17,15,.85)}
.sf-body .sf-detail{
  display:flex;flex-direction:column;gap:0;
  border-top:1px solid rgba(18,17,15,.10);margin-top:8px;
}
.sf-detail-row{
  display:flex;align-items:baseline;gap:14px;
  padding:14px 0;border-bottom:1px solid rgba(18,17,15,.07);
  transition:padding-left .38s var(--ease);
}
.sf-detail-row:last-child{border-bottom:none}
.sf-detail-row:hover{padding-left:10px}
.sf-dr-label{
  font-size:9px;font-weight:500;letter-spacing:.22em;text-transform:uppercase;
  color:rgba(18,17,15,.32);min-width:90px;flex-shrink:0;
}
.sf-dr-text{font-size:14px;font-weight:300;color:rgba(18,17,15,.55);line-height:1.55}

/* ══ COME INIZIAMO ══ */
.come-iniziamo{
  display:grid;grid-template-columns:1fr 1fr;
  gap:clamp(48px,7vw,108px);align-items:center;
}
.ci-copy .kicker{margin-bottom:20px}
.ci-copy h2{font-size:clamp(42px,5vw,80px);color:var(--cream);line-height:.96;margin-bottom:28px}
.ci-copy h2 .italic{color:rgba(245,241,232,.38)}
.ci-copy p{font-size:clamp(15px,1.1vw,18px);font-weight:300;color:rgba(245,241,232,.55);line-height:1.76;max-width:480px;margin-bottom:20px}

.ci-timeline{
  display:flex;flex-direction:column;gap:0;
  position:relative;
}
.ci-timeline::before{
  content:"";position:absolute;left:16px;top:8px;bottom:8px;
  width:1px;background:rgba(245,241,232,.12);
}
.ci-step{
  display:flex;gap:28px;padding-bottom:36px;
  position:relative;
}
.ci-step:last-child{padding-bottom:0}
.ci-dot{
  width:32px;height:32px;border-radius:50%;
  border:1px solid rgba(245,241,232,.20);background:rgba(245,241,232,.05);
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;z-index:1;
  font-size:10px;font-weight:500;letter-spacing:.10em;color:rgba(245,241,232,.45);
  transition:background .38s var(--ease),border-color .38s var(--ease),color .38s var(--ease);
}
.ci-step:hover .ci-dot{background:var(--cream);border-color:var(--cream);color:var(--black)}
.ci-content 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;
  padding-top:4px;
}
.ci-content p{font-size:14px;font-weight:300;color:rgba(245,241,232,.50);line-height:1.68}

/* ══ TEMPI E MODALITÀ ══ */
.modalita-grid{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:1px;background:var(--line);border:1px solid var(--line);
  margin-top:64px;
}
.modalita-card{
  background:#080807;padding:44px 36px;
  display:flex;flex-direction:column;gap:16px;
  transition:transform .42s var(--ease),filter .32s var(--ease);
  position:relative;overflow:hidden;
}
.modalita-card:hover{transform:translateY(-6px);filter:brightness(1.08);z-index:2;box-shadow:0 24px 72px rgba(0,0,0,.28)}
.modalita-card::before{
  content:"";position:absolute;inset:0;
  background:linear-gradient(105deg,transparent 35%,rgba(255,255,255,.36) 47%,rgba(255,244,214,.12) 53%,transparent 65%);
  opacity:0;transform:translateX(-120%);pointer-events:none;mix-blend-mode:screen;
}
.modalita-card:hover::before{animation:mcFlash .82s var(--ease) both}
@keyframes mcFlash{0%{opacity:0;transform:translateX(-120%)}18%{opacity:.8}100%{opacity:0;transform:translateX(120%)}}
.mc-icon{
  font-family:"Playfair Display",serif;font-size:52px;font-weight:400;
  color:rgba(245,241,232,.10);line-height:1;letter-spacing:-.04em;
  transition:color .38s var(--ease);
}
.modalita-card:hover .mc-icon{color:rgba(245,241,232,.18)}
.mc-title{
  font-family:"Playfair Display",serif;font-size:clamp(22px,2vw,32px);
  font-weight:400;letter-spacing:-.03em;color:var(--cream);
  transition:transform .38s var(--ease);
}
.modalita-card:hover .mc-title{transform:translateY(-3px)}
.mc-text{font-size:clamp(13px,.95vw,15px);font-weight:300;color:rgba(245,241,232,.48);line-height:1.68;transition:color .38s var(--ease)}
.modalita-card:hover .mc-text{color:rgba(245,241,232,.70)}

/* ══ CTA ══ */
.rotta-cta{
  margin-top:72px;
  display:flex;align-items:center;justify-content:space-between;
  gap:48px;padding-top:64px;
  border-top:1px solid rgba(245,241,232,.12);
}
.rotta-cta p{
  font-family:"Playfair Display",serif;
  font-size:clamp(28px,3vw,48px);font-weight:400;
  letter-spacing:-.04em;line-height:1.1;color:var(--cream);max-width:520px;
}
.rotta-cta p em{font-style:italic;color:rgba(245,241,232,.42)}
.cta-btns{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}
  .rotta-hero__inner{grid-template-columns:1fr}
  .step-full{grid-template-columns:1fr;direction:ltr}
  .step-full.reverse{grid-template-columns:1fr;direction:ltr}
  .come-iniziamo{grid-template-columns:1fr}
  .modalita-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr 1fr}
  .rotta-cta{flex-direction:column;align-items:flex-start;gap:28px}
}
@media(max-width:680px){
  .nav{padding:0 24px}.logo{width:140px}.nav__cta{display:none}
  .rotta-hero{padding-top:100px}
  .scroll-ind{display:none}
  .footer-grid{grid-template-columns:1fr}
}
@media(prefers-reduced-motion:reduce){*,*::before,*::after{animation-duration:.001ms!important;transition-duration:.001ms!important}}

/* ANCORE ROTTA — offset per nav fissa */
.step-full{
  scroll-margin-top:110px;
}


/* 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;
  }
}

