/**
 * Shared Diamond Vogel top (navy) navigation + search (dvcorp module).
 * Z-index below Drupal toolbar (~502).
 */
/* Clear Bootstrap body offset when the fixed navy strip is present. */
body.dv-has-top-navigation {
  margin-top: 0 !important;
}

:root {
  /* Corporate nav typography (Montserrat across division themes + Vogelpaint). */
  --dv-font-family: 'Montserrat', sans-serif;
  --dv-brand-logo-height: 56px;
  --dv-top-nav-height: 70px;
  --dv-top-nav-link-size: 14px;
  /* White bar primary menu (#003763 text); navy strip + search keep --dv-top-nav-link-size */
  --dv-primary-nav-link-size: 18px;
  --dv-top-nav-divider-width: 1px;
  --dv-top-nav-divider-height: 16px;
  --dv-top-nav-divider-gap: 12px;
  /* Brand gold (Vogelpaint / corporate); search icon uses currentColor */
  --dv-top-nav-accent-gold: #de7c00;
  /* Mobile unified hamburger (≤991px): white header, charcoal panel */
  --dv-mobile-menu-header-bg: #fff;
  --dv-mobile-menu-panel-bg: #222;
  --dv-mobile-menu-top-link: #fff;
  --dv-mobile-menu-secondary-link: #de7c00;
  --dv-top-nav-search-max: 292px;
  --dv-top-nav-search-height: 40px;
  /*
   * Fallback before/without JS: core toolbar anti-flicker rem values.
   * dv-top-navigation.js sets body { --dv-toolbar-offset: Npx } from measured
   * #toolbar-bar + #toolbar-item-administration-tray (when tray has height).
   */
  --dv-toolbar-offset: 0px;
}

body.toolbar-fixed.toolbar-horizontal {
  --dv-toolbar-offset: 2.4375rem;
}

body.toolbar-fixed.toolbar-horizontal.toolbar-tray-open {
  --dv-toolbar-offset: 4.91331rem;
}

/*
 * Fixed navy strip — full width; sits below admin toolbar when present.
 * Drupal block ids are normalized with hyphens, e.g. block-vogelpaint-diamond-vogel-top-navigation
 * (so [id*='diamondvogeltopnavigation'] alone does not match). :has() covers any theme block wrapper.
 */
#block-diamondvogeltopnavigation,
.block-system-menu-blockdiamond-vogel-top-navigation,
[id*='diamond-vogel-top-navigation'],
[id*='diamondvogeltopnavigation'],
.block:has(.menu--diamond-vogel-top-navigation),
/* JS adds this class to the menu block wrapper (fallback if id / :has() differs by theme) */
section.dv-top-nav-block,
div.dv-top-nav-block {
  background: #003763;
  position: fixed;
  top: var(--dv-toolbar-offset);
  left: 0;
  right: 0;
  width: 100%;
  /* Above white primary bar (460) so the navy strip always reads first when layers meet. */
  z-index: 485;
  min-height: var(--dv-top-nav-height);
  border-bottom: 1px solid rgba(255, 255, 255, 0.35);
  opacity: 1 !important;
  visibility: visible !important;
  box-sizing: border-box;
}

.block:has(.menu--diamond-vogel-top-navigation) h2,
.block [id*='diamond-vogel-top-navigation'] h2,
.block [id*='diamondvogeltopnavigation'] h2,
#block-vogelpaint-diamondvogeltopnavigation h2,
#block-vogelpaint-diamond-vogel-top-navigation h2,
#block-diamondvogeltopnavigation h2 {
  display: none !important;
}

.dv-top-nav-block {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  min-height: var(--dv-top-nav-height);
  padding: 2px 15px;
  box-sizing: border-box;
  font-family: var(--dv-font-family);
}

/* Flush first link with logo row below (strip padding already matches .container gutter). */
.menu--diamond-vogel-top-navigation.menu.nav > li:first-child > a {
  padding-left: 0;
}

/* Match Bootstrap 3 .container gutters (15px) + max-widths at each breakpoint */
@media screen and (min-width: 992px) and (max-width: 1199px) {
  .dv-top-nav-block {
    padding-left: calc((100vw - 970px) / 2 + 15px);
    padding-right: calc((100vw - 970px) / 2 + 15px);
  }
}

@media screen and (min-width: 1200px) {
  .dv-top-nav-block {
    padding-left: calc((100vw - 1170px) / 2 + 15px);
    padding-right: calc((100vw - 1170px) / 2 + 15px);
  }
}

.menu--diamond-vogel-top-navigation.menu.nav {
  position: static;
  margin: 0;
  padding: 0;
  display: flex;
  align-items: center;
  justify-content: flex-start;
  flex: 1;
  flex-wrap: wrap;
  list-style: none;
}

.menu--diamond-vogel-top-navigation.menu.nav > li {
  float: none;
  padding: 0;
  margin: 0;
  display: flex;
  align-items: center;
}

.menu--diamond-vogel-top-navigation.menu.nav > li + li::before {
  content: none !important;
  display: none !important;
  width: 0 !important;
  height: 0 !important;
  margin: 0 !important;
  border: 0 !important;
}

@media screen and (min-width: 768px) {
  .menu--diamond-vogel-top-navigation.menu.nav > li::before,
  .menu--diamond-vogel-top-navigation.menu.nav > li::after {
    content: none !important;
    display: none !important;
    width: 0 !important;
    height: 0 !important;
    margin: 0 !important;
    border: 0 !important;
  }

  .menu--diamond-vogel-top-navigation.menu.nav > li.dv-nav-has-next-on-same-row::after {
    content: "" !important;
    display: block !important;
    width: var(--dv-top-nav-divider-width) !important;
    height: var(--dv-top-nav-divider-height) !important;
    background: #fff !important;
    opacity: 0.85;
    margin-left: var(--dv-top-nav-divider-gap) !important;
    margin-right: var(--dv-top-nav-divider-gap) !important;
    flex-shrink: 0;
    border: 0 !important;
    position: static !important;
    float: none !important;
    transform: none !important;
  }
}

.menu--diamond-vogel-top-navigation.menu.nav > li > a {
  color: #fff !important;
  text-transform: uppercase;
  font-family: var(--dv-font-family) !important;
  font-size: var(--dv-top-nav-link-size) !important;
  font-weight: 400 !important;
  letter-spacing: 0.03em;
  line-height: 1.25;
  display: inline-block;
  padding: 0.25em 0.15em;
  opacity: 1 !important;
  visibility: visible !important;
  text-decoration: none;
}

.menu--diamond-vogel-top-navigation.menu.nav > li > a:hover,
.menu--diamond-vogel-top-navigation.menu.nav > li > a:focus,
.menu--diamond-vogel-top-navigation.menu.nav > .active > a {
  color: #fff !important;
  text-decoration: underline;
  background: transparent;
  font-family: var(--dv-font-family) !important;
  font-weight: 400 !important;
  font-size: var(--dv-top-nav-link-size) !important;
}

/*
 * Corporate fullPage: keep duplicate anchor menu in DOM but off-screen.
 * Do not clip the same menu machine name when it is the real primary nav in
 * #navbar (e.g. Vogel Custom header).
 */
body.dv-has-top-navigation .menu--homepage-anchors {
  position: absolute !important;
  width: 1px !important;
  height: 1px !important;
  padding: 0 !important;
  margin: -1px !important;
  overflow: hidden !important;
  clip: rect(0, 0, 0, 0) !important;
  white-space: nowrap !important;
  border: 0 !important;
}

/*
 * Vogel Custom only: homepage-anchors menu is the real primary nav in-header.
 * Vogel Paint keeps anchors off-screen in #navbar (fullPage + navy strip already
 * cover those links); a global reset here duplicated a second visible menu.
 */
body.dv-has-top-navigation.dv-header-primary-homepage-anchors #navbar .menu--homepage-anchors,
body.dv-has-top-navigation.dv-header-primary-homepage-anchors #navbar-collapse .menu--homepage-anchors {
  position: static !important;
  width: auto !important;
  height: auto !important;
  padding: 0 !important;
  margin: 0 !important;
  overflow: visible !important;
  clip: auto !important;
  white-space: normal !important;
  border: 0 !important;
}

.dv-top-nav-search {
  display: flex;
  align-items: center;
  width: 100%;
  max-width: var(--dv-top-nav-search-max);
  margin: 0;
  flex-shrink: 0;
}

.dv-top-nav-search input[type="search"] {
  flex: 1;
  min-width: 0;
  height: var(--dv-top-nav-search-height);
  border: 1px solid #d7d7d7;
  border-right: 0;
  border-radius: calc(var(--dv-top-nav-search-height) / 2) 0 0 calc(var(--dv-top-nav-search-height) / 2);
  padding: 0 0.75rem;
  color: #2e3a47;
  font-family: var(--dv-font-family);
  font-size: var(--dv-top-nav-link-size);
  font-weight: 400;
  box-sizing: border-box;
}

