/*=============================*/
/*=====----- GENERAL -----=====*/
/*=============================*/

.header-container,
.panel-header {
	position: relative;
	z-index: 100;
}

.panel-header {
	translate: none;
	color: var(--gray-dark);
	transition: translate var(--transition-appendix);
}

.panel-header .header-inner {
	display: flex;
	gap: 20px;
	padding: 10px 15px;
	background: var(--white);
}

.panel-header .logo-col {
	flex: 0 1 110px;
}

.panel-header .logo a {
	display: block;
	text-decoration: none !important;
}

.panel-header .logo img {
	width: 100%;
}

.panel-header .logo .white-logo {
	display: none;
}

.panel-header .nav-col {
	margin-left: auto;
}

.panel-header .header-button {
	display: inline-grid;
	grid-template-columns: 14px 42px;
	align-items: center;
	gap: 6px;
	padding: 6px;
	font-family: var(--font-display);
	font-weight: bold;
	font-size: 0.9375rem;
	line-height: 1;
	text-align: left;
	text-decoration: none !important;
	color: inherit;
	background-color: transparent;
	border: 2px solid var(--blue-mid-light);
	border-radius: 0;
	transition:
		color var(--transition-appendix),
		background-color var(--transition-appendix);
}

.panel-header .header-button::before {
	font: var(--fa-font-solid);
	font-size: var(--text-xs);
	content: '\f594';
}

.panel-header .search-col {
	display: flex;
	align-items: center;
	gap: 2px;
	flex-shrink: 0;
}

.body-overlay {
	position: fixed;
	inset: 0;
	z-index: 90;
}

.panel-header .curated-nav-col,
.panel-header .weather-col,
.panel-header .secondary-nav-row,
.panel-header .search-container,
.body-overlay {
	display: none;
}

/*----- fixed header -----*/

.panel-header.fixed,
.panel-header.home.fixed {
	position: fixed;
	inset: 0 0 auto;
	translate: 0 -101%;
}

.panel-header.fixed.menu-open,
.panel-header.home.fixed.menu-open,
.panel-header.reveal,
.panel-header.home.reveal {
	translate: none;
}

/*================================*/
/*=====----- NAVIGATION -----=====*/
/*================================*/

/*----- menu toggle button -----*/

.panel-header .menu-toggle {
	position: relative;
	display: flex;
	justify-content: center;
	align-items: center;
	width: 40px;
	aspect-ratio: 1;
	padding: 0;
	margin: 0;
	font-size: var(--text-2xl);
	line-height: 1;
	color: var(--white);
	background-color: transparent;
	border: none;
	border-radius: 0;
	transition: background-color var(--transition-appendix);
}

.panel-header .menu-container .menu-toggle {
	background-color: var(--blue-mid);
}

.panel-header .menu-container .menu-toggle,
.panel-header .menu-toggle .lines {
	display: none;
}

.panel-header .menu-toggle .icon-open,
.panel-header .menu-toggle .icon-close {
	width: 100%;
	flex-shrink: 0;
	transition: opacity var(--transition-appendix);
}

.panel-header .menu-toggle .icon-open {
	opacity: 1;
}

.panel-header .menu-toggle .icon-close {
	position: absolute;
	inset: 50% auto auto 50%;
	translate: -50% -50%;
	opacity: 0;
}

/*----- mobile menu -----*/

.panel-header .menu-container,
.panel-header .menu-container * {
	pointer-events: none;
}

.panel-header .menu-container {
	position: absolute;
	inset: 100% 0 auto 0;
	color: var(--white);
	background: var(--blue-mid-dark);
	border-top: 1px solid rgba(255, 255, 255, 0.2);
	overflow-x: hidden;
	overflow-y: auto;
	overscroll-behavior: contain;
	opacity: 0;
	visibility: hidden;
	transition:
		opacity var(--transition-appendix),
		visibility var(--transition-appendix);
}

.panel-header .search-row {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 20px;
	padding: 20px 15px;
}

.panel-header .menu-container.no-search .search-row {
	display: none;
}

.panel-header .menu-logo {
	display: none;
	width: 181px;
}

