/*required for position: sticky*/
/*body {
    width: max-content;
}*/

.headersOuter, .headersOuterSpacer {/*.headersOuter would not scroll properly with position: sticky. But I am now using position: fixed with .headersOuterSpacer to cause the same effect.*/
    flex: 0 0 auto;
}

.headersOuter {
    position: sticky;
    left: 0;
    top: 0;
    right: 0;
    z-index: 2; /*Above #jobMenuContainer*/
}

#jobMenu {
    left: 0;
    z-index: 2; /*Above floating <thead>*/
}
/*end required for position: sticky*/

#header, #menuDialog > .topRow {
    background-color: #004463;
    display: flex;
    align-items: center;
    height: 48px;
}

#header > .menuDialogOpener, #header > a.logo, #header > .branding, #menuDialog > .topRow > .menuDialogCloser {
    flex: 0 1 auto;
}

#header > .menuDialogOpener, #menuDialog > .topRow > .menuDialogCloser {
    color: white;
    text-decoration: none;
}

#menuDialog > .topRow > .menuDialogCloser {
    display: flex;
}

#header > .menuDialogOpener, #header a.logo, #menuDialog > .topRow > .menuDialogCloser {
    height: 100%;
}

#header a.logo {
    display: flex;
}

#header > .menuDialogOpener {
    display: none;
}

#header a.logo > img, #header > .menuDialogOpener > span, #menuDialog > .topRow > .menuDialogCloser > span, #menuDialog > .topRow > .logo {
    display: block;
    padding: 0 10px;
    align-self: center;
}

#header > .menuDialogOpener > span, #menuDialog > .topRow > .menuDialogCloser > span {
    text-align: center;
    font-size: 14px;
    width: 14px;
}

#menuDialog > .topRow > .logo > img {
    display: block;
}

#menuDialog > .topRow > h2.temporaryTitle {
    display: none;
    color: white;
    text-transform: none;
    font-size: 15px;
    padding-left: 5px;
}

nav.siteMenuJobMenuOrMenuDialog ul {
    list-style: none;
    padding: 0;
    margin: 0;
}

nav.siteMenuJobMenuOrMenuDialog ul > li > a {
    display: block;
}

nav.siteMenu ul {
    flex: 1 0 auto;
}

#header > .siteMenuOuter {
    flex: 1 0 auto;
    align-self: stretch;
}

nav.siteMenu, nav.siteMenu > ul, nav.siteMenu > ul > li, nav.siteMenu > ul > li > a {
    height: 100%;
}

nav.siteMenu > ul > li {
    display: inline-block;
}

nav.siteMenu > ul > li > a {
    display: flex;
}

nav.jobMenuOrMenuDialog ul > li > a {
    display: block;
}

nav.siteMenu > ul > li > a {
    padding: 0 10px;
}

nav.siteMenu > ul > li > a > span {
    align-self: center;
    color: white;
    padding-right: 5px;
}

nav.siteMenu > ul > li > a > span:last-child {
    padding-right: 0;
}

nav.siteMenu > ul > li > a > span.icon {
    opacity: .3;
}

nav.siteMenu > ul > li > a > span.label {
    font-size: 13px;
    font-weight: 450;
    letter-spacing: .2px;
}

nav.siteMenu > ul > li > a {
    display: flex;
}

#header > a, nav.siteMenu > ul > li > a, #menuDialog > .topRow > .menuDialogCloser {
    border-width: 0 1px;
    border-style: solid;
    border-color: transparent;
}

#header > a:hover, nav.siteMenu > ul > li > a:hover, #menuDialog > .topRow > .menuDialogCloser:hover {
    background-color: #00000080;
    border-color: #000000b2;
}

#header > a:active, nav.siteMenu > ul > li > a:active, #menuDialog > .topRow > .menuDialogCloser:active, nav.siteMenu > ul > li.open > a {
    background-color: #00000033;
    border-color: #00000051;
}

nav.siteMenu > ul > li > a.selected {
    background-color: #00000030;
}

nav.siteMenuJobMenuOrMenuDialog a:hover {
    text-decoration: none;
}

nav.siteMenuJobMenuOrMenuDialog > ul > li a > span.icon {
    padding-right: 10px;
}

nav.siteMenuJobMenuOrMenuDialog > ul > li a > span.menuArrow {
    color: var(--gray-400);
    padding-left: 5px;
}

