/* ==========================================================================
   BEJCO NAVBAR
   ========================================================================== */
.bj-nav {
    --bj-blue-deep: #00458a;
    --bj-blue-bright: #2885c1;
    --bj-red: #e2161c;
    --bj-cream: #f7f0da;
    --bj-white: #ffffff;
    --bj-off-white: #fafbfc;
    --bj-ink-900: #0a1628;
    --bj-ink-700: #2a3748;
    --bj-ink-500: #5a6578;
    --bj-ink-100: #e5e9ef;

    --bj-radius-pill: 999px;
    --bj-radius-lg: 24px;
    --bj-radius-md: 16px;
    --bj-ease-out: cubic-bezier(0.23, 1, 0.32, 1);
    --bj-shadow-pill: 0 8px 24px -8px rgba(0, 69, 138, 0.18), 0 24px 48px -16px rgba(0, 69, 138, 0.12);
    --bj-shadow-dropdown: 0 24px 56px -16px rgba(0, 69, 138, 0.22), 0 12px 28px -12px rgba(0, 69, 138, 0.14);

    --bj-font-body: 'Source Sans 3', system-ui, sans-serif;
    --bj-font-display: 'Oswald', system-ui, sans-serif;
    --bj-gutter: clamp(24px, 5vw, 72px);
    /* Maks bredde pa selve navbar-indholdet, sa det folger banner-kolonnen
       og de yderste menupunkter ikke stikker ud over banner-gutteren.
       Juster denne, hvis dit banner-content bruger en anden max-bredde. */
    --bj-content-max: 1320px;

    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    z-index: 100;
    pointer-events: none;
    transition: padding 420ms var(--bj-ease-out);
    padding: 22px var(--bj-gutter) 0;
    display: flex;
    justify-content: center;
    font-family: var(--bj-font-body);
}

.bj-nav *,
.bj-nav *::before,
.bj-nav *::after {
    box-sizing: border-box;
}

.bj-nav__bar {
    pointer-events: auto;
    position: relative;
    width: 100%;
    max-width: var(--bj-content-max);
    padding: 16px clamp(20px, 3vw, 40px);
    border-radius: 14px;
    background-color: transparent;
    transition: width 520ms var(--bj-ease-out),
                max-width 520ms var(--bj-ease-out),
                padding 420ms var(--bj-ease-out),
                background-color 320ms ease,
                backdrop-filter 320ms ease,
                box-shadow 420ms ease,
                border-radius 520ms var(--bj-ease-out);
}

.bj-nav.is-scrolled {
    padding-top: 44px;
}

.bj-nav.is-scrolled .bj-nav__bar {
    width: fit-content;
    max-width: 100%;
    padding: 0 28px;
    background-color: var(--bj-white);
    box-shadow: var(--bj-shadow-pill);
    border-radius: var(--bj-radius-pill);
    overflow: visible;
}

.bj-nav__inner {
    display: grid;
    grid-template-columns: 1fr auto 1fr;
    align-items: center;
    gap: clamp(16px, 2.2vw, 32px);
    transition: gap 320ms var(--bj-ease-out);
}

.bj-nav.is-scrolled .bj-nav__inner {
    display: flex;
    justify-content: center;
    gap: 32px;
}

.bj-nav__logo {
    display: block;
    height: clamp(64px, 6.5vw, 96px);
    width: clamp(96px, 9.5vw, 140px);
    background-image: var(--bj-logo);
    background-repeat: no-repeat;
    background-position: center;
    background-size: contain;
    transition: height 420ms var(--bj-ease-out),
                width 420ms var(--bj-ease-out),
                filter 320ms ease,
                transform 240ms var(--bj-ease-out);
}

.bj-nav.is-scrolled .bj-nav__logo {
    height: clamp(64px, 6.5vw, 96px);
    width: clamp(104px, 10vw, 150px);
    margin: -16px 4px;
}

.bj-nav__logo-link {
    display: inline-flex;
    justify-content: center;
    position: relative;
    z-index: 2;
    text-decoration: none;
}

@media (hover: hover) and (pointer: fine) {
    .bj-nav__logo-link:hover .bj-nav__logo,
    .bj-nav__logo-link:focus .bj-nav__logo {
        transform: scale(1.04);
    }
}

.bj-nav__list {
    display: flex;
    align-items: center;
    gap: clamp(28px, 3vw, 56px);
    transition: gap 320ms var(--bj-ease-out);
    list-style: none;
    margin: 0;
    padding: 0;
}

.bj-nav.is-scrolled .bj-nav__list {
    gap: clamp(20px, 2vw, 36px);
}

