/*Header Navigation*/
/* Nav General Styles */
.headerBottomContainer {
    background: linear-gradient(90deg, var(--theme-dark-blue) 0%, var(--theme-dark-blue) 100%);
    font-size: 16px;
    line-height: 1em;
    margin-left: auto;
    margin-right: auto;
    height: var(--header-nav-height);
}
.headerNavigation {
    position: relative;
    height: 100%;
    max-width: var(--page-max-width);
    margin-left: auto;
    margin-right: auto;
    font-weight: bold;
}
.headerNavigation :is(a, a:visited, a:active) {
    color: rgba(255,255,255,0);
    text-shadow: 0px 0px 0px white;
    display: inline-block;
    text-decoration: none;
    font-size: 15px;
    padding-top: 10px;
    padding-bottom: 10px;
    margin-right: 25px;
}
.headerNavigation ul {
    margin: 0;
    padding: 0;
    list-style: none;
}
.headerNavList {
    display: flex;
    opacity: 1;
    flex-wrap: wrap;
    /* Have the items line up top to bottom by default */
    flex-direction: column;
}
.nestedLinkList__manualDropDown:not(:checked) ~ .headerNavList,
.nestedLinkList__manualDropDown:not(:checked) ~ .headerNavList > li {
    /* Menus and their children should be hidden by default if their toggle is not checked */
    display: none;
    opacity: 0;
}


/* Style the List Expander checkbox */
.headerNavList input:checked {
    transform: rotate(90deg);
}
.headerNavList input {
    all: unset;
    cursor: pointer;
    transition: transform .3s;

    /* Make it a triangle pointing right */
    border-top: 0.5em solid transparent;
    border-bottom: 0.5em solid transparent;
    border-left: 1em solid white;
    height: 0;
    width: 0;
}

/* Layout the nav nestings */
.headerNavList li {
    display: grid;
    opacity: 1;
    grid:
        "arrow . parent" min-content
        ". child child" 1fr
        / 1em 1em auto;
    align-items: center;
}
.headerNavList input {
    grid-area: arrow;
}
.headerNavList a {
    grid-area: parent;
}
.headerNavList {
    grid-area: child;
}




/********* Desktop Nav *****************/
.headerNavList.nestedLinkList--d1:not(.useMobile) {
    /* For desktop nav we want the initial menu to go left to right */
    flex-direction: row;
    /* Ensure the initial menu is always desplayed on desktop */
    display: flex;
    opacity: 1;
    margin-left: 30px;
}
@media screen and (max-width: 470px) {
    .headerNavList.nestedLinkList--d1:not(.useMobile) {
        margin-left: 150px;
    }
}
@media screen and (min-width: 570px) {
    .headerNavList.nestedLinkList--d1:not(.useMobile) {
        /* Padding so we don't overlap with logo */
        margin-left: 150px; /* logo p-l (5px) + logo w (100px) + m-l jlogo (10px) + 3px to make it feel lines up */
    }
}
@media screen and (max-width: 300px) {
    .headerNavList.nestedLinkList--d1:not(.useMobile) {
        margin-left: 30px;
    }
}

/* This creates the container for overlaying the 2nd level+ of navs */
.headerNavList.nestedLinkList--d1:not(.useMobile) .headerNavList.nestedLinkList--d2 {
    position: absolute;
    border: 1px solid rgba(255, 255, 255, .5);
    padding: 10px;
    padding-top: 5px;
    padding-bottom: 5px;
    background: linear-gradient(90deg, var(--theme-dark-blue) 0%, var(--theme-dark-blue) 100%);
    height: auto;
    margin-top: -1px;
    margin-left: -20px;
    width: 280px;
}
/* Ensures 2nd level container displays properly and main level nav appears */
.headerNavList.nestedLinkList--d1:not(.useMobile) > li {
    display: block;
    opacity: 1;
}
.headerNavigation .nestedLinkList__manualDropDown.nestedLinkList--d1:not(.useMobile),
.headerNavList.nestedLinkList--d1:not(.useMobile) .nestedLinkList__manualDropDown.nestedLinkList--d2 {
    /* Hide the checkbox for main nav and 1st level on desktop */
    display: none;
    opacity: 0;
}
/***** Open the 1st level menus on hover ****/
.headerNavList.nestedLinkList--d1:not(.useMobile) .headerNavList.nestedLinkList--d2 {
    opacity: 0;
    display: none;
    translate: 0 -1em;
    transition:
        opacity 0.4s,
        display 0.4s allow-discrete,
        translate 0.4s;
}
.headerNavList.nestedLinkList--d1:not(.useMobile) > li:hover > .headerNavList,
.headerNavList.nestedLinkList--d1:not(.useMobile) > li > .headerNavList:hover,
.headerNavList.nestedLinkList--d1:not(.useMobile) > li:hover > .headerNavList > li,
.headerNavList.nestedLinkList--d1:not(.useMobile) > li > .headerNavList:hover > li {
    opacity: 1;
    display: grid;
    translate: 0;
}
@starting-style {
    .headerNavList.nestedLinkList--d1:not(.useMobile) > li:hover > .headerNavList,
    .headerNavList.nestedLinkList--d1:not(.useMobile) > li > .headerNavList:hover {
        opacity: 0;
        translate: 0 -1em;
    }
}



/******** Mobile Nav *****************/
.headerNavList.nestedLinkList--d1.useMobile {
    background: linear-gradient(90deg, var(--theme-dark-blue) 0%, var(--theme-dark-blue) 100%);
    padding: 10px;
    padding-top: 0;
    display: inherit;
    opacity: 1;
}

/* Hamburger styling */
/* Make the checkbox for the main nav take up
    the whole area to then be covered by the hamburger */
.nestedLinkList__manualDropDown.nestedLinkList--d1:has(~ .headerNavList.useMobile) {
    all: unset;
    width: 100%;
    align-items: center;
    height: 100%;
    justify-content: space-evenly;
    cursor: pointer;
    display: flex;
}
/* Create top and bottom elements */
.headerNavigation .nestedLinkList__manualDropDown.nestedLinkList--d1:before,
.headerNavigation .nestedLinkList__manualDropDown.nestedLinkList--d1:after {
    content: '';
}
.headerNavigation .nestedLinkList__manualDropDown.nestedLinkList--d1:before {
    transform: translateY(-10px);
}
.headerNavigation .nestedLinkList__manualDropDown.nestedLinkList--d1:after {
    transform: translateY(10px);
}
/* Create middle element (using the ul) */
.nestedLinkList__manualDropDown.nestedLinkList--d1:not(:checked) ~ .headerNavList.useMobile {
    background: none;
    left: calc(50% - 18px);
    top: calc(50% - 2px);
    margin: 0;
    padding: 0;
}
/* Style the hamburger parts */
.nestedLinkList__manualDropDown.nestedLinkList--d1:not(:checked) ~ .headerNavList.useMobile,
.headerNavigation .nestedLinkList__manualDropDown.nestedLinkList--d1:before,
.headerNavigation .nestedLinkList__manualDropDown.nestedLinkList--d1:after {
    position: absolute;
    width: 36px;
    height: 4px;
    background-color: white;
    border-radius: 2px;
    transition: transform 0.6s;
    cursor: pointer;
}
.headerNavigation .nestedLinkList__manualDropDown.nestedLinkList--d1:checked:before {
    transform: rotate(45deg);
}
.headerNavigation .nestedLinkList__manualDropDown.nestedLinkList--d1:checked:after {
    transform: rotate(-45deg);
}