#jobMenuContainer.collapsed nav > ul > li a > span.menuArrow {
    padding-left: 0;
    margin-left: -2px;
}

nav.siteMenu > ul > li a > span.menuArrow:before {
    content: "\f107";
}

#header li:hover > a > span, #header li.open > a > span {
    opacity: 1;
}

#header > .branding, #header > .branding > img {
    box-sizing: border-box;
    height: 100%;
}

#header > .branding {
    padding: 5px;
}

#header > .branding > img {
    height: 100%;
    display: block;
    border-radius: 5px;
    padding: 3px;
    background-color: white;
}

.jobHeader, #jobMenuContainer {
    background-color: var(--gray-100);
}

#menuDialog {
    margin-left: 0;
    margin-top: 0;
    height: 100%;
    max-height: 100%;
    width: 95%;
}

#menuDialog > div > nav {
    padding: 10px;
}

#menuDialog ul > li > a {
    display: block;
}

#menuDialog ul > li > a > span.icon {
    min-width: 20px;
}

#menuDialog ul > li > a > span.menuArrow {
    float: right;
}

#menuDialog ul > li > a > span.menuArrow:before {
    content: "\f0da";
}

#jobMenuContainer {
    flex: 0 0 auto;
    width: 224px;
    transition: width linear .1s;
    z-index: 1;
    position: sticky;
    left: 0;
}

#jobMenuContainer.collapsed {
    width: 60px;
}

#jobMenuContainer .topRow h2, #jobMenuContainer div > nav > ul > li > a > span.label { /*for collapse transition*/
    white-space: nowrap;
    overflow: hidden;
}

#jobMenuContainer.collapsed .topRow h2 {
    opacity: 0;
    width: 0;
    padding-left: 0;
    flex-grow: 0;
}

/* Start of Fake Tooltip */

#jobMenuContainer.collapsed > div > nav > ul > li > a > span.label {
    width: 0;
    margin-top: -5px;
    font-weight: normal;
}

#jobMenuContainer.collapsed > div > nav > ul > li > a:hover > span.label {
    left: 100%;
}

#jobMenuContainer.collapsed > div > nav > ul > li > a > span.label:before {
    content: attr(data-tooltip);
    position: absolute;
    left: 100%;
    margin-left: 10px;
    padding: 8px 12px;
    border-radius: 8px;
    color: white;
    background: #101828;
    display: none;
    box-shadow: 0px 12px 16px -4px #10182854;
}

#jobMenuContainer.collapsed > div > nav > ul > li > a > span.label:after {
    content: "";
    position: absolute;
    left: 100%;
    margin-left: 0px;
    margin-top: -4px;
    border-width: 5px;
    border-style: solid;
    border-color: transparent #101828 transparent transparent;
    display: none;
}

#jobMenuContainer.collapsed > div > nav > ul > li > a:hover > span.label:before, #jobMenuContainer.collapsed > div > nav > ul > li > a:hover > span.label:after {
    display: block;
}

/* End of Fake Tooltip */

#jobMenuContainer .topRow {
    display: flex;
    padding: 5px;
}

#jobMenuContainer .topRow > * {
    align-self: center;
}

#jobMenu {
    position: sticky;
    & > .topRow > h2, #menuDialog h2 {
        color: var(--gray-500);
        font-size: 12px;
        text-transform: uppercase;
    }
}

#jobMenuContainer .topRow h2 {
    font-size: 12px;
    flex: 1 0 auto;
    padding-left: 5px;
}

#jobMenuContainer .topRow button {
    flex: 0 1 auto;
    width: 36px;
    height: 36px;
    border-radius: 4px;
    border: 1px solid transparent;
    background-color: transparent;
    box-shadow: none;
}

#jobMenuContainer .topRow button:hover {
    background-color: rgba(0,69,99,0.09);
    border-color: rgba(0,69,99,0.09);
    color: var(--primary-700);
}

#jobMenuContainer .topRow button span:before {
    content: "\f191";
}

#jobMenuContainer.collapsed .topRow button {
    margin: 0 auto;
}

#jobMenuContainer.collapsed .topRow button span:before {
    content: "\f152";
}

nav.siteMenu ul ul > li, nav.jobMenu ul > li, nav.menuDialog > ul ul li, nav.menuDialog.temporaryContent ul li {
    border-top: 1px solid #96bbcf33;
}

nav.jobMenuOrMenuDialog ul > li:first-child {
    border-top-width: 0;
}

