/* ========================================
   visitPanicale.com — Navigation
   ======================================== */

.site-nav {
  position: fixed;
  top: 0; left: 0; right: 0;
  z-index: 100;
  background: var(--parchment);
  height: 54px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 40px;
  border-bottom: 2px solid var(--terracotta);
}

.nav-logo {
  font-family: var(--font-display);
  font-size: 20px;
  font-weight: 300;
  font-style: italic;
  color: var(--ink);
  letter-spacing: .06em;
  text-decoration: none;
}

.nav-links {
  display: flex;
  align-items: center;
  gap: 22px;
}

.nav-links a {
  font-family: var(--font-body);
  font-size: 8.5px;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--ink-medium);
  text-decoration: none;
  transition: color .2s;
}

.nav-links a:hover { color: var(--terracotta); }
.nav-links a.active { color: var(--terracotta); }

.lang-toggle {
  background: var(--terracotta);
  color: white;
  font-family: var(--font-body);
  font-size: 8px;
  letter-spacing: .14em;
  text-transform: uppercase;
  padding: 6px 14px;
  border: none;
  border-radius: 2px;
  cursor: pointer;
  transition: background .2s;
}

.lang-toggle:hover { background: var(--terracotta-hover); }

.nav-hamburger {
  display: none;
  background: none;
  border: none;
  font-size: 20px;
  cursor: pointer;
  color: var(--ink);
}

@media (max-width: 768px) {
  .site-nav { padding: 0 20px; }
  .nav-links { display: none; }
  .nav-hamburger { display: block; }
  .nav-links.open {
    display: flex;
    flex-direction: column;
    position: fixed;
    top: 54px; left: 0; right: 0; bottom: 0;
    background: var(--parchment);
    padding: 2rem;
    gap: 1.5rem;
    z-index: 99;
  }
  .nav-links.open a { font-size: 18px; }
  .nav-links.open .lang-toggle {
    font-size: 12px;
    padding: 10px 20px;
    align-self: flex-start;
  }
}