.bj-nav__list--left { justify-content: flex-end; }
.bj-nav__list--right { justify-content: flex-start; }

/* Top-level menu items */
.bj-nav__list .menu-item {
    list-style: none;
    position: relative;
}

.bj-nav__list > .menu-item > a {
    font-size: clamp(0.8125rem, 0.95vw, 0.9375rem);
    font-weight: 500;
    color: var(--bj-white);
    position: relative;
    display: inline-flex;
    align-items: center;
    gap: 6px;
    transition: color 280ms ease, font-size 320ms var(--bj-ease-out);
    white-space: nowrap;
    text-shadow: 0 1px 8px rgba(0, 30, 60, 0.25);
    text-decoration: none;
    background-color: transparent;
    padding: 6px 0;
    cursor: pointer;
}

.bj-nav.is-scrolled .bj-nav__list > .menu-item > a {
    color: var(--bj-ink-900);
    text-shadow: none;
    font-size: clamp(0.8125rem, 0.9vw, 0.875rem);
    background-color: transparent;
}

.bj-nav__link-label {
    position: relative;
}

.bj-nav__link-label::after {
    content: '';
    position: absolute;
    left: 0;
    right: 0;
    bottom: -6px;
    height: 2px;
    background-color: var(--bj-red);
    border-radius: 2px;
    transform: scaleX(0);
    transform-origin: left center;
    transition: transform 220ms var(--bj-ease-out);
}

.bj-nav__chevron {
    width: 12px;
    height: 12px;
    flex-shrink: 0;
    margin-top: 1px;
    transition: transform 280ms var(--bj-ease-out);
    opacity: 0.75;
}

@media (hover: hover) and (pointer: fine) {
    .bj-nav__list > .menu-item > a:hover,
    .bj-nav__list > .menu-item > a:focus,
    .bj-nav__list > .menu-item.is-open > a {
        color: var(--bj-cream);
        background-color: transparent;
    }
    .bj-nav__list > .menu-item > a:hover .bj-nav__link-label::after,
    .bj-nav__list > .menu-item > a:focus .bj-nav__link-label::after,
    .bj-nav__list > .menu-item.is-open > a .bj-nav__link-label::after {
        transform: scaleX(1);
    }
    .bj-nav__list > .menu-item > a:hover .bj-nav__chevron,
    .bj-nav__list > .menu-item.is-open > a .bj-nav__chevron {
        transform: rotate(180deg);
        opacity: 1;
    }
    .bj-nav.is-scrolled .bj-nav__list > .menu-item > a:hover,
    .bj-nav.is-scrolled .bj-nav__list > .menu-item > a:focus,
    .bj-nav.is-scrolled .bj-nav__list > .menu-item.is-open > a {
        color: var(--bj-blue-deep);
        background-color: transparent;
    }
}

.bj-nav__list .current-menu-item > a .bj-nav__link-label::after,
.bj-nav__list .current-menu-ancestor > a .bj-nav__link-label::after {
    transform: scaleX(1);
}

/* ==========================================================================
   DROPDOWN / SUBMENU
   ========================================================================== */
.bj-nav__submenu {
    position: absolute;
    top: calc(100% + 14px);
    left: 50%;
    transform: translateX(-50%) translateY(-8px);
    min-width: 260px;
    max-width: 320px;
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transition: opacity 280ms var(--bj-ease-out),
                transform 320ms var(--bj-ease-out),
                visibility 280ms;
    z-index: 10;
}

.bj-nav__submenu::before {
    content: '';
    position: absolute;
    top: -14px;
    left: 0;
    right: 0;
    height: 14px;
}

.bj-nav__submenu-inner {
    background-color: var(--bj-white);
    border-radius: 18px;
    padding: 8px;
    box-shadow: var(--bj-shadow-dropdown);
    position: relative;
    overflow: hidden;
}

.bj-nav__submenu-inner::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 3px;
    background: linear-gradient(90deg, var(--bj-blue-deep), var(--bj-blue-bright), var(--bj-red));
    opacity: 0;
    transform: translateY(-3px);
    transition: opacity 320ms ease 80ms, transform 320ms var(--bj-ease-out) 80ms;
}

.bj-nav__list > .menu-item.is-open > .bj-nav__submenu {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
    transform: translateX(-50%) translateY(0);
}

.bj-nav__list > .menu-item.is-open > .bj-nav__submenu .bj-nav__submenu-inner::before {
    opacity: 1;
    transform: translateY(0);
}

.bj-nav__sublist {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 1px;
}

.bj-nav__subitem {
    list-style: none;
}

