@charset "UTF-8";

/* Hoogtes sticky bars
   LET OP: de echte waarden voor --topbar-h en --navbar-h
   worden nu gezet in menu.inc.php via CSS-variabelen.
   Hier doen we alleen nog de optelsom. */
:root {
  --sticky-offset: calc(var(--topbar-h) + var(--navbar-h));
}

/* Forceer horizontale weergave zodra we ≥ lg zijn (failsafe na resize) */
@media (min-width: 992px) {
  #site-navbar .navbar-nav {
    flex-direction: row !important;
  }

  #site-navbar .navbar-nav .nav-item {
    display: flex;
    align-items: center;
  }
}

/* Hover feedback in offcanvas (alleen op devices met muis) */
@media (hover: hover) and (pointer: fine) {
  .offcanvas .nav-link:hover,
  .offcanvas .dropdown-item:hover {
    background-color: var(--bs-secondary-bg) !important;
  }
}

/* --------------------------------------------------
   TOPBAR (smalle balk bovenin)
-------------------------------------------------- */
.topbar {
  font-family: var(--font1); /* uit database */
  background-color: var(--basiskleureen) !important; /* uit database */
  font-size: var(--fontsize1); /* uit database */
  line-height: var(--topbar-h);
  height: var(--topbar-h);
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  z-index: 1032;
}

.topbar .container,
.topbar .container-xxl,
.topbar .container-fluid {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 2rem;
}

.topbar a {
  font-family: var(--font1); /* uit database */
  color: var(--basiskleurtwee) !important; /* uit database */
  background-color: var(--basiskleurdrie) !important; /* uit database */
  text-decoration: none;
  transition: color 0.2s ease, background-color 0.2s ease;
}

.topbar a:hover {
  color: var(--basiskleurvier) !important; /* uit database */
  background-color: var(--basiskleurvijf) !important; /* uit database */
}

.topbar .topbar-text {
  font-family: var(--font1); /* uit database */
  color: var(--basiskleurtwee) !important; /* uit database */
  text-decoration: none;
}

/* --------------------------------------------------
   NAVBAR Menu (normaal in flow, niet sticky)
-------------------------------------------------- */

/* verwijder standaard caret van BS */
.dropdown-toggle::after {
  display: none !important;
}

.navbar {
  font-family: var(--font2); /* uit database */
  font-size: var(--fontsize2); /* uit database */
  background-color: var(--basiskleurzes) !important; /*uit database */
  position: fixed;
  left: 0;
  width: 100%;
  z-index: 1031;
  backdrop-filter: none;
  padding-top: 0.25rem;
  padding-bottom: 0.25rem;
  transition: none;
  top: 0;
  --bs-navbar-active-color: var(--basiskleurzeven);
}

/* specifieke hoofdnavbar (site-navbar) gebruikt CMS-hoogte */
#site-navbar {
  min-height: var(--navbar-h);
}

/* vanaf md (≥768px) de navbar onder de topbar positioneren o.b.v. variabele */
@media (min-width: 768px) {
  .navbar {
    top: var(--topbar-h);
  }
}

/* vanaf desktop (≥992px): bij scroll (navbar--raised) mag de balk echt lager worden */
@media (min-width: 992px) {
  #site-navbar.navbar--raised {
    min-height: calc(var(--navbar-h) * 0.5);
  }
}

/* hamburger button clean */
.navbar-toggler {
  border: none;
  outline: none;
  box-shadow: none;
}

/* hoofdnavigatie (desktop) */
.navbar-nav {
  font-family: var(--font2); /* uit database */
  font-size: var(--fontsize2); /* uit database */
  color: var(--basiskleurdrie) !important; /* uit database */
  padding: 0;
  font-weight: 600;
  font-variation-settings: "wdth" 100;
  display: flex;
  gap: 1rem;
}

/* gewone nav-items (desktop) */
.nav-item a:not(.btn1):not(.btn2):not(.btn3) {
  color: var(--basiskleurzeven) !important; /*uit database */
  background-color: var(--basiskleuracht) !important; /* uit database */
  text-decoration: none;
  transition: color 0.3s, background-color 0.2s;
  border-radius: 0rem;
  padding: 0.35rem 0.6rem;
}

.nav-item a:not(.btn1):not(.btn2):not(.btn3):hover {
  color: var(--basiskleurnegen) !important; /*uit database */
  background-color: var(--basiskleurtien) !important; /*uit database */
}

/* active state gewone menu-items */
.nav-item a.active:not(.btn1):not(.btn2):not(.btn3),
.nav-item.active a:not(.btn1):not(.btn2):not(.btn3) {
  font-weight: bold;
  color: var(--basiskleurelf) !important; /*uit database */
  background-color: var(--basiskleurtwaalf) !important; /*uit database */
}

