.quick-search-container { display:none; font-size:0.75em; margin-left:46px; }
.quick-search-container input { border-radius:2px; border:3px solid #aaa; }
.qs-go-btn { border:none; color:white; border-radius:2px; }
.favorite-wrapper:hover .quick-search-container, .favorite-wrapper.stay-open .quick-search-container, .favorite-icon:hover + .favorite-wrapper > .quick-search-container { display:block; position:relative; }

.pagetitlerow {
	color:#152C53;
	background: linear-gradient(120deg, #fff 0%, #fafafa 70%, #152C53 205%);
   	border-bottom: 2px solid #152C53;
	font-weight: unset !important;
}
.pagetitlerow .pgtitlenav, .pagetitlerow .pgtitlenav a { color: #152C53 !important; }
.pagetitlerow.ptr-1 {
    background: linear-gradient(120deg, #fff 0%, #fafafa 70%, #04a169 205%);
}
.pagetitlerow.ptr-2 {
    background: linear-gradient(120deg, #fff 0%, #fafafa 70%, #00CEC9 205%);
}
.pagetitlerow.ptr-3 {
    background: linear-gradient(120deg, #fff 0%, #fafafa 70%, #FDCB6E 205%);
}
.pagetitlerow.ptr-4 {
    background: linear-gradient(120deg, #fff 0%, #fafafa 70%, #E17055 205%);
}
.pagetitlerow.ptr-5 {
    background: linear-gradient(120deg, #fff 0%, #fafafa 70%, #A29BFE 205%);
}
.pagetitlerow.ptr-6 {
    background: linear-gradient(120deg, #fff 0%, #fafafa 70%, #0984E3 205%);
}
.pagetitlerow.ptr-7 {
    background: linear-gradient(120deg, #fff 0%, #fafafa 70%, #FD79A8 205%);
}
.pagetitlerow.ptr-8 {
    background: linear-gradient(120deg, #fff 0%, #fafafa 70%, #D63031 205%);
}
.background-color-1 { background-color: #04a169; }
.background-color-2 { background-color: #00CEC9; }
.background-color-3 { background-color: #FDCB6E; }
.background-color-4 { background-color: #E17055; }
.background-color-5 { background-color: #A29BFE; }
.background-color-6 { background-color: #0984E3; }
.background-color-7 { background-color: #FD79A8; }
.background-color-8 { background-color: #D63031; }
.border-color-1 { border-color: #04a169 !important; }
.border-color-2 { border-color: #00CEC9 !important; }
.border-color-3 { border-color: #FDCB6E !important; }
.border-color-4 { border-color: #E17055 !important; }
.border-color-5 { border-color: #A29BFE !important; }
.border-color-6 { border-color: #0984E3 !important; }
.border-color-7 { border-color: #FD79A8 !important; }
.border-color-8 { border-color: #D63031 !important; }
.border-color-9 { border-color: #c71585 !important; }
.be-menu-category:hover .color-1.be-menu-category-heading { color: #04a169 !important; }
.be-menu-category:hover .color-2.be-menu-category-heading { color: #00CEC9 !important; }
.be-menu-category:hover .color-3.be-menu-category-heading { color: #FDCB6E !important; }
.be-menu-category:hover .color-4.be-menu-category-heading { color: #E17055 !important; }
.be-menu-category:hover .color-5.be-menu-category-heading { color: #A29BFE !important; }
.be-menu-category:hover .color-6.be-menu-category-heading { color: #0984E3 !important; }
.be-menu-category:hover .color-7.be-menu-category-heading { color: #FD79A8 !important; }
.be-menu-category:hover .color-8.be-menu-category-heading { color: #D63031 !important; }
.be-menu-category:hover .color-9.be-menu-category-heading { color: #c71585 !important; }
#be-nav-menu-container { 
	position:fixed;
	top:0;
	min-height:32px;
	width:100%;
	background-color:#f1f1f1;
    border-bottom: solid 1px #ddd;
	box-sizing:border-box;
	margin-left:0;
	/* z-index:90; */
}
#be-mobile-header { 
	top: 0; 
	width: 100%; 
	min-width: 940px;
	position: fixed; 
	padding: 8px 0;     
	background-color: #244c8e; /* Fallback color */
	background: linear-gradient(0deg, rgba(0, 0, 0, 0.6), rgba(0, 0, 0, 0.6)), url(/Files/Org_Images/NAVBAR_test.jpg?version=2021_1_7);
	background-size: cover;
	background-position: center;
	display: none;
	overflow: hidden;
}
.ngb-logo, .big-company-name { display:none;}
/* Global Small Screen */
@media (max-width: 805px) {
	#be-nav-menu-container {
		display: none !important;
		/* position: unset !important; */
	}
	.hamburger-box {
		display: inline-block;
	}
	#be-mobile-header { display:block !important; position:relative;}
	.ngb-logo {display:block !important;}
	#be-footer-menu-container {margin-left: unset !important; margin-top: unset !important;}
	/*div.srch-container > .subtab { position: absolute; width: 100vw; left:0; top:-20px}*/
	#be-nav-menu-container-small #be-nav-menu-cats { max-width:unset !important; padding:0 !important; }
	#be-nav-menu-container-small div.be-menu-category {margin-top:0px !important; padding:0 !important; }
	#be-nav-menu-container-small div.be-menu-category ul { list-style-type:none; padding-left:5px; }
}
/* Global Large Screen */
@media (min-width: 805px) {
	#be-nav-menu-container {
		display: block;
		z-index: 90 !important;
	}
	#be-mobile-header, .ngb-logo { display:none !important;}
	#main-pane { margin-left:50px !important; display:block !important;}
	#sidebar { 
		overflow:hidden;
		box-shadow:0 0 4px hsla(0, 0%, 0%, 0.3);
		background-color:#444;
		color:white;
		width:50px;
		min-height:100%;
		position:fixed;
		transition:width 0.3s cubic-bezier(0.65, 0, 0.076, 1);
		/* HERE */
		transition-delay:0.75s;
		z-index:9998;
		bottom:0;
		top:0;
	}
	#sidebar .contact-link-container {
		/* Hide contact link when not hovering */
		visibility:hidden; 
		transition-delay:0.1s;
		display: inline-block;
		vertical-align: top;
		padding-top: 6px;
		padding-bottom: 6px;
		margin: 6px 0 6px 12px;
	}

	#sidebar:hover, #sidebar.stay-open { overflow-y:scroll; }
	#sidebar:hover .sidebar-top, #sidebar.stay-open .sidebar-top,#sidebar:hover .sidebar-main, #sidebar.stay-open .sidebar-main { width:264px !important; transition-delay:0s; }
	#sidebar:hover .menu-settings-link, #sidebar.stay-open .menu-settings-link, #sidebar:hover .contact-link-container { visibility:visible; transition-delay:0.1s; }
	#sidebar:hover, #sidebar.stay-open { width: 276px; transition-delay:0s; }
	#sidebar:hover .favorite-wrapper, #sidebar.stay-open .favorite-wrapper { width:270px; border-radius: 4px  0 0 4px; transition-delay:0; }
	#sidebar:hover .favorite-item, #sidebar.stay-open .favorite-item { display:inline-block; }
	#sidebar:hover .side-bar-basic-links, #sidebar.stay-open .side-bar-basic-links{ opacity:1; }
	#be-nav-menu-container-small {display:none !important;}
}

#sidebar .contact-link-container a { color: white; }
#WPSrchBar { top:0; font-size:0.75em; margin-top:0 !important; display:inline-block; }
#WPSrchBar li { float:left; margin:0; }
#WPSrchBar input.inputbox { width:60px; background-color:white; }
#WPSrchBar #LName, #WPSrchBar #FName { width: 60px; }

#WPSrchBar-addtlFlds {
    display: none; /* Hide by default */
}
#WPSrchBar:hover #WPSrchBar-addtlFlds {
    display: block; /* Show on hover */
}
#WPSrchBar:hover .bs-carot-spin {
	transform: rotate(180deg);
}
#WpSrchBar-bs-carot-spin {
	display: flex;
	align-items: center;
	justify-content: center;
	height: 30px; /*this is current height of top nav bar*/
}
.bs-carot-spin {
	transition: transform 0.2s ease-in-out;
}

/* #be-nav-menu-cats { max-width:calc(100% - 200px); } */
#be-nav-menu-container div.be-menu-category { padding:0; margin:0; }
#be-nav-menu-container .be-menu-category { display:inline-block; position:relative; }
#be-nav-menu-container .be-menu-category-heading { cursor:default !important; color: #152c53; font-size: 12px; font-weight:normal; text-transform:uppercase; margin-top:0; margin-bottom:0; margin-left:0; margin-right: 0; padding: 7px 22px 7px 14px; }
#be-nav-menu-container .be-menu-category:hover > ul { display:inline-block; }
#be-nav-menu-container .be-menu-category > ul { z-index:9999; display:none; box-shadow: 0 2px 4px #ccc; border-radius: 0 0 3px 3px; position:absolute; /*top:30px;*/ background-color:#f5f5f5; }
#be-nav-menu-container .be-menu-expander ~ ul { position:relative; display:none; border-radius: 0 2px 2px 2px;  box-shadow: 0 2px 4px #ccc; margin-top:-7px; }
#be-nav-menu-container .be-menu-expander {
	display:inline-block;
	padding: 8px 32px 10px 24px;
	margin: 0 0 0 0;
	min-width: 225px;
   	width: 100%;
   	box-sizing: border-box;
	font-size:12px;
}
#sidebar .sidebar-main > ul { padding:0 0 0 0; min-height: calc(100vh - 129px); }
#sidebar .sidebar-top img { box-sizing:border-box; width:43px !important; }
#sidebar .sidebar-top {
    padding-left: 3px;
   	padding-top: 5px;
   	padding-bottom: 5px;
	padding-right:3px;
   	border-bottom: 1px solid #777;
	width:43px;
	/* overflow: hidden; */
	white-space:nowrap;
	position:relative;
	background-color:#444;
	transition:width 0.3s cubic-bezier(0.65, 0, 0.076, 1);
	transition-delay:0.3s;
}
#sidebar .sidebar-main {
	width:43px;
	padding-left: 2px;
	padding-right:2px;
}

#sidebar .contact-link-container a { color: #ccc; }
#sidebar:hover, #sidebar.stay-open { overflow-y:scroll; }
#sidebar:hover .sidebar-top, #sidebar.stay-open .sidebar-top,#sidebar:hover .sidebar-main, #sidebar.stay-open .sidebar-main { width:264px; transition-delay:0s; }

.menu-settings-link {
    position: absolute;
    right: 10px;
    color: #777;
    font-size: 20px;
	display:inline-block;
	visibility:hidden;
	transition: visibility 0.2s;
	transition-delay:0.25s;
}
#sidebar { 
	overflow:hidden;
	box-shadow:0 0 4px hsla(0, 0%, 0%, 0.3);
	background-color:#444;
	color:white;
	width:50px;
	min-height:100%;
	transition:width 0.3s cubic-bezier(0.65, 0, 0.076, 1);
	transition-delay:0.3s;
	z-index:9998;
	bottom:0;
	top:0;
}
#sidebar .fh-banner-logo { padding-top:16px; padding-bottom:10px; }
#sidebar .favorite-wrapper { transition-delay:0.3s; white-space:nowrap; box-sizing:border-box; margin-top:2px; margin-left:10px; border-radius:15px; overflow-x:hidden; background:linear-gradient(90deg, #aaa, #aaa, #aaa, #777); width:35px; min-height:32px; transition:width 0.3s, height 0.2s; position:relative; }
#sidebar .favorite-wrapper:hover { background:linear-gradient(90deg, #bbb, #bbb, #bbb, #888); top:-1px; }
#sidebar .favorite-item a { color:black !important; display:inline-block; padding:6px 14px; text-decoration:none; }
#sidebar .favorite-item b { font-weight:normal !important; }
#sidebar .favorite-item a span { color:black !important; font-weight:normal !important; }
#sidebar .favorite-item { display:none; font-size:0.85em; margin-left: 34px; }
#sidebar .favorite-icon { border:solid 2px transparent; background-color:#555; cursor:pointer; text-transform:lowercase; box-shadow: 0 0 4px #333; position:relative; top:38px; margin-top:-26px; z-index:99; left:3px; box-sizing:border-box; height:42px; width:42px; border-radius:21px; vertical-align:top; padding-top:7px; text-align:center; }
#sidebar .favorite-icon:hover { box-shadow: 0 0 6px #222; top:37px; }
#sidebar .side-bar-basic-links { transition:opacity 0.3s; transition-delay:0.2s; padding-top:15px; padding-bottom:20px; color:#999; opacity:0; white-space:nowrap; bottom:0; width:100%; }
#sidebar .side-bar-basic-links i { display:none; }
#sidebar .side-bar-basic-links a { color:#999 !important; background-color:transparent !important; font-weight:normal; font-size:12px !important; letter-spacing:0 !important; }
#sidebar .side-bar-basic-links a:hover { text-decoration:underline !important; }
#sidebar:hover, #sidebar.stay-open { width: 276px; transition-delay:0s; }
#sidebar:hover .favorite-wrapper, #sidebar.stay-open .favorite-wrapper { width:270px; border-radius: 4px  0 0 4px; transition-delay:0; }
#sidebar:hover .favorite-item, #sidebar.stay-open .favorite-item { display:inline-block; }
#sidebar:hover .side-bar-basic-links, #sidebar.stay-open .side-bar-basic-links{ opacity:1; }
body { padding-top:0 !important; }
#be-nav-menu-container .be-menu-item.favorite-item { background-color:#ddd; }
#be-nav-menu-container .be-menu-item.favorite-item ~ .be-menu-item.favorite-item { border-top:1px solid #ccc; }
#be-nav-menu-container .be-subcategory:hover { background-color: #ddd; }
#be-nav-menu-container .be-subcategory > ul { column-gap: 1px; column-rule: 1px double #ccc; -moz-column-fill: balance;
      column-fill: balance; background-color:#eee; }
#be-nav-menu-container .be-subcategory:hover > ul  { position: absolute; left:100%; top:auto; display:inline; }
#be-nav-menu-container .be-subcategory { padding-bottom:0; margin-bottom:0; color:#555; }
#be-nav-menu-container .be-subcategory::before { transform: rotate(45deg); top:16px; }
#be-nav-menu-container .be-menu-item, #be-nav-menu-container .be-menu-item ~ li { background-color:#eee; box-sizing:border-box; font-size:11px !important; display:list-item; margin:0; padding: 6px 12px; min-width:200px; width:100%; }
#be-nav-menu-container .be-menu-item:hover { background-color:#ddd; }
#be-nav-menu-container .be-menu-item:first-of-type { padding-top:10px; border-radius: 0 2px 0 0; }
#be-nav-menu-container .be-menu-item:last-of-type { padding-bottom:10px; border-radius: 0 0 2px 2px; }
#be-nav-menu-container div.be-menu-category::before { 
    border-style: solid;
    border-width: 0.1em 0.1em 0 0;
    content: '';
    display: inline-block;
    height: 0.25em;
    left: -8px;
    position: relative;
    top: 12px;
    float: right;
    transform: rotate(135deg);
    vertical-align: top;
    width: 0.25em;
	color:#bbb;
}
/* no subcategories so no caret needed */
#be-nav-menu-container div.be-menu-category + .no-caret::before {
	transform: unset !important;
	border-style: unset !important;
	border-width: unset !important;
}
#sidebar ::-webkit-scrollbar { width: 6px; height:6px; }
::-webkit-scrollbar-track { background: #e1e5e7; }
::-webkit-scrollbar-thumb { background: #586E81; }
::-webkit-scrollbar-thumb:hover { background: #152C53; }

#be-footer-menu-container { padding: 0 3%; 
	background-color: #e1e5e7;
    border-top: 1px solid #152C53;
    background: -webkit-linear-gradient(top, #e1e4ec, white);
	/*margin-top:100px;*/
	font-size:80%;
	margin-left:50px;
	margin-right:0px;
 }
#be-footer-menu-container > .row { margin:0 auto; max-width:1900px; }
#be-footer-menu-container h6.be-menu-expander ~ ul { display:none; padding:0; }
#be-footer-menu-container .be-menu-category-flat > ul { display:none; }
#be-footer-menu-container .be-menu-category-flat > h6.be-menu-category-heading { cursor:pointer !important; padding-right:20px; position:relative; }
#be-footer-menu-container .be-menu-category-flat > h6.be-menu-category-heading:hover { background-color:#ddd; color:#555; }
#be-footer-menu-container .be-menu-category-flat > h6.be-menu-category-heading::after {
	border-style: solid; border-width: 0.15em 0.15em 0 0; content:''; display:inline-block;
	height: 0.35em; width: 0.35em; margin-left: 0.5em; vertical-align: middle;
	transform: rotate(135deg); transition: transform 0.2s;
}
#be-footer-menu-container .be-menu-category-flat.is-expanded > h6.be-menu-category-heading::after { transform: rotate(-45deg); }
.be-menu-item { margin-bottom: 8px; margin-top:8px; }
h6.be-menu-expander { margin:0 0 3px 0; padding-right:20px; font-size:1em; font-weight:normal; }
h6.be-menu-expander:hover { cursor:pointer; background-color:#ddd; color:#555; }
div.be-menu-category > ul { display:block; padding:0; }
#be-footer-menu-container h6.be-menu-category-heading, #be-menu-settings-container  h6.be-menu-category-heading { margin:8px 4px 0 0; font-size:1.1em; text-transform:uppercase; cursor:default !important; }
div.be-menu-category { color:#777; padding: 0 2%; margin-top:32px; box-sizing:border-box; }
div.be-menu-category ul { list-style-type:none; padding-left:0; }
#be-footer-menu-container-small .be-subcategory { border-bottom: none; }
.be-subcategory { border-bottom: 1px solid #ccc; margin-bottom:10px; padding-bottom:5px; margin-left:0; }
.be-subcategory::before { 
    border-style: solid;
    border-width: 0.15em 0.15em 0 0;
    content: '';
    display: inline-block;
    height: 0.25em;
    left: -8px;
    position: relative;
    top: 0.55em;
    float: right;
    transform: rotate(135deg);
    vertical-align: top;
    width: 0.25em;
 }
#be-footer-menu-container div.be-menu-category i.fa, #be-menu-settings-container div.be-menu-category i.fa { display:none; }


#be-menu-settings-container { font-size:85%; padding-left:16px; padding-right:16px; }
#be-menu-settings-container h6.be-menu-expander ~ ul { display:none; padding:0; }
#be-menu-settings-container h6.be-menu-expander { padding-right: 50px; width: calc(100% - 5em); margin-right:-16px; }
#be-menu-settings-container .be-menu-item a { width:70%; display:inline-block; }
.menu-setting { display:inline-block; width:15%; text-align:center; }
.menu-setting p { margin:0 0 2px 0;}
#be-menu-settings-container .be-menu-item:first-of-type .menu-setting-show p::before { content:'show'; }
#be-menu-settings-container .be-menu-item:first-of-type .menu-setting-fav p::before { content:'fav'; }
.cascade-checkbox, .cascade-checkbox ~ h6 { display:inline-block; }/* JMC - 04/20/2026 - MDB navbar upgrade overrides - v27 */
/* Loaded after BE_Menu.css for PHP BE pages only. */
/* Do NOT modify BE_Menu.css — it is shared with the ASP site. */

/* --- Sidebar: shift down below fixed navbar (desktop only) --- */
/* BE_Menu.css sets top:0; on mobile the sidebar uses position:relative — top would double-offset.
   Also shrink height so the nav bottom lands at viewport bottom (not offscreen) —
   absolute-bottom children (.side-bar-basic-links) rely on nav fitting the viewport. */
@media (min-width: 806px) {
    #sidebar {
        top: var(--be-nav-height) !important;
        --mdb-sidenav-height: calc(100vh - var(--be-nav-height));
    }
}
/* JMC - 04/21/2026 - Sidebar-top: always-on padding (logo/gear now in navbar).
   Contact-link-container visibility is handled by MDB Sidenav slim-class rules further down. */
#sidebar .sidebar-top { padding-top: 10px !important; padding-bottom: 8px !important; border-bottom: none !important; position: relative !important; z-index: 200 !important; }

/* Style the user name link as a pill button — clearly clickable, aligned with the icons */
#sidebar .contact-link-container a {
    display: inline-block !important;
    margin-left: 10px !important;
    padding: 4px 14px !important;
    border: 1px solid #888 !important;
    border-radius: 20px !important;
    color: #ddd !important;
    font-size: 0.8rem !important;
    white-space: nowrap !important;
    text-decoration: none !important;
    background-color: transparent !important;
    transition: background-color 0.15s, border-color 0.15s !important;
}
#sidebar .contact-link-container a:hover { background-color: rgba(255,255,255,0.15) !important; border-color: #bbb !important; color: #fff !important; }

/* --- Navbar z-index, height, overflow --- */
/* z-index must exceed sidebar's 9998 so mobile collapse overlays it */
#be-nav-menu-container {
    z-index: 9999 !important;
    min-height: unset !important;
    overflow: visible !important;
    padding-top: 0.2rem !important;
    padding-bottom: 0.2rem !important;
}

/* --- Desktop (>805px): always-expanded, nav items wrap freely inside collapse --- */
/* navbar-expand forces collapse display:flex and hides toggler; we allow internal wrapping */
@media (min-width: 806px) {
    #be-nav-menu-container .navbar-collapse {
        display: flex !important;
        flex-basis: auto !important;
        align-items: flex-start !important;
    }
    /* navbar-nav wraps onto multiple rows when screen is too narrow */
    #be-nav-menu-container .navbar-nav {
        flex-wrap: wrap !important;
        align-items: center !important;
    }
    #be-nav-menu-container .navbar-toggler { display: none !important; }
    /* Compact logo — image only, no company name text (sidebar carries that) */
    #be-nav-menu-container .navbar-brand { padding: 0 !important; margin-right: 0.5rem !important; }
    #be-nav-menu-container .navbar-brand img { max-height: 34px; width: auto; }
    #be-nav-menu-container .navbar-brand .big-company-name { display: none !important; }
    /* Both icons pinned to top-right regardless of how many rows menu items wrap to */
    #WPSrchDropdown,
    .be-navbar-icon { align-self: flex-start; padding-top: 6px; }
    /* Search is primary — give it breathing room from the gear */
    #WPSrchDropdown { margin-right: 1.5rem; }
}

/* --- Mobile (≤805px): hamburger, accordion nav panel --- */
@media (max-width: 805px) {
    #be-nav-menu-container { display: flex !important; }

    /* flex-wrap:wrap keeps brand+toggler on their own top row;
       collapse wraps to a separate full-width row below them so the
       logo never drifts to vertical-center of the expanded panel */
    #be-nav-menu-container .container-fluid {
        flex-wrap: wrap !important;
        align-items: center !important;
    }

    /* Collapse: hidden by default; shown state = full-width scrollable panel */
    #be-nav-menu-container .navbar-collapse { display: none !important; }
    #be-nav-menu-container .navbar-collapse.show {
        display: block !important;
        flex: 0 0 100% !important;
        max-height: calc(100vh - 50px);
        overflow-y: auto;
        background: #fff;
        border-top: 1px solid rgba(0,0,0,.1);
        padding-bottom: 2rem;
    }

    #be-nav-menu-container .navbar-toggler { display: block !important; }
    /* Desktop search icon hidden — search form lives at bottom of hamburger panel */
    #WPSrchDropdown { display: none !important; }

    /* Stack categories vertically */
    #be-nav-menu-container .navbar-nav { flex-direction: column !important; }

    /* Full-width tappable category rows */
    #be-nav-menu-container .nav-link,
    #be-nav-menu-container .be-menu-category > .dropdown-menu .dropdown-item {
        display: block !important;
        padding: 0.5rem 1rem !important;
        border-bottom: 1px solid rgba(0,0,0,.06) !important;
        white-space: normal !important;
    }

    /* Chevron rotates to indicate open/closed state */
    #be-nav-menu-container .nav-link.dropdown-toggle::after { transition: transform 0.2s; }
    #be-nav-menu-container .be-menu-category.mobile-open > .nav-link.dropdown-toggle::after {
        transform: rotate(180deg);
    }
}

/* Hide mobile-only nav items on desktop */
@media (min-width: 806px) {
    .be-navbar-mobile-search { display: none !important; }
    .be-navbar-profile-mobile { display: none !important; }
    .be-navbar-mobile-actions { display: none !important; }
}

/* Hide desktop-only nav items on mobile */
@media (max-width: 805px) {
    .be-navbar-profile-desktop { display: none !important; }
    /* JMC - 04/22/2026 - Belt-and-suspenders: zero the main-pane margin on mobile.
       BE_menu2.js calls MdbSidenav.hide() on mobile which removes the inline
       margin-left injection, but this rule defeats the legacy BE_Style.css
       baseline (`#main-pane { margin-left: 50px }`) in case JS hasn't run yet. */
    #main-pane { margin-left: 0 !important; }
}

/* Main-pane top padding — updated dynamically by JS when navbar wraps to 2 rows */
#main-pane { padding-top: 46px !important; }

/* Compress nav item padding at medium widths to keep categories in one row */
@media (min-width: 806px) and (max-width: 1280px) {
    #be-nav-menu-container .be-menu-category-heading {
        padding-left: 8px !important;
        padding-right: 8px !important;
        font-size: 11px !important;
        letter-spacing: 0 !important;
    }
}

/* --- Remove old pseudo-element carets (BE_Menu.css adds arrows via ::before) --- */
#be-nav-menu-container .be-menu-category::before { display: none !important; }
#be-nav-menu-container .be-subcategory::before { display: none !important; }

/* --- Remove old subcategory borders/margins (BE_Menu.css global rule adds dividers) --- */
#be-nav-menu-container .be-subcategory {
    border-bottom: none !important;
    margin-bottom: 0 !important;
    padding-bottom: 0 !important;
}
#be-nav-menu-container .be-subcategory > ul {
    columns: unset !important;
    column-gap: unset !important;
    column-rule: unset !important;
}

/* --- Explicit dropdown positioning ---
// Top-level: position:absolute top:100% places the dropdown flush against the bottom of the <li>.
// This is zero-gap — cursor moves seamlessly from heading into dropdown, keeping :hover active.
// position:fixed was tried but created a physical gap (fixed is viewport-relative, not li-relative). */
#be-nav-menu-container .be-menu-category > .dropdown-menu {
    position: absolute !important;
    top: 100% !important;
    left: 0 !important;
    margin-top: 0 !important;
    transform: none !important;
}
#be-nav-menu-container .be-subcategory > .dropdown-menu {
    position: absolute !important;
    top: -4px !important;
    left: calc(100% - 4px) !important;
    margin-top: 0 !important;
    transform: none !important;
}

/* --- Hover dropdowns: instant show/hide, no delay ---
// Scope display:none only to nav menu dropdowns — NOT #WPSrchDropdown (which uses Bootstrap JS).
// Overlap triggers by a few px so the hover chain stays unbroken. */
#be-nav-menu-container .be-menu-category > .dropdown-menu,
#be-nav-menu-container .be-subcategory > .dropdown-menu { display: none; animation: none !important; }

#be-nav-menu-container .be-menu-category:hover > .dropdown-menu { display: block !important; }
#be-nav-menu-container .be-subcategory:hover > .dropdown-menu { display: block !important; }

/* .show class for JS / mobile touch */
#be-nav-menu-container .be-menu-category > ul.show { display: block !important; }
#be-nav-menu-container .be-subcategory > ul.show { display: block !important; }

/* Mobile overrides — MUST be after all global rules above.
   Same specificity means last-in-file wins. Covers position, display, and hover-disable. */
@media (max-width: 805px) {
    /* Accordion: flow inline so expanded items push content below down */
    #be-nav-menu-container .be-menu-category > .dropdown-menu,
    #be-nav-menu-container .be-subcategory > .dropdown-menu {
        position: static !important;
        float: none !important;
        box-shadow: none !important;
        border: none !important;
        border-radius: 0 !important;
        padding: 0 0 0.5rem 1.25rem !important;
        margin: 0 !important;
        background-color: transparent !important;
        min-width: unset !important;
        width: 100% !important;
        transform: none !important;
    }
    /* No sticky gray highlight on subcategory expander row after tap */
    #be-nav-menu-container .be-subcategory,
    #be-nav-menu-container .be-menu-expander:hover,
    #be-nav-menu-container .be-menu-expander:focus,
    #be-nav-menu-container .be-menu-expander:active { background-color: transparent !important; }
    /* Disable hover-open on touch */
    #be-nav-menu-container .be-menu-category:hover > .dropdown-menu,
    #be-nav-menu-container .be-subcategory:hover > .dropdown-menu { display: none !important; }
    /* JS .mobile-open shows the panel — must follow hover-disable above */
    #be-nav-menu-container .be-menu-category.mobile-open > .dropdown-menu,
    #be-nav-menu-container .be-subcategory.mobile-open > .dropdown-menu { display: block !important; }
}

/* --- Fix be-menu-item spacing and display --- */
/* BE_Menu.css line 315 has a GLOBAL .be-menu-item { margin: 8px 0 } that inflates every row */
#be-nav-menu-container .be-menu-item,
#be-nav-menu-container .be-menu-item ~ li {
    display: block !important;
    margin: 0 !important;
    padding: 0 !important;
    background-color: transparent !important;
    min-width: unset !important;
    width: unset !important;
    font-size: unset !important;
    box-sizing: unset !important;
    border-radius: unset !important;
}
#be-nav-menu-container .be-menu-item:hover { background-color: transparent !important; }
#be-nav-menu-container .be-menu-item.favorite-item { background-color: unset !important; }

/* --- Search form --- */
#WPSrchBar { margin-top: 0 !important; }

/* JMC - 04/21/2026 - Shared plain icon style for search + gear */
.be-navbar-icon { color: #6c757d; text-decoration: none !important; }
.be-navbar-icon:hover { color: #343a40 !important; text-decoration: none !important; }

/* --- Modern dropdown typography --- */
/* BE_Style.css body font falls back to Century Gothic (not loaded); use Bootstrap's system stack.
// --bs-dropdown-font-size defaults to 1rem (16px) which is too large for a dense admin nav. */
#be-nav-menu-container .dropdown-menu {
    font-family: var(--bs-body-font-family) !important;
    font-size: 0.8125rem !important;
    border-radius: var(--bs-dropdown-border-radius, 0.375rem) !important;
    box-shadow: 0 0.25rem 0.75rem rgba(0,0,0,.12) !important;
    border: 1px solid rgba(0,0,0,.15) !important;
}

/* Override a { color: #094B87; text-decoration:underline on hover } from BE_Style.css */
#be-nav-menu-container .dropdown-menu a,
#be-nav-menu-container .dropdown-menu .dropdown-item {
    color: var(--bs-dropdown-link-color, #212529) !important;
    text-decoration: none !important;
    font-family: var(--bs-body-font-family) !important;
    font-size: 0.8125rem !important;
    padding: 0.375rem 1rem !important;
    line-height: 1.4 !important;
}
#be-nav-menu-container .dropdown-menu a:hover,
#be-nav-menu-container .dropdown-menu .dropdown-item:hover {
    color: var(--bs-dropdown-link-hover-color, #1e2125) !important;
    background-color: var(--bs-dropdown-link-hover-bg, #f8f9fa) !important;
    text-decoration: none !important;
}

/* --- Style function-generated links (GroupItemsLink, RptLink, etc.) as dropdown items --- */
.dropdown-menu .be-menu-item > a {
    display: block;
    padding: 0.375rem 1rem;
    color: var(--bs-dropdown-link-color, #212529);
    text-decoration: none !important;
    white-space: nowrap;
    font-family: var(--bs-body-font-family);
    font-size: 0.8125rem;
    line-height: 1.4;
}
.dropdown-menu .be-menu-item > a:hover {
    color: var(--bs-dropdown-link-hover-color, #1e2125) !important;
    background-color: var(--bs-dropdown-link-hover-bg, #f8f9fa);
    text-decoration: none !important;
}

/* ================================================================ */
/* JMC - 04/21/2026 - MDB Sidenav modernization                     */
/* Replaces legacy custom hover-expand sidebar with MDB 9.3.0.      */
/* Loaded after BE_Menu.css (shared w/ ASP) so overrides win.       */
/* ================================================================ */

/* A. Neutralize BE_Menu.css sidebar rules. No !important on width — external !important
   would beat MDB's inline width injection. BE_Menu.css widths are non-!important, so
   MDB's inline style naturally wins without our intervention. */
#sidebar {
    min-height: unset !important;
    overflow: unset !important;
    transition: unset !important;
    transition-delay: unset !important;
}
#sidebar:hover, #sidebar.stay-open {
    overflow-y: unset !important;
}
.sidebar-top {
    transition: unset !important;
    transition-delay: unset !important;
}
#sidebar:hover .sidebar-top, #sidebar.stay-open .sidebar-top {
    transition-delay: unset !important;
}
/* JMC - 04/21/2026 - Neutralize BE_Menu.css:190 min-height on favorites UL
   (it's calc(100vh - 129px) which pushes .side-bar-basic-links below viewport).
   Also add top padding so the first icon breathes under the navbar. */
#sidebar .sidebar-main > ul {
    min-height: unset !important;
    padding-top: 14px !important;
}

/* JMC - 04/21/2026 - Kill the opacity/visibility transitions from BE_Menu.css so
   bottom links + user-name pill collapse in sync with MDB instead of lagging behind. */
#sidebar.sidenav .side-bar-basic-links,
#sidebar.sidenav .contact-link-container,
#sidebar.sidenav .contact-link-container a {
    transition: none !important;
    transition-delay: 0s !important;
}

/* JMC - 04/21/2026 - Kill any stray hover background on sidebar favorites.
   The wrapper's gradient should be the only visible background — the <li> clone and
   its anchor must stay transparent so the gradient shows through consistently. */
#sidebar .favorite-item,
#sidebar .favorite-item:hover,
#sidebar .favorite-item:focus,
#sidebar .favorite-item > a,
#sidebar .favorite-item > a:hover,
#sidebar .favorite-item > a:focus,
#sidebar .favorite-item > a:active {
    background-color: transparent !important;
    background-image: none !important;
}

/* B. MDB Sidenav color, z-index. Widths come from data-mdb-slim-width / data-mdb-width
   attributes on the <nav>, not CSS vars (MDB reads these as JS options). */
#sidebar.sidenav {
    background-color: #2d3748 !important;
    color: white !important;
    z-index: 9998 !important;
    bottom: 0 !important;
}

/* C. Let MDB manage #main-pane margin-left (neutralize BE_Menu.css:112 on desktop) */
@media (min-width: 806px) {
    #main-pane { margin-left: unset !important; }
}

/* D. Content visibility keyed on MDB's .sidenav-slim class.
   Confirmed in MDB source: _setSlim() adds/removes the class on expand/collapse
   (including hover). The [data-mdb-slim-collapsed] attribute is only the init option
   and does NOT get toggled at runtime. */
@media (min-width: 806px) {
    /* Slim state */
    #sidebar.sidenav.sidenav-slim .contact-link-container { height: 0 !important; overflow: hidden !important; margin: 0 !important; padding: 0 !important; }
    #sidebar.sidenav.sidenav-slim .side-bar-basic-links { opacity: 0 !important; pointer-events: none !important; }
    #sidebar.sidenav.sidenav-slim .favorite-item { display: none !important; }
    #sidebar.sidenav.sidenav-slim .favorite-wrapper { width: 35px !important; }

    /* Expanded state */
    #sidebar.sidenav:not(.sidenav-slim) .contact-link-container { height: auto !important; overflow: visible !important; visibility: visible !important; margin-bottom: 6px !important; position: relative !important; z-index: 100 !important; }
    #sidebar.sidenav:not(.sidenav-slim) .side-bar-basic-links { opacity: 1 !important; pointer-events: auto !important; }
    #sidebar.sidenav:not(.sidenav-slim) .favorite-item { display: inline-block !important; }
    /* Expanded wrapper width: 255px + 10px margin-left (BE_Menu.css:240) = 265px, fits inside 276px sidenav */
    #sidebar.sidenav:not(.sidenav-slim) .favorite-wrapper { width: 255px !important; border-radius: 6px !important; }
}

/* ================================================================ */
/* JMC - 04/21/2026 - Direction B: Flat card favorites (no gradient)*/
/* Modern sidebar favorites styling — keeps abbreviation circles +  */
/* quick-search form fields intact, just flattens the visuals.      */
/* ================================================================ */

/* Wrapper: flat solid color, subtle border, no gradient, no hover jump */
#sidebar .favorite-wrapper {
    background: #3a4558 !important;
    background-image: none !important;
    border: 1px solid rgba(255, 255, 255, 0.08) !important;
    box-shadow: none !important;
    margin-top: 6px !important;
    transition: background-color 0.15s ease !important;
}
#sidebar .favorite-wrapper:hover {
    background: #4a5569 !important;
    background-image: none !important;
    top: 0 !important;
}

/* Label: light text on dark bg, modern system font stack */
#sidebar .favorite-item > a,
#sidebar .favorite-item > a span,
#sidebar .favorite-item > a b {
    color: #e0e0e0 !important;
    font-family: var(--bs-body-font-family) !important;
    font-size: 13px !important;
    font-weight: 400 !important;
    letter-spacing: 0 !important;
}
#sidebar .favorite-item > a:hover,
#sidebar .favorite-item > a:hover span,
#sidebar .favorite-item > a:hover b {
    color: #ffffff !important;
    text-decoration: none !important;
}
/* Inline search/icon markers stay on-theme */
#sidebar .favorite-item > a i,
#sidebar .favorite-item > a svg {
    color: #c0c0c0 !important;
}

/* Icons: squircles instead of perfect circles, cleaner type */
#sidebar .favorite-icon {
    border-radius: 10px !important;
    box-shadow: none !important;
    border-width: 2px !important;
    font-family: var(--bs-body-font-family) !important;
    font-size: 13px !important;
    font-weight: 500 !important;
    color: #fff !important;
    background-color: #3a4558 !important;
    left: 2px !important;
}
#sidebar .favorite-icon:hover {
    box-shadow: 0 0 0 3px rgba(255,255,255,0.08) !important;
    top: 38px !important;
}

/* Form inputs: dark-mode styling so they don't look like a white popup */
#sidebar .quick-search-container input[type="text"],
#sidebar .quick-search-container input:not([type]),
#sidebar .quick-search-container input:not([type="hidden"]):not([type="button"]):not([type="submit"]):not([type="checkbox"]):not([type="radio"]) {
    background-color: #232b38 !important;
    border: 1px solid rgba(255, 255, 255, 0.15) !important;
    border-radius: 4px !important;
    color: #e0e0e0 !important;
    font-size: 12px !important;
    padding: 4px 8px !important;
    box-shadow: none !important;
}
#sidebar .quick-search-container input:focus {
    border-color: rgba(255, 255, 255, 0.35) !important;
    background-color: #2b3443 !important;
    outline: none !important;
}
#sidebar .quick-search-container input::placeholder {
    color: rgba(255, 255, 255, 0.4) !important;
}