.bj-nav__sublink {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 9px 12px;
    border-radius: 12px;
    text-decoration: none;
    background-color: transparent;
    transition: background-color 240ms ease, transform 240ms var(--bj-ease-out);
    position: relative;
}

.bj-nav__sublink-content {
    display: flex;
    flex-direction: column;
    gap: 1px;
    flex: 1 1 auto;
    min-width: 0;
}

.bj-nav__sublink-title {
    font-family: var(--bj-font-body);
    font-size: 0.875rem;
    font-weight: 600;
    color: var(--bj-ink-900);
    line-height: 1.3;
    letter-spacing: -0.005em;
    transition: color 240ms ease;
}

.bj-nav__sublink-desc {
    font-size: 0.75rem;
    font-weight: 400;
    color: var(--bj-ink-500);
    line-height: 1.4;
    transition: color 240ms ease;
}

.bj-nav__sublink-arrow {
    width: 26px;
    height: 26px;
    flex-shrink: 0;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    background-color: var(--bj-off-white);
    color: var(--bj-ink-500);
    transition: background-color 280ms ease,
                color 280ms ease,
                transform 380ms var(--bj-ease-out);
}

.bj-nav__sublink-arrow svg {
    width: 11px;
    height: 11px;
}

@media (hover: hover) and (pointer: fine) {
    .bj-nav__sublink:hover,
    .bj-nav__sublink:focus,
    .bj-nav__sublink:active {
        background-color: var(--bj-cream);
        transform: translateX(2px);
    }
    .bj-nav__sublink:hover .bj-nav__sublink-title,
    .bj-nav__sublink:focus .bj-nav__sublink-title {
        color: var(--bj-blue-deep);
    }
    .bj-nav__sublink:hover .bj-nav__sublink-arrow,
    .bj-nav__sublink:focus .bj-nav__sublink-arrow {
        background-color: var(--bj-red);
        color: var(--bj-white);
        transform: rotate(-45deg);
    }
}

/* current state in dropdown */
.bj-nav__subitem.current-menu-item > .bj-nav__sublink {
    background-color: var(--bj-cream);
}

.bj-nav__subitem.current-menu-item > .bj-nav__sublink .bj-nav__sublink-title {
    color: var(--bj-blue-deep);
}

/* ==========================================================================
   MOBILE MENU BUTTON
   ========================================================================== */
.bj-nav__menu-btn {
    display: none;
    width: 44px;
    height: 44px;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    background-color: rgba(255, 255, 255, 0.14);
    color: var(--bj-white);
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
    border: 0;
    transition: background-color 220ms ease, color 220ms ease;
    cursor: pointer;
    font-family: inherit;
    padding: 0;
    position: relative;
    z-index: 2;
}

.bj-nav.is-scrolled .bj-nav__menu-btn {
    background-color: var(--bj-blue-deep);
    color: var(--bj-white);
}

@media (hover: hover) and (pointer: fine) {
    .bj-nav__menu-btn:hover,
    .bj-nav__menu-btn:focus,
    .bj-nav__menu-btn:active {
        background-color: rgba(255, 255, 255, 0.22);
    }
    .bj-nav.is-scrolled .bj-nav__menu-btn:hover,
    .bj-nav.is-scrolled .bj-nav__menu-btn:focus,
    .bj-nav.is-scrolled .bj-nav__menu-btn:active {
        background-color: var(--bj-ink-900);
    }
}

.bj-nav__menu-btn:focus-visible {
    outline: none;
    box-shadow: 0 0 0 3px rgba(255, 255, 255, 0.4);
}

.bj-nav.is-scrolled .bj-nav__menu-btn:focus-visible {
    box-shadow: 0 0 0 3px rgba(0, 69, 138, 0.25);
}

/* Hamburger -> X icon morph */
.bj-nav__menu-btn-icon {
    position: relative;
    width: 18px;
    height: 14px;
    display: inline-block;
}

.bj-nav__menu-btn-bar {
    position: absolute;
    left: 0;
    width: 100%;
    height: 2px;
    border-radius: 2px;
    background-color: currentColor;
    transition: transform 380ms var(--bj-ease-out),
                opacity 220ms ease,
                top 380ms var(--bj-ease-out);
}

.bj-nav__menu-btn-bar:nth-child(1) { top: 0; }
.bj-nav__menu-btn-bar:nth-child(2) { top: 6px; }
.bj-nav__menu-btn-bar:nth-child(3) { top: 12px; }