.dv-top-nav-search input[type="search"]::placeholder {
  color: #7b7b7b;
  font-family: var(--dv-font-family);
  font-weight: 400;
  font-size: var(--dv-top-nav-link-size);
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.dv-top-nav-search button {
  width: var(--dv-top-nav-search-height);
  min-width: var(--dv-top-nav-search-height);
  height: var(--dv-top-nav-search-height);
  flex-shrink: 0;
  border: 1px solid #d7d7d7;
  border-left: 0;
  background: #fff;
  /* SVG uses fill="currentColor" */
  color: var(--dv-top-nav-accent-gold);
  padding: 0;
  border-radius: 0 calc(var(--dv-top-nav-search-height) / 2) calc(var(--dv-top-nav-search-height) / 2) 0;
  box-sizing: border-box;
}

.dv-top-nav-search button:hover,
.dv-top-nav-search button:focus {
  background: #f8f8f8;
  color: #f0a020;
}

.dv-top-nav-search button svg {
  width: 18px;
  height: 18px;
  display: block;
  margin: 0 auto;
}

.dv-top-nav-search label.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

/*
 * Front page: header sits in normal flow below the fixed navy strip so page content / hero
 * begins after the white logo + main-navigation row (not underneath an absolute navbar).
 * Logged-in: omit toolbar in this margin — --dv-toolbar-offset stacks with the real toolbar
 * and double-pushes the header; themes / .header-wrapper padding handle clearance instead.
 */
@media screen and (max-width: 991px) {
  /*
   * Until unified mobile runs, hide only the navy strip *above* the header.
   * Vogel Paint (and similar) place the top menu inside #navbar-collapse already —
   * do not hide in-collapse copies or the hamburger panel looks empty.
   */
  body.dv-has-top-navigation:not(.dv-mobile-menu-unified)
    .dv-top-nav-block:not(.dv-top-nav-block--mobile-drawer):not(:where(#navbar-collapse *)) {
    display: none !important;
  }

  body.dv-mobile-menu-unified .dv-top-nav-block:not(.dv-top-nav-block--in-mobile-collapse) {
    display: none !important;
  }

  :root {
    --dv-top-nav-height: auto;
    --dv-top-nav-search-height: 42px;
  }

  #block-diamondvogeltopnavigation,
  .block-system-menu-blockdiamond-vogel-top-navigation,
  [id*='diamond-vogel-top-navigation'],
  [id*='diamondvogeltopnavigation'],
  .block:has(.menu--diamond-vogel-top-navigation),
  section.dv-top-nav-block,
  div.dv-top-nav-block {
    position: static;
    width: auto;
    min-height: 0;
  }

  .dv-top-nav-block {
    flex-direction: column;
    align-items: stretch;
    min-height: 0;
    padding-left: 15px;
    padding-right: 15px;
  }

  .menu--diamond-vogel-top-navigation.menu.nav {
    display: block;
    width: 100%;
  }

  .menu--diamond-vogel-top-navigation.menu.nav > li {
    display: block;
  }

  .menu--diamond-vogel-top-navigation.menu.nav > li + li::before {
    display: none;
  }

  .menu--diamond-vogel-top-navigation.menu.nav > li > a {
    padding: 10px 0;
    font-family: var(--dv-font-family) !important;
    font-weight: 400 !important;
    font-size: var(--dv-top-nav-link-size) !important;
  }

  .menu--diamond-vogel-top-navigation.menu.nav > li:first-child > a {
    padding-left: 0;
  }

  .dv-top-nav-search {
    max-width: 100%;
    padding: 8px 0 12px;
  }

  body.dv-has-top-navigation.path-frontpage #navbar {
    top: auto;
  }

  /*
   * Navy strip is in-flow here — drop fixed-strip clearance on #navbar for every route.
   * (Avoid overlap / double-gap vs desktop fixed strip + padding-top: 90px.)
   */
  body.dv-has-top-navigation header#navbar {
    padding-top: 0 !important;
  }

  body.dv-has-top-navigation .navbar-header {
    height: auto !important;
    min-height: 0;
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: nowrap;
    gap: 0.75rem;
    box-sizing: border-box;
  }

  /*
   * Division themes often center the navigation region on small screens; corporate row is logo-left.
   */
  body.dv-has-top-navigation header#navbar .navbar-header,
  body.dv-has-top-navigation header#navbar .navbar-header .region-navigation {
    text-align: left !important;
  }

  body.dv-has-top-navigation header#navbar .navbar-header a.logo,
  body.dv-has-top-navigation header#navbar .navbar-header .logo {
    margin-left: 0 !important;
    margin-right: 0 !important;
  }

  body.dv-has-top-navigation header#navbar .navbar-header [class*='-branding-group'] {
    justify-content: flex-start !important;
    align-items: center;
    flex: 0 0 auto !important;
    min-width: min-content !important;
  }

  /*
   * Theme legacy offsets (e.g. fixed-header clearance) break stacked corporate chrome.
   */
  body.dv-has-top-navigation ol.breadcrumb:not(.dv-breadcrumb--relocated):not(.dv-breadcrumb--in-navy-drawer) {
    margin-top: 0 !important;
    margin-bottom: 0 !important;
  }

  /*
   * Mobile: corporate navy + full breadcrumb live inside a <details> drawer (closed by default).
   */
  body.dv-mobile-navy-in-drawer header#navbar .navbar-header {
    position: relative;
    align-items: center;
  }

  body.dv-has-top-navigation header#navbar .navbar-header details.dv-mobile-breadcrumb-navy {
    flex: 1 1 auto;
    order: 2;
    min-width: 0;
    margin: 0;
  }

  body.dv-has-top-navigation
    header#navbar
    .navbar-header
    details.dv-mobile-breadcrumb-navy
    > summary.dv-mobile-breadcrumb-navy__summary {
    list-style: none;
    cursor: pointer;
    font-family: var(--dv-font-family);
    font-size: 11px;
    font-weight: 600;
    line-height: 1.3;
    color: #003763;
    padding: 4px 22px 4px 4px;
    margin: 0;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    position: relative;
    border: 1px solid rgba(0, 55, 99, 0.2);
    border-radius: 4px;
    background: rgba(0, 55, 99, 0.04);
  }

  body.dv-has-top-navigation
    header#navbar
    .navbar-header
    details.dv-mobile-breadcrumb-navy
    > summary.dv-mobile-breadcrumb-navy__summary::-webkit-details-marker {
    display: none;
  }

  body.dv-has-top-navigation
    header#navbar
    .navbar-header
    details.dv-mobile-breadcrumb-navy
    > summary.dv-mobile-breadcrumb-navy__summary::after {
    content: "";
    position: absolute;
    right: 6px;
    top: 50%;
    width: 0;
    height: 0;
    margin-top: -2px;
    border-left: 4px solid transparent;
    border-right: 4px solid transparent;
    border-top: 5px solid #003763;
    opacity: 0.75;
  }

  body.dv-has-top-navigation
    header#navbar
    .navbar-header
    details.dv-mobile-breadcrumb-navy[open]
    > summary.dv-mobile-breadcrumb-navy__summary::after {
    transform: rotate(180deg);
    transform-origin: 50% 30%;
    margin-top: -3px;
  }

  body.dv-has-top-navigation
    header#navbar
    .navbar-header
    details.dv-mobile-breadcrumb-navy
    .dv-mobile-breadcrumb-navy__panel {
    position: absolute;
    left: 0;
    right: 0;
    top: calc(100% + 6px);
    z-index: 470;
    max-height: min(70vh, 28rem);
    overflow-x: hidden;
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
    background: #fff;
    border: 1px solid rgba(0, 55, 99, 0.15);
    border-radius: 4px;
    box-shadow: 0 10px 28px rgba(0, 0, 0, 0.12);
  }

  body.dv-has-top-navigation
    header#navbar
    .navbar-header
    details.dv-mobile-breadcrumb-navy
    .dv-mobile-breadcrumb-navy__crumbs {
    padding: 10px 12px;
    border-bottom: 1px solid rgba(0, 55, 99, 0.1);
    background: #fff;
  }

  body.dv-has-top-navigation
    header#navbar
    .navbar-header
    details.dv-mobile-breadcrumb-navy
    .dv-mobile-breadcrumb-navy__crumbs--empty {
    display: none;
    padding: 0;
    border: 0;
  }

  body.dv-has-top-navigation
    header#navbar
    .navbar-header
    details.dv-mobile-breadcrumb-navy
    ol.breadcrumb {
    margin: 0 !important;
    padding: 0 !important;
    font-size: 12px;
    line-height: 1.45;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.15rem 0.35rem;
    list-style: none;
    background: transparent;
    border: 0;
    box-shadow: none;
  }

  body.dv-has-top-navigation
    header#navbar
    .navbar-header
    details.dv-mobile-breadcrumb-navy
    ol.breadcrumb
    > li {
    display: inline-flex;
    align-items: center;
    white-space: normal;
  }

  body.dv-has-top-navigation header#navbar .navbar-header .navbar-toggle {
    order: 3;
    flex-shrink: 0;
  }

  body.dv-has-top-navigation
    header#navbar
    .navbar-header
    > :not(.navbar-toggle):not(details.dv-mobile-breadcrumb-navy) {
    order: 1;
  }

  /* Navy block inside drawer: full blue bar styling (already on .dv-top-nav-block). */
  body.dv-has-top-navigation
    header#navbar
    .dv-top-nav-block--mobile-drawer {
    border-radius: 0 0 3px 3px;
  }

  /*
   * White primary bar (≤991px): vertical top-level links; nested .dropdown-menu panels
   * stack in-flow (see nested static rules below) so every depth is tappable. Requires
   * dropdown-toggle on all expanded tiers (vogelpaint menu--diamond-vogel-navigation).
   */
  body.dv-has-top-navigation header#navbar #navbar-collapse .navbar-nav,
  body.dv-has-top-navigation header#navbar #navbar-collapse .menu.nav {
    flex-direction: column !important;
    align-items: stretch !important;
    flex-wrap: nowrap !important;
    width: 100% !important;
  }

  body.dv-has-top-navigation header#navbar #navbar-collapse .navbar-nav > li,
  body.dv-has-top-navigation
    header#navbar
    #navbar-collapse
    .menu.menu--diamond-vogel-navigation.nav
    > li {
    float: none !important;
    width: 100% !important;
    display: block !important;
  }

  body.dv-has-top-navigation header#navbar #block-diamondvogelnavigation .diamond-vogel-menu {
    height: auto !important;
    min-height: 0 !important;
  }

  body.dv-has-top-navigation header#navbar #block-diamondvogelnavigation .diamond-vogel-menu .container {
    width: 100% !important;
    max-width: none !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
  }

  /*
   * Unified mobile hamburger (mockup): white header (logo + toggle), charcoal panel —
   * white corporate links, orange division links, search last.
   */
  body.dv-mobile-menu-unified details.dv-mobile-breadcrumb-navy {
    display: none !important;
  }

  body.dv-mobile-menu-unified
    #navbar-collapse
    .region-navigation-collapsible
    .menu--diamond-vogel-top-navigation,
  body.dv-mobile-menu-unified
    #navbar-collapse
    .region-navigation-collapsible
    [id*='diamond-vogel-top-navigation'],
  body.dv-mobile-menu-unified
    #navbar-collapse
    .region-navigation-collapsible
    nav[id*='diamondvogeltopnavigation'] {
    display: none !important;
  }

  body.dv-mobile-menu-unified
    #navbar-collapse
    .dv-mobile-menu__corporate
    .menu--diamond-vogel-top-navigation,
  body.dv-mobile-menu-unified
    #navbar-collapse
    .dv-mobile-menu__corporate
    [id*='diamond-vogel-top-navigation'],
  body.dv-mobile-menu-unified
    #navbar-collapse
    .dv-mobile-menu__corporate
    nav[id*='diamondvogeltopnavigation'] {
    display: block !important;
  }

  body.dv-mobile-menu-unified header#navbar {
    background-color: var(--dv-mobile-menu-header-bg) !important;
    padding-top: 0 !important;
    border-bottom: 0 !important;
    display: flex !important;
    flex-direction: column !important;
    flex-wrap: nowrap !important;
    align-items: stretch !important;
  }

  body.dv-mobile-menu-unified header#navbar :is(.navbar-default, .navbar-inverse) {
    background-color: var(--dv-mobile-menu-header-bg) !important;
  }

  body.dv-mobile-menu-unified header#navbar > .container,
  body.dv-mobile-menu-unified header#navbar.container {
    display: flex !important;
    flex-direction: column !important;
    flex-wrap: nowrap !important;
    width: 100% !important;
    max-width: 100% !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
    margin: 0 !important;
    background: transparent !important;
  }

  body.dv-mobile-menu-unified header#navbar .navbar-header {
    background-color: var(--dv-mobile-menu-header-bg) !important;
    border-bottom: 0 !important;
    padding: 12px 15px !important;
    margin: 0 !important;
    width: 100% !important;
    max-width: none !important;
    min-height: 0 !important;
    height: auto !important;
    display: flex !important;
    flex-wrap: nowrap !important;
    align-items: center !important;
    justify-content: space-between !important;
    box-sizing: border-box;
  }

  body.dv-mobile-menu-unified header#navbar .navbar-header .region-navigation {
    flex: 1 1 auto;
    min-width: 0;
    padding: 0;
    margin: 0;
  }

  body.dv-mobile-menu-unified header#navbar .navbar-toggle {
    order: 2;
    flex-shrink: 0;
    float: none !important;
    margin: 0 0 0 12px !important;
    padding: 10px 11px !important;
    background: #e8e8e8 !important;
    border: 1px solid #c8c8c8 !important;
    border-radius: 6px !important;
    display: block !important;
    visibility: visible !important;
    pointer-events: auto !important;
    position: relative;
    z-index: 5;
  }

  body.dv-mobile-menu-unified header#navbar .navbar-toggle .icon-bar {
    background-color: #4a4a4a !important;
  }

  body.dv-mobile-menu-unified #navbar-collapse.collapse:not(.in):not(.collapsing) {
    display: none !important;
    visibility: hidden !important;
    height: 0 !important;
    overflow: hidden !important;
    padding: 0 !important;
    margin: 0 !important;
  }

  body.dv-has-top-navigation.dv-mobile-menu-unified
    header#navbar
    #navbar-collapse.collapse.in,
  body.dv-has-top-navigation.dv-mobile-menu-unified
    header#navbar
    #navbar-collapse.collapsing,
  body.dv-has-top-navigation.dv-mobile-menu-unified
    header#navbar
    .navbar-collapse.collapse.in,
  body.dv-has-top-navigation.dv-mobile-menu-unified
    header#navbar
    .navbar-collapse.collapsing {
    display: flex !important;
    flex-direction: column !important;
    align-items: stretch !important;
    background-color: var(--dv-mobile-menu-panel-bg) !important;
    border: 0 !important;
    box-shadow: none !important;
    margin: 0 !important;
    padding: 18px 15px 22px !important;
    padding-bottom: calc(22px + env(safe-area-inset-bottom, 0px)) !important;
    width: 100% !important;
    max-width: 100% !important;
    flex: 1 1 auto !important;
    min-height: 0 !important;
    height: auto !important;
    max-height: var(
      --dv-mobile-menu-max-height,
      calc(
        100vh - var(--dv-mobile-menu-header-height, 72px) - var(--dv-toolbar-offset, 0px)
      )
    );
    overflow-x: hidden !important;
    overflow-y: auto !important;
    -webkit-overflow-scrolling: touch;
    scroll-padding-bottom: env(safe-area-inset-bottom, 0px);
    visibility: visible !important;
  }

  body.dv-mobile-menu-unified #navbar-collapse :is(section, div).dv-top-nav-block--in-mobile-collapse {
    background: transparent !important;
    min-height: 0;
    padding: 0;
  }

  body.dv-mobile-menu-unified.path-frontpage #navbar-collapse .dv-mobile-menu__crumbs,
  body.dv-mobile-menu-unified #navbar-collapse .dv-mobile-menu__crumbs--empty {
    display: none !important;
  }

  body.dv-mobile-menu-unified #navbar-collapse nav > h2,
  body.dv-mobile-menu-unified #navbar-collapse .visually-hidden {
    display: none !important;
    margin: 0 !important;
    padding: 0 !important;
    height: 0 !important;
    overflow: hidden !important;
  }

  body.dv-mobile-menu-unified #navbar-collapse .dv-top-nav-block--in-mobile-collapse {
    display: block !important;
    width: 100%;
    min-height: 0;
    padding: 0;
    margin: 0;
    background: transparent;
    border: 0;
    position: static;
  }

  body.dv-mobile-menu-unified #navbar-collapse .dv-top-nav-block--in-mobile-collapse .menu--diamond-vogel-top-navigation {
    display: block !important;
    width: 100%;
    margin: 0;
    padding: 0;
  }

  body.dv-mobile-menu-unified #navbar-collapse .menu--diamond-vogel-top-navigation.menu.nav > li {
    display: block !important;
    float: none !important;
    width: 100%;
  }

  body.dv-mobile-menu-unified #navbar-collapse .menu--diamond-vogel-top-navigation.menu.nav > li + li::before {
    display: none !important;
  }

  body.dv-mobile-menu-unified #navbar-collapse .menu--diamond-vogel-top-navigation.menu.nav > li > a,
  body.dv-mobile-menu-unified #navbar-collapse .menu--diamond-vogel-top-navigation.menu.nav > li > a:hover,
  body.dv-mobile-menu-unified #navbar-collapse .menu--diamond-vogel-top-navigation.menu.nav > li > a:focus {
    color: var(--dv-mobile-menu-top-link) !important;
    background: transparent !important;
    text-transform: uppercase !important;
    font-family: var(--dv-font-family) !important;
    font-size: var(--dv-top-nav-link-size) !important;
    font-weight: 400 !important;
    letter-spacing: 0.06em;
    line-height: 1.35;
    padding: 0.65rem 0 !important;
    display: block !important;
    border: 0;
    text-decoration: none;
  }

  body.dv-mobile-menu-unified #navbar-collapse .dv-mobile-menu__corporate {
    margin: 0;
    padding: 0;
    border: 0;
  }


  body.dv-mobile-menu-unified #navbar-collapse .dv-mobile-menu__divisions {
    display: block !important;
    width: 100%;
    margin: 1.15rem 0 0;
    padding: 0;
    border: 0;
  }

  body.dv-mobile-menu-unified.path-frontpage
    #navbar-collapse
    .dv-mobile-menu__divisions
    .region-navigation-collapsible,
  body.dv-mobile-menu-unified.path-frontpage
    #navbar-collapse
    .region-navigation-collapsible {
    height: auto !important;
    min-height: 0 !important;
  }

  body.dv-mobile-menu-unified #navbar-collapse #block-diamondvogelnavigation {
    display: block !important;
    visibility: visible !important;
    opacity: 1 !important;
    position: static !important;
    width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
  }

  body.dv-mobile-menu-unified #navbar-collapse .region-navigation-collapsible,
  body.dv-mobile-menu-unified #navbar-collapse .dv-mobile-menu__divisions .region-navigation-collapsible {
    display: block !important;
    width: 100%;
    margin: 0;
    padding: 0;
    border: 0;
  }

  body.dv-mobile-menu-unified #navbar-collapse #block-diamondvogelnavigation .diamond-vogel-menu,
  body.dv-mobile-menu-unified #navbar-collapse #block-diamondvogelnavigation .diamond-vogel-menu .container {
    width: 100% !important;
    max-width: none !important;
    padding: 0 !important;
    margin: 0 !important;
    background: transparent !important;
    height: auto !important;
    min-height: 0 !important;
    border: 0;
    box-shadow: none;
  }

  body.dv-mobile-menu-unified #navbar-collapse .menu--diamond-vogel-navigation.menu.nav,
  body.dv-mobile-menu-unified #navbar-collapse .menu.nav:not(.menu--diamond-vogel-top-navigation) {
    display: block !important;
    width: 100%;
    margin: 0;
    padding: 0;
  }

  body.dv-mobile-menu-unified #navbar-collapse #block-diamondvogelnavigation .menu.nav,
  body.dv-mobile-menu-unified #navbar-collapse .menu--diamond-vogel-navigation.menu.nav {
    position: static !important;
    top: auto !important;
    right: auto !important;
    left: auto !important;
    float: none !important;
  }

  body.dv-mobile-menu-unified #navbar-collapse #block-diamondvogelnavigation .menu.nav > li > a,
  body.dv-mobile-menu-unified
    #navbar-collapse
    #block-diamondvogelnavigation
    .menu.nav
    > li
    > a {
    color: var(--dv-mobile-menu-secondary-link) !important;
  }

  body.dv-mobile-menu-unified #navbar-collapse .menu--diamond-vogel-navigation.menu.nav > li,
  body.dv-mobile-menu-unified #navbar-collapse .menu.nav:not(.menu--diamond-vogel-top-navigation) > li {
    display: block !important;
    float: none !important;
    width: 100%;
  }

  body.dv-mobile-menu-unified #navbar-collapse .menu--diamond-vogel-navigation.menu.nav > li > a,
  body.dv-mobile-menu-unified #navbar-collapse .menu.nav:not(.menu--diamond-vogel-top-navigation) > li > a,
  body.dv-mobile-menu-unified #navbar-collapse .navbar-nav > li > a,
  body.dv-mobile-menu-unified #navbar-collapse .menu--diamond-vogel-navigation.menu.nav > li > a:visited {
    color: var(--dv-mobile-menu-secondary-link) !important;
    background: transparent !important;
    text-transform: uppercase !important;
    font-family: var(--dv-font-family) !important;
    font-size: var(--dv-primary-nav-link-size) !important;
    font-weight: 400 !important;
    letter-spacing: 0.04em;
    line-height: 1.35;
    padding: 0.65rem 0 !important;
    display: flex !important;
    align-items: center;
    justify-content: space-between;
    border: 0;
    text-decoration: none;
  }

  body.dv-mobile-menu-unified #navbar-collapse .menu--diamond-vogel-navigation.menu.nav > li > a:hover,
  body.dv-mobile-menu-unified #navbar-collapse .menu--diamond-vogel-navigation.menu.nav > li > a:focus,
  body.dv-mobile-menu-unified #navbar-collapse .menu.nav:not(.menu--diamond-vogel-top-navigation) > li > a:hover,
  body.dv-mobile-menu-unified #navbar-collapse .menu.nav:not(.menu--diamond-vogel-top-navigation) > li > a:focus,
  body.dv-mobile-menu-unified #navbar-collapse .menu--diamond-vogel-navigation.menu.nav > li.open > a {
    color: var(--dv-mobile-menu-secondary-link) !important;
    text-decoration: underline;
  }

  body.dv-mobile-menu-unified #navbar-collapse .menu--diamond-vogel-navigation .caret,
  body.dv-mobile-menu-unified #navbar-collapse .menu.nav:not(.menu--diamond-vogel-top-navigation) .caret,
  body.dv-mobile-menu-unified #navbar-collapse .navbar-nav .caret {
    border-top-color: var(--dv-mobile-menu-secondary-link) !important;
    margin-left: 0.35rem;
  }

  body.dv-mobile-menu-unified #navbar-collapse .menu.nav > li + li::before {
    display: none !important;
  }

  body.dv-mobile-menu-unified #navbar-collapse .dv-mobile-menu__search {
    margin-top: 1.35rem;
    padding-top: 1.15rem;
    border-top: 1px solid rgba(255, 255, 255, 0.25);
  }

  body.dv-mobile-menu-unified #navbar-collapse .dv-top-nav-search {
    max-width: 100%;
    width: 100%;
    padding: 0;
    margin: 0;
  }

  body.dv-mobile-menu-unified #navbar-collapse .dv-top-nav-search input[type="search"] {
    background: #fff;
    border-color: rgba(255, 255, 255, 0.35);
    color: #333;
  }

  body.dv-mobile-menu-unified #navbar-collapse .dv-top-nav-search button {
    background: var(--dv-top-nav-accent-gold);
    border-color: var(--dv-top-nav-accent-gold);
    color: #fff;
  }

  body.dv-mobile-menu-unified #navbar-collapse .dropdown-menu,
  body.dv-mobile-menu-unified
    #navbar-collapse
    #block-diamondvogelnavigation
    .menu.nav
    .dropdown-menu,
  body.dv-mobile-menu-unified
    #navbar-collapse
    .menu--diamond-vogel-navigation.nav
    .dropdown-menu,
  body.dv-mobile-menu-unified
    #navbar-collapse
    #block-diamondvogelnavigation
    .diamond-vogel-menu,
  body.dv-mobile-menu-unified
    #navbar-collapse
    #block-diamondvogelnavigation
    .diamond-vogel-menu
    .container {
    border-left-color: rgba(255, 255, 255, 0.3) !important;
    background: transparent !important;
    background-color: transparent !important;
    box-shadow: none !important;
  }

  body.dv-mobile-menu-unified #navbar-collapse .dropdown-menu li > a,
  body.dv-mobile-menu-unified
    #navbar-collapse
    #block-diamondvogelnavigation
    .menu.nav
    .dropdown-menu
    li
    > a,
  body.dv-mobile-menu-unified
    #navbar-collapse
    .menu--diamond-vogel-navigation.nav
    .dropdown-menu
    li
    > a {
    color: var(--dv-mobile-menu-top-link, #fff) !important;
    text-transform: none;
    font-size: var(--dv-primary-nav-link-size) !important;
    padding: 0.5rem 0 0.5rem 0.5rem !important;
    line-height: 1.35 !important;
  }

  body.dv-mobile-menu-unified
    #navbar-collapse
    .dropdown-menu
    li.dv-has-nested-submenu
    > a {
    display: flex !important;
    justify-content: space-between;
    align-items: center;
    gap: 0.35rem;
    cursor: pointer;
    touch-action: manipulation;
  }

  body.dv-mobile-menu-unified #navbar-collapse .dropdown-menu li > a:hover,
  body.dv-mobile-menu-unified #navbar-collapse .dropdown-menu li > a:focus,
  body.dv-mobile-menu-unified
    #navbar-collapse
    #block-diamondvogelnavigation
    .menu.nav
    .dropdown-menu
    li
    > a:hover,
  body.dv-mobile-menu-unified
    #navbar-collapse
    #block-diamondvogelnavigation
    .menu.nav
    .dropdown-menu
    li
    > a:focus {
    color: var(--dv-mobile-menu-top-link, #fff) !important;
    background-color: rgba(255, 255, 255, 0.08) !important;
  }

  body.dv-mobile-menu-unified
    #navbar-collapse
    .dropdown-menu
    li.dv-has-nested-submenu
    > a
    .caret.dv-nested-submenu-caret,
  body.dv-mobile-menu-unified
    #navbar-collapse
    .dropdown-menu
    .dropdown-menu
    li.dv-has-nested-submenu
    > a
    .caret.dv-nested-submenu-caret {
    border-top-color: var(--dv-mobile-menu-top-link, #fff) !important;
  }

  /*
   * Division themes (Architectural, Industrial, …): primary nav is Bootstrap .navbar-nav
   * (menu--main). Desktop flyout rules above use white panels; override every tier here.
   */
  body.dv-has-top-navigation.dv-mobile-menu-unified
    header#navbar
    #navbar-collapse
    :is(
      .navbar-nav,
      .menu--main.menu.nav,
      .menu--homepage-anchors.menu.nav,
      [id*='main-menu']
    )
    .dropdown-menu,
  body.dv-has-top-navigation.dv-mobile-menu-unified
    header#navbar
    #navbar-collapse
    :is(
      .navbar-nav,
      .menu--main.menu.nav,
      .menu--homepage-anchors.menu.nav,
      [id*='main-menu']
    )
    .dropdown-menu
    .dropdown-menu {
    background: transparent !important;
    background-color: transparent !important;
    box-shadow: none !important;
    border-top: 0 !important;
    border-bottom: 0 !important;
    border-right: 0 !important;
    border-left-color: rgba(255, 255, 255, 0.3) !important;
  }

  body.dv-has-top-navigation.dv-mobile-menu-unified
    header#navbar
    #navbar-collapse
    :is(
      .navbar-nav,
      .menu--main.menu.nav,
      .menu--homepage-anchors.menu.nav,
      [id*='main-menu']
    )
    .dropdown-menu
    li
    > a,
  body.dv-has-top-navigation.dv-mobile-menu-unified
    header#navbar
    #navbar-collapse
    :is(
      .navbar-nav,
      .menu--main.menu.nav,
      .menu--homepage-anchors.menu.nav,
      [id*='main-menu']
    )
    .dropdown-menu
    li:hover
    > a,
  body.dv-has-top-navigation.dv-mobile-menu-unified
    header#navbar
    #navbar-collapse
    :is(
      .navbar-nav,
      .menu--main.menu.nav,
      .menu--homepage-anchors.menu.nav,
      [id*='main-menu']
    )
    .dropdown-menu
    li
    > a:hover,
  body.dv-has-top-navigation.dv-mobile-menu-unified
    header#navbar
    #navbar-collapse
    :is(
      .navbar-nav,
      .menu--main.menu.nav,
      .menu--homepage-anchors.menu.nav,
      [id*='main-menu']
    )
    .dropdown-menu
    li
    > a:focus {
    color: var(--dv-mobile-menu-top-link, #fff) !important;
    background: transparent !important;
    background-color: transparent !important;
    border-left: none !important;
    border-right: none !important;
  }

  body.dv-has-top-navigation.dv-mobile-menu-unified
    header#navbar
    #navbar-collapse
    :is(
      .navbar-nav,
      .menu--main.menu.nav,
      .menu--homepage-anchors.menu.nav,
      [id*='main-menu']
    )
    .dropdown-menu
    li
    > a:hover,
  body.dv-has-top-navigation.dv-mobile-menu-unified
    header#navbar
    #navbar-collapse
    :is(
      .navbar-nav,
      .menu--main.menu.nav,
      .menu--homepage-anchors.menu.nav,
      [id*='main-menu']
    )
    .dropdown-menu
    li
    > a:focus {
    background-color: rgba(255, 255, 255, 0.08) !important;
  }

  /*
   * Cross-theme (all sites in _dvcorp_top_navigation_themes): legacy mobile collapse
   * panels often force a white background or light border (Architectural, Fill-n-Spray,
   * Vogel Paint responsive.css, etc.). Unified drawer always uses charcoal + tokens.
   */
  body.dv-has-top-navigation.dv-mobile-menu-unified #navbar .navbar-collapse.collapse.in,
  body.dv-has-top-navigation.dv-mobile-menu-unified #navbar .navbar-collapse.collapsing,
  body.dv-has-top-navigation.dv-mobile-menu-unified .navbar-default .navbar-collapse.collapse.in,
  body.dv-has-top-navigation.dv-mobile-menu-unified .navbar-default .navbar-collapse.collapsing,
  body.dv-has-top-navigation.dv-mobile-menu-unified .header-wrapper #navbar-collapse.collapse.in,
  body.dv-has-top-navigation.dv-mobile-menu-unified .header-wrapper #navbar-collapse.collapsing {
    background-color: var(--dv-mobile-menu-panel-bg) !important;
    background: var(--dv-mobile-menu-panel-bg) !important;
    border-top: 0 !important;
    box-shadow: none !important;
  }

  /* Block ids are theme-prefixed (e.g. block-vogelindustrial-diamondvogelnavigation). */
  body.dv-mobile-menu-unified #navbar-collapse [id*='diamondvogelnavigation'],
  body.dv-mobile-menu-unified #navbar-collapse [id*='diamond-vogel-navigation'] {
    display: block !important;
    visibility: visible !important;
    opacity: 1 !important;
    position: static !important;
    width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
  }

  body.dv-mobile-menu-unified
    #navbar-collapse
    [id*='diamondvogelnavigation']
    .diamond-vogel-menu,
  body.dv-mobile-menu-unified
    #navbar-collapse
    [id*='diamondvogelnavigation']
    .diamond-vogel-menu
    .container {
    width: 100% !important;
    max-width: none !important;
    padding: 0 !important;
    margin: 0 !important;
    background: transparent !important;
    height: auto !important;
    min-height: 0 !important;
    border: 0;
    box-shadow: none;
  }

  body.dv-mobile-menu-unified
    #navbar-collapse
    [id*='diamondvogelnavigation']
    .menu.nav,
  body.dv-mobile-menu-unified
    #navbar-collapse
    [id*='diamond-vogel-navigation']
    .menu.nav {
    position: static !important;
    top: auto !important;
    right: auto !important;
    left: auto !important;
    float: none !important;
  }

  body.dv-mobile-menu-unified
    #navbar-collapse
    [id*='diamondvogelnavigation']
    .menu.nav
    > li
    > a {
    color: var(--dv-mobile-menu-secondary-link) !important;
  }

  /* Site primary menus in the divisions stack (e.g. architectural-main-menu). */
  body.dv-mobile-menu-unified
    #navbar-collapse
    .dv-mobile-menu__divisions
    .navbar-nav
    > li
    > a,
  body.dv-mobile-menu-unified
    #navbar-collapse
    .dv-mobile-menu__divisions
    .menu--main.menu.nav
    > li
    > a {
    color: var(--dv-mobile-menu-secondary-link) !important;
  }

  /*
   * Vogel Custom: homepage-anchors is the site primary nav in the orange stack.
   */
  body.dv-mobile-menu-unified.dv-header-primary-homepage-anchors
    #navbar-collapse
    .dv-mobile-menu__divisions
    #block-homepageanchors {
    display: block !important;
    width: 100%;
  }

  body.dv-mobile-menu-unified.dv-header-primary-homepage-anchors
    #navbar-collapse
    .menu--homepage-anchors.menu.nav {
    display: block !important;
    flex-direction: column !important;
    flex-wrap: nowrap !important;
    width: 100%;
    margin: 0;
    padding: 0;
    float: none !important;
    position: static !important;
  }

  body.dv-mobile-menu-unified.dv-header-primary-homepage-anchors
    #navbar-collapse
    .menu--homepage-anchors.menu.nav
    > li {
    display: block !important;
    float: none !important;
    width: 100%;
  }

  body.dv-mobile-menu-unified.dv-header-primary-homepage-anchors
    #navbar-collapse
    .menu--homepage-anchors.menu.nav
    > li
    + li::before {
    display: none !important;
  }

  body.dv-mobile-menu-unified.dv-header-primary-homepage-anchors
    #navbar-collapse
    .menu--homepage-anchors.menu.nav
    > li
    > a,
  body.dv-mobile-menu-unified.dv-header-primary-homepage-anchors
    #navbar-collapse
    .menu--homepage-anchors.menu.nav
    > li
    > a:visited {
    color: var(--dv-mobile-menu-secondary-link) !important;
    background: transparent !important;
    text-transform: uppercase !important;
    font-family: var(--dv-font-family) !important;
    font-size: var(--dv-primary-nav-link-size) !important;
    font-weight: 400 !important;
    letter-spacing: 0.04em;
    line-height: 1.35;
    padding: 0.65rem 0 !important;
    display: block !important;
    white-space: normal;
  }
}