/* Go button: tighter, cleaner; category color stays via .background-color-N */
#sidebar .qs-go-btn {
    border-radius: 4px !important;
    border: none !important;
    padding: 4px 12px !important;
    font-size: 12px !important;
    font-weight: 500 !important;
    color: #fff !important;
    box-shadow: none !important;
    transition: filter 0.15s ease !important;
    flex: 0 0 auto !important;
}
#sidebar .qs-go-btn:hover {
    filter: brightness(1.15) !important;
}

/* JMC - 04/21/2026 - Log Out link: danger color. Higher specificity than
   BE_Menu.css:250 (#sidebar .side-bar-basic-links a { color:#999 !important }). */
#sidebar .side-bar-basic-links a.sidebar-logout-link {
    color: var(--bs-danger, #dc3545) !important;
    font-weight: 500 !important;
}
#sidebar .side-bar-basic-links a.sidebar-logout-link:hover {
    color: #ff6b80 !important;
    text-decoration: underline !important;
}

/* Form layout: flex row so inputs share space and Go button doesn't get clipped
   by .favorite-wrapper's overflow-x:hidden. min-width:0 lets inputs shrink
   below their intrinsic size. */
#sidebar .quick-search-container form {
    display: flex !important;
    align-items: center !important;
    gap: 4px !important;
    flex-wrap: nowrap !important;
    padding-right: 4px !important;
}
#sidebar .quick-search-container input:not([type="hidden"]):not([type="button"]):not([type="submit"]):not([type="checkbox"]):not([type="radio"]) {
    flex: 1 1 40px !important;
    min-width: 0 !important;
    width: auto !important;
}