.bj-nav__menu-btn[aria-expanded="true"] .bj-nav__menu-btn-bar:nth-child(1) {
    top: 6px;
    transform: rotate(45deg);
}
.bj-nav__menu-btn[aria-expanded="true"] .bj-nav__menu-btn-bar:nth-child(2) {
    opacity: 0;
    transform: scaleX(0.4);
}
.bj-nav__menu-btn[aria-expanded="true"] .bj-nav__menu-btn-bar:nth-child(3) {
    top: 6px;
    transform: rotate(-45deg);
}

@media (max-width: 1160px) {
    .bj-nav__inner {
        display: flex;
        align-items: center;
        justify-content: space-between;
        gap: 16px;
    }
    .bj-nav__list {
        display: none;
    }
    .bj-nav__menu-btn {
        display: inline-flex;
    }
    .bj-nav__logo-link {
        margin-right: auto;
    }
    .bj-nav__logo {
        height: 56px;
        width: 90px;
    }
    .bj-nav.is-scrolled .bj-nav__logo {
        height: 56px;
        width: 90px;
        margin: -8px 0;
    }
    .bj-nav__bar {
        padding: 12px 18px;
    }
    /* When scrolled on mobile: keep full width + space-between, don't shrink to fit-content */
    .bj-nav.is-scrolled .bj-nav__bar {
        width: 100%;
        max-width: 100%;
        padding: 8px 14px;
    }
    .bj-nav.is-scrolled .bj-nav__inner {
        display: flex;
        justify-content: space-between;
        gap: 16px;
    }
    .bj-nav.is-scrolled .bj-nav__logo-link {
        margin-right: auto;
    }
}

@media (max-width: 560px) {
    .bj-nav__logo {
        height: 48px;
        width: 76px;
    }
    .bj-nav.is-scrolled .bj-nav__logo {
        height: 48px;
        width: 76px;
    }
}

/* ==========================================================================
   SIDE DRAWER
   ========================================================================== */
.bj-drawer-root {
    --bj-blue-deep: #00458a;
    --bj-blue-bright: #2885c1;
    --bj-red: #e2161c;
    --bj-cream: #f7f0da;
    --bj-white: #ffffff;
    --bj-off-white: #fafbfc;
    --bj-ink-900: #0a1628;
    --bj-ink-500: #5a6578;
    --bj-ease-out: cubic-bezier(0.23, 1, 0.32, 1);
    --bj-font-body: 'Source Sans 3', system-ui, sans-serif;
    --bj-font-display: 'Oswald', system-ui, sans-serif;

    position: fixed;
    inset: 0;
    z-index: 110;
    pointer-events: none;
    /* Hard-hidden i initial state - ingen rendering for af menuen abnes.
       display:none fjerner den fuldstandig fra layout/paint, sa intet kan glimte
       ind under sideloading uanset transition-timing. */
    display: none;
    visibility: hidden;
    font-family: var(--bj-font-body);
}

/* Aktiveres bade nar menuen abnes OG mens den lukker (so exit-animationen kan kores) */
.bj-drawer-root.is-open,
.bj-drawer-root.is-closing,
.bj-drawer-root.is-prep {
    display: block;
    visibility: visible;
}

.bj-drawer-root.is-open {
    pointer-events: auto;
}

.bj-drawer-root *,
.bj-drawer-root *::before,
.bj-drawer-root *::after {
    box-sizing: border-box;
}

/* BACKDROP */
.bj-drawer__backdrop {
    position: absolute;
    inset: 0;
    background-color: rgba(10, 22, 40, 0);
    backdrop-filter: blur(0px);
    -webkit-backdrop-filter: blur(0px);
    transition: background-color 500ms var(--bj-ease-out),
                backdrop-filter 500ms var(--bj-ease-out),
                -webkit-backdrop-filter 500ms var(--bj-ease-out);
    cursor: pointer;
}

.bj-drawer-root.is-open .bj-drawer__backdrop {
    background-color: rgba(10, 22, 40, 0.55);
    backdrop-filter: blur(6px);
    -webkit-backdrop-filter: blur(6px);
}

/* DRAWER PANEL */
.bj-drawer {
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    width: min(440px, 92vw);
    background-color: var(--bj-blue-deep);
    color: var(--bj-white);
    box-shadow: -32px 0 80px -16px rgba(0, 30, 60, 0.4);
    display: flex;
    flex-direction: column;
    overflow: hidden;
    isolation: isolate;
    transform: translateX(100%);
    transition: transform 600ms var(--bj-ease-out);
    will-change: transform;
}

.bj-drawer-root.is-open .bj-drawer {
    transform: translateX(0);
}

