/* ============================================================
   Vandelay Companies — Top navigation
   Active only inside .vc-design-context.
   ============================================================ */

.vc-design-context {
  --_vc-topbar-height: 64px;
}

/* ── Top bar shell ───────────────────────────────────────────── */
.vc-design-context .vc-topbar {
  display: flex;
  align-items: center;
  gap: var(--vc-space-5);
  height: var(--_vc-topbar-height);
  padding: 0 var(--vc-space-6);
  background: var(--vc-paper);
  border-bottom: 1px solid var(--vc-rule);
  font-family: var(--vc-sans);
  color: var(--vc-ink-2);
  position: relative;
  z-index: 1030;
}

@media (max-width: 767.98px) {
  .vc-design-context .vc-topbar {
    padding: 0 var(--vc-space-4);
    gap: var(--vc-space-3);
  }
}

/* ── Brand lockup ────────────────────────────────────────────── */
.vc-design-context .vc-brand {
  display: flex;
  align-items: center;
  gap: var(--vc-space-3);
  text-decoration: none;
  color: var(--vc-ink);
  flex-shrink: 0;
}

.vc-design-context .vc-brand:hover { color: var(--vc-navy); }

.vc-design-context .vc-brand__mark {
  height: 36px;
  width: auto;
  display: block;
}

.vc-design-context .vc-brand__rule {
  width: 1px;
  height: 28px;
  background: var(--vc-rule-strong);
}

.vc-design-context .vc-brand__wordmark {
  font-family: var(--vc-serif);
  font-size: 18px;
  font-weight: 500;
  letter-spacing: -0.01em;
  line-height: 1;
  white-space: nowrap;
}

.vc-design-context .vc-brand__sublabel {
  display: block;
  font-family: var(--vc-mono);
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--vc-ink-3);
  margin-top: 3px;
}

/* Progressive disclosure of brand lockup */
@media (max-width: 1319.98px) {
  .vc-design-context .vc-brand__sublabel { display: none; }
}
@media (max-width: 1023.98px) {
  .vc-design-context .vc-brand__rule,
  .vc-design-context .vc-brand__wordmark { display: none; }
}

/* ── Primary nav links ──────────────────────────────────────── */
.vc-design-context .vc-topbar__nav {
  display: flex;
  align-items: center;
  gap: var(--vc-space-1);
  flex: 1;
  margin: 0;
  padding: 0;
  list-style: none;
}

.vc-design-context .vc-nav-item { position: relative; }

.vc-design-context .vc-nav-link {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 8px 12px;
  font-family: var(--vc-sans);
  font-size: 13.5px;
  font-weight: 500;
  color: var(--vc-ink-2);
  background: transparent;
  border: 0;
  border-radius: var(--vc-r-md);
  text-decoration: none;
  cursor: pointer;
  transition: background-color 0.12s ease, color 0.12s ease;
}

.vc-design-context .vc-nav-link:hover,
.vc-design-context .vc-nav-link:focus-visible,
.vc-design-context .vc-nav-link[aria-expanded="true"] {
  background: var(--vc-paper-2);
  color: var(--vc-navy);
  outline: none;
}

.vc-design-context .vc-nav-link i { font-size: 15px; }

.vc-design-context .vc-nav-link.dropdown-toggle::after {
  margin-left: 4px;
  border-top-color: currentColor;
  opacity: 0.6;
}

/* Hide primary nav under 992px (mobile menu takes over) */
@media (max-width: 991.98px) {
  .vc-design-context .vc-topbar__nav { display: none; }
  .vc-design-context .vc-topbar__nav.is-open {
    display: flex;
    flex-direction: column;
    align-items: stretch;
    position: absolute;
    top: var(--_vc-topbar-height);
    left: 0;
    right: 0;
    background: var(--vc-surface);
    border-bottom: 1px solid var(--vc-rule);
    padding: var(--vc-space-3);
    gap: 2px;
    z-index: 1020;
    box-shadow: var(--vc-shadow-md);
  }
  .vc-design-context .vc-topbar__nav.is-open .vc-nav-link {
    width: 100%;
    justify-content: flex-start;
  }
}

/* ── Dropdowns (Bootstrap data-bs-toggle drives behavior) ───── */
.vc-design-context .dropdown-menu {
  background: var(--vc-surface);
  border: 1px solid var(--vc-rule);
  border-radius: var(--vc-r-lg);
  box-shadow: var(--vc-shadow-lg);
  padding: var(--vc-space-2) 0;
  font-family: var(--vc-sans);
  font-size: 13.5px;
  min-width: 220px;
}

.vc-design-context .dropdown-menu .dropdown-header {
  font-family: var(--vc-mono);
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--vc-ink-3);
  font-weight: 500;
  padding: 8px 16px 6px;
  margin-bottom: 0;
}

.vc-design-context .dropdown-menu .dropdown-item {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 8px 16px;
  color: var(--vc-ink-2);
  font-weight: 400;
  border-left: 2px solid transparent;
  transition: background-color 0.1s ease, color 0.1s ease;
}

.vc-design-context .dropdown-menu .dropdown-item:hover,
.vc-design-context .dropdown-menu .dropdown-item:focus {
  background: var(--vc-navy-tint);
  color: var(--vc-navy);
  border-left-color: var(--vc-navy);
}

.vc-design-context .dropdown-menu .dropdown-item i {
  color: var(--vc-ink-3);
  font-size: 15px;
  width: 18px;
  text-align: center;
}
.vc-design-context .dropdown-menu .dropdown-item:hover i,
.vc-design-context .dropdown-menu .dropdown-item:focus i {
  color: var(--vc-navy);
}