/* JMC - 04/22/2026 - BE Menu Settings page: card-per-category modernization.
   All rules are scoped to #be-menu-settings-container so legacy uses of the
   same classes/IDs in the navbar, sidebar, and footer menus are untouched. */
#be-menu-settings-container { font-size: unset !important; padding-left: 0 !important; padding-right: 0 !important; }

/* Suppress the legacy ::before "show"/"fav" labels on the first item of each
   category — the new .bems-col-headers row replaces them */
#be-menu-settings-container .be-menu-item:first-of-type .menu-setting-show p::before,
#be-menu-settings-container .be-menu-item:first-of-type .menu-setting-fav p::before { content: none !important; }

/* Suppress the legacy subcategory chevron + bottom border (settings page only).
   Also use flex so the cascade-checkbox + h6.be-menu-expander always sit on
   one row, with the items <ul> wrapping to a new full-width row below. */
#be-menu-settings-container .be-subcategory {
    border-bottom: 0 !important;
    margin-bottom: .5rem;
    padding-bottom: 0;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
}
#be-menu-settings-container .be-subcategory::before { content: none !important; }
#be-menu-settings-container .be-subcategory > .cascade-checkbox { flex: 0 0 auto; margin-right: .35rem; vertical-align: middle; }
#be-menu-settings-container .be-subcategory > h6.be-menu-expander { flex: 1 1 auto; min-width: 0; margin: 0; width: auto; }
#be-menu-settings-container .be-subcategory > ul { flex: 1 1 100%; width: 100%; }