/* Decorative red side line + grid */
.bj-drawer::before {
    content: '';
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    width: 3px;
    background: linear-gradient(180deg, var(--bj-red) 0%, var(--bj-blue-bright) 100%);
    z-index: 2;
    opacity: 0;
    transform: scaleY(0);
    transform-origin: top center;
    transition: transform 700ms var(--bj-ease-out) 200ms,
                opacity 400ms ease 200ms;
}

.bj-drawer::after {
    content: '';
    position: absolute;
    inset: 0;
    background-image:
        linear-gradient(rgba(255, 255, 255, 0.035) 1px, transparent 1px),
        linear-gradient(90deg, rgba(255, 255, 255, 0.035) 1px, transparent 1px);
    background-size: 80px 80px;
    mask-image: radial-gradient(ellipse at 80% 20%, black 5%, transparent 70%);
    -webkit-mask-image: radial-gradient(ellipse at 80% 20%, black 5%, transparent 70%);
    pointer-events: none;
    opacity: 0;
    transition: opacity 800ms ease 300ms;
    z-index: 0;
}

.bj-drawer-root.is-open .bj-drawer::before {
    opacity: 1;
    transform: scaleY(1);
}

.bj-drawer-root.is-open .bj-drawer::after {
    opacity: 1;
}

/* HEADER */
.bj-drawer__header {
    position: relative;
    z-index: 1;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    padding: 20px 24px;
    border-bottom: 1px solid rgba(255, 255, 255, 0.08);
    flex-shrink: 0;
}

.bj-drawer__logo-link {
    display: inline-flex;
    text-decoration: none;
    margin-right: auto;
}

.bj-drawer__logo {
    display: block;
    width: 78px;
    height: 44px;
    background-repeat: no-repeat;
    background-position: left center;
    background-size: contain;
}

.bj-drawer__close {
    width: 44px;
    height: 44px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    background-color: rgba(255, 255, 255, 0.08);
    color: var(--bj-white);
    border: 0;
    cursor: pointer;
    padding: 0;
    transition: background-color 240ms ease,
                color 240ms ease,
                transform 320ms var(--bj-ease-out);
}

.bj-drawer__close svg {
    width: 18px;
    height: 18px;
}

@media (hover: hover) and (pointer: fine) {
    .bj-drawer__close:hover,
    .bj-drawer__close:focus {
        background-color: var(--bj-red);
        transform: rotate(90deg);
    }
}

.bj-drawer__close:focus-visible {
    outline: none;
    box-shadow: 0 0 0 3px rgba(247, 240, 218, 0.4);
}

.bj-drawer__close:active {
    transform: scale(0.94);
}

/* BODY */
.bj-drawer__body {
    position: relative;
    z-index: 1;
    flex: 1 1 auto;
    overflow-y: auto;
    overflow-x: hidden;
    padding: 36px 32px 24px;
    -webkit-overflow-scrolling: touch;
}

/* Scrollbar styling */
.bj-drawer__body::-webkit-scrollbar { width: 6px; }
.bj-drawer__body::-webkit-scrollbar-track { background: transparent; }
.bj-drawer__body::-webkit-scrollbar-thumb {
    background: rgba(255, 255, 255, 0.12);
    border-radius: 3px;
}
.bj-drawer__body::-webkit-scrollbar-thumb:hover {
    background: rgba(255, 255, 255, 0.2);
}

/* Eyebrow */
.bj-drawer__eyebrow {
    display: inline-flex;
    align-items: center;
    gap: 12px;
    font-size: 0.75rem;
    font-weight: 600;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--bj-cream);
    margin-bottom: 16px;
}

.bj-drawer__eyebrow-line {
    width: 28px;
    height: 2px;
    background-color: var(--bj-red);
    border-radius: 2px;
    display: inline-block;
}

/* Title */
.bj-drawer__title {
    font-family: var(--bj-font-display);
    font-weight: 500;
    font-size: clamp(1.75rem, 4vw, 2.25rem);
    line-height: 1.05;
    letter-spacing: -0.02em;
    color: var(--bj-white);
    margin: 0 0 36px;
    max-width: 320px;
}

.bj-drawer__title-accent {
    color: var(--bj-cream);
    font-style: italic;
    font-weight: 600;
    position: relative;
    display: inline-block;
}

.bj-drawer__title-accent::after {
    content: '';
    position: absolute;
    left: 0;
    right: 0;
    bottom: 2px;
    height: 10px;
    background-color: var(--bj-red);
    z-index: -1;
    border-radius: 3px;
    opacity: 0.85;
    transform: scaleX(0);
    transform-origin: left center;
    transition: transform 600ms var(--bj-ease-out) 700ms;
}

.bj-drawer-root.is-open .bj-drawer__title-accent::after {
    transform: scaleX(1);
}