/*
 * Views / core search blocks in the Bootstrap primary header duplicate navy-strip search.
 */
body.dv-has-top-navigation header#navbar .views-exposed-form,
body.dv-has-top-navigation header#navbar form[id^='views-exposed-form-search'],
body.dv-has-top-navigation header#navbar form[id*='views-exposed-form-search'],
body.dv-has-top-navigation header#navbar [id*='block-exposedformsearch'],
body.dv-has-top-navigation header#navbar [id*='block-exposed-form-search'],
body.dv-has-top-navigation header#navbar [class*='block-views-exposed-filter-blocksearch'],
body.dv-has-top-navigation header#navbar .block-search-form-block,
body.dv-has-top-navigation header#navbar form.search-form {
  display: none !important;
}

/* Tablet: static navy strip still uses BS3 750px container math (wins over 15px reset above). */
@media screen and (min-width: 768px) and (max-width: 991px) {
  .dv-top-nav-block {
    padding-left: max(15px, calc((100vw - 750px) / 2 + 15px));
    padding-right: max(15px, calc((100vw - 750px) / 2 + 15px));
  }
}

/* -----------------------------------------------------------------------------
 * Primary header (logo + main menu): solid white bar; hero / content follow below.
 * -------------------------------------------------------------------------- */

body.dv-has-top-navigation header#navbar {
  position: relative;
  width: 100%;
  background-color: #fff;
  padding-top: 90px;
  border-bottom: 1px solid rgba(0, 55, 99, 0.12);
  /* Below fixed navy (485); under toolbar; beats theme .path-frontpage #navbar { z-index: 502 }. */
  z-index: 460 !important;
}

