/* === Nav pubblica === */

.site-nav{
  position: fixed;
  top: 0; left: 0; right: 0;
  padding: 20px 48px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  z-index: 100;
  background: rgba(250, 246, 239, 0.85);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border-bottom: 1px solid var(--line);
}

.site-nav-logo{
  display: flex;
  align-items: center;
  gap: 12px;
  text-decoration: none;
  color: var(--ink);
}
.site-nav-logo-img{
  height: 38px;
  width: auto;
  display: block;
}
.site-nav-logo-mark{
  width: 36px; height: 36px;
  display: flex; align-items: center; justify-content: center;
}
.site-nav-logo-text{
  font-family: 'Cormorant Garamond', serif;
  font-size: 24px;
  font-weight: 600;
  letter-spacing: 0.5px;
}
.site-nav-logo-text em{ color: var(--gold); font-style: italic; }

.site-nav-links{
  display: flex;
  align-items: center;
  gap: 36px;
  list-style: none;
}
.site-nav-links a{
  color: var(--ink-soft);
  text-decoration: none;
  font-size: 14px;
  font-weight: 500;
  letter-spacing: 0.3px;
  transition: color 0.3s;
  position: relative;
}
.site-nav-links a:hover{ color: var(--gold); }
.site-nav-links a::after{
  content:'';
  position: absolute;
  bottom: -4px; left: 0;
  width: 0; height: 1px;
  background: var(--gold);
  transition: width 0.3s;
}
.site-nav-links a:hover::after{ width: 100%; }

/* Stato attivo: la voce nav della pagina corrente è leggermente
   evidenziata. Riusiamo l'idioma già presente (la sottolineatura oro
   dell'hover), tenendola visibile a riposo, e un colore del testo un
   filo più scuro. Niente grassetto né riempimenti: il CTA nero resta
   la CTA dominante, questo è solo un "sei qui" discreto. Il CTA
   Iscriviti non riceve mai questo stato. */
.site-nav-links a.is-active{
  color: var(--ink);
}
.site-nav-links a.is-active::after{
  width: 100%;
}

.site-nav-cta{
  padding: 10px 22px;
  background: var(--ink);
  color: var(--bg) !important;
  border-radius: 999px;
  font-size: 13px !important;
  line-height: 1 !important;
  letter-spacing: 0.5px !important;
}
.site-nav-cta:hover{ background: var(--gold); }
.site-nav-cta::after{ display:none !important; }

/* --- Link Admin (solo se loggato) --- */
/* Per allinearsi in altezza a .site-nav-cta (che non ha border), compenso
   i 2px dei bordi con padding verticale ridotto di 1px per lato. */
.site-nav-admin{
  padding: 9px 18px;
  background: transparent;
  color: var(--gold) !important;
  border: 1px solid var(--gold);
  border-radius: 999px;
  font-size: 13px !important;
  line-height: 1 !important;
  letter-spacing: 0.5px !important;
  font-weight: 500 !important;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  transition: all 0.2s;
}
.site-nav-admin-icon{
  width: 14px;
  height: 14px;
  flex-shrink: 0;
}
.site-nav-admin:hover{
  background: var(--gold);
  color: var(--bg) !important;
}
.site-nav-admin::after{ display:none !important; }

.site-nav-toggle{
  display: none;
  background: none;
  border: none;
  cursor: pointer;
  padding: 8px;
  color: var(--ink);
}
.site-nav-toggle svg{ width: 24px; height: 24px; }

/* Menu mobile aperto */
.site-nav-links.is-open{
  display: flex;
  position: absolute;
  top: 100%; left: 0; right: 0;
  flex-direction: column;
  background: var(--bg);
  padding: 24px;
  gap: 20px;
  border-bottom: 1px solid var(--line);
  box-shadow: 0 12px 30px rgba(0,0,0,0.08);
}

@media (max-width: 900px){
  .site-nav{ padding: 16px 20px; }
  .site-nav-links{ display: none; }
  .site-nav-toggle{ display: block; }
}