/* kleinere caret achter hoofditem (draait bij hover/open) */
.nav-item .dropdown-caret {
  display: inline-block;
  font-size: 0.85em;
  line-height: 1;
  transition: transform 0.32s ease;
  transform-origin: 50% 45%;
  vertical-align: middle;
  margin-left: 0.35rem;
}

.nav-item.dropdown:hover .dropdown-caret,
.nav-item.dropdown.show .dropdown-caret {
  transform: rotate(180deg);
}

/* focusring weg */
.navbar .nav-link:focus,
.navbar .nav-link:focus-visible,
.navbar .nav-link.dropdown-toggle:focus,
.navbar .nav-link.dropdown-toggle:focus-visible,
.dropdown-menu .dropdown-item:focus,
.dropdown-menu .dropdown-item:focus-visible,
.navbar-toggler:focus,
.navbar-toggler:focus-visible {
  outline: none !important;
  box-shadow: none !important;
}

/* --------------------------------------------------
   DROPDOWN (desktop)
-------------------------------------------------- */

/* Hover-bridge: buffer houdt hover actief tussen toggle en menu */
.nav-item.dropdown {
  position: relative;
}

.nav-item.dropdown::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  top: 100%;
  height: 10px;
  pointer-events: none;
}

.dropdown-menu {
  color: var(--basiskleurvierenveertig) !important; /*uit database */
  background-color: var(--basiskleurdrieenveertig) !important; /*uit database */
  min-width: 16.5rem;
  padding: 0;
  font-size: 1rem;
  border: 1px solid rgba(0, 0, 0, 0.08);
  border-radius: 0rem;
  box-shadow: 0 12px 28px rgba(0, 0, 0, 0.12);
  overflow: hidden;
  margin-top: 0;
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.42s ease, visibility 0s linear 0.42s;
  pointer-events: none;
  z-index: 1000;
}

.dropdown-menu a.dropdown-item {
  color: var(--basiskleurvierenveertig) !important; /*uit database */
  background-color: var(--basiskleurvijfenveertig) !important; /*uit database */
  padding: 0.65rem 1rem;
  border-radius: 0;
  transition: background-color 0.15s ease;
}

.dropdown-menu a.dropdown-item:not(:first-child) {
  border-top: 1px solid rgba(0, 0, 0, 0.08);
}

.dropdown-menu a.dropdown-item:hover {
  color: var(--basiskleurzesenveertig) !important; /*uit database */
  background-color: var(--basiskleurzevenenveertig) !important; /*uit database */
}

/* tonen bij hover/open */
.dropdown:hover > .dropdown-menu,
.dropdown.show > .dropdown-menu {
  opacity: 1;
  visibility: visible;
  transition: opacity 0.42s ease, visibility 0s linear 0s;
  pointer-events: auto;
}

/* --------------------------------------------------
   Mobiele menu (offcanvas) — strakker en moderner
-------------------------------------------------- */

/* VOLLE breedte offcanvas */
#offcanvasNavbar {
  --bs-offcanvas-width: 100vw;
}

