
: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}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;background:var(--black)}
body{font-family:Inter,system-ui,sans-serif;background:#050505;color:var(--cream);overflow-x:hidden;line-height:1.65;-webkit-font-smoothing:antialiased;cursor:none;opacity:0;transition:opacity .75s var(--ease);min-height:100vh}
body.is-ready{opacity:1}
a{text-decoration:none;color:inherit} svg{display:block} ::selection{background:#faf9f6;color:var(--black)}
.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)}
body.cursor-hover .cursor-ring{width:68px;height:68px}
.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)}
.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)}
.footer{border-top:1px solid var(--line);padding:76px clamp(24px,4vw,58px) 42px;background:linear-gradient(180deg,#050505,#060606)}
.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)}
@media(max-width:1080px){.nav__links{display:none}.footer-grid{grid-template-columns:1fr 1fr}}
@media(max-width:680px){.nav{padding:0 24px}.logo{width:140px}.nav__cta{display:none}.footer-grid{grid-template-columns:1fr}}
@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;
  }
}




.legal-hero{padding:148px clamp(24px,4vw,58px) 64px;background:#050505;border-bottom:1px solid rgba(245,241,232,.08)}
.legal-hero__inner{max-width:820px;margin:0 auto}
.legal-hero .kicker{font-size:10px;font-weight:500;letter-spacing:.32em;text-transform:uppercase;color:rgba(245,241,232,.32);margin-bottom:20px}
.legal-hero h1{font-family:"Playfair Display",Georgia,serif;font-size:clamp(44px,5.5vw,84px);font-weight:400;letter-spacing:-.045em;line-height:.94;color:var(--cream);margin-bottom:24px}
.legal-hero h1 em{font-style:italic;color:rgba(245,241,232,.45)}
.legal-hero .meta{display:flex;gap:32px;flex-wrap:wrap}
.legal-hero .meta span{font-size:12px;font-weight:300;color:rgba(245,241,232,.36);letter-spacing:.06em}
.legal-body{padding:72px clamp(24px,4vw,58px);background:#050505}
.legal-inner{max-width:820px;margin:0 auto}
.legal-section{margin-bottom:56px;padding-bottom:56px;border-bottom:1px solid rgba(245,241,232,.08)}
.legal-section:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}
.legal-section h2{font-family:"Playfair Display",Georgia,serif;font-size:clamp(24px,2.4vw,36px);font-weight:400;letter-spacing:-.04em;color:var(--cream);margin-bottom:20px}
.legal-section h3{font-size:14px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:rgba(245,241,232,.55);margin:24px 0 12px}
.legal-section p{font-size:clamp(14px,1vw,16px);font-weight:300;color:rgba(245,241,232,.55);line-height:1.78;margin-bottom:16px}
.legal-section p:last-child{margin-bottom:0}
.legal-section ul{list-style:none;padding:0;display:flex;flex-direction:column;gap:10px;margin-bottom:16px}
.legal-section ul li{font-size:clamp(14px,1vw,16px);font-weight:300;color:rgba(245,241,232,.52);line-height:1.65;padding-left:20px;position:relative}
.legal-section ul li::before{content:"·";position:absolute;left:0;color:rgba(245,241,232,.28)}
.legal-section a{color:rgba(245,241,232,.65);border-bottom:1px solid rgba(245,241,232,.20);transition:.2s}
.legal-section a:hover{color:var(--cream);border-color:rgba(245,241,232,.55)}
.legal-section strong{font-weight:500;color:rgba(245,241,232,.75)}
/* tabella cookie */
.cookie-table{width:100%;border-collapse:collapse;margin:20px 0;font-size:13px}
.cookie-table th{text-align:left;padding:12px 16px;font-size:9px;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:rgba(245,241,232,.38);border-bottom:1px solid rgba(245,241,232,.10)}
.cookie-table td{padding:14px 16px;font-weight:300;color:rgba(245,241,232,.52);border-bottom:1px solid rgba(245,241,232,.06);vertical-align:top;line-height:1.55}
.cookie-table tr:last-child td{border-bottom:none}
.cookie-table tr:hover td{background:rgba(245,241,232,.02)}
.badge-tech{display:inline-block;font-size:9px;font-weight:500;letter-spacing:.12em;text-transform:uppercase;background:rgba(245,241,232,.08);border:1px solid rgba(245,241,232,.14);border-radius:4px;padding:2px 8px;color:rgba(245,241,232,.55)}
.legal-box{background:rgba(245,241,232,.04);border:1px solid rgba(245,241,232,.08);border-radius:14px;padding:24px 28px;margin:20px 0}
.legal-box p{margin-bottom:0;font-size:13px}



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