body.dv-has-top-navigation :is(.navbar-default, .navbar-inverse) {
  background-color: #fff;
  border-color: transparent;
}

/*
 * Keep division stacked logos the same visual height so the white header bar
 * stays consistent across sites regardless of each image's native aspect ratio.
 * Mobile/tablet: 56px. Desktop (≥992px): 121px — one variable, all corporate themes.
 *
 * Selectors cover Bootstrap branding markup, *-branding-group wrappers (Industrial,
 * Custom), and Traffic’s a.logo > img without .site-logo-img. !important beats
 * theme rules like img { max-width: 100%; height: auto } and dv_base fixed widths.
 */
@media screen and (min-width: 768px) {
  body.dv-has-top-navigation header#navbar a.logo img,
  body.dv-has-top-navigation header#navbar .navbar-btn.logo img,
  body.dv-has-top-navigation .navbar .logo img,
  body.dv-has-top-navigation .navbar-header .logo img,
  body.dv-has-top-navigation .navbar .logo img.site-logo-img,
  body.dv-has-top-navigation .navbar-header .logo img.site-logo-img,
  body.dv-has-top-navigation header#navbar [class*='-branding-group'] img {
    width: auto !important;
    max-width: min(560px, 58vw) !important;
    height: var(--dv-brand-logo-height) !important;
    min-height: var(--dv-brand-logo-height) !important;
    max-height: var(--dv-brand-logo-height) !important;
    object-fit: contain;
    display: block;
    margin-top: 0 !important;
    padding-top: 0 !important;
  }

  /*
   * Vogel Custom: single stacked logo asset — align to top of the slot so transparent
   * PNG padding does not read as extra space above the mark.
   */
  body.dv-has-top-navigation.dv-header-primary-homepage-anchors
    header#navbar
    [class*='-branding-group']
    img,
  body.dv-has-top-navigation.dv-header-primary-homepage-anchors
    header#navbar
    a.logo
    img {
    object-position: top center;
  }
}

@media screen and (min-width: 992px) {
  :root {
    --dv-brand-logo-height: 121px;
    --dv-primary-bar-pad-y: 0.75rem;
  }

  /*
   * White primary row must be at least as tall as the logo so the image background
   * does not hang below the bar (division themes often set a shorter .navbar-header).
   */
  body.dv-has-top-navigation header#navbar {
    padding-top: 90px !important;
    padding-bottom: var(--dv-primary-bar-pad-y);
    box-sizing: border-box;
    min-height: calc(
      90px + var(--dv-brand-logo-height) + var(--dv-primary-bar-pad-y) * 2
    );
  }

  body.dv-has-top-navigation .navbar-header,
  body.dv-has-top-navigation .navbar-collapse {
    min-height: var(--dv-brand-logo-height);
    align-items: center;
    align-self: center;
    box-sizing: border-box;
    padding-top: 0 !important;
    padding-bottom: var(--dv-primary-bar-pad-y) !important;
  }

  body.dv-has-top-navigation .header-wrapper header#navbar > .container .navbar-header,
  body.dv-has-top-navigation header#navbar.container > .navbar-header,
  body.dv-has-top-navigation header#navbar .navbar-header,
  body.dv-has-top-navigation.path-frontpage header#navbar .navbar-header,
  body.dv-has-top-navigation:not(.path-frontpage) header#navbar .navbar-header {
    height: auto !important;
    width: max-content !important;
    max-width: min(560px, 58vw) !important;
  }

  body.dv-has-top-navigation header#navbar .navbar-header .region-navigation,
  body.dv-has-top-navigation header#navbar [class*='-branding-group'] {
    display: flex;
    align-items: center;
    margin: 0;
    padding: 0;
  }

  body.dv-has-top-navigation header#navbar .navbar-header a.logo,
  body.dv-has-top-navigation header#navbar .navbar-header .navbar-btn {
    margin-top: 0 !important;
    margin-bottom: 0 !important;
    padding-top: 0 !important;
    padding-bottom: 0 !important;
    display: flex;
    align-items: center;
  }

  body.dv-has-top-navigation.path-frontpage header#navbar .navbar-header,
  body.dv-has-top-navigation:not(.path-frontpage) header#navbar .navbar-header {
    padding-top: 0 !important;
    padding-bottom: var(--dv-primary-bar-pad-y) !important;
  }
}

/*
 * Full primary chrome (logo + menus): white on wrapper and inner regions so
 * theme base grays / transparent .navbar-default do not show through.
 */
body.dv-has-top-navigation .header-wrapper {
  background-color: #fff !important;
}

body.dv-has-top-navigation .navbar-header,
body.dv-has-top-navigation #navbar-collapse,
body.dv-has-top-navigation #navbar .container,
body.dv-has-top-navigation header#navbar > .container,
body.dv-has-top-navigation #navbar .region-navigation,
body.dv-has-top-navigation #navbar .region-navigation-collapsible {
  background-color: #fff;
}

/*
 * Bootstrap sub-themes often put .container on #navbar itself. That caps max-width
 * so the white background only paints the centered column and body gray shows at
 * the sides — match the navy strip gutters and let the bar span the viewport.
 */
body.dv-has-top-navigation header#navbar.container {
  max-width: none !important;
  box-sizing: border-box;
}

@media screen and (min-width: 768px) and (max-width: 991px) {
  body.dv-has-top-navigation header#navbar.container {
    padding-left: max(15px, calc((100vw - 750px) / 2 + 15px));
    padding-right: max(15px, calc((100vw - 750px) / 2 + 15px));
  }
}

@media screen and (min-width: 992px) and (max-width: 1199px) {
  body.dv-has-top-navigation header#navbar.container {
    padding-left: calc((100vw - 970px) / 2 + 15px);
    padding-right: calc((100vw - 970px) / 2 + 15px);
  }
}

@media screen and (min-width: 1200px) {
  body.dv-has-top-navigation header#navbar.container {
    padding-left: calc((100vw - 1170px) / 2 + 15px);
    padding-right: calc((100vw - 1170px) / 2 + 15px);
  }
}

/*
 * Tablet + desktop: one primary row (logo / toggle + collapse). Covers Bootstrap 3
 * patterns with an inner .container and with .container on #navbar itself.
 */
@media screen and (min-width: 768px) and (max-width: 991px) {
  body.dv-has-top-navigation header#navbar {
    margin-top: 0 !important;
    top: 0 !important;
  }

  body.dv-has-top-navigation .navbar-toggle {
    display: block !important;
    margin-top: 0;
    margin-bottom: 0;
  }

  body.dv-has-top-navigation .navbar-default .container:first-child,
  body.dv-has-top-navigation header#navbar > .container {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem 1rem;
    padding-top: 0;
  }

  body.dv-has-top-navigation header#navbar.container {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem 1rem;
  }

  body.dv-has-top-navigation .navbar-header {
    float: none !important;
    margin-top: 0;
    flex: 0 0 auto;
    width: 100%;
    min-width: 0;
    display: flex !important;
    flex-wrap: nowrap;
    align-items: center;
    justify-content: space-between;
  }

  body.dv-has-top-navigation .navbar-collapse.collapse:not(.in):not(.collapsing) {
    display: none !important;
    visibility: hidden !important;
    height: 0 !important;
    overflow: hidden !important;
  }

  body.dv-has-top-navigation .navbar-collapse.collapse.in,
  body.dv-has-top-navigation .navbar-collapse.collapsing {
    display: flex !important;
    flex: 1 1 100%;
    width: 100% !important;
    min-width: 0 !important;
    height: auto !important;
    overflow: visible !important;
    visibility: visible !important;
    flex-direction: column;
    align-items: stretch;
    justify-content: flex-start;
    flex-wrap: nowrap;
    padding: 0;
    margin: 0;
  }

  body.dv-has-top-navigation .navbar-collapse {
    float: none !important;
    flex-basis: 100%;
    width: 100% !important;
    padding-right: 0;
    justify-content: flex-start;
  }

  body.dv-has-top-navigation .navbar-nav {
    float: none;
    margin: 0;
    display: flex;
    flex-direction: column;
    flex-wrap: nowrap;
    align-items: stretch;
    justify-content: flex-start;
    width: 100%;
  }
}

/*
 * White-bar menu pipes (768px+): divider on previous item (::after), not on wrapped row
 * start (::before), so a new line never begins with a pipe.
 */
