/**
 * Dpublish site header + mobile menu — Bootstrap offcanvas (panel lives outside .navbar
 * so the sticky Headhesive clone does not duplicate it).
 */
.dp-site-header {
  background: rgba(255, 255, 255, 0.92);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  border-bottom: 1px solid rgba(226, 232, 240, 0.6);
  position: relative;
  z-index: 1030;
}

.dp-nav-demo-btn {
  padding: 10px 24px;
  font-size: 0.9rem;
}

/* Desktop dropdown */
.dp-nav-dropdown-menu {
  border: none;
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.1);
  border-radius: 12px;
  padding: 12px;
  min-width: 260px;
}

.dp-nav-dropdown-menu .dropdown-item {
  border-radius: 8px;
  padding: 10px 14px;
  font-size: 0.88rem;
}

.dp-nav-dropdown-menu .dropdown-divider {
  margin: 6px 0;
}

.dp-nav-dd-viewall {
  color: var(--dp-primary, #4f46e5) !important;
  font-weight: 600;
}

/* Mobile offcanvas — light panel (theme defaults offcanvas to dark) */
.dp-mobile-nav {
  --bs-offcanvas-width: min(100vw - 1.5rem, 20rem);
  --bs-offcanvas-bg: #ffffff;
  --bs-offcanvas-color: #1e293b;
  z-index: 1050;
}

/*
 * Theme (style.css) sets .offcanvas:not(.offcanvas-nav) { overflow-y: auto } while the
 * panel is a column flex container. That combination collapses .offcanvas-body to ~0
 * height, so only the header row appears. Lock full viewport height and move scrolling
 * to the body only (flex-basis 0 + min-height 0 is the standard fix).
 */
.dp-mobile-nav.offcanvas {
  top: 0 !important;
  bottom: 0 !important;
  left: 0 !important;
  height: 100vh !important;
  height: 100dvh !important;
  max-height: none !important;
  overflow: hidden !important;
}

.dp-mobile-nav .offcanvas-body {
  flex: 1 1 0 !important;
  min-height: 0 !important;
  overflow-y: auto !important;
  overflow-x: hidden !important;
  -webkit-overflow-scrolling: touch;
  padding-top: 1rem !important;
  padding-bottom: 1.5rem !important;
}

/* ul.navbar-nav here is NOT inside .navbar — set nav vars so .nav-link colors resolve */
.dp-mobile-nav .navbar-nav {
  --bs-navbar-color: #334155;
  --bs-navbar-hover-color: #4f46e5;
  --bs-nav-link-color: #334155;
  --bs-nav-link-hover-color: #4f46e5;
  display: flex !important;
  flex-direction: column !important;
  width: 100% !important;
  gap: 0.125rem;
}

.dp-mobile-nav .navbar-nav > .nav-item {
  display: block !important;
  width: 100% !important;
}

.dp-mobile-nav .nav-link {
  color: #334155 !important;
  font-weight: 500;
  padding: 0.45rem 0;
}

.dp-mobile-nav .nav-link:hover,
.dp-mobile-nav .nav-link:focus {
  color: #4f46e5 !important;
}

.dp-mobile-nav .dropdown-menu {
  position: static !important;
  transform: none !important;
  border: none;
  box-shadow: none;
  background: #f1f5f9;
  margin: 0 0 0.5rem 0 !important;
  padding: 0.35rem 0;
  width: 100%;
}

.dp-mobile-nav .dropdown-item {
  color: #334155 !important;
  border-radius: 6px;
  padding: 0.45rem 0.75rem;
  font-size: 0.88rem;
}

.dp-mobile-nav .dropdown-item:hover,
.dp-mobile-nav .dropdown-item:focus {
  color: #1e293b !important;
}

.dp-mobile-nav .btn-close {
  opacity: 0.55;
}

/* Hamburger stays theme-styled; used as Bootstrap offcanvas trigger */
.dp-site-header .hamburger {
  color: #343f52;
}

/* Match main site CTA inside drawer (clr.css maps .btn-primary to theme red) */
.dp-mobile-nav .btn-primary {
  background: linear-gradient(135deg, #4f46e5 0%, #06b6d4 100%);
  border: none;
  font-weight: 600;
}

.dp-mobile-nav .btn-primary:hover,
.dp-mobile-nav .btn-primary:focus {
  background: linear-gradient(135deg, #4338ca 0%, #0891b2 100%);
  color: #fff;
}