/* NAV LIST */
.bj-drawer__nav {
    margin: 0 0 36px;
}

.bj-drawer__list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
}

.bj-drawer__item {
    list-style: none;
    border-bottom: 1px solid rgba(255, 255, 255, 0.08);
}

.bj-drawer__item:first-child {
    border-top: 1px solid rgba(255, 255, 255, 0.08);
}

.bj-drawer__link {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    padding: 18px 4px;
    color: var(--bj-white);
    text-decoration: none;
    font-family: var(--bj-font-display);
    font-size: 1.375rem;
    font-weight: 400;
    letter-spacing: -0.01em;
    transition: color 240ms ease, padding-left 320ms var(--bj-ease-out);
    position: relative;
}

.bj-drawer__link-label {
    position: relative;
    z-index: 1;
}

.bj-drawer__link-arrow {
    width: 36px;
    height: 36px;
    flex-shrink: 0;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    background-color: rgba(255, 255, 255, 0.06);
    color: rgba(255, 255, 255, 0.6);
    transition: background-color 280ms ease,
                color 280ms ease,
                transform 420ms var(--bj-ease-out);
}

.bj-drawer__link-arrow svg {
    width: 14px;
    height: 14px;
}

@media (hover: hover) and (pointer: fine) {
    .bj-drawer__link:hover,
    .bj-drawer__link:focus-visible {
        color: var(--bj-cream);
        padding-left: 16px;
        outline: none;
    }
    .bj-drawer__link:hover .bj-drawer__link-arrow,
    .bj-drawer__link:focus-visible .bj-drawer__link-arrow {
        background-color: var(--bj-red);
        color: var(--bj-white);
        transform: rotate(-45deg);
    }
}

.bj-drawer__link:active {
    transform: scale(0.98);
}

/* SUBLIST */
.bj-drawer__sublist {
    list-style: none;
    margin: 0 0 16px;
    padding: 0 0 0 18px;
    display: flex;
    flex-direction: column;
    gap: 2px;
    border-left: 1px solid rgba(255, 255, 255, 0.1);
    margin-left: 4px;
}

.bj-drawer__subitem {
    list-style: none;
}

.bj-drawer__sublink {
    display: block;
    padding: 8px 0;
    color: rgba(255, 255, 255, 0.7);
    text-decoration: none;
    font-size: 0.9375rem;
    font-weight: 400;
    transition: color 240ms ease, padding-left 280ms var(--bj-ease-out);
}

@media (hover: hover) and (pointer: fine) {
    .bj-drawer__sublink:hover,
    .bj-drawer__sublink:focus-visible {
        color: var(--bj-cream);
        padding-left: 8px;
        outline: none;
    }
}

/* CTA */
.bj-drawer__cta-row {
    margin-top: 8px;
}

.bj-drawer__cta {
    display: inline-flex;
    align-items: center;
    gap: 14px;
    padding: 12px 14px 12px 28px;
    border-radius: 999px;
    background-color: var(--bj-white);
    color: var(--bj-blue-deep);
    font-family: var(--bj-font-body);
    font-weight: 600;
    font-size: 0.9375rem;
    letter-spacing: 0.01em;
    text-decoration: none;
    transition: background-color 240ms ease,
                color 240ms ease,
                transform 200ms var(--bj-ease-out),
                box-shadow 280ms ease;
}

.bj-drawer__cta-arrow {
    width: 36px;
    height: 36px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    background-color: var(--bj-blue-deep);
    color: var(--bj-white);
    flex-shrink: 0;
    transition: background-color 280ms ease,
                transform 420ms var(--bj-ease-out);
}

.bj-drawer__cta-arrow svg {
    width: 14px;
    height: 14px;
}

@media (hover: hover) and (pointer: fine) {
    .bj-drawer__cta:hover,
    .bj-drawer__cta:focus-visible {
        background-color: var(--bj-cream);
        box-shadow: 0 12px 28px rgba(0, 30, 60, 0.35);
        outline: none;
    }
    .bj-drawer__cta:hover .bj-drawer__cta-arrow,
    .bj-drawer__cta:focus-visible .bj-drawer__cta-arrow {
        background-color: var(--bj-red);
        transform: rotate(-45deg);
    }
}

.bj-drawer__cta:active {
    transform: scale(0.97);
}

/* ==========================================================================
   STAGGER ANIMATIONS - drawer content
   ========================================================================== */
.bj-drawer-root [data-bj-stagger],
.bj-drawer-root .bj-drawer__item {
    opacity: 0;
    transform: translateX(24px);
    transition: opacity 600ms var(--bj-ease-out),
                transform 700ms var(--bj-ease-out);
}