@media screen and (min-width: 768px) {
  body.dv-has-top-navigation:not(.dv-mobile-menu-unified) header#navbar #navbar-collapse .navbar-default .navbar-nav > li + li::before,
  body.dv-has-top-navigation:not(.dv-mobile-menu-unified) header#navbar #navbar-collapse .menu.nav:not(.menu--diamond-vogel-top-navigation) > li + li::before,
  body.dv-has-top-navigation:not(.dv-mobile-menu-unified) header#navbar .navbar .nav:not(.menu--diamond-vogel-top-navigation) > li + li::before,
  body.dv-has-top-navigation:not(.dv-mobile-menu-unified)
    header#navbar
    #navbar-collapse
    :is(
      .menu--diamond-vogel-navigation.menu.nav,
      #block-diamondvogelnavigation .menu.nav,
      .menu--main.menu.nav,
      .menu--homepage-anchors.menu.nav,
      ul.navbar-nav.menu--main,
      ul.navbar-nav.menu--homepage-anchors,
      ul.navbar-nav.menu--diamond-vogel-navigation,
      [id*='diamond-vogel-navigation'] .menu.nav,
      [id*='diamond_vogel_navigation'] .menu.nav,
      [id*='main-menu'] .menu.nav
    )
    > li::before,
  body.dv-has-top-navigation:not(.dv-mobile-menu-unified)
    header#navbar
    #navbar-collapse
    :is(
      .menu--diamond-vogel-navigation.menu.nav,
      #block-diamondvogelnavigation .menu.nav,
      .menu--main.menu.nav,
      .menu--homepage-anchors.menu.nav,
      ul.navbar-nav.menu--main,
      ul.navbar-nav.menu--homepage-anchors,
      ul.navbar-nav.menu--diamond-vogel-navigation,
      [id*='diamond-vogel-navigation'] .menu.nav,
      [id*='diamond_vogel_navigation'] .menu.nav,
      [id*='main-menu'] .menu.nav
    )
    > li::after {
    content: none !important;
    display: none !important;
    width: 0 !important;
    height: 0 !important;
    margin: 0 !important;
    border: 0 !important;
  }

  body.dv-has-top-navigation:not(.dv-mobile-menu-unified) .menu.nav.dv-nav-measuring > li::before,
  body.dv-has-top-navigation:not(.dv-mobile-menu-unified) .menu.nav.dv-nav-measuring > li::after,
  body.dv-has-top-navigation:not(.dv-mobile-menu-unified) .menu--diamond-vogel-top-navigation.menu.nav.dv-nav-measuring > li::before,
  body.dv-has-top-navigation:not(.dv-mobile-menu-unified) .menu--diamond-vogel-top-navigation.menu.nav.dv-nav-measuring > li::after {
    content: none !important;
    display: none !important;
    width: 0 !important;
    height: 0 !important;
    margin: 0 !important;
    border: 0 !important;
  }

  body.dv-has-top-navigation:not(.dv-mobile-menu-unified)
    header#navbar
    #navbar-collapse
    :is(
      .menu--diamond-vogel-navigation.menu.nav,
      #block-diamondvogelnavigation .menu.nav,
      .menu--main.menu.nav,
      .menu--homepage-anchors.menu.nav,
      ul.navbar-nav.menu--main,
      ul.navbar-nav.menu--homepage-anchors,
      ul.navbar-nav.menu--diamond-vogel-navigation,
      [id*='diamond-vogel-navigation'] .menu.nav,
      [id*='diamond_vogel_navigation'] .menu.nav,
      [id*='main-menu'] .menu.nav
    )
    > li {
    border-right: none !important;
    border-left: none !important;
  }

  body.dv-has-top-navigation:not(.dv-mobile-menu-unified)
    header#navbar
    #navbar-collapse
    :is(
      .menu--diamond-vogel-navigation.menu.nav,
      #block-diamondvogelnavigation .menu.nav,
      .menu--main.menu.nav,
      .menu--homepage-anchors.menu.nav,
      ul.navbar-nav.menu--main,
      ul.navbar-nav.menu--homepage-anchors,
      ul.navbar-nav.menu--diamond-vogel-navigation,
      [id*='diamond-vogel-navigation'] .menu.nav,
      [id*='diamond_vogel_navigation'] .menu.nav,
      [id*='main-menu'] .menu.nav
    )
    > li.dv-nav-has-next-on-same-row::after {
    content: "" !important;
    display: block !important;
    width: var(--dv-top-nav-divider-width) !important;
    height: var(--dv-top-nav-divider-height) !important;
    background: rgba(0, 55, 99, 0.4) !important;
    margin-left: var(--dv-top-nav-divider-gap) !important;
    margin-right: var(--dv-top-nav-divider-gap) !important;
    flex-shrink: 0;
    border: 0 !important;
    position: static !important;
    float: none !important;
    transform: none !important;
  }

  /*
   * Toll: merged primary list (dv-unified-primary-nav-list) is not in :is() above.
   */
  body.dv-has-top-navigation:not(.dv-mobile-menu-unified)
    header#navbar
    #navbar-collapse
    ul.menu.nav.dv-unified-primary-nav-list
    > li + li::before {
    content: none !important;
    display: none !important;
    width: 0 !important;
    height: 0 !important;
    margin: 0 !important;
    border: 0 !important;
  }

  body.dv-has-top-navigation:not(.dv-mobile-menu-unified)
    header#navbar
    #navbar-collapse
    ul.menu.nav.dv-unified-primary-nav-list
    > li {
    border-right: none !important;
    border-left: none !important;
  }

  body.dv-has-top-navigation:not(.dv-mobile-menu-unified)
    header#navbar
    #navbar-collapse
    ul.menu.nav.dv-unified-primary-nav-list
    > li.dv-nav-has-next-on-same-row::after {
    content: "" !important;
    display: block !important;
    width: var(--dv-top-nav-divider-width) !important;
    height: var(--dv-top-nav-divider-height) !important;
    background: rgba(0, 55, 99, 0.4) !important;
    margin-left: var(--dv-top-nav-divider-gap) !important;
    margin-right: var(--dv-top-nav-divider-gap) !important;
    flex-shrink: 0;
    border: 0 !important;
    position: static !important;
    float: none !important;
    transform: none !important;
  }
}

@media screen and (min-width: 992px) {
  body.dv-has-top-navigation header#navbar {
    margin-top: 0 !important;
    top: 0 !important;
  }

  body.dv-has-top-navigation .navbar-toggle {
    display: none !important;
  }

  /*
   * Logo column + menu column: --dv-logo-slot-width is measured in dv-top-navigation.js
   * so primary links always begin after the rendered logo (wide anniversary marks, etc.).
   */
  body.dv-has-top-navigation header#navbar.container,
  body.dv-has-top-navigation .navbar-default .container:first-child,
  body.dv-has-top-navigation header#navbar > .container {
    display: grid !important;
    grid-template-columns: max-content minmax(0, 1fr) !important;
    grid-template-rows: auto;
    align-items: center;
    column-gap: 1rem;
    row-gap: 0.5rem;
    justify-content: stretch;
    padding-top: 0;
  }

  body.dv-has-top-navigation .navbar-header {
    float: none !important;
    grid-column: 1;
    grid-row: 1;
    justify-self: start;
    margin: 0;
    flex: 0 0 auto;
    flex-shrink: 0;
    width: max-content;
    min-width: min-content;
    max-width: min(560px, 58vw);
    display: flex;
    flex-wrap: nowrap;
    align-items: center;
    justify-content: flex-start;
    overflow: visible;
  }

  /* Toll: narrower logo column so five primary links can fill row 1 before wrapping. */
  body.dv-has-top-navigation.dv-header-primary-homepage-anchors header#navbar .navbar-header {
    max-width: min(400px, 40vw);
  }

  body.dv-has-top-navigation .navbar-collapse,
  body.dv-has-top-navigation header#navbar.container > #navbar-collapse,
  body.dv-has-top-navigation .header-wrapper header#navbar > .container #navbar-collapse {
    float: none !important;
    grid-column: 2;
    grid-row: 1;
    justify-self: stretch;
    align-self: center;
    flex: none;
    min-width: 0;
    width: 100% !important;
    max-width: 100%;
    padding: 0 !important;
    margin-top: 0 !important;
    display: flex;
    justify-content: flex-start !important;
    align-items: center !important;
    position: relative !important;
    overflow: visible;
  }

  body.dv-has-top-navigation .navbar-collapse.collapse {
    display: flex !important;
    height: auto !important;
    overflow: visible !important;
    visibility: visible !important;
  }

  body.dv-has-top-navigation header#navbar .region-navigation-collapsible {
    display: flex !important;
    flex-direction: row !important;
    flex-wrap: wrap;
    align-items: center;
    justify-content: flex-start !important;
    gap: 0 0.75rem;
    flex: 1 1 auto;
    min-width: 0;
    width: 100%;
    max-width: 100%;
  }

  body.dv-has-top-navigation:not(.dv-header-primary-homepage-anchors) .navbar-nav,
  body.dv-has-top-navigation:not(.dv-header-primary-homepage-anchors) header#navbar #navbar-collapse .menu.nav,
  body.dv-has-top-navigation header#navbar .menu--diamond-vogel-navigation.menu.nav,
  body.dv-has-top-navigation:not(.dv-header-primary-homepage-anchors) header#navbar .menu--homepage-anchors.menu.nav,
  body.dv-has-top-navigation header#navbar #block-diamondvogelnavigation .menu.nav {
    float: none !important;
    margin: 0;
    position: static !important;
    left: auto !important;
    right: auto !important;
    top: auto !important;
    width: 100% !important;
    max-width: 100%;
    display: flex !important;
    flex-direction: row !important;
    flex-wrap: wrap;
    align-items: center;
    align-content: flex-start !important;
    justify-content: flex-start !important;
    row-gap: 0.35rem;
  }

  /*
   * Toll: flatten blocks so every top-level <li> shares one flex-wrap (display:contents).
   */
  body.dv-has-top-navigation.dv-header-primary-homepage-anchors
    header#navbar
    .region-navigation-collapsible
    .navbar-nav,
  body.dv-has-top-navigation.dv-header-primary-homepage-anchors
    header#navbar
    .region-navigation-collapsible
    nav:not([id*='diamondvogeltopnavigation']):not([id*='diamond-vogel-top'])
    > ul.menu.nav {
    display: contents !important;
    width: auto !important;
    max-width: none !important;
    flex-wrap: nowrap !important;
    margin: 0 !important;
  }

  body.dv-has-top-navigation:not(.dv-header-primary-homepage-anchors) header#navbar #block-diamondvogelnavigation,
  body.dv-has-top-navigation:not(.dv-header-primary-homepage-anchors) header#navbar #block-diamondvogelnavigation .diamond-vogel-menu,
  body.dv-has-top-navigation:not(.dv-header-primary-homepage-anchors) header#navbar #block-diamondvogelnavigation .diamond-vogel-menu .container,
  body.dv-has-top-navigation:not(.dv-header-primary-homepage-anchors) header#navbar [id*='main-menu'] {
    position: static !important;
    width: 100% !important;
    max-width: none !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
    display: flex !important;
    flex-direction: row !important;
    flex-wrap: wrap;
    align-items: center;
    align-content: flex-start !important;
    justify-content: flex-start !important;
    text-align: left !important;
  }

  /*
   * Vogel Paint: duplicate anchor block in #navbar (fullPage uses off-screen copy).
   * Vogel Custom: #block-homepageanchors is the primary nav — keep visible (see
   * .dv-header-primary-homepage-anchors).
   */
  body.dv-has-top-navigation:not(.dv-header-primary-homepage-anchors) header#navbar #block-homepageanchors {
    display: none !important;
  }

  /*
   * Toll blocks are <nav> elements: display:contents so <li> items share one flex row.
   */
  body.dv-has-top-navigation.dv-header-primary-homepage-anchors header#navbar #block-homepageanchors,
  body.dv-has-top-navigation.dv-header-primary-homepage-anchors header#navbar #block-vogelcustom-main-menu,
  body.dv-has-top-navigation.dv-header-primary-homepage-anchors header#navbar #navbar-collapse #block-homepageanchors,
  body.dv-has-top-navigation.dv-header-primary-homepage-anchors header#navbar #navbar-collapse #block-vogelcustom-main-menu {
    display: contents !important;
  }

  body.dv-has-top-navigation.dv-header-primary-homepage-anchors header#navbar #block-footeranchors,
  body.dv-has-top-navigation.dv-header-primary-homepage-anchors header#navbar #navbar-collapse #block-footeranchors {
    display: none !important;
  }

  /*
   * Toll: homepage-anchors + system main menu are separate blocks; flatten into one flex
   * row so items fill row 1 before wrapping and row 2+ center (corporate behavior).
   */
  body.dv-has-top-navigation.dv-header-primary-homepage-anchors
    header#navbar
    .region-navigation-collapsible {
    display: flex !important;
    flex-wrap: wrap !important;
    flex-direction: row !important;
    align-items: center !important;
    align-content: flex-start !important;
    justify-content: flex-start !important;
    width: 100% !important;
    max-width: 100%;
    row-gap: 0.35rem;
  }

  body.dv-has-top-navigation.dv-header-primary-homepage-anchors
    header#navbar
    .region-navigation-collapsible
    nav[id*='diamondvogeltopnavigation'],
  body.dv-has-top-navigation.dv-header-primary-homepage-anchors
    header#navbar
    .region-navigation-collapsible
    nav[id*='diamond-vogel-top'] {
    display: none !important;
  }

  /* Block titles must not participate in the unified flex row (would force wraps). */
  body.dv-has-top-navigation.dv-header-primary-homepage-anchors
    header#navbar
    .region-navigation-collapsible
    nav
    > h2 {
    display: none !important;
  }

  body.dv-has-top-navigation.dv-header-primary-homepage-anchors
    header#navbar
    .region-navigation-collapsible
    nav:not([id*='diamondvogeltopnavigation']):not([id*='diamond-vogel-top'])
    > ul.menu.nav
    > li {
    display: flex !important;
    align-items: center !important;
    float: none !important;
  }

  /* Toll: JS merges blocks into one flex-wrap list (dv-unified-primary-nav-list). */
  body.dv-has-top-navigation.dv-header-primary-homepage-anchors
    header#navbar
    .region-navigation-collapsible
    > ul.dv-unified-primary-nav-list {
    display: flex !important;
    flex-direction: row !important;
    flex-wrap: wrap !important;
    align-items: center !important;
    align-content: flex-start !important;
    justify-content: flex-start !important;
    width: 100% !important;
    max-width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
    list-style: none !important;
    row-gap: 0.35rem;
  }

  body.dv-has-top-navigation.dv-header-primary-homepage-anchors
    header#navbar
    .region-navigation-collapsible
    > nav[hidden] {
    display: none !important;
  }

  /*
   * Some themes place a copy of the navy top menu inside #navbar-collapse; hide it on
   * desktop so only the fixed strip shows and the primary row stays vertically aligned.
   */
  body.dv-has-top-navigation header#navbar #navbar-collapse .menu--diamond-vogel-top-navigation,
  body.dv-has-top-navigation header#navbar #navbar-collapse [id*='diamond-vogel-top-navigation'],
  body.dv-has-top-navigation header#navbar #navbar-collapse .block-system-menu-blockdiamond-vogel-top-navigation,
  body.dv-has-top-navigation header#navbar #navbar-collapse nav[id*='diamondvogeltopnavigation'] {
    display: none !important;
  }

  /* Bootstrap sub-themes: core menu block <h2 class="visually-hidden"> still occupies layout. */
  body.dv-has-top-navigation header#navbar #navbar-collapse nav > h2 {
    display: none !important;
  }

  body.dv-has-top-navigation header#navbar #navbar-collapse .menu.nav > li,
  body.dv-has-top-navigation header#navbar .navbar-nav > li {
    display: flex;
    align-items: center;
  }

  body.dv-has-top-navigation header#navbar #navbar-collapse .menu.nav > li > a,
  body.dv-has-top-navigation header#navbar .navbar-nav > li > a {
    display: inline-flex;
    align-items: center;
    line-height: 1.3;
    padding-top: 0.35em !important;
    padding-bottom: 0.35em !important;
  }
}