/* Square ALL cards on this page consistently (category cards + action bar) so
   no card looks "randomly" different and the colored stripe on the card-header
   reaches the top edge of the card without being clipped by rounded corners.
   Page scope: applied via the .bems-page class on the outer container. */
.bems-page .card { border-radius: 0 !important; position: relative; }
.bems-page .card > .card-header { border-radius: 0 !important; }
.bems-page .card > .card-body:last-child { border-radius: 0 !important; }

/* Colored 4px left-border accent on the card-header (visible right where the
   title sits). Default neutral; overridden per category via color-N classes. */
#be-menu-settings-container .bems-card-header {
    padding: .25rem .75rem;
    padding-right: 2.25rem; /* room for the absolute-positioned cascade-checkbox */
    min-height: 0;
    font-size: 1rem;
    line-height: 1.4;
    border-left: 4px solid #6c757d;
    color: #333;
}
#be-menu-settings-container .bems-card-header.color-1 { border-left-color: #04a169; color: #04a169; }
#be-menu-settings-container .bems-card-header.color-2 { border-left-color: #00CEC9; color: #00a39f; } /* darken #00CEC9 for contrast on bg-light */
#be-menu-settings-container .bems-card-header.color-3 { border-left-color: #FDCB6E; color: #b8860b; } /* darken pale yellow */
#be-menu-settings-container .bems-card-header.color-4 { border-left-color: #E17055; color: #E17055; }
#be-menu-settings-container .bems-card-header.color-5 { border-left-color: #A29BFE; color: #6c5cd6; } /* darken */
#be-menu-settings-container .bems-card-header.color-6 { border-left-color: #0984E3; color: #0984E3; }
#be-menu-settings-container .bems-card-header.color-7 { border-left-color: #FD79A8; color: #d63a82; } /* darken */
#be-menu-settings-container .bems-card-header.color-8 { border-left-color: #D63031; color: #D63031; }
#be-menu-settings-container .bems-card-header.color-9 { border-left-color: #c71585; color: #c71585; }

