:root{
  --asg-white:#ffffff;
  --asg-black:#111111;
  --asg-text:#f5f7fb;
  --asg-text-soft:rgba(255,255,255,0.72);
  --asg-accent:#4f8cff;
  --asg-accent-2:#00c98d;
  --asg-border:rgba(255,255,255,0.08);
  --asg-border-strong:rgba(255,255,255,0.12);
  --asg-shadow:0 18px 50px rgba(0,0,0,0.22);
  --asg-shadow-strong:0 24px 60px rgba(0,0,0,0.32);
  --asg-max-w:1200px;
  --asg-ease:cubic-bezier(.16,1,.3,1);
  --asg-font:'Montserrat',system-ui,sans-serif;
}

/* container */
.asg-container{
  width:min(100% - 2rem,var(--asg-max-w));
  margin-inline:auto;
}

/* navbar */
.asg-navbar{
  position:fixed;
  top:0;
  left:0;
  width:100%;
  z-index:99999;
  font-family:var(--asg-font);
  padding:1.2rem 0;
  transition:
    background-color .35s ease,
    backdrop-filter .35s ease,
    -webkit-backdrop-filter .35s ease,
    border-color .35s ease,
    box-shadow .35s ease,
    padding .35s ease,
    transform .35s ease;
}

/* stato iniziale */
.asg-navbar.is-transparent{
  background:
    linear-gradient(
      to bottom,
      rgba(10,14,26,0.58) 0%,
      rgba(10,14,26,0.24) 50%,
      rgba(10,14,26,0.00) 100%
    );
  border-bottom:1px solid rgba(255,255,255,0.04);
  backdrop-filter:blur(4px);
  -webkit-backdrop-filter:blur(4px);
  box-shadow:none;
}

/* stato scroll */
.asg-navbar.is-scrolled{
  background:rgba(10,14,26,0.74);
  backdrop-filter:blur(16px);
  -webkit-backdrop-filter:blur(16px);
  border-bottom:1px solid rgba(255,255,255,0.08);
  box-shadow:var(--asg-shadow);
  padding:.95rem 0;
}

/* layout desktop */
.asg-navbar .asg-container{
  display:grid;
  grid-template-columns:auto 1fr auto auto;
  align-items:center;
  gap:2rem;
}

/* brand */
.asg-brand{
  position:relative;
  display:inline-flex;
  align-items:center;
  justify-self:start;
  text-decoration:none;
  flex:0 0 auto;
}

/* logo */
.asg-nav-logo{
  height:44px;
  width:auto;
  display:block;
  transition:filter .3s ease, opacity .3s ease, transform .3s ease;
}

.asg-navbar.is-transparent .asg-nav-logo{
  filter:brightness(0) invert(1);
}

.asg-navbar.is-scrolled .asg-nav-logo{
  filter:none;
}

/* links desktop */
.asg-nav-links{
  display:flex;
  align-items:center;
  justify-content:center;
  justify-self:center;
  gap:2rem;
  min-width:0;
}

.asg-nav-links a{
  position:relative;
  display:inline-flex;
  align-items:center;
  gap:.45rem;
  text-decoration:none;
  font-size:.82rem;
  font-weight:600;
  color:rgba(255,255,255,0.92);
  text-shadow:0 1px 4px rgba(0,0,0,0.20);
  white-space:nowrap;
  transition:
    color .28s ease,
    opacity .28s ease,
    transform .28s ease;
}

.asg-nav-links a i{
  font-size:.82em;
  opacity:.92;
}

.asg-nav-links a::after{
  content:'';
  position:absolute;
  left:0;
  bottom:-6px;
  width:0;
  height:2px;
  border-radius:999px;
  background:linear-gradient(90deg,var(--asg-accent),var(--asg-accent-2));
  transition:width .32s var(--asg-ease);
}

.asg-nav-links a:hover{
  color:#ffffff;
}

.asg-nav-links a:hover::after{
  width:100%;
}

/* CTA desktop */
.asg-nav-actions{
  display:flex;
  align-items:center;
  justify-content:flex-end;
  justify-self:end;
  flex:0 0 auto;
}

