/* nav.css — Product mega-menu + dropdown chrome.
   Loaded on EVERY page via base.njk so the dropdown works regardless of which page
   stylesheet (landing.css / pricing.css) supplies the rest of the nav. Uses the design
   tokens from whichever :root the page already loads. */

.nav-item { position: relative; display: inline-flex; align-items: center; }

.nav-trigger {
  font-family: var(--font-display);
  font-size: 14px;
  color: var(--muted-foreground);
  padding: 6px 10px;
  border-radius: 6px;
  background: transparent;
  border: 0;
  cursor: pointer;
  display: inline-flex; align-items: center; gap: 5px;
  transition: color 150ms ease, background 150ms ease;
}
.nav-trigger:hover,
.nav-item:hover .nav-trigger,
.nav-item.open .nav-trigger,
.nav-trigger.is-active { color: var(--foreground); }
.nav-trigger:hover, .nav-item.open .nav-trigger { background: rgba(255,255,255,0.04); }
.nav-trigger .chev { width: 13px; height: 13px; opacity: 0.7; transition: transform 180ms ease; }
.nav-item:hover .nav-trigger .chev, .nav-item.open .nav-trigger .chev { transform: rotate(180deg); }

.mega {
  position: absolute;
  top: calc(100% + 10px);
  left: -14px;
  width: 660px;
  max-width: calc(100vw - 32px);
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 14px;
  box-shadow: 0 24px 60px -18px rgba(0,0,0,0.6);
  padding: 16px;
  opacity: 0; visibility: hidden; transform: translateY(-6px);
  transition: opacity 160ms ease, transform 160ms ease, visibility 0s linear 160ms;
  z-index: 200;
}
.nav-item:hover .mega,
.nav-item:focus-within .mega,
.nav-item.open .mega {
  opacity: 1; visibility: visible; transform: translateY(0);
  transition: opacity 160ms ease, transform 160ms ease;
}
/* invisible bridge so the menu stays open while the cursor crosses the gap */
.mega::before { content: ""; position: absolute; top: -12px; left: 0; right: 0; height: 12px; }

.mega-inner { display: grid; grid-template-columns: repeat(3, 1fr); gap: 6px 12px; }
.mega-col { display: flex; flex-direction: column; }
.mega-col-h {
  font-family: var(--font-mono);
  font-size: 10px; letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--muted-foreground);
  padding: 8px 10px 6px;
}
.mega-link { display: block; padding: 9px 10px; border-radius: 9px; }
a.mega-link { transition: background 140ms ease; }
a.mega-link:hover { background: rgba(255,255,255,0.05); }
.mega-name { display: flex; align-items: center; gap: 8px; color: var(--foreground); font-size: 14px; font-weight: 500; }
.mega-desc { display: block; color: var(--muted-foreground); font-size: 12.5px; margin-top: 3px; line-height: 1.4; }
.mega-link.is-soon { cursor: default; }
.mega-link.is-soon .mega-name { opacity: 0.55; }
.mega-link.is-soon .mega-desc { opacity: 0.5; }
.soon-pill {
  font-family: var(--font-mono); font-size: 9px; letter-spacing: 0.06em; text-transform: uppercase;
  color: var(--muted-foreground); background: var(--muted);
  border-radius: 999px; padding: 2px 6px; line-height: 1;
}

@media (max-width: 760px) {
  .mega { display: none; }
}