/* Inner .be-menu-category sits flush inside the card body (no extra margin) */
#be-menu-settings-container .card-body .be-menu-category { margin-top: 0; padding: 0; color: inherit; }

/* Hide the legacy in-body category heading — the title now lives in the card-header.
   The <h6> stays in the DOM so line 297's cascade-checkbox prepend still anchors correctly. */
#be-menu-settings-container .card-body > .be-menu-category > .be-menu-category-heading { display: none !important; }

/* Float the category-level cascade-checkbox into the top-right of the card-header.
   It stays a direct child of .be-menu-category structurally (so the cascade-down
   handler at line 301 still works via $(this).parent().find()), but visually
   sits in the header area. */
#be-menu-settings-container .be-menu-category > .cascade-checkbox {
    position: absolute;
    top: .55rem;
    right: .75rem;
    margin: 0;
    z-index: 2;
}

/* Column headers row injected by JS at the top of each card body */
#be-menu-settings-container .bems-col-headers {
    display: flex;
    justify-content: flex-end;
    gap: .5rem;
    padding: .15rem .25rem;
    font-size: .7rem;
    font-weight: 600;
    color: #555;
    text-transform: uppercase;
    border-bottom: 1px solid #dee2e6;
    margin-bottom: .25rem;
}
#be-menu-settings-container .bems-col-headers .bems-col-show,
#be-menu-settings-container .bems-col-headers .bems-col-fav { width: 2.5rem; text-align: center; }