.panel-header .menu-logo .logo .color-logo {
	display: none;
}

.panel-header .menu-logo .logo .white-logo {
	display: block;
}

.panel-header .navs {
	background: var(--blue-dark);
}

.panel-header .navs-inner {
	display: grid;
	grid-template-columns: minmax(0, 1fr);
	align-items: start;
	gap: 30px;
	padding: 30px 15px 50px;
}

.panel-header .navs-inner > * {
	padding-bottom: 40px;
	border-bottom: 2px solid var(--blue-mid-dark);
}

.panel-header .navs-inner > *:first-child {
	padding-top: 0;
}

.panel-header .navs-inner > *:last-child {
	padding-bottom: 0;
	border: none;
}

.panel-header .ctas {
	display: grid;
	grid-template-columns: minmax(0, 1fr);
	align-items: start;
	gap: 20px;
	padding: 20px 15px;
}

/*----- open menu -----*/

.panel-header .menu-container.active,
.panel-header .menu-container.active * {
	pointer-events: all;
}

.panel-header .menu-container.active {
	opacity: 1;
	visibility: visible;
}

.panel-header .menu-toggle.active .icon-open {
	opacity: 0;
}

.panel-header .menu-toggle.active .icon-close {
	opacity: 1;
}

.body-overlay.active {
	display: block;
}

/*=======================================*/
/*=====----- MOBILE ICON LINKS -----=====*/
/*=======================================*/

.panel-header .mobile-icon-links {
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	color: var(--white);
	background: var(--blue-mid-dark);
}

.panel-header .mobile-icon-links > * {
	border-right: 1px solid rgba(255, 255, 255, 0.2);
}

.panel-header .mobile-icon-links > *:last-child {
	border: none;
}

/*=============================================*/
/*=====----- MICROSITE (black) THEME -----=====*/
/*=============================================*/

.panel-header.microsite .logo-col {
	display: flex;
	align-items: center;
	flex-basis: 170px;
}

.panel-header.microsite .menu-logo {
	width: 281px;
}

.panel-header.microsite .header-button {
	border-color: var(--ms-orange);
}

.panel-header.microsite .mobile-icon-links {
	background: var(--black);
}

.panel-header.microsite .menu-container {
	color: var(--black);
	background: var(--black);
}

.panel-header.microsite .navs {
	background: var(--white);
}

.panel-header.microsite .navs-inner > * {
	border-bottom-color: var(--ms-gray);
}

.panel-header.microsite .ctas {
	background: var(--gray-light);
}

/*====================================*/
/*=====----- LAVENDER THEME -----=====*/
/*====================================*/

.panel-header.lavender .mobile-icon-links,
.panel-header.lavender .menu-container {
	background: var(--lavender-dark);
}

.panel-header.lavender .navs {
	background: var(--lavender);
}

.panel-header.lavender .navs-inner > * {
	border-bottom-color: rgba(255, 255, 255, 0.5);
}

/*===================================*/
/*=====----- MEDIA QUERIES -----=====*/
/*===================================*/

@media (hover: hover) {
	.panel-header .header-button:hover {
		color: var(--white);
		background-color: var(--blue-mid-light);
	}

	.panel-header.microsite .header-button:hover {
		background-color: var(--ms-orange);
	}
}

