/**
 * AWLL Global Styles (Applied to all pages)
 *
 * @package WordPress
 * @subpackage Twenty_Seventeen
 * @since AWLL 1.0
 */

/* ==========================================================================
   Variables
   ========================================================================== */
:root {
	--awll-primary: #5AB5B2;
	--awll-header-top: #2E5B61;
	--awll-header-middle: #357075;
	--awll-header-bottom: #3C7A7F;
	--awll-header-dark: #1F3A40;
	--awll-accent-warm: #F2A541;
	--awll-accent-warm-hover: #D98C32;
	--awll-text-offwhite: #F4F8F8;
	--awll-white: #FFFFFF;
	--transition-smooth: 0.25s ease;
	--transition-fast: 0.2s ease;
}

/* ==========================================================================
   Header - Applied to all pages
   ========================================================================== */
.site-header {
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	z-index: 1000;
	background: linear-gradient(195deg, rgba(46, 91, 97, 0.90) 0%, rgba(53, 112, 117, 0.90) 50%, rgba(60, 122, 127, 0.90) 100%) !important;
	background-color: transparent !important;
	backdrop-filter: blur(12px);
	-webkit-backdrop-filter: blur(12px);
	box-shadow: 0 2px 12px rgba(31, 58, 64, 0.15);
	border-bottom: 1px solid rgba(31, 58, 64, 0.08);
	transition: background var(--transition-smooth), box-shadow var(--transition-smooth), border var(--transition-smooth);
}

/* Force transparent backgrounds on all header child elements */
.site-branding,
.navigation-top,
.navigation-top .wrap,
.navigation-top .menu-2024-11-container,
.main-navigation,
.main-navigation > div,
.main-navigation .wrap,
.main-navigation .menu-container,
nav.main-navigation,
div.navigation-top,
[class*="menu-"][class*="-container"],
ul.menu,
#top-menu,
.menu li {
	background: transparent !important;
	background-color: transparent !important;
}

/* White text for header links */
.site-title a,
.navigation-top a,
.main-navigation a,
.menu a {
	color: var(--awll-text-offwhite) !important;
	transition: color var(--transition-fast), border-bottom var(--transition-fast);
	text-decoration: none;
	border-bottom: 2px solid transparent;
	padding-bottom: 2px;
}

/* Orange accent on hover */
.menu li a:hover,
.main-navigation a:hover,
.navigation-top a:hover {
	color: var(--awll-accent-warm) !important;
	border-bottom-color: var(--awll-accent-warm) !important;
}

/* Keep logo in teal */
.site-title a {
	color: var(--awll-primary) !important;
	border-bottom: none !important;
	font-weight: 700;
}

.site-title a:hover {
	color: var(--awll-primary) !important;
	opacity: 0.9;
}

/* Compact header presentation on all pages */
.custom-header {
	display: flex;
	align-items: center;
	justify-content: center;
	min-height: 0;
	padding: 0.75rem 1.5rem !important;
	margin-bottom: 0 !important;
	background: transparent !important;
}

.custom-header-media {
	display: none !important;
}

.site-branding {
	margin: 0 !important;
	padding: 0 !important;
	width: 100%;
}

.site-branding .wrap {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: 0;
	margin: 0;
	width: 100%;
}

.site-title {
	margin: 0 !important;
	font-size: 1.5rem;
	line-height: 1.2;
}

.site-description {
	display: none;
}

/* Scrolled header - slightly darker for better readability */
.site-header.scrolled {
	background: linear-gradient(195deg, rgba(63, 119, 126, 0.95) 0%, rgba(58, 108, 113, 0.95) 50%, rgba(53, 97, 102, 0.95) 100%) !important;
	box-shadow: 0 4px 16px rgba(31, 58, 64, 0.18);
	border-bottom-color: rgba(31, 58, 64, 0.12);
	padding-top: 10px;
	padding-bottom: 10px;
}

/* Add padding to body content to account for fixed header */
.site-content-contain {
	padding-top: 80px;
}

/* ==========================================================================
   Mobile Menu Toggle Button
   ========================================================================== */
button.menu-toggle,
.menu-toggle.button {
	display: none !important;
	width: auto;
	height: auto;
	padding: 0;
	margin: 0;
	border: 0;
	border-radius: 0;
	background: none;
	box-shadow: none;
	backdrop-filter: none;
	-webkit-backdrop-filter: none;
	transition: none;
}

button.menu-toggle svg,
.menu-toggle.button svg {
	width: 1em;
	height: 1em;
	color: inherit;
	display: block;
}