/* Stagger delays - applied when drawer opens */
.bj-drawer-root.is-open [data-bj-stagger],
.bj-drawer-root.is-open .bj-drawer__item {
    opacity: 1;
    transform: translateX(0);
}

/* Custom stagger order */
.bj-drawer-root.is-open .bj-drawer__eyebrow            { transition-delay: 280ms; }
.bj-drawer-root.is-open .bj-drawer__title              { transition-delay: 340ms; }
.bj-drawer-root.is-open .bj-drawer__item:nth-child(1)  { transition-delay: 420ms; }
.bj-drawer-root.is-open .bj-drawer__item:nth-child(2)  { transition-delay: 470ms; }
.bj-drawer-root.is-open .bj-drawer__item:nth-child(3)  { transition-delay: 520ms; }
.bj-drawer-root.is-open .bj-drawer__item:nth-child(4)  { transition-delay: 570ms; }
.bj-drawer-root.is-open .bj-drawer__item:nth-child(5)  { transition-delay: 620ms; }
.bj-drawer-root.is-open .bj-drawer__item:nth-child(6)  { transition-delay: 670ms; }
.bj-drawer-root.is-open .bj-drawer__item:nth-child(7)  { transition-delay: 720ms; }
.bj-drawer-root.is-open .bj-drawer__item:nth-child(8)  { transition-delay: 770ms; }
.bj-drawer-root.is-open .bj-drawer__item:nth-child(9)  { transition-delay: 820ms; }
.bj-drawer-root.is-open .bj-drawer__item:nth-child(10) { transition-delay: 870ms; }

.bj-drawer-root.is-open .bj-drawer__cta-row            { transition-delay: 880ms; }

/* When closing - all elements exit together quickly */
.bj-drawer-root.is-closing [data-bj-stagger],
.bj-drawer-root.is-closing .bj-drawer__item {
    opacity: 0;
    transform: translateX(24px);
    transition-delay: 0ms !important;
    transition-duration: 240ms;
}

/* Body lock helper */
body.bj-drawer-locked {
    overflow: hidden;
    touch-action: none;
}

/* ==========================================================================
   PREFERS REDUCED MOTION
   ========================================================================== */
@media (prefers-reduced-motion: reduce) {
    .bj-nav,
    .bj-nav *,
    .bj-nav *::before,
    .bj-nav *::after,
    .bj-drawer-root,
    .bj-drawer-root *,
    .bj-drawer-root *::before,
    .bj-drawer-root *::after {
        transition-duration: 0.01ms !important;
        animation-duration: 0.01ms !important;
        transition-delay: 0ms !important;
    }
}

/* ============================================
   Under opbygning - tooltip badge
   Brug ved at sætte CSS-class "under-opbygning"
   pa menupunktet i WP menu-editoren
   ============================================ */

/* ============================================
   Under opbygning - tooltip badge
   Brug ved at sætte CSS-class "under-opbygning"
   pa menupunktet i WP menu-editoren
   ============================================ */

/* Sikrer at containere ikke klipper badget */
.bj-nav__bar,
.bj-nav__menu,
.bj-nav__submenu,
.bj-nav__submenu-inner,
.bj-nav__sublist {
    overflow: visible !important;
}

/* Behold contain hvor det betyder noget visuelt (border-radius corners) */
.bj-nav__submenu-inner {
    /* badget skal kunne stikke ud - vi accepterer at corner-clipping af submenu indhold falder vak */
    border-radius: 18px;
}

/* Position anchor */
.bj-nav__list .under-opbygning > a,
.bj-nav__sublist .under-opbygning > .bj-nav__sublink,
.bj-drawer .under-opbygning > .bj-drawer__link,
.bj-drawer .under-opbygning > .bj-drawer__sublink,
.bj-drawer__sublist .under-opbygning > .bj-drawer__sublink {
    position: relative !important;
}

/* ---------------------------------------------
   TOP-NIVEAU (desktop) - badge under menupunkt
   --------------------------------------------- */
.bj-nav__list .under-opbygning > a::before {
    content: "Under opbygning";
    position: absolute;
    top: calc(100% + 8px);
    left: 50%;
    transform: translateX(-50%) translateY(-4px);
    background: #EC672E;
    color: #fff;
    font-family: 'Source Sans 3', Manrope, system-ui, sans-serif;
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 0.4px;
    text-transform: uppercase;
    line-height: 1;
    padding: 5px 9px;
    border-radius: 999px;
    white-space: nowrap;
    pointer-events: none;
    opacity: 0;
    transition: opacity .25s cubic-bezier(.23,1,.32,1),
                transform .25s cubic-bezier(.23,1,.32,1);
    z-index: 1000;
    box-shadow: 0 6px 16px rgba(236, 103, 46, 0.35);
}