@media (min-width: 64em) {
	.panel-header {
		background: var(--white);
	}

	.panel-header .header-inner {
		padding: 12px 15px 0 50px;
		background: none;
	}

	.panel-header .logo-col {
		flex-basis: 181px; 
	}

	.panel-header .nav-col {
		display: flex;
		flex-direction: column;
		align-items: end;
		gap: 10px;
		opacity: 1;
		visibility: visible;
		transition:
			opacity var(--transition-appendix),
			visibility var(--transition-appendix);
	}

	.panel-header.search-open .nav-col {
		opacity: 0;
		visibility: hidden;
		pointer-events: none;
	}

	.panel-header.search-open .nav-col * {
		pointer-events: none;
	}

	.panel-header .top-bar {
		display: flex;
		align-items: center;
		justify-content: end;
		gap: 24px;
	}

	.panel-header .curated-nav-col,
	.panel-header .weather-col,
	.panel-header .secondary-nav-row,
	.panel-header .search-container {
		display: block;
	}

	.panel-header .header-button {
		display: flex;
		padding: 8px 10px;
		gap: 7px;
		font-size: 0.8125rem;
		letter-spacing: 0.02em;
		text-transform: uppercase;
	}

	.panel-header .search-col {
		align-self: start;
		margin-top: 3px;
	}

	/*----- navigation -----*/

	.panel-header .menu-toggle {
		width: 70px;
		background: var(--blue-mid-dark);
	}

	.panel-header .menu-toggle .lines {
		display: block;
	}

	.panel-header .menu-toggle .icon-open,
	.panel-header .menu-toggle .icon-close,
	.panel-header .mobile-icon-links,
	.panel-header .mobile-weather {
		display: none;
	}

	.panel-header .menu-container {
		position: fixed;
		inset: 0;
		z-index: 200;
		display: grid;
		grid-template:
			'search search' 95px
			'nav cta' 1fr
			'nav cards' 2.24fr / minmax(0, 1fr) 34%;
		height: 100vh;
		max-height: 100vh !important;
		background: var(--blue-dark);
		overflow-y: scroll;
	}

	.panel-header .search-row,
	.panel-header .menu-container.no-search .search-row {
		display: grid;
		grid-template-columns: minmax(0, 1fr) 34%;
		align-items: stretch;
		grid-area: search;
		height: 100%;
		padding: 0;
	}

	.panel-header .menu-logo,
	.panel-header .search-and-menu-button {
		display: flex;
		align-items: center;
	}

	.panel-header .search-and-menu-button {
		justify-content: space-between;
		gap: 20px;
		padding: 0 15px 0 25px;
		background: var(--blue-mid);
	}

	.panel-header .menu-logo {
		height: 100%;
		margin-left: 50px;
	}

	.panel-header .menu-container .menu-toggle {
		display: flex;
	}

	.panel-header .navs {
		align-self: start;
		grid-area: nav;
		background: none;
	}

	.panel-header .navs-inner {
		width: 100%;
		max-width: 394px;
		padding: 40px 50px;
		gap: 40px;
	}

	.panel-header .ctas {
		align-content: center;
		align-items: center;
		grid-area: cta;
		padding: 25px 57px;
		background: var(--blue-mid-dark);
	}

	.panel-header .image-cards-container {
		grid-area: cards;
	}

	.panel-header .image-cards-container > * {
		height: 100%;
	}

	@media (hover: hover) {
		.panel-header .menu-toggle:hover {
			background-color: var(--blue-mid-light);
		}
	}

	/*----- homepage styles -----*/

	.panel-header.home {
		position: absolute;
		inset: 100% 0 auto;
		color: var(--white);
		background: none;
	}

	.panel-header.home::before {
		position: absolute;
		inset: 0 0 auto;
		z-index: -1;
		display: block;
		height: 145px;
		content: '';
		background: linear-gradient(to bottom, rgba(0, 0, 0, 0.8), rgba(0, 0, 0, 0));
		pointer-events: none;
		opacity: 1;
		transition: opacity var(--transition-appendix);
	}

	.panel-header.home.fixed::before {
		opacity: 0;
	}

	.panel-header.home.reveal::before {
		opacity: 1;
	}

	.panel-header.home .logo .color-logo {
		display: none;
	}
	
	.panel-header.home .logo .white-logo {
		display: block;
	}

	/*----- microsite (black) theme -----*/

	.panel-header.microsite .logo-col {
		flex-basis: 281px;
	}

	.panel-header.microsite .menu-toggle {
		background: var(--black);
	}

	.panel-header.microsite .menu-container {
		background: var(--white);
	}

	.panel-header.microsite .search-and-menu-button {
		background: var(--black);
	}

	/*----- lavender theme -----*/

	.panel-header.lavender .menu-toggle {
		background: var(--lavender-dark);
	}

	.panel-header.lavender .navs {
		background: none;
	}

	.panel-header.lavender .search-and-menu-button {
		background: var(--lavender-light);
	}

	.panel-header.lavender .ctas {
		background: var(--lavender);
	}
}