/*
 * Architectural (sites/architectural + sites/default/themes/architectural): base
 * style.css sets .navbar-nav .caret { display: none } and all .navbar-nav ul.dropdown-menu
 * to width:100%. Do not require .navbar-default — header may be navbar-inverse per theme
 * settings; match header#navbar .navbar-nav only.
 */
body.dv-has-top-navigation header#navbar .navbar-nav .caret {
  display: inline-block !important;
  vertical-align: middle;
  border-top-color: #003763;
}

/*
 * Nested flyouts: same panel sizing as first tier (Architectural theme width:100%
 * pins panels to the parent tab; width:auto alone shrinks to the narrowest row).
 */
body.dv-has-top-navigation header#navbar .navbar-nav ul.dropdown-menu ul.dropdown-menu {
  width: max-content !important;
  min-width: max(100%, 190px) !important;
}

/* Bootstrap .navbar-nav (Industrial, Peridium, etc.) — pipes use ::before, not borders. */
body.dv-has-top-navigation header#navbar #navbar-collapse :is(.navbar-default, .navbar-inverse) .navbar-nav > li {
  border-right: none !important;
  border-left: none !important;
}

body.dv-has-top-navigation :is(.navbar-default, .navbar-inverse) .navbar-nav > li > a,
body.dv-has-top-navigation :is(.navbar-default, .navbar-inverse) .navbar-nav > li > a:visited {
  color: #003763;
}

body.dv-has-top-navigation :is(.navbar-default, .navbar-inverse) .navbar-nav > li > a:hover,
body.dv-has-top-navigation :is(.navbar-default, .navbar-inverse) .navbar-nav > li > a:focus,
body.dv-has-top-navigation :is(.navbar-default, .navbar-inverse) .navbar-nav > li > a.is-active,
body.dv-has-top-navigation :is(.navbar-default, .navbar-inverse) .navbar-nav > li > a.is-active:hover,
body.dv-has-top-navigation :is(.navbar-default, .navbar-inverse) .navbar-nav > li > a.is-active:focus {
  color: var(--dv-top-nav-accent-gold, #de7c00);
  background-color: transparent;
}

/*
 * White primary nav: Montserrat Regular 18px on top-level links and all dropdown/flyout tiers.
 */
body.dv-has-top-navigation :is(.navbar-default, .navbar-inverse) .navbar-nav > li > a,
body.dv-has-top-navigation :is(.navbar-default, .navbar-inverse) .navbar-nav > li > a:visited,
body.dv-has-top-navigation :is(.navbar-default, .navbar-inverse) .menu.nav:not(.menu--diamond-vogel-top-navigation):not(.menu--diamond-vogel-navigation) > li > a,
body.dv-has-top-navigation :is(.navbar-default, .navbar-inverse) .menu.nav:not(.menu--diamond-vogel-top-navigation):not(.menu--diamond-vogel-navigation) > li > a:visited,
body.dv-has-top-navigation .menu--diamond-vogel-navigation.menu.nav > li > a,
body.dv-has-top-navigation .menu--diamond-vogel-navigation.menu.nav > li > a:visited,
body.dv-has-top-navigation #block-diamondvogelnavigation .menu.nav > li > a,
body.dv-has-top-navigation #block-diamondvogelnavigation .menu.nav > li > a:visited {
  font-family: var(--dv-font-family) !important;
  font-weight: 400 !important;
  font-size: var(--dv-primary-nav-link-size, 18px) !important;
}

body.dv-has-top-navigation :is(.navbar-default, .navbar-inverse) .navbar-nav .dropdown-menu li > a,
body.dv-has-top-navigation :is(.navbar-default, .navbar-inverse) .menu.nav:not(.menu--diamond-vogel-top-navigation):not(.menu--diamond-vogel-navigation) .dropdown-menu li > a,
body.dv-has-top-navigation .menu--diamond-vogel-navigation.menu.nav .dropdown-menu li > a,
body.dv-has-top-navigation #block-diamondvogelnavigation .menu.nav .dropdown-menu li > a {
  font-family: var(--dv-font-family) !important;
  font-weight: 400 !important;
  font-size: var(--dv-primary-nav-link-size, 18px) !important;
}

/* Suppress section-specific accent hovers when corporate top nav is present */
body.dv-has-top-navigation.path-frontpage :is(.navbar-default, .navbar-inverse) .navbar-nav > li > a:hover,
body.dv-has-top-navigation.path-frontpage :is(.navbar-default, .navbar-inverse) .navbar-nav > li > a:focus,
body.dv-has-top-navigation.path-frontpage :is(.navbar-default, .navbar-inverse) .navbar-nav > li > a.is-active,
body.dv-has-top-navigation.path-frontpage :is(.navbar-default, .navbar-inverse) .navbar-nav > li > a.is-active:hover,
body.dv-has-top-navigation.path-frontpage :is(.navbar-default, .navbar-inverse) .navbar-nav > li > a.is-active:focus,
body.dv-has-top-navigation.powder-coatings :is(.navbar-default, .navbar-inverse) .navbar-nav > li > a:hover,
body.dv-has-top-navigation.powder-coatings :is(.navbar-default, .navbar-inverse) .navbar-nav > li > a:focus,
body.dv-has-top-navigation.powder-coatings :is(.navbar-default, .navbar-inverse) .navbar-nav > li > a.is-active,
body.dv-has-top-navigation.powder-coatings :is(.navbar-default, .navbar-inverse) .navbar-nav > li > a.is-active:hover,
body.dv-has-top-navigation.powder-coatings :is(.navbar-default, .navbar-inverse) .navbar-nav > li > a.is-active:focus,
body.dv-has-top-navigation.liquid-coatings :is(.navbar-default, .navbar-inverse) .navbar-nav > li > a:hover,
body.dv-has-top-navigation.liquid-coatings :is(.navbar-default, .navbar-inverse) .navbar-nav > li > a:focus,
body.dv-has-top-navigation.liquid-coatings :is(.navbar-default, .navbar-inverse) .navbar-nav > li > a.is-active,
body.dv-has-top-navigation.liquid-coatings :is(.navbar-default, .navbar-inverse) .navbar-nav > li > a.is-active:hover,
body.dv-has-top-navigation.liquid-coatings :is(.navbar-default, .navbar-inverse) .navbar-nav > li > a.is-active:focus {
  color: var(--dv-top-nav-accent-gold, #de7c00);
  background-color: transparent !important;
}

/*
 * Desktop flyout panels (white dropdowns). Division sites use .navbar-nav for menu--main;
 * scoped to ≥992px so unified mobile (charcoal panel) is not overridden.
 */
@media screen and (min-width: 992px) {
body.dv-has-top-navigation :is(.navbar-default, .navbar-inverse) .navbar-nav .dropdown-menu {
  background-color: #fff;
  border: 1px solid rgba(0, 55, 99, 0.15);
  border-radius: 0;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.08);
}

/*
 * Architectural (+ .navbar-nav division menus): theme sets ul.dropdown-menu { width:100% }
 * (parent tab width only) and link backgrounds on <a> only. Size each panel to its
 * widest label (max-content), at least as wide as the tab, and stretch row hovers.
 */
body.dv-has-top-navigation header#navbar .navbar-nav ul.dropdown-menu {
  width: max-content !important;
  min-width: max(100%, 190px) !important;
  background-color: #fff !important;
}

body.dv-has-top-navigation header#navbar .navbar-nav .dropdown-menu > li > a {
  display: block !important;
  width: auto !important;
  min-width: 100% !important;
  box-sizing: border-box !important;
  white-space: nowrap;
}

/*
 * Default row: white panel + navy text. Use .dropdown-menu li > a (not li:hover ul li a)
 * so Architectural’s descendant hovers do not paint every row gray/beige.
 */
body.dv-has-top-navigation header#navbar .navbar-nav .dropdown-menu li > a {
  background-color: #fff !important;
  background: #fff !important;
  color: #003763 !important;
  border-left: none !important;
  border-right: none !important;
}

/*
 * Hovered submenu row: gold on the row link only (not ancestor rows while a nested flyout is open).
 * Beats Architectural .navbar-nav li:hover ul li:hover a { gray !important } (theme loads after).
 */