.jobMenuOrMenuDialog ul > li > a > span.icon {
    color: var(--gray-400);
    flex: 0 0 auto;
    width: 20px;
    text-align: center;
    padding-right: 5px;
    font-size: 16px;
}

.jobMenuOrMenuDialog ul > li > a > span.label {
    color: var(--gray-800);
}

.jobMenuOrMenuDialog ul > li > a > span.menuArrow {
    color: var(--gray-500);
}

#jobMenuContainer.collapsed > div > nav > ul > li > a > span.icon {
    font-size: 20px;
    width: 35px;
    padding-right: 0;
}

nav.siteMenuJobMenuOrMenuDialog a:hover {
    color: var(--gray-600);
}

nav.siteMenu ul ul > li > a, nav.jobMenuOrMenuDialog ul > li > a, nav.jobMenuOrMenuDialog ul > li > a:hover > span.icon, nav.jobMenuOrMenuDialog ul > li > a.selected > span.icon, nav.jobMenuOrMenuDialog ul > li.open > a > span.icon {
    color: var(--gray-600);
    opacity: 1;
}

nav.siteMenu ul ul > li > a, nav.jobMenuOrMenuDialog ul > li > a {
    padding: 5px;
}

nav.siteMenuJobMenuOrMenuDialog ul ul > li > a.selected {
    background-color: var(--gray-200);
}

nav.siteMenuJobMenuOrMenuDialog ul ul > li > a:hover, nav.jobMenuOrMenuDialog > ul > li > a:hover, nav.jobMenuOrMenuDialog > ul > li.open > a {
    background-color: #e0e7eb;
}

nav.siteMenu ul ul > li > a, nav.jobMenuOrMenuDialog ul > li > a {
    font-size: 13px;
    font-weight: 450;
    line-height: 14px;
    display: flex;
    padding: 10px;
}

nav.jobMenuOrMenuDialog > ul > li > a.selected {
    font-weight: 500;
}

nav.jobMenuOrMenuDialog ul > li > a {
    align-items: center;
}

nav.jobMenu {
    padding: 2px;
}

nav.jobMenu > ul > li > a {
    padding: 11px;
}

nav.jobMenu > ul > li > a.selected {
    border-width: 1px 0;
    border-style: solid;
    border-color: var(--gray-300);
    background-color: var(--primary-700);
    border-radius: 6px;
}
nav.jobMenu > ul > li > a.selected > span, nav.jobMenu > ul > li > a.selected > span.icon {
    color: var(--base-white);
}

nav.jobMenu ul ul > li > a {
    padding: 8px;
}

.jobMenuOrMenuDialog ul > li > a > span.menuArrow {
    flex: 1 0 auto;
    text-align: right;
    align-self: center;
}

#jobMenuContainer ul > li > a > span.menuArrow:before {
    content: "\f0da";
}

nav.jobMenuOrMenuDialog > ul ul > li.nonLink > a, nav.menuDialog.temporaryContent ul > li.nonLink > a {
    padding: 6px 8px;
}

nav.siteMenuJobMenuOrMenuDialog ul ul {
    display: none;
    position: absolute;
    background-color: white;
    padding: 12px;
    border-radius: 12px;
    width: max-content;
    box-shadow: 0px 8px 48px -8px #10182833;
    outline: 1px solid rgba(0,0,0,0.25);
}

nav.siteMenuJobMenuOrMenuDialog ul ul li:first-child, nav.jobMenuOrMenuDialog ul.anyGroups li.nonLink, nav.jobMenuOrMenuDialog ul.anyGroups li.nonLink + li {
    border-top-width: 0;
}

nav.jobMenuOrMenuDialog ul.anyGroups li.nonLink {
    font-size: 12px;
}

nav.jobMenuOrMenuDialog ul.anyGroups > li.nonLink > a {
    cursor: default;
    color: var(--gray-500);
    background-color: var(--gray-200);
    border-radius: 5px;
}

nav.jobMenuOrMenuDialog ul.anyGroups li:not(.nonLink) a {
    padding-left: 16px;
}

#menuDialog .jobMenuNav {
    border-top: 1px solid var(--gray-300);
}

@media (max-width: 700px) {
    #header > .siteMenuOuter > nav {
        display: none;
    }

    #header > .menuDialogOpener {
        display: flex;
    }

    #jobMenuContainer {
        display: none;
    }
}

@media print {
    #jobMenu {position:static}
}