/* Menu items as flex rows: link grows, show/fav columns fixed-width on the right */
#be-menu-settings-container .be-menu-item {
    display: flex !important;
    align-items: center !important;
    gap: .5rem;
    padding: .25rem .25rem;
    margin: 0;
    border-radius: .25rem;
    line-height: 1.3;
}
#be-menu-settings-container .be-menu-item:hover { background-color: rgba(0,0,0,0.04); }
#be-menu-settings-container .be-menu-item a { flex: 1 1 auto; width: auto !important; display: inline-block !important; min-width: 0; }
#be-menu-settings-container .menu-setting { flex: 0 0 auto; width: 2.5rem !important; text-align: center; }
#be-menu-settings-container .menu-setting input[type="checkbox"] { margin: 0; cursor: pointer; }

/* Subcategory expander as a modern toggle row */
#be-menu-settings-container h6.be-menu-expander {
    font-weight: 600;
    font-size: .95rem;
    padding: .25rem .35rem;
    margin: .35rem 0 .15rem 0;
    border-radius: .25rem;
    width: auto;
    color: #444;
}
#be-menu-settings-container h6.be-menu-expander:hover { background-color: rgba(0,0,0,0.06); color: #222; }

/* Cascade-checkbox spacing alongside category and subcategory headings */
#be-menu-settings-container .cascade-checkbox { margin-right: .35rem; vertical-align: middle; }