.asg-nav-cta{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:.5rem;
  padding:.72rem 1.35rem;
  border-radius:999px;
  background:linear-gradient(135deg,var(--asg-accent),#3366cc);
  color:#ffffff !important;
  text-decoration:none;
  text-shadow:none !important;
  font-size:.78rem;
  font-weight:700;
  white-space:nowrap;
  box-shadow:0 10px 24px rgba(79,140,255,0.24);
  transition:
    transform .28s ease,
    box-shadow .28s ease,
    opacity .28s ease;
}

.asg-nav-cta:hover{
  transform:translateY(-2px);
  box-shadow:0 14px 30px rgba(79,140,255,0.34);
}

.asg-nav-cta::after{
  display:none;
}

/* CTA mobile dentro menu */
.asg-nav-special-mobile{
  display:none !important;
}

/* hamburger */
.asg-hamburger{
  display:none;
  flex-direction:column;
  justify-content:center;
  align-items:center;
  gap:5px;
  background:none;
  border:none;
  padding:4px;
  cursor:pointer;
  flex:0 0 auto;
}

.asg-hamburger span{
  display:block;
  width:24px;
  height:2px;
  border-radius:999px;
  background:rgba(255,255,255,0.95);
  transition:
    transform .3s ease,
    opacity .3s ease,
    background-color .3s ease;
}

.asg-hamburger.is-active span:nth-child(1){
  transform:rotate(45deg) translate(5px,5px);
}

.asg-hamburger.is-active span:nth-child(2){
  opacity:0;
}

.asg-hamburger.is-active span:nth-child(3){
  transform:rotate(-45deg) translate(5px,-5px);
}

/* body */
body{
  padding-top:0;
}

body.asg-menu-open{
  overflow:hidden;
}

/* tablet / desktop stretto */
@media (max-width: 1180px){
  .asg-navbar .asg-container{
    grid-template-columns:auto 1fr auto;
    gap:1.4rem;
  }

  .asg-nav-links{
    gap:1.2rem;
  }

  .asg-nav-links a{
    font-size:.76rem;
  }

  .asg-nav-cta{
    padding:.66rem 1.12rem;
    font-size:.75rem;
  }
}

/* mobile */
@media (max-width: 768px){
  .asg-navbar{
    padding:calc(env(safe-area-inset-top) + .55rem) 0 .7rem;
  }
.asg-mobile-only{
  display:flex !important;
}
  .asg-navbar.is-transparent{
    background:
      linear-gradient(
        to bottom,
        rgba(10,14,26,0.82) 0%,
        rgba(10,14,26,0.42) 58%,
        rgba(10,14,26,0.12) 100%
      );
    backdrop-filter:blur(10px);
    -webkit-backdrop-filter:blur(10px);
    border-bottom:1px solid rgba(255,255,255,0.05);
  }

  .asg-navbar.is-scrolled{
    background:rgba(10,14,26,0.9);
    backdrop-filter:blur(18px);
    -webkit-backdrop-filter:blur(18px);
    border-bottom:1px solid rgba(255,255,255,0.08);
    box-shadow:0 14px 40px rgba(0,0,0,0.28);
    padding:calc(env(safe-area-inset-top) + .45rem) 0 .65rem;
  }

  .asg-navbar .asg-container{
    position:relative;
    display:grid;
    grid-template-columns:1fr auto 1fr;
    align-items:center;
    gap:0;
    min-height:48px;
  }

  .asg-brand{
    grid-column:2;
    justify-self:center;
    align-items:center;
    justify-content:center;
    z-index:2;
  }

  .asg-nav-logo{
    height:30px;
    max-width:170px;
    width:auto;
    object-fit:contain;
  }

  .asg-nav-actions{
    display:none;
  }

  .asg-hamburger{
    display:flex;
    grid-column:3;
    justify-self:end;
    width:42px;
    height:42px;
    padding:0;
    margin:0;
    border-radius:12px;
    background:rgba(255,255,255,0.05);
    border:1px solid rgba(255,255,255,0.07);
    backdrop-filter:blur(10px);
    -webkit-backdrop-filter:blur(10px);
    z-index:100002;
  }

  .asg-hamburger span{
    width:20px;
    height:2px;
  }

  .asg-nav-links{
    position:fixed;
    top:0;
    right:-100%;
    width:min(360px,100vw);
    height:100dvh;
    margin:0;
    padding:
      calc(env(safe-area-inset-top) + 5.4rem)
      1.35rem
      calc(env(safe-area-inset-bottom) + 1.5rem);
    display:flex;
    flex-direction:column;
    align-items:stretch;
    justify-content:flex-start;
    gap:.4rem;
    background:rgba(6,10,20,0.98);
    backdrop-filter:blur(18px);
    -webkit-backdrop-filter:blur(18px);
    border-left:1px solid rgba(255,255,255,0.08);
    box-shadow:-20px 0 60px rgba(0,0,0,0.38);
    z-index:100001;
    overflow-y:auto;
    transition:right .36s var(--asg-ease);
  }

  .asg-nav-links.is-open{
    right:0;
  }

  .asg-nav-links a{
    display:flex;
    align-items:center;
    gap:.75rem;
    width:100%;
    padding:1rem 0;
    color:#ffffff !important;
    text-decoration:none;
    border-bottom:1px solid rgba(255,255,255,0.07);
    font-size:1rem;
    font-weight:700;
    line-height:1.25;
    text-shadow:none;
  }

  .asg-nav-links a i{
    width:20px;
    text-align:center;
    opacity:.95;
    flex:0 0 auto;
  }

  .asg-nav-links a::after{
    display:none;
  }

.asg-nav-special-mobile{
  display:flex !important;
  align-items:center !important;
  justify-content:center !important;
  margin-top:.35rem !important;
  padding:1rem 1.15rem !important;
  border:none !important;
  border-radius:999px !important;
  background:linear-gradient(135deg,#4f8cff,#3366cc) !important;
  color:#ffffff !important;
  box-shadow:0 14px 30px rgba(79,140,255,0.28) !important;
}
  body.asg-menu-open{
    overflow:hidden;
    touch-action:none;
  }
}

/* touch refinement */
@media (hover: none){
  .asg-nav-links a:hover{
    color:rgba(255,255,255,0.92);
  }

  .asg-nav-links a:hover::after{
    width:0;
  }

  .asg-nav-cta:hover{
    transform:none;
  }
}

.asg-mobile-only{
  display:none !important;
}