body.dv-has-top-navigation header#navbar .navbar-nav .dropdown-menu li > a:hover,
body.dv-has-top-navigation header#navbar .navbar-nav .dropdown-menu li > a:focus,
body.dv-has-top-navigation :is(.navbar-default, .navbar-inverse) .navbar-nav .dropdown-menu > li > a:hover,
body.dv-has-top-navigation :is(.navbar-default, .navbar-inverse) .navbar-nav .dropdown-menu > li > a:focus {
  background-color: rgba(0, 55, 99, 0.06) !important;
  background: rgba(0, 55, 99, 0.06) !important;
  color: var(--dv-top-nav-accent-gold, #de7c00) !important;
  border-left: none !important;
  border-right: none !important;
}

body.dv-has-top-navigation
  header#navbar
  .menu.nav:not(.menu--diamond-vogel-top-navigation):not(.menu--diamond-vogel-navigation)
  > li
  > ul.dropdown-menu
  > li
  > a,
/*
 * Open flyout: default rows only (not the hovered row). A rule on > li:hover … > li > a
 * beats gold hover because it adds an extra element chain; use :not(:hover) on the row.
 */
body.dv-has-top-navigation
  header#navbar
  .menu.nav:not(.menu--diamond-vogel-top-navigation):not(.menu--diamond-vogel-navigation)
  > li:hover
  > ul.dropdown-menu
  > li:not(:hover):not(.dv-submenu-hover)
  > a {
  background-color: #fff !important;
  color: #003763 !important;
}

body.dv-has-top-navigation
  header#navbar
  .menu.nav:not(.menu--diamond-vogel-top-navigation):not(.menu--diamond-vogel-navigation)
  > li:hover
  > ul.dropdown-menu
  > li:hover
  > a:hover,
body.dv-has-top-navigation
  header#navbar
  .menu.nav:not(.menu--diamond-vogel-top-navigation):not(.menu--diamond-vogel-navigation)
  > li:hover
  > ul.dropdown-menu
  > li:hover
  > a:focus,
body.dv-has-top-navigation
  header#navbar
  .menu.nav:not(.menu--diamond-vogel-top-navigation):not(.menu--diamond-vogel-navigation)
  > li:hover
  > ul.dropdown-menu
  > li.dv-submenu-hover
  > a:hover,
body.dv-has-top-navigation
  header#navbar
  .menu.nav:not(.menu--diamond-vogel-top-navigation):not(.menu--diamond-vogel-navigation)
  > li:hover
  > ul.dropdown-menu
  > li.dv-submenu-hover
  > a:focus,
body.dv-has-top-navigation
  header#navbar
  .menu.nav:not(.menu--diamond-vogel-top-navigation):not(.menu--diamond-vogel-navigation)
  .dropdown-menu
  > li:hover
  > a:hover,
body.dv-has-top-navigation
  header#navbar
  .menu.nav:not(.menu--diamond-vogel-top-navigation):not(.menu--diamond-vogel-navigation)
  .dropdown-menu
  > li:hover
  > a:focus,
body.dv-has-top-navigation
  header#navbar
  .menu.nav:not(.menu--diamond-vogel-top-navigation):not(.menu--diamond-vogel-navigation)
  .dropdown-menu
  > li
  > a:hover,
body.dv-has-top-navigation
  header#navbar
  .menu.nav:not(.menu--diamond-vogel-top-navigation):not(.menu--diamond-vogel-navigation)
  .dropdown-menu
  > li
  > a:focus {
  background-color: rgba(0, 55, 99, 0.06) !important;
  color: var(--dv-top-nav-accent-gold, #de7c00) !important;
}

/*
 * Nested flyout tiers: same default + gold hover as first column (rules above use
 * .dropdown-menu li at any depth). Only reset borders inherited from the theme.
 */
body.dv-has-top-navigation header#navbar .navbar-nav .dropdown-menu .dropdown-menu > li > a {
  border-left: none !important;
  border-right: none !important;
}

body.dv-has-top-navigation
  header#navbar
  .menu.nav:not(.menu--diamond-vogel-top-navigation):not(.menu--diamond-vogel-navigation)
  .dropdown-menu
  .dropdown-menu
  > li
  > a {
  background-color: #fff !important;
  color: #003763 !important;
}

body.dv-has-top-navigation
  header#navbar
  .menu.nav:not(.menu--diamond-vogel-top-navigation):not(.menu--diamond-vogel-navigation)
  .dropdown-menu
  .dropdown-menu
  > li:hover
  > a,
body.dv-has-top-navigation
  header#navbar
  .menu.nav:not(.menu--diamond-vogel-top-navigation):not(.menu--diamond-vogel-navigation)
  .dropdown-menu
  .dropdown-menu
  > li
  > a:hover,
body.dv-has-top-navigation
  header#navbar
  .menu.nav:not(.menu--diamond-vogel-top-navigation):not(.menu--diamond-vogel-navigation)
  .dropdown-menu
  .dropdown-menu
  > li
  > a:focus {
  background-color: rgba(0, 55, 99, 0.06) !important;
  color: var(--dv-top-nav-accent-gold, #de7c00) !important;
}

body.dv-has-top-navigation header#navbar .navbar-nav .dropdown-menu .dropdown-menu .dropdown-menu > li > a {
  background-color: #fff !important;
  color: #003763 !important;
  border-left: none !important;
  border-right: none !important;
}

body.dv-has-top-navigation
  header#navbar
  .navbar-nav
  .dropdown-menu
  .dropdown-menu
  .dropdown-menu
  > li:hover
  > a,
body.dv-has-top-navigation
  header#navbar
  .navbar-nav
  .dropdown-menu
  .dropdown-menu
  .dropdown-menu
  > li
  > a:hover,
body.dv-has-top-navigation
  header#navbar
  .navbar-nav
  .dropdown-menu
  .dropdown-menu
  .dropdown-menu
  > li
  > a:focus {
  background-color: rgba(0, 55, 99, 0.06) !important;
  color: var(--dv-top-nav-accent-gold, #de7c00) !important;
}

/* Themes using .menu.nav for primary links (not the fixed navy menu) */
body.dv-has-top-navigation :is(.navbar-default, .navbar-inverse) .menu.nav:not(.menu--diamond-vogel-top-navigation):not(.menu--diamond-vogel-navigation) > li > a,
body.dv-has-top-navigation :is(.navbar-default, .navbar-inverse) .menu.nav:not(.menu--diamond-vogel-top-navigation):not(.menu--diamond-vogel-navigation) > li > a:visited {
  color: #003763;
}

body.dv-has-top-navigation :is(.navbar-default, .navbar-inverse) .menu.nav:not(.menu--diamond-vogel-top-navigation):not(.menu--diamond-vogel-navigation) > li > a:hover,
body.dv-has-top-navigation :is(.navbar-default, .navbar-inverse) .menu.nav:not(.menu--diamond-vogel-top-navigation):not(.menu--diamond-vogel-navigation) > li > a:focus {
  color: var(--dv-top-nav-accent-gold, #de7c00);
}

/*
 * Toll (homepage-anchors primary nav): hash/front links often all get .is-active — keep
 * navy until hover; gold only on :hover/:focus (matches corporate white-bar UX).
 */
body.dv-has-top-navigation.dv-header-primary-homepage-anchors
  header#navbar
  .menu--homepage-anchors.navbar-nav
  > li
  > a.is-active:not(:hover):not(:focus) {
  color: #003763 !important;
  background-color: transparent !important;
}

/* Machine name diamond-vogel-navigation (when rendered as a system menu block) */
body.dv-has-top-navigation .menu--diamond-vogel-navigation.menu.nav > li > a,
body.dv-has-top-navigation .menu--diamond-vogel-navigation.menu.nav > li > a:visited {
  color: #003763;
}

body.dv-has-top-navigation .menu--diamond-vogel-navigation.menu.nav > li > a:hover,
body.dv-has-top-navigation .menu--diamond-vogel-navigation.menu.nav > li > a:focus,
body.dv-has-top-navigation .menu--diamond-vogel-navigation.menu.nav > li > a.is-active {
  color: var(--dv-top-nav-accent-gold, #de7c00);
}

body.dv-has-top-navigation .menu--diamond-vogel-navigation.menu.nav .dropdown-menu {
  background-color: #fff;
  border: 1px solid rgba(0, 55, 99, 0.15);
  border-radius: 0;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.08);
}

body.dv-has-top-navigation .menu--diamond-vogel-navigation.menu.nav .dropdown-menu > li > a {
  color: #003763;
}

body.dv-has-top-navigation .menu--diamond-vogel-navigation.menu.nav .dropdown-menu > li > a:hover,
body.dv-has-top-navigation .menu--diamond-vogel-navigation.menu.nav .dropdown-menu > li:hover > a,
body.dv-has-top-navigation .menu--diamond-vogel-navigation.menu.nav .dropdown-menu > li > a:focus {
  background-color: rgba(0, 55, 99, 0.06);
  color: var(--dv-top-nav-accent-gold, #de7c00);
}

body.dv-has-top-navigation .menu--diamond-vogel-navigation.menu.nav .open > a,
body.dv-has-top-navigation .menu--diamond-vogel-navigation.menu.nav .open > a:hover,
body.dv-has-top-navigation .menu--diamond-vogel-navigation.menu.nav .open > a:focus {
  background-color: transparent;
  border-color: transparent;
  color: #003763;
}

body.dv-has-top-navigation header#navbar .dropdown-menu .dropdown-menu {
  position: absolute;
  top: 0;
  left: 100%;
  right: auto !important;
  margin-top: 0;
  margin-left: 1px;
  width: max-content !important;
  min-width: max(100%, 190px) !important;
}

body.dv-has-top-navigation #block-diamondvogelnavigation .menu.nav .dropdown-menu .dropdown-menu {
  left: 100%;
  right: auto !important;
}

} /* min-width: 992px — desktop flyout dropdowns */

/*
 * Multi-level menus (grandchildren and deeper): Bootstrap 3 navbar markup only
 * documents one dropdown tier. Nested <ul class="dropdown-menu"> lists default to
 * the same coordinates as the first panel or inherit theme rules like
 * #block-diamondvogelnavigation … .dropdown-menu { right: 0 }, which pins every
 * tier incorrectly. Establish flyout positioning and clipping so unlimited depth
 * from the menu block can render.
 */
body.dv-has-top-navigation header#navbar .navbar-collapse,
body.dv-has-top-navigation header#navbar .navbar-collapse.collapse {
  overflow-y: visible !important;
}

body.dv-has-top-navigation header#navbar .dropdown-menu > li {
  position: relative;
}

/*
 * Mobile / tablet collapsed nav: stack nested tiers in-flow (not flyouts off-screen).
 */
@media screen and (max-width: 991px) {
  /*
   * Hub uses .menu--diamond-vogel-navigation; division themes use .navbar-nav / menu--main.
   * Force every open tier visible in the collapsed drawer.
   */
  body.dv-has-top-navigation
    header#navbar
    #navbar-collapse
    :is(
      .menu--diamond-vogel-navigation.nav,
      .navbar-nav,
      .menu--main.menu.nav,
      .menu--homepage-anchors.menu.nav
    )
    li.open
    > ul.dropdown-menu,
  body.dv-has-top-navigation
    header#navbar
    #navbar-collapse
    :is(
      .menu--diamond-vogel-navigation.nav,
      .navbar-nav,
      .menu--main.menu.nav,
      .menu--homepage-anchors.menu.nav
    )
    li.dropdown.open
    > ul.dropdown-menu {
    display: block !important;
    visibility: visible !important;
    opacity: 1 !important;
    clip: auto !important;
    pointer-events: auto !important;
  }

  body.dv-has-top-navigation.dv-mobile-menu-unified
    header#navbar
    .dropdown-menu
    .dropdown-menu {
    border-left-color: rgba(255, 255, 255, 0.3) !important;
    background: transparent !important;
    background-color: transparent !important;
  }

  /*
   * First-tier dropdown under the collapsed nav: Bootstrap defaults to absolute;
   * theme rules pin right:0 — stack full-width in-flow so panels don’t float over
   * sibling tabs (matches nested tiers below).
   */
  body.dv-has-top-navigation
    header#navbar
    #navbar-collapse
    :is(
      .menu--diamond-vogel-navigation.nav,
      .navbar-nav,
      .menu--main.menu.nav,
      .menu--homepage-anchors.menu.nav
    )
    > li
    > .dropdown-menu {
    position: static !important;
    left: auto !important;
    right: auto !important;
    top: auto !important;
    float: none !important;
    width: 100% !important;
    margin: 0 !important;
    padding: 0.35rem 0 0.35rem 0.5rem !important;
    box-shadow: none !important;
    border: 0 !important;
    border-left: 2px solid rgba(0, 55, 99, 0.15) !important;
    border-radius: 0 !important;
  }

  body.dv-has-top-navigation.dv-mobile-menu-unified
    header#navbar
    #navbar-collapse
    :is(
      .menu--diamond-vogel-navigation.nav,
      .navbar-nav,
      .menu--main.menu.nav,
      .menu--homepage-anchors.menu.nav,
      #block-diamondvogelnavigation .menu.nav
    )
    > li
    > .dropdown-menu {
    border-left-color: rgba(255, 255, 255, 0.3) !important;
    background: transparent !important;
    background-color: transparent !important;
  }

  body.dv-has-top-navigation
    header#navbar
    #navbar-collapse
    #block-diamondvogelnavigation
    .menu.nav
    > li
    + li::before {
    display: none !important;
  }

  /*
   * Any nested panel under the primary bar (2nd tier and deeper): in-flow stack.
   * Selector matches unlimited depth (descendant .dropdown-menu inside .dropdown-menu).
   */
  body.dv-has-top-navigation header#navbar .dropdown-menu .dropdown-menu {
    position: static !important;
    left: auto !important;
    right: auto !important;
    top: auto !important;
    float: none !important;
    width: 100% !important;
    min-width: 0 !important;
    margin: 0 !important;
    padding: 0.25rem 0 0.25rem 0.75rem !important;
    border: 0 !important;
    border-left: 2px solid rgba(0, 55, 99, 0.2) !important;
    border-radius: 0 !important;
    box-shadow: none !important;
  }

  body.dv-has-top-navigation header#navbar .dropdown-menu > li {
    float: none !important;
  }

  body.dv-has-top-navigation header#navbar .dropdown-menu li.dropdown {
    position: static !important;
  }

  /* Keep nested tiers visible once opened (BS3 + theme rules can leave panels hidden). */
  body.dv-has-top-navigation header#navbar .dropdown-menu li.open > ul.dropdown-menu,
  body.dv-has-top-navigation header#navbar .dropdown-menu li.dropdown.open > ul.dropdown-menu {
    display: block !important;
    visibility: visible !important;
    height: auto !important;
    max-height: none !important;
    overflow: visible !important;
  }

  body.dv-has-top-navigation header#navbar .dropdown-menu > li.dv-has-nested-submenu > a .caret.dv-nested-submenu-caret {
    transform: none;
    border-left: 4px solid transparent;
    border-right: 4px solid transparent;
    border-top: 4px solid #003763;
    border-bottom: 0;
    margin-left: 0.35rem;
    vertical-align: middle;
  }

  body.dv-has-top-navigation.dv-mobile-menu-unified
    header#navbar
    .dropdown-menu
    > li.dv-has-nested-submenu
    > a
    .caret.dv-nested-submenu-caret,
  body.dv-has-top-navigation.dv-mobile-menu-unified
    header#navbar
    .dropdown-menu
    .dropdown-menu
    li.dv-has-nested-submenu
    > a
    .caret.dv-nested-submenu-caret {
    border-top-color: var(--dv-mobile-menu-top-link, #fff) !important;
  }
}

/*
 * Nested flyout rows: same Bootstrap <span class="caret"> as top-level tabs
 * (injected as .caret.dv-nested-submenu-caret in dv-top-navigation.js).
 */
body.dv-has-top-navigation header#navbar .dropdown-menu > li.dv-has-nested-submenu > a {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 0.35rem;
}

body.dv-has-top-navigation header#navbar .dropdown-menu > li.dv-has-nested-submenu > a .caret {
  flex-shrink: 0;
  display: inline-block;
  border-top-color: #003763;
  opacity: 0.75;
  /* Bootstrap .caret points down; rotate so nested flyouts read “opens to the side”. */
  transform: rotate(-90deg);
  transform-origin: center;
}

body.dv-has-top-navigation header#navbar .dropdown-menu > li.dv-submenu-hover > a .caret,
body.dv-has-top-navigation header#navbar .dropdown-menu > li.dv-has-nested-submenu:hover > a .caret {
  opacity: 1;
}

/*
 * Desktop (≥992px): primary + nested panels open on hover; JS strips data-toggle
 * so hover CSS is not fighting Bootstrap click state. ≤991px uses Bootstrap taps.
 *
 * Do not require li.dropdown: Bootstrap menu.html.twig only adds "dropdown" when
 * the link is marked "Show as expanded"; children still render for other parents,
 * so those items need li:hover > ul.dropdown-menu instead (staging/local parity).
 */