/* JMC - 04/28/2026 - BE Footer link-grid modernization (scoped to #be-footer-menu-container only) */
/* JMC - 04/28/2026 - Convert the 50px sidebar offset from margin-left to padding-left so the footer's gradient background spans full viewport width while content positioning stays identical. Eliminates the visible left-edge "border" between the page bg and the indented footer bg.
   The 50px offset is wrapped in a min-width:768px media query — on mobile the sidebar isn't visible, so the 50px would be dead space on the left. */
#be-footer-menu-container {
	margin-left: 0;
	margin-right: 0;
	padding: 1.5rem 3% 1rem;
}
@media (min-width: 768px) {
	#be-footer-menu-container {
		padding-left: calc(50px + 3%);
	}
}
#be-footer-menu-container > .row { margin: 0 auto; max-width: 1900px; padding-top: .25rem; }
#be-footer-menu-container div.be-menu-category { padding: 0 1.25rem; margin-top: 1.25rem; }
#be-footer-menu-container .be-menu-category-heading {
	font-weight: 700 !important;
	/* JMC - 04/28/2026 - Reduced further to .8rem now that categories are collapsed by default; smaller than subcategory text so the colored headings read as compact section markers rather than dominant labels. */
	font-size: .8rem !important;
	letter-spacing: .04em;
	padding-bottom: .5rem;
	margin: 0 0 .85rem 0 !important;
	border-bottom: 2px solid currentColor;
}
#be-footer-menu-container .be-menu-category-heading.color-1 { color: #04a169; }
#be-footer-menu-container .be-menu-category-heading.color-2 { color: #00CEC9; }
#be-footer-menu-container .be-menu-category-heading.color-3 { color: #FDCB6E; }
#be-footer-menu-container .be-menu-category-heading.color-4 { color: #E17055; }
#be-footer-menu-container .be-menu-category-heading.color-5 { color: #A29BFE; }
#be-footer-menu-container .be-menu-category-heading.color-6 { color: #0984E3; }
#be-footer-menu-container .be-menu-category-heading.color-7 { color: #FD79A8; }
#be-footer-menu-container .be-menu-category-heading.color-8 { color: #D63031; }
#be-footer-menu-container .be-menu-category-heading.color-9 { color: #c71585; }
#be-footer-menu-container .be-subcategory {
	border-bottom: none;
	padding-bottom: 0;
	margin-bottom: .4rem;
	padding-left: 0;
}
#be-footer-menu-container .be-subcategory::before { content: none; }
#be-footer-menu-container .be-subcategory > h6.be-menu-expander {
	font-weight: 600;
	font-size: .875rem;
	color: #495057;
	margin: 0;
	padding: .4rem .5rem;
	padding-right: 1.5rem;
	border-radius: 4px;
	position: relative;
	transition: background-color .15s ease, color .15s ease;
}
#be-footer-menu-container .be-subcategory > h6.be-menu-expander:hover {
	background-color: rgba(0, 0, 0, .05);
	color: #212529;
}
#be-footer-menu-container .be-subcategory > h6.be-menu-expander::after {
	border-style: solid;
	border-width: .15em .15em 0 0;
	content: '';
	display: inline-block;
	height: .4em;
	width: .4em;
	position: absolute;
	right: .7rem;
	top: 50%;
	transform: translateY(-65%) rotate(135deg);
	transition: transform .2s ease;
}
#be-footer-menu-container .be-subcategory.is-expanded > h6.be-menu-expander::after {
	transform: translateY(-25%) rotate(-45deg);
}
#be-footer-menu-container .be-subcategory > h6.be-menu-expander ~ ul {
	padding: .25rem 0 .5rem .75rem;
	margin: 0;
	list-style: none;
}
#be-footer-menu-container .be-menu-item {
	margin: 0;
	padding: .2rem 0;
	list-style: none;
	line-height: 1.4;
}
#be-footer-menu-container .be-menu-item > a {
	color: #212529;
	text-decoration: none;
}
#be-footer-menu-container .be-menu-item > a:hover {
	color: #000;
	text-decoration: underline;
}
#be-footer-menu-container .be-menu-category-flat > .be-menu-category-heading {
	padding-right: 1.5rem;
}
#be-footer-menu-container .be-menu-category-flat > .be-menu-category-heading:hover {
	background-color: rgba(0, 0, 0, .04);
	color: inherit;
}