/* Hide close icon by default */
.menu-toggle .icon-close {
	display: none !important;
}

/* Show close icon and hide bars icon when toggled */
.toggled-on .menu-toggle .icon-bars {
	display: none !important;
}

.toggled-on .menu-toggle .icon-close {
	display: inline-block !important;
}

/* Mobile menu expanded state (Card Design) */
.main-navigation.toggled-on {
	background: linear-gradient(180deg, #2e5b61, #23464a) !important;
	border-radius: 16px !important;
	margin: 0.75rem auto !important;
	width: calc(100% - 2rem) !important;
	max-width: 320px !important;
	padding: 1.5rem 1.25rem !important;
	box-shadow: 0 20px 45px rgba(10, 64, 71, 0.35) !important;
}

.main-navigation.toggled-on ul,
.main-navigation.toggled-on ul.nav-menu {
	display: block !important;
	padding: 0 !important;
	margin: 0 !important;
}

.main-navigation.toggled-on ul li,
.main-navigation.toggled-on ul.nav-menu li {
	display: block !important;
	width: 100% !important;
	border-bottom: 1px solid rgba(255, 255, 255, 0.15) !important;
}

.main-navigation.toggled-on ul.nav-menu li:last-child {
	border-bottom: none !important;
}

.main-navigation.toggled-on ul.nav-menu li a {
	color: var(--awll-text-offwhite) !important;
	text-transform: uppercase !important;
	letter-spacing: 0.12em !important;
	font-weight: 600 !important;
	padding: 0.75rem 1rem !important;
	display: block !important;
	transition: color var(--transition-fast), transform var(--transition-fast) !important;
	border-bottom: none !important;
}

.main-navigation.toggled-on ul.nav-menu li a:hover,
.main-navigation.toggled-on ul.nav-menu li a:focus {
	color: var(--awll-accent-warm) !important;
	transform: translateX(4px) !important;
	background: rgba(255, 255, 255, 0.05) !important;
}

/* ==========================================================================
   Footer - Applied to all pages
   ========================================================================== */
.awll-footer {
	background: var(--awll-header-dark);
	color: var(--awll-white);
	padding: 30px 0;
	margin-top: 0;
}

.awll-footer .wrap {
	max-width: 1200px;
	margin: 0 auto;
	padding: 0 20px;
	background: none !important;
	background-color: transparent !important;
}

.awll-footer-content {
	display: grid;
	grid-template-columns: auto 1fr;
	align-items: center;
	gap: 20px;
}

.awll-footer-nav {
	justify-self: start;
	margin-left: 0;
}

.awll-footer-copyright {
	text-align: center;
	font-size: 0.9rem;
	color: rgba(255, 255, 255, 0.85);
	margin: 0;
	letter-spacing: 0.02em;
	justify-self: center;
}

.awll-footer-link {
	font-size: 0.9rem;
	color: #fff !important;
	text-decoration: none;
	transition: color var(--transition-fast), border-bottom var(--transition-fast);
	border-bottom: 1px solid transparent;
	padding-bottom: 2px;
}

.awll-footer-link:hover {
	color: var(--awll-primary) !important;
	border-bottom-color: var(--awll-primary) !important;
}

/* ==========================================================================
   Responsive Design
   ========================================================================== */
@media screen and (min-width: 769px) {
	.site-header {
		display: flex;
		align-items: center;
		padding: 0.75rem 1.5rem;
	}

	.site-branding {
		margin: 0 !important;
		padding: 0 !important;
		display: flex;
		align-items: center;
		gap: 0.75rem;
	}

	.site-branding .custom-logo-link img {
		max-height: 48px;
		width: auto;
	}

	.navigation-top {
		margin: 0 !important;
		padding: 0 !important;
	}

	.navigation-top .wrap {
		display: flex;
		align-items: center;
		justify-content: flex-end;
		padding: 0 !important;
		gap: 2rem;
	}

	.main-navigation {
		width: auto;
	}

	.main-navigation > div,
	.main-navigation .menu-container,
	.main-navigation .wrap {
		padding: 0 !important;
		margin: 0 !important;
	}

	.main-navigation ul,
	.main-navigation ul.nav-menu {
		display: flex !important;
		align-items: center;
		gap: 1.5rem;
		margin: 0 !important;
		padding: 0 !important;
		border: 0 !important;
	}

	.main-navigation li,
	.main-navigation ul li {
		border: 0 !important;
		margin: 0 !important;
		padding: 0 !important;
	}

	.main-navigation a {
		padding: 0.35rem 0 !important;
		line-height: 1.2;
	}
}

@media screen and (max-width: 768px) {
	.site-content-contain {
		padding-top: 60px;
	}

	/* Mobile hamburger button */
	button.menu-toggle,
	.menu-toggle.button {
		display: inline-flex !important;
		align-items: center !important;
		justify-content: center !important;
		width: 52px !important;
		height: 52px !important;
		padding: 0 !important;
		border: 1px solid rgba(255, 255, 255, 0.3) !important;
		border-radius: 16px !important;
		background: rgba(53, 112, 117, 0.92) !important;
		color: var(--awll-text-offwhite) !important;
		box-shadow: none !important;
		backdrop-filter: none !important;
		-webkit-backdrop-filter: none !important;
		position: absolute !important;
		top: 0.75rem !important;
		right: 1rem !important;
		z-index: 1200 !important;
		transition: background var(--transition-fast), transform var(--transition-fast);
	}

	button.menu-toggle svg,
	.menu-toggle.button svg {
		width: 24px !important;
		height: 24px !important;
	}

	.menu-toggle .icon {
		margin-right: 0 !important;
		top: 0 !important;
	}

	button.menu-toggle:hover,
	button.menu-toggle:focus,
	.menu-toggle.button:hover,
	.menu-toggle.button:focus {
		background: rgba(60, 122, 127, 0.98) !important;
		transform: translateY(-1px);
	}

	button.menu-toggle:focus-visible,
	.menu-toggle.button:focus-visible {
		outline: 2px solid var(--awll-accent-warm);
		outline-offset: 2px;
	}

	.toggled-on button.menu-toggle,
	.toggled-on .menu-toggle.button {
		background: rgba(46, 91, 97, 0.95) !important;
	}

	/* Mobile menu: hide by default */
	.main-navigation ul,
	.main-navigation ul.nav-menu,
	.js .main-navigation ul,
	.js .main-navigation ul.nav-menu {
		display: none !important;
	}

	/* Mobile menu: show when toggled, with vertical stacking */
	.main-navigation.toggled-on ul,
	.main-navigation.toggled-on ul.nav-menu {
		display: block !important;
		flex-direction: column !important;
		margin-top: 0 !important;
	}

	.main-navigation.toggled-on {
		position: fixed !important;
		top: 72px !important;
		left: 50% !important;
		transform: translateX(-50%);
		z-index: 1100 !important;
		margin: 0 !important;
		width: min(320px, calc(100% - 2rem)) !important;
		padding: 1.5rem 1.25rem !important;
	}

	.main-navigation.toggled-on ul li,
	.main-navigation.toggled-on ul.nav-menu li {
		display: block !important;
		width: 100%;
	}

	.main-navigation a,
	.main-navigation ul a,
	.main-navigation.toggled-on a {
		padding: 0.75rem 1rem;
		display: block;
	}

	/* Footer - stack vertically on mobile */
	.awll-footer-content {
		grid-template-columns: 1fr;
		text-align: center;
		gap: 15px;
	}

	.awll-footer-nav {
		justify-self: center;
	}

	.awll-footer-copyright,
	.awll-footer-link {
		font-size: 0.85rem;
	}
}

/* ==========================================================================
   Hamburger Menu Brand Color Override
   ========================================================================== */
/* Apply brand teal color to hamburger icon (overrides style.css:4578) */
svg.icon.icon-bars,
svg.icon.icon-close,
button.menu-toggle .icon-bars,
button.menu-toggle .icon-close,
.menu-toggle .icon-bars,
.menu-toggle .icon-close {
	color: var(--awll-primary) !important;
}

/* Maintain brand color on hover and focus states */
button.menu-toggle:hover .icon-bars,
button.menu-toggle:hover .icon-close,
button.menu-toggle:focus .icon-bars,
button.menu-toggle:focus .icon-close,
.menu-toggle.button:hover .icon-bars,
.menu-toggle.button:hover .icon-close,
.menu-toggle.button:focus .icon-bars,
.menu-toggle.button:focus .icon-close {
	color: var(--awll-primary) !important;
}

/* Brand color in toggled state */
.toggled-on button.menu-toggle .icon-bars,
.toggled-on button.menu-toggle .icon-close,
.toggled-on .menu-toggle.button .icon-bars,
.toggled-on .menu-toggle.button .icon-close {
	color: var(--awll-primary) !important;
}
