:root {
  --cubic-default: cubic-bezier(0.525, 0, 0, 1);
  --duration-fast: 0.2s;
  --duration-normal: 0.450s;
  --color-dark: #2b1d15;
  --nav-bg-buffer: 0;
  --nav-grid-gap: 1rem;
  /* default gap for grid dropdown */
}

a {
  color: inherit;
  text-decoration: none;
}

a:focus-visible,
button:focus-visible {
  outline: 1px solid var(--color-dark);
}

.nav-bg {
  transition: height var(--duration-normal) var(--cubic-default);
  height: 0;
  pointer-events: none;
  /* controlled by JS now */
  overflow: hidden;
  /* prevents visual overspill */
}

.page-bg {
  transition: opacity var(--duration-fast) var(--cubic-default);
}

.nav {
  transition: color var(--duration-fast) var(--cubic-default);
}

.nav-button {
  transition: all var(--duration-fast) var(--cubic-default);
}

/* ———— SHOW DROPDOWN ———— */
.nav-dropdown {
  transition: all var(--duration-fast) ease,
    transform var(--duration-normal) var(--cubic-default);
}

[data-dropdown-toggle]:not([data-dropdown-toggle="closed"]):hover+.nav-dropdown,
[data-dropdown-toggle]:not([data-dropdown-toggle="closed"]):focus-visible+.nav-dropdown,
[data-dropdown-toggle]:not([data-dropdown-toggle="closed"])+.nav-dropdown:hover,
[data-dropdown-toggle]:not([data-dropdown-toggle="closed"])+.nav-dropdown:focus-within {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
}

/*———— STYLING WHEN DROPDOWN IS OPEN ———— */
:is(body:has([data-dropdown-toggle]:not([data-dropdown-toggle="closed"]):hover),
  body:has([data-dropdown-toggle]:not([data-dropdown-toggle="closed"]):focus-visible),
  body:has([data-dropdown-toggle]:not([data-dropdown-toggle="closed"]):focus-within),
  body:has([data-dropdown-toggle]:not([data-dropdown-toggle="closed"])+.nav-dropdown:hover),
  body:has([data-dropdown-toggle]:not([data-dropdown-toggle="closed"])+.nav-dropdown:focus-within)) {
  .page-bg {
    opacity: 1;
  }

  .nav {
    color: var(--color-dark);
  }
}

/*———— DROPDOWN TOGGLE ———— */
.nav-link__dropdown-icon {
  transition: transform var(--duration-normal) var(--cubic-default);
}

[data-dropdown-toggle] {
  transition: background-color var(--duration-fast) var(--cubic-default);
}

/*———— DESKTOP HOVER AND FOCUS ———— */
@media screen and (min-width: 768px) {

  [data-dropdown-toggle]:not([data-dropdown-toggle="closed"]):hover .nav-link__dropdown-icon,
  [data-dropdown-toggle]:not([data-dropdown-toggle="closed"]):focus .nav-link__dropdown-icon,
  [data-dropdown-toggle]:not([data-dropdown-toggle="closed"]):focus-within .nav-link__dropdown-icon,
  [data-dropdown-toggle]:not([data-dropdown-toggle="closed"]):has(+ .nav-dropdown:hover) .nav-link__dropdown-icon,
  [data-dropdown-toggle]:not([data-dropdown-toggle="closed"]):has(+ .nav-dropdown:focus-within) .nav-link__dropdown-icon {
    transform: rotate(180deg);
  }

  [data-dropdown-toggle]:not([data-dropdown-toggle="closed"]):hover,
  [data-dropdown-toggle]:not([data-dropdown-toggle="closed"]):focus,
  [data-dropdown-toggle]:not([data-dropdown-toggle="closed"]):focus-within,
  [data-dropdown-toggle]:not([data-dropdown-toggle="closed"]):has(+ .nav-dropdown:hover),
  [data-dropdown-toggle]:not([data-dropdown-toggle="closed"]):has(+ .nav-dropdown:focus-within) {
    background-color: #EBE7E4;
  }
}

/* ———— GRID DEFAULT FOR ALL DROPDOWNS ———— */
.nav-dropdown__content {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  /* mobile: two per row */
  gap: var(--nav-grid-gap);
  align-items: start;
  list-style: none;
  /* if it's a <ul> */
  margin: 0;
  padding: 0;
  /* keep outer wrapper’s padding instead if needed */
}

/* Tiny screens safeguard: 1 per row on very narrow devices */
@media (max-width: 380px) {
  .nav-dropdown__content {
    grid-template-columns: 1fr;
  }
}

