@media (max-width: 960px) {
  .nav-toggle { display: block; }

  .primary-nav {
    position: fixed;
    inset: var(--header-height) 0 0 0;
    z-index: 99;
    background: var(--color-cream);
    flex-direction: column;
    align-items: flex-start;
    padding: var(--space-8) var(--space-6);
    gap: var(--space-2);
    transform: translateX(100%);
    transition: transform var(--duration) var(--ease);
    overflow-y: auto;
    width: 100%;
  }
  .primary-nav.is-open { transform: translateX(0); }
  .primary-nav a {
    width: 100%;
    padding-block: var(--space-4);
    font-size: 1.1rem;
    border-bottom: 1px solid var(--color-border);
  }

  .header-phone { display: none; }
  body.nav-open { overflow: hidden; }
}

.site-header.is-scrolled {
  box-shadow: var(--shadow-sm);
}