/* JMC - 04/28/2026 - BE Footer copyright band — nested inside #be-footer-menu-container so it inherits the same margin-left/padding/font-size context, guaranteeing column alignment with the link grid below. */
/* JMC - 04/28/2026 - Divider line moved off the copyright entirely; it now lives on the link-grid `> .row` as a border-top (see rule below), since the divider is conceptually "the line above the categories" and naturally hides on mobile where the link-grid is display:none. Copyright keeps just internal padding + text-align. */
#be-footer-menu-container #be-footer-copyright {
	padding-top: .5rem;
	padding-bottom: 1rem;
	text-align: left; /* override the parent footer's text-center */
}
/* JMC - 04/28/2026 - Top divider on the link-grid row, separating it from the copyright above. Hides automatically on mobile (link-grid is display:none under 768px). */
#be-footer-menu-container > .row {
	border-top: 1px solid rgba(0, 0, 0, .08);
	padding-top: 1.25rem;
}
#be-footer-menu-container #be-footer-copyright > .row {
	max-width: 1900px;
	margin: 0 auto;
}
/* JMC - 04/28/2026 - Mobile-first: center the logo and copyright text on small screens, left-align at md+ when brand sits side-by-side with the link cols */
#be-footer-copyright .be-footer-brand {
	display: flex;
	flex-direction: column;
	gap: .5rem;
	align-items: center;
}
@media (min-width: 768px) {
	#be-footer-copyright .be-footer-brand {
		align-items: flex-start;
	}
}
#be-footer-copyright .be-footer-logo {
	display: block;
	height: 30px;
	width: auto;
	max-width: 200px;
}
#be-footer-copyright .be-footer-copy {
	font-size: .8rem;
	color: #6c757d;
	margin: 0;
}
/* JMC - 04/28/2026 - Iteration 3: hide Support category in footer link grid (still shown in Menu Settings page); add column layout + heading styles for the copyright band */
#be-footer-menu-container [data-cat="9"] { display: none; }

#be-footer-copyright .be-footer-col-heading {
	text-transform: uppercase;
	font-weight: 600;
	font-size: .875rem;
	color: #212529;
	margin: 0 0 .85rem 0;
	letter-spacing: .03em;
}
#be-footer-copyright .be-footer-col ul li { padding: .2rem 0; line-height: 1.4; }
#be-footer-copyright .be-footer-col ul a {
	color: #6c757d;
	text-decoration: none;
	font-size: .875rem;
	transition: color .15s ease;
}
#be-footer-copyright .be-footer-col ul a:hover {
	color: #000;
	text-decoration: underline;
}
/* JMC - 04/28/2026 - Removed stale @media (max-width: 640px) rule that was forcing .be-footer-brand back to flex-start; the mobile-first rule above (align-items: center, with min-width: 768px override) is the only rule we need now. */

/* JMC - 04/28/2026 - Make ALL footer link-grid colored categories collapsible (not just .be-menu-category-flat ones). Default state: every category collapsed; click on any category heading toggles `.is-expanded` on the parent .be-menu-category, which reveals/hides its <ul>. Same pattern subcategories already use. Scoped to #be-footer-menu-container so the Menu Settings page (which uses the same .be-menu-category markup under #be-menu-settings-container) and the navbar are both unaffected. */
#be-footer-menu-container .be-menu-category > ul { display: none; }
#be-footer-menu-container .be-menu-category.is-expanded > ul { display: block; }
#be-footer-menu-container h6.be-menu-category-heading {
	cursor: pointer !important;
	transition: opacity .15s ease;
}
#be-footer-menu-container h6.be-menu-category-heading:hover {
	opacity: .8;
}
#be-footer-menu-container h6.be-menu-category-heading::after {
	border-style: solid;
	border-width: .15em .15em 0 0;
	content: '';
	display: inline-block;
	height: .4em;
	width: .4em;
	margin-left: .5em;
	vertical-align: middle;
	transform: rotate(135deg);
	transition: transform .2s ease;
}
#be-footer-menu-container .be-menu-category.is-expanded > h6.be-menu-category-heading::after {
	transform: rotate(-45deg);
}

/* JMC - 04/28/2026 - On mobile (<768px) hide the colored sitemap categories entirely — only the copyright band (logo, Support, Legal) shows in the footer. The divider line lives on the link-grid `> .row` itself, so when that's display:none the divider also disappears — no copyright overrides needed here. */
@media (max-width: 767.98px) {
	#be-footer-menu-container > .row {
		display: none;
	}
}