@media (max-width: 991.98px) {
  .offcanvas-body {
    background-color: var(--basiskleurtweeenveertig) !important;
    padding: 1.25rem 1.5rem 1.75rem 1.5rem;
  }

  /* hoofdmenublok */
  .offcanvas-body > .list-unstyled:first-of-type {
    margin: 0 0 1.25rem 0;
    padding: 0;
    overflow: hidden;
    color: var(--basiskleurvijfenvijftig) !important;
    background-color: rgba(255, 255, 255, 0.10);
    border: 1px solid rgba(255, 255, 255, 0.15);
    border-radius: 1rem;
  }

  .offcanvas-body > .list-unstyled:first-of-type > li.nav-item {
    margin: 0;
    border-radius: 0;
    overflow: hidden;
    color: var(--basiskleurvijfenvijftig) !important;
  }

  .offcanvas-body > .list-unstyled:first-of-type > li.nav-item + li.nav-item {
    border-top: 1px solid rgba(255, 255, 255, 0.08);
  }

  .offcanvas-body > .list-unstyled:first-of-type > li.nav-item > a {
    display: flex;
    align-items: center;
    justify-content: space-between;
    width: 100%;
    min-height: 48px;
    padding: 0.7rem 0.9rem;
    background: transparent !important;
    color: var(--basiskleurvijfenvijftig) !important;
    text-decoration: none;
    border-radius: 0;
    transition: background-color 0.2s ease, color 0.2s ease, padding-left 0.2s ease;
  }

  .offcanvas-body > .list-unstyled:first-of-type > li.nav-item > a:hover {
    color: var(--basiskleurzesenvijftig) !important;
    background-color: rgba(255, 255, 255, 0.04) !important;
    padding-left: 1.15rem;
  }

  .offcanvas-body .nav-item.active > a,
  .offcanvas-body .nav-item > a.active {
    color: var(--basiskleurvijfenvijftig) !important;
    font-weight: 700;
    background-color: rgba(255, 255, 255, 0.08) !important;
  }

  .offcanvas-body .nav-item.dropdown > a .dropdown-caret {
    display: inline-block;
    font-size: 0.85em;
    line-height: 1;
    margin-left: 0.5rem;
    transition: transform 0.32s ease;
    transform-origin: 50% 45%;
  }

  .offcanvas-body .nav-item.dropdown.show > a .dropdown-caret,
  .offcanvas-body .nav-item.dropdown.open > a .dropdown-caret,
  .offcanvas-body .nav-item.dropdown[aria-expanded="true"] > a .dropdown-caret {
    transform: rotate(180deg);
  }

  .offcanvas-body .sub-menu {
    background-color: transparent !important;
    border: none;
    box-shadow: none;
    margin: 0 0 0.4rem 0.9rem;
    padding: 0.35rem 0 0.15rem 0.85rem;
    border-left: 2px solid rgba(255, 255, 255, 0.12);
    overflow: hidden;
    max-height: 0;
    opacity: 0;
    transition: max-height 0.35s ease, opacity 0.35s ease;
  }

  .offcanvas-body .nav-item.dropdown.show > .sub-menu,
  .offcanvas-body .nav-item.dropdown.open > .sub-menu {
    max-height: 1200px;
    opacity: 1;
    background: transparent !important;
  }

  .offcanvas-body .sub-menu li.nav-item {
    border-top: 0 !important;
  }

  .offcanvas-body .sub-menu li.nav-item a {
    display: block;
    padding: 0.7rem 0.9rem;
    color: var(--basiskleurvijfenvijftig) !important;
    text-decoration: none;
    background: transparent !important;
    border-radius: 0.5rem;
    transition: background-color 0.15s ease, color 0.15s ease, padding-left 0.2s ease;
  }

  .offcanvas-body .sub-menu li.nav-item a:not(:first-child) {
    border-top: 0;
  }

  .offcanvas-body .sub-menu li.nav-item a:hover {
    background-color: rgba(255, 255, 255, 0.05) !important;
    padding-left: 1.05rem;
  }

  /* onderste blok(ken) */
  .offcanvas-body > .list-unstyled:not(:first-of-type) {
    margin: 1.25rem 0 0 0;
    padding: 0;
    overflow: hidden;
    color: var(--basiskleurvijfenvijftig) !important;
    background-color: rgba(255, 255, 255, 0.04);
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-radius: 1rem;
  }

  .offcanvas-body > .list-unstyled:not(:first-of-type) > li.nav-item,
  .offcanvas-body > .list-unstyled:not(:first-of-type) > li {
    margin: 0;
  }

  .offcanvas-body > .list-unstyled:not(:first-of-type) > li + li {
    border-top: 1px solid rgba(255, 255, 255, 0.08);
  }

  .offcanvas-body > .list-unstyled:not(:first-of-type) a,
  .offcanvas-body > .list-unstyled:not(:first-of-type) .nav-link,
  .offcanvas-body > .list-unstyled:not(:first-of-type) .topbar-text,
  .offcanvas-body > .list-unstyled:not(:first-of-type) span {
    display: flex;
    align-items: center;
    width: 100%;
    min-height: 54px;
    padding: 0.95rem 1rem;
    text-decoration: none;
    color: var(--basiskleurvijfenvijftig) !important;
    background: transparent !important;
    transition: background-color 0.2s ease, color 0.2s ease, padding-left 0.2s ease;
  }

  .offcanvas-body > .list-unstyled:not(:first-of-type) a:hover,
  .offcanvas-body > .list-unstyled:not(:first-of-type) .nav-link:hover {
    color: var(--basiskleurzesenvijftig) !important;
    background-color: rgba(255, 255, 255, 0.04) !important;
    padding-left: 1.15rem;
  }

  .offcanvas-body .nav-item a:focus,
  .offcanvas-body .nav-item a:focus-visible,
  .offcanvas-body a:focus,
  .offcanvas-body a:focus-visible {
    outline: none !important;
    box-shadow: none !important;
  }

  .navbar-toggler {
    border: none;
    outline: none;
    box-shadow: none;
  }
}

/* veiligheid */
.content-section {
  position: relative;
  z-index: 1;
}