.vc-design-context .dropdown-menu .dropdown-divider {
  border-color: var(--vc-rule);
  margin: 6px 0;
}

.vc-design-context .dropdown-menu .dropdown-item-text {
  padding: 6px 16px;
  color: var(--vc-ink-3);
}

/* ── Search ──────────────────────────────────────────────────── */
.vc-design-context .vc-topbar__search {
  flex: 0 0 auto;
  width: 280px;
  max-width: 320px;
}

.vc-design-context .vc-search-input {
  display: flex;
  align-items: center;
  gap: 8px;
  height: 36px;
  padding: 0 12px;
  background: var(--vc-surface);
  border: 1px solid var(--vc-rule);
  border-radius: var(--vc-r-md);
  transition: border-color 0.12s ease, box-shadow 0.12s ease;
}

.vc-design-context .vc-search-input:focus-within {
  border-color: var(--vc-navy);
  box-shadow: 0 0 0 3px var(--vc-navy-tint);
}

.vc-design-context .vc-search-input i {
  color: var(--vc-ink-3);
  font-size: 14px;
}

.vc-design-context .vc-search-input input {
  flex: 1;
  border: 0;
  background: transparent;
  font-family: var(--vc-sans);
  font-size: 13px;
  color: var(--vc-ink);
  outline: none;
}

.vc-design-context .vc-search-input input::placeholder {
  color: var(--vc-ink-4);
}

.vc-design-context .vc-search-input kbd {
  font-family: var(--vc-mono);
  font-size: 10px;
  color: var(--vc-ink-3);
  background: var(--vc-paper-2);
  border: 1px solid var(--vc-rule);
  border-radius: 3px;
  padding: 1px 5px;
}

@media (max-width: 1199.98px) {
  .vc-design-context .vc-topbar__search { width: 220px; }
}
@media (max-width: 899.98px) {
  .vc-design-context .vc-topbar__search { display: none; }
  .vc-design-context .vc-search-icon-btn { display: inline-flex; }
}
@media (min-width: 900px) {
  .vc-design-context .vc-search-icon-btn { display: none; }
}

/* ── Right-side chrome ──────────────────────────────────────── */
.vc-design-context .vc-topbar__actions {
  display: flex;
  align-items: center;
  gap: var(--vc-space-2);
  flex-shrink: 0;
}

.vc-design-context .vc-icon-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  background: transparent;
  border: 0;
  border-radius: var(--vc-r-md);
  color: var(--vc-ink-2);
  cursor: pointer;
  position: relative;
  text-decoration: none;
  transition: background-color 0.12s ease, color 0.12s ease;
}

.vc-design-context .vc-icon-btn:hover,
.vc-design-context .vc-icon-btn:focus-visible,
.vc-design-context .vc-icon-btn[aria-expanded="true"] {
  background: var(--vc-paper-2);
  color: var(--vc-navy);
  outline: none;
}

.vc-design-context .vc-icon-btn i { font-size: 17px; }

/* Notification bubble */
.vc-design-context .vc-notif-badge {
  position: absolute;
  top: 4px;
  right: 4px;
  min-width: 18px;
  height: 18px;
  padding: 0 5px;
  background: var(--vc-navy);
  color: var(--vc-paper);
  font-family: var(--vc-mono);
  font-size: 10px;
  font-weight: 500;
  font-variant-numeric: tabular-nums;
  border-radius: 9px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  line-height: 1;
}
.vc-design-context .vc-notif-badge.d-none { display: none; }

/* User chip */
.vc-design-context .vc-user-chip {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 4px 10px 4px 4px;
  background: transparent;
  border: 1px solid var(--vc-rule);
  border-radius: 999px;
  color: var(--vc-ink-2);
  font-family: var(--vc-sans);
  font-size: 13px;
  font-weight: 500;
  text-decoration: none;
  cursor: pointer;
  transition: border-color 0.12s ease, background-color 0.12s ease;
}

.vc-design-context .vc-user-chip:hover,
.vc-design-context .vc-user-chip:focus-visible,
.vc-design-context .vc-user-chip[aria-expanded="true"] {
  border-color: var(--vc-rule-strong);
  background: var(--vc-paper-2);
  outline: none;
}

.vc-design-context .vc-user-chip__avatar {
  width: 28px;
  height: 28px;
  border-radius: 50%;
  background: var(--vc-navy);
  color: var(--vc-paper);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-family: var(--vc-mono);
  font-size: 11px;
  letter-spacing: 0.04em;
  font-weight: 500;
}

.vc-design-context .vc-user-chip__name {
  white-space: nowrap;
  max-width: 160px;
  overflow: hidden;
  text-overflow: ellipsis;
}

@media (max-width: 899.98px) {
  .vc-design-context .vc-user-chip__name { display: none; }
  .vc-design-context .vc-user-chip { padding: 4px; border-radius: 50%; }
}

/* ── Mobile hamburger ───────────────────────────────────────── */
.vc-design-context .vc-mobile-toggle { display: none; }
@media (max-width: 991.98px) {
  .vc-design-context .vc-mobile-toggle { display: inline-flex; }
}

/* ── Impersonation banner ───────────────────────────────────── */
.vc-design-context .vc-impersonation-banner {
  background: var(--vc-warning);
  color: var(--vc-paper);
  padding: var(--vc-space-2) var(--vc-space-6);
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-family: var(--vc-sans);
  font-size: 13px;
  position: relative;
  z-index: 1050;
}
.vc-design-context .vc-impersonation-banner strong { font-weight: 600; }
.vc-design-context .vc-impersonation-banner a {
  color: var(--vc-paper);
  text-decoration: underline;
  text-underline-offset: 3px;
}