/* Tablet + Desktop: 3 per row */
@media (min-width: 768px) {
  .nav-dropdown__content {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

/* Ensure items behave nicely inside the grid */
.nav-dropdown__content .nav-dropdown__content-li {
  width: 100%;
}

/*————  DROPDOWN CONTENT LIST ITEMS (animations) ———— */
.nav-dropdown__content-li {
  transition: all var(--duration-normal) var(--cubic-default);
  transition-delay: 0.18s;
  opacity: 0;
  transform: translate(4em, 0px);
}

.nav-dropdown__content-li:nth-child(2) {
  transition-delay: 0.24s;
}

.nav-dropdown__content-li:nth-child(3) {
  transition-delay: 0.3s;
}

.nav-dropdown__content-li:nth-child(4) {
  transition-delay: 0.36s;
}

.nav-dropdown__content-li:nth-child(5) {
  transition-delay: 0.44s;
}

.nav-dropdown__content-li:nth-child(6) {
  transition-delay: 0.5s;
}

body:has([data-dropdown-toggle]:not([data-dropdown-toggle="closed"]):hover) [data-dropdown-toggle]:not([data-dropdown-toggle="closed"]):hover+.nav-dropdown .nav-dropdown__content-li,
body:has([data-dropdown-toggle]:not([data-dropdown-toggle="closed"]):focus-visible) .nav-dropdown__content-li,
body:has([data-dropdown-toggle]:not([data-dropdown-toggle="closed"]):focus-within) .nav-dropdown__content-li,
body:has([data-dropdown-toggle]:not([data-dropdown-toggle="closed"])+.nav-dropdown:hover) .nav-dropdown__content-li,
body:has([data-dropdown-toggle]:not([data-dropdown-toggle="closed"])+.nav-dropdown:focus-within) .nav-dropdown__content-li {
  opacity: 1;
  transform: translate(0em, 0px);
}

/*————  DROPDOWN LINKS + IMAGES ———— */
.nav-dropdown__link:hover .nav-dropdown__img-overlay,
.nav-dropdown__link:focus-visible .nav-dropdown__img-overlay {
  opacity: 0;
}

.nav-dropdown__link:hover .nav-dropdown__img,
.nav-dropdown__link:focus-visible .nav-dropdown__img {
  transform: scale(1.1);
}

/*———— DROPDOWN LINKS ———— */
.nav-dropdown__link.is--static:hover,
.nav-dropdown__link.is--static:focus-visible {
  background: #D7D1CD;
}

/* ———— NAV LINKS ———— */
a.nav-link .nav-link__label::after {
  content: '';
  position: absolute;
  left: 0;
  bottom: -1px;
  width: 100%;
  height: 1px;
  background: currentColor;
  transition: transform var(--duration-normal) var(--cubic-default);
  transform: scale(0, 1);
  transform-origin: right center;
}

a.nav-link:hover .nav-link__label::after,
a.nav-link:focus-visible .nav-link__label::after {
  transform: scale(1, 1);
  transform-origin: left center;
}

/* ———— MOBILE STATE WITH BURGER MENU ———— */
@media screen and (max-width: 767px) {
  .nav-dropdown__overflow {
    transition: grid-template-rows var(--duration-normal) var(--cubic-default);
  }

  .nav-center {
    transition: all var(--duration-normal) var(--cubic-default),
      opacity var(--duration-fast) var(--cubic-default);
  }

  .menu-button__line {
    transition: all var(--duration-normal) var(--cubic-default);
  }

  /* ———— STYLES WHEN MENU IS OPEN ———— */
  :is([data-menu-status="open"]) {
    color: var(--color-dark);

    .menu-button {
      color: var(--color-dark);
    }

    .menu-button__line:nth-of-type(1) {
      transform: translate(0px, 0.175em) rotate(135deg);
      background-color: #FFF;
    }

    .menu-button__line:nth-of-type(2) {
      transform: translate(0px, -0.2em) rotate(-135deg);
      background-color: #FFF;
    }

    .nav-bg {
      height: 100dvh;
    }

    /* fill viewport on mobile */
    .page-bg {
      opacity: 1;
    }

    .nav-button.is--primary {
      background-color: var(--color-dark);
      border-color: var(--color-dark);
      color: #FFF;
    }

    .nav-center {
      opacity: 1;
      visibility: visible;
      transform: translate(0px, 0em);
      transition-delay: 0.1s;
    }
  }

  [data-dropdown-toggle="open"]+.nav-dropdown .nav-dropdown__overflow {
    grid-template-rows: 1fr;
  }

  [data-dropdown-toggle="open"]+.nav-dropdown .nav-dropdown__content-li {
    opacity: 1;
    transform: translate(0em, 0px);
  }

  [data-dropdown-toggle="open"] .nav-link__dropdown-icon {
    transform: rotate(180deg);
  }

  /* NEW: Mobile/Tablet backdrop uses max-height animation (smooth, no iOS jump) */
  .nav-bg {
    overflow: hidden;
    max-height: 0;
    transition: max-height 0.65s ease;
  }

  [data-menu-status="open"] .nav-bg {
    max-height: 200vh;
  }

}

.nav-dropdown__link-inner {
  display: flex;
  flex-direction: row;
  align-items: flex-end;
  gap: 1em;
}

.nav-dropdown__link-bubble {
  flex-shrink: 0;
}

/* robust hyphenation for long single words (Danish) */
.nav-dropdown__link-label {
  flex: 1 1 auto;
  min-width: 0;
  white-space: normal !important;
  /* must allow wrapping */
  hyphens: auto;
  -webkit-hyphens: auto;
  /* iOS/Safari */
  -ms-hyphens: auto;
  /* old Edge */
  overflow-wrap: anywhere;
  /* allow break if no hyphenation point */
  word-break: normal;
  /* avoid break-all unless last resort */
  line-height: 1.1;
}

/* menu fills the real viewport height, scrolls inside if needed */
[data-menu-status="open"] {
  height: 100dvh;
  /* dynamic vh fixes iOS bottom bar */
  overflow: auto;
  /* menu content scrolls */
}

/* lock background when menu is open */
html.menu-locked,
body.menu-locked {
  overflow: hidden;
  overscroll-behavior: none;
}

/* Locking already in your file */
[data-menu-status="open"] {
  height: 100dvh;
  overflow: auto;
}

html.menu-locked,
body.menu-locked {
  overflow: hidden;
  overscroll-behavior: none;
}