/* Vis ved hover/focus pa top-niveau */
@media (hover: hover) {
    .bj-nav__list .under-opbygning:hover > a::before,
    .bj-nav__list .under-opbygning > a:focus-visible::before {
        opacity: 1;
        transform: translateX(-50%) translateY(0);
    }
}
/* Sikker fallback uden hover-media (touch m.m.) */
.bj-nav__list .under-opbygning > a:focus-visible::before {
    opacity: 1;
    transform: translateX(-50%) translateY(0);
}

/* ---------------------------------------------
   SUBMENU (mega-flyout) - badge svaver over linket
   --------------------------------------------- */
.bj-nav__sublist .under-opbygning > .bj-nav__sublink::before {
    content: "Under opbygning";
    position: absolute;
    top: 4px;
    left: 16px;
    transform: translateY(4px);
    background: #EC672E;
    color: #fff;
    font-family: 'Source Sans 3', Manrope, system-ui, sans-serif;
    font-size: 9px;
    font-weight: 700;
    letter-spacing: 0.4px;
    text-transform: uppercase;
    line-height: 1;
    padding: 4px 8px;
    border-radius: 999px;
    white-space: nowrap;
    pointer-events: none;
    opacity: 0;
    transition: opacity .25s cubic-bezier(.23,1,.32,1),
                transform .25s cubic-bezier(.23,1,.32,1);
    z-index: 5;
    box-shadow: 0 4px 12px rgba(236, 103, 46, 0.3);
}

/* Vis ved hover/focus pa submenu-punkt */
@media (hover: hover) {
    .bj-nav__sublist .under-opbygning > .bj-nav__sublink:hover::before,
    .bj-nav__sublist .under-opbygning > .bj-nav__sublink:focus-visible::before {
        opacity: 1;
        transform: translateY(-12px);
    }
}
.bj-nav__sublist .under-opbygning > .bj-nav__sublink:focus-visible::before {
    opacity: 1;
    transform: translateY(-12px);
}

/* Pilen fader ud nar man hover pa et under-opbygning punkt,
   sa fokus er pa "Under opbygning"-badget */
.bj-nav__sublist .under-opbygning > .bj-nav__sublink .bj-nav__sublink-arrow {
    transition: background-color 280ms ease,
                color 280ms ease,
                transform 380ms var(--bj-ease-out),
                opacity 250ms cubic-bezier(.23,1,.32,1);
}

@media (hover: hover) and (pointer: fine) {
    .bj-nav__sublist .under-opbygning > .bj-nav__sublink:hover .bj-nav__sublink-arrow,
    .bj-nav__sublist .under-opbygning > .bj-nav__sublink:focus .bj-nav__sublink-arrow,
    .bj-nav__sublist .under-opbygning > .bj-nav__sublink:focus-visible .bj-nav__sublink-arrow {
        opacity: 0;
        transform: scale(0.8);
        background-color: var(--bj-off-white);
        color: var(--bj-ink-500);
    }
}



/* ---------------------------------------------
   MOBIL DRAWER - badge inline efter teksten
   Vises ALTID som default pa de relevante punkter, sa brugeren
   ser "Under opbygning" med det samme - ikke forst ved tap/klik.
   --------------------------------------------- */
.bj-drawer .under-opbygning > .bj-drawer__link::after,
.bj-drawer .under-opbygning > .bj-drawer__sublink::after {
    content: "Under opbygning";
    display: inline-block;
    margin-left: 10px;
    background: #EC672E;
    color: #fff;
    font-family: 'Source Sans 3', Manrope, system-ui, sans-serif;
    font-size: 9px;
    font-weight: 700;
    letter-spacing: 0.4px;
    text-transform: uppercase;
    line-height: 1;
    padding: 4px 8px;
    border-radius: 999px;
    white-space: nowrap;
    vertical-align: middle;
    flex-shrink: 0;
    margin-right: auto;
    box-shadow: 0 4px 12px rgba(236, 103, 46, 0.3);
    /* Default synlig - ingen afhangighed af hover/touch-detektion */
    opacity: 1;
    transform: translateX(0);
    transition: opacity .25s cubic-bezier(.23,1,.32,1),
                transform .25s cubic-bezier(.23,1,.32,1);
}

/* Respekter reduceret bevagelse */
@media (prefers-reduced-motion: reduce) {
    .bj-nav__list .under-opbygning > a::before {
        transition: opacity .15s ease;
    }
}