@media screen and (min-width: 992px) {
  /*
   * Corporate: gold on the top-level tab link only — not while the pointer is on submenu rows
   * (li:hover > a would keep the parent highlighted inside the dropdown panel).
   */
  body.dv-has-top-navigation header#navbar .navbar-nav > li > a:hover,
  body.dv-has-top-navigation header#navbar .navbar-nav > li > a:focus,
  body.dv-has-top-navigation
    header#navbar
    .menu.nav:not(.menu--diamond-vogel-top-navigation):not(.menu--diamond-vogel-navigation)
    > li > a:hover,
  body.dv-has-top-navigation
    header#navbar
    .menu.nav:not(.menu--diamond-vogel-top-navigation):not(.menu--diamond-vogel-navigation)
    > li > a:focus {
    color: var(--dv-top-nav-accent-gold, #de7c00) !important;
    background-color: transparent !important;
    text-decoration: underline;
  }

  body.dv-has-top-navigation header#navbar .navbar-nav > li.open > a,
  body.dv-has-top-navigation
    header#navbar
    .menu.nav:not(.menu--diamond-vogel-top-navigation):not(.menu--diamond-vogel-navigation)
    > li.open
    > a {
    color: var(--dv-top-nav-accent-gold, #de7c00) !important;
    background-color: transparent !important;
    text-decoration: underline;
  }

  body.dv-has-top-navigation header#navbar .navbar-nav > li,
  body.dv-has-top-navigation header#navbar .menu.nav:not(.menu--diamond-vogel-top-navigation):not(.menu--diamond-vogel-navigation) > li {
    position: relative;
  }

  /*
   * Top-level tabs only: open first panel immediately on hover.
   * Nested rows use .dv-submenu-hover from dv-top-navigation.js (short delay) so
   * users hover the child row before its submenu opens.
   */
  body.dv-has-top-navigation header#navbar .navbar-nav > li:hover > ul.dropdown-menu,
  body.dv-has-top-navigation
    header#navbar
    .menu.nav:not(.menu--diamond-vogel-top-navigation):not(.menu--diamond-vogel-navigation)
    > li:hover
    > ul.dropdown-menu {
    display: block !important;
    margin-top: 0;
  }

  body.dv-has-top-navigation header#navbar .dropdown-menu > li.dv-submenu-hover > ul.dropdown-menu {
    display: block !important;
    margin-top: 0;
  }

  /*
   * Global: some themes use ul.nav li.dropdown:hover ul.dropdown-menu (descendant),
   * which opens every nested tier while the pointer is anywhere under the tab.
   * Keep deeper panels closed until .dv-submenu-hover is set on that row.
   *
   * Apply at every depth: do not require ul.nav li.dropdown — nested tiers sit under
   * .dropdown-menu > li that may omit the dropdown class; scoping only under the
   * first top-level panel left depth-3+ flyouts stuck closed.
   */
  body.dv-has-top-navigation
    header#navbar
    .dropdown-menu
    > li:not(.dv-submenu-hover)
    > ul.dropdown-menu {
    display: none !important;
  }

  /*
   * Explicit first-tier panel when li.dropdown is hovered (beats descendant-only rules).
   */
  body.dv-has-top-navigation header#navbar ul.nav li.dropdown:hover > ul.dropdown-menu {
    display: block !important;
    margin-top: 0;
  }

  body.dv-has-top-navigation header#navbar .navbar-nav > li:hover,
  body.dv-has-top-navigation header#navbar .menu.nav:not(.menu--diamond-vogel-top-navigation):not(.menu--diamond-vogel-navigation) > li:hover {
    z-index: 490;
  }

  body.dv-has-top-navigation header#navbar .dropdown-menu li:hover,
  body.dv-has-top-navigation header#navbar .dropdown-menu li.dv-submenu-hover {
    z-index: 500;
  }

  /*
   * Nested flyouts: when the pointer is in a deeper panel, keep the parent row link navy
   * (.dv-submenu-hover stays for panel open; gold is only on > a:hover above).
   */
  body.dv-has-top-navigation header#navbar .dropdown-menu > li:has(> ul.dropdown-menu:hover) > a:not(:hover):not(:focus),
  body.dv-has-top-navigation
    header#navbar
    .menu.nav:not(.menu--diamond-vogel-top-navigation):not(.menu--diamond-vogel-navigation)
    .dropdown-menu
    > li:has(> ul.dropdown-menu:hover)
    > a:not(:hover):not(:focus) {
    background-color: #fff !important;
    background: #fff !important;
    color: #003763 !important;
    border-left: none !important;
    border-right: none !important;
  }
}

/* -----------------------------------------------------------------------------
 * Search results experience: normalize layout/controls across division sites.
 * Baseline matches Architectural + Industrial spacing and CTA treatment.
 * -------------------------------------------------------------------------- */
body.path-search .main-container,
body.path-search-node .main-container {
  background-color: #fff;
  color: #333;
}

body.path-search .main-container .page-header,
body.path-search .main-container h1,
body.path-search-node .main-container .page-header,
body.path-search-node .main-container h1 {
  color: #003763;
  margin-bottom: 20px;
  border-left: 0 !important;
  padding-left: 0;
  padding-top: 0;
}

/* Match Architectural search page: remove duplicate in-content search form block. */
body.path-search .region-content > form.search-form,
body.path-search-node .region-content > form.search-form,
body.path-search .region-content > .search-help-link,
body.path-search-node .region-content > .search-help-link {
  display: none !important;
}

body.path-search .region-content form.search-form,
body.path-search-node .region-content form.search-form,
body.path-search .region-content .search-help-link,
body.path-search-node .region-content .search-help-link {
  display: none !important;
}

/* Align /search/node heading and helper copy to Architectural search page pattern. */
body.path-search .region-content > .page-header {
  color: #003763;
  font-family: var(--dv-font-family, 'Montserrat', sans-serif);
  font-size: 32px;
  font-weight: 700;
  line-height: 1.2;
  margin-bottom: 20px;
  visibility: hidden;
  position: relative;
}

body.path-search .region-content > .page-header::after {
  content: "Search Results";
  visibility: visible;
  position: absolute;
  inset: 0 auto auto 0;
}

body.path-search-node .region-content > .page-header {
  color: #003763;
  font-family: var(--dv-font-family, 'Montserrat', sans-serif);
  font-size: 32px;
  font-weight: 700;
  line-height: 1.2;
  margin-bottom: 20px;
  visibility: hidden;
  position: relative;
}

body.path-search-node .region-content > .page-header::after {
  content: "Search Results";
  visibility: visible;
  position: absolute;
  inset: 0 auto auto 0;
}

/* Robust title normalization: some themes render page title outside .region-content. */
body.path-search h1.page-header,
body.path-search-node h1.page-header {
  visibility: hidden;
  position: relative;
}

body.path-search h1.page-header::after,
body.path-search-node h1.page-header::after {
  content: "Search Results";
  visibility: visible;
  position: absolute;
  inset: 0 auto auto 0;
  color: #003763;
  font-family: var(--dv-font-family, 'Montserrat', sans-serif);
  font-size: 32px;
  font-weight: 700;
  line-height: 1.2;
}

/* Keep a single visible results title (Architectural-style). */
body.path-search .region-content > h2,
body.path-search-node .region-content > h2 {
  display: none !important;
}

body.path-search .region-content > p:first-of-type {
  display: none !important;
}

body.path-search-node .region-content > p:first-of-type {
  display: none !important;
}

body.path-search #views-exposed-form-search-page-1 input,
body.path-search #search-form input[type="search"],
body.path-search #search-form input[type="text"],
body.path-search-node #views-exposed-form-search-page-1 input,
body.path-search-node #search-form input[type="search"],
body.path-search-node #search-form input[type="text"] {
  border-radius: 0;
  margin: 0;
}

body.path-search #views-exposed-form-search-page-1 .btn,
body.path-search #search-form .form-submit,
body.path-search #search-form input[type="submit"],
body.path-search-node #views-exposed-form-search-page-1 .btn,
body.path-search-node #search-form .form-submit,
body.path-search-node #search-form input[type="submit"] {
  background-color: #e27c00;
  border-color: #d16c00;
  border-radius: 0;
  color: #fff;
  text-transform: uppercase;
}

body.path-search .view-search .view-content,
body.path-search .view-search .view-empty,
body.path-search .search-results,
body.path-search-node .view-search .view-content,
body.path-search-node .view-search .view-empty,
body.path-search-node .search-results {
  margin: 30px 0;
}

body.path-search ol.search-results,
body.path-search .search-results,
body.path-search-node ol.search-results,
body.path-search-node .search-results,
body.path-search-node .region-content > ol,
body.path-search .region-content > ol {
  list-style: none !important;
  list-style-type: none !important;
  padding-left: 0;
  counter-reset: none !important;
}

body.path-search .view-search .views-row,
body.path-search .search-results > li,
body.path-search-node .view-search .views-row,
body.path-search-node .search-results > li,
body.path-search-node .region-content > ol > li,
body.path-search .region-content > ol > li {
  margin: 0 0 20px;
  list-style: none !important;
  list-style-type: none !important;
  counter-increment: none !important;
}

body.path-search ol.search-results > li,
body.path-search-node ol.search-results > li {
  list-style: none !important;
  list-style-type: none !important;
}

body.path-search .search-results > li::marker,
body.path-search-node .search-results > li::marker,
body.path-search ol.search-results > li::marker,
body.path-search-node ol.search-results > li::marker,
body.path-search-node .region-content > ol > li::marker,
body.path-search .region-content > ol > li::marker {
  content: "" !important;
  display: none !important;
}

body.path-search .search-results > li::before,
body.path-search-node .search-results > li::before,
body.path-search-node .region-content > ol > li::before,
body.path-search .region-content > ol > li::before,
body.path-search .search-results h3::before,
body.path-search-node .search-results h3::before,
body.path-search-node .region-content > ol h3::before,
body.path-search .region-content > ol h3::before,
body.path-search .search-results h3 a::before,
body.path-search-node .search-results h3 a::before,
body.path-search-node .region-content > ol h3 a::before,
body.path-search .region-content > ol h3 a::before {
  content: none !important;
  display: none !important;
}

body.path-search .view-search .views-field-title,
body.path-search .search-results h3,
body.path-search-node .view-search .views-field-title,
body.path-search-node .search-results h3,
body.path-search-node .region-content > ol h3,
body.path-search .region-content > ol h3 {
  font-family: var(--dv-font-family, 'Montserrat', sans-serif);
  font-size: 16px !important;
  font-weight: 700 !important;
  line-height: 1.3;
  margin: 0 0 8px;
}

/* Search result title links (Industrial /search reference). */
body.path-search .view-search .views-field-title a,
body.path-search-node .view-search .views-field-title a,
body.path-search .search-results h3 a,
body.path-search-node .search-results h3 a,
body.path-search .region-content > ol h3 a,
body.path-search-node .region-content > ol h3 a {
  color: #0066cc;
  text-decoration: none;
}

body.path-search .view-search .views-field-title a:hover,
body.path-search-node .view-search .views-field-title a:hover,
body.path-search .view-search .views-field-title a:focus,
body.path-search-node .view-search .views-field-title a:focus,
body.path-search .search-results h3 a:hover,
body.path-search-node .search-results h3 a:hover,
body.path-search .search-results h3 a:focus,
body.path-search-node .search-results h3 a:focus,
body.path-search .region-content > ol h3 a:hover,
body.path-search-node .region-content > ol h3 a:hover,
body.path-search .region-content > ol h3 a:focus,
body.path-search-node .region-content > ol h3 a:focus {
  color: #004c99;
  text-decoration: underline;
}

/* Excerpt / snippet. */
body.path-search .view-search .views-field-search-api-excerpt,
body.path-search-node .view-search .views-field-search-api-excerpt,
body.path-search .search-result__snippet,
body.path-search-node .search-result__snippet,
body.path-search .search-results p.search-result__snippet,
body.path-search-node .search-results p.search-result__snippet,
body.path-search .region-content > ol > li > p.search-result__snippet,
body.path-search-node .region-content > ol > li > p.search-result__snippet {
  color: #333;
  font-size: 15px;
  line-height: 1.5;
  margin: 0 0 6px;
}

body.path-search .view-search .views-field-search-api-excerpt strong,
body.path-search-node .view-search .views-field-search-api-excerpt strong,
body.path-search .search-result__snippet strong,
body.path-search-node .search-result__snippet strong {
  font-weight: 700;
  color: #111;
}

/* Date/time row (Search API created field + core node search). */
body.path-search .view-search .views-field-created,
body.path-search-node .view-search .views-field-created,
body.path-search .view-search .views-field-created .field-content,
body.path-search-node .view-search .views-field-created .field-content,
body.path-search .search-result__date,
body.path-search-node .search-result__date {
  color: #333;
  font-size: 15px;
  line-height: 1.5;
  margin: 0;
}

body.path-search .region-content > ol > li > p:empty,
body.path-search-node .region-content > ol > li > p:empty {
  display: none;
  margin: 0;
}

/*
 * Vogel Custom + unified mobile: beat global primary-link navy (§1825) and theme
 * .navbar-default .navbar-collapse { transparent }.
 */
@media screen and (max-width: 991px) {
  body.dv-has-top-navigation.dv-mobile-menu-unified.dv-header-primary-homepage-anchors
    #navbar
    .navbar-collapse.collapse.in,
  body.dv-has-top-navigation.dv-mobile-menu-unified.dv-header-primary-homepage-anchors
    #navbar
    .navbar-collapse.collapsing {
    background-color: var(--dv-mobile-menu-panel-bg) !important;
  }

  body.dv-mobile-menu-unified.dv-header-primary-homepage-anchors
    #navbar-collapse
    .menu--homepage-anchors.menu.nav.navbar-nav
    > li
    > a,
  body.dv-mobile-menu-unified.dv-header-primary-homepage-anchors
    #navbar-collapse
    .menu--homepage-anchors.menu.nav.navbar-nav
    > li
    > a:visited,
  body.dv-mobile-menu-unified.dv-header-primary-homepage-anchors
    #navbar-collapse
  :is(.navbar-default, .navbar-inverse)
    .menu--homepage-anchors.menu.nav
    > li
    > a {
    color: var(--dv-mobile-menu-secondary-link) !important;
  }
}

/*
 * Vogel Paint legacy .menu.nav { position:absolute; right:0 } pins wrapped rows to the
 * right edge (row 2 wider → starts left of row 1). Force left-aligned flex rows.
 */
@media screen and (min-width: 992px) {
  body.dv-has-top-navigation header#navbar #block-diamondvogelnavigation,
  body.dv-has-top-navigation header#navbar #block-diamondvogelnavigation .diamond-vogel-menu,
  body.dv-has-top-navigation header#navbar #block-diamondvogelnavigation .diamond-vogel-menu .container {
    width: 100% !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    justify-content: flex-start !important;
    text-align: left !important;
  }

  body.dv-has-top-navigation header#navbar #block-diamondvogelnavigation .menu.nav,
  body.dv-has-top-navigation header#navbar .menu--diamond-vogel-navigation.menu.nav {
    position: static !important;
    right: auto !important;
    left: auto !important;
    top: auto !important;
    float: none !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    width: 100% !important;
    max-width: 100% !important;
    justify-content: flex-start !important;
    align-content: flex-start !important;
  }
}
