/**
 * Custom Header Styles
 */

/* Header Wrapper - Overlay but not fixed */
.site-header-wrapper {
	position: relative;
	top: 0;
	left: 0;
	right: 0;
	z-index: 1000;
	background: transparent;
}

/* Main Navigation Bar */
.main-navigation-bar {
	background: transparent;
	padding: 46px 0 0;
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	z-index: 9999;
}
.page-template-default .main-navigation-bar  {
	padding:0;
}
.main-nav-container {
	max-width: 1228px;
	margin: 0 auto;
	padding: 0 5px 0 0;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 30px;
}

/* Site Logo */
.site-logo {
	flex-shrink: 0;
}

.site-logo a {
	display: block;
	text-decoration: none;
	line-height: 0;
}

.logo-img {
	width: 110px;
	max-width: 100%;
	height: auto;
	object-fit: contain;
	display: block;
	image-rendering: -webkit-optimize-contrast;
	-ms-interpolation-mode: bicubic;
}

.site-title {
	font-family: var(--wp--preset--font-family--signature-moment);
	font-size: 28px;
	color: #2F2E2C;
	margin: 0;
}

/* Primary Navigation */
.nav-primary {
	flex: 1;
	display: flex;
	justify-content: flex-end;
	padding-bottom: 10px;
}

.primary-menu {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	align-items: center;
	justify-content: space-between;
	width: 100%;
}

.primary-menu li {
	position: relative;
	margin: 0;
	padding: 0;
}

.primary-menu a {
	color: #4C4C3B;
	text-decoration: none;
	font-size: 15px;
	font-family: var(--wp--preset--font-family--sunrider);
	font-weight: 400;
	text-transform: uppercase;
	transition: opacity 0.2s ease;
	display: block;
	padding: 8px 0;
	letter-spacing: 0rem;
}

.primary-menu a:hover {
	opacity: 0.7;
}

/* Button style for nav items with .button class */
.primary-menu .button a,
.primary-menu li.button > a {
	border: 2px solid #4C4C3B;
	border-radius: 7px;
	background-color: #D4B055;
	color: #4C4C3B;
	padding: 2px 7px 0;
	outline: none;
	-webkit-appearance: none;
	height: 29px;
	display: block;
}
.primary-menu li.button {
	border:none;
	background:transparent;
	padding:0;
}

.primary-menu .button a:hover,
.primary-menu li.button > a:hover {
	opacity: 1;
	transform: translateY(0px);
}

/* Light Menu Template Styles */
/* Footer logo is used directly for light-menu-template, no filter needed */

.light-menu-template .primary-menu a {
	color: #F8F2DF;
}

.light-menu-template .primary-menu .button a,
.light-menu-template .primary-menu li.button > a {
	color: #4C4C3B;
}

/* Dropdown Menus with Block Areas - Full Width Mega Menu Style */
.primary-menu .menu-item-has-children {
	position: static;
}

.primary-menu .menu-item-has-children > a::after {
	content: '';
	display: inline-block;
	width: 0;
	height: 0;
	margin-left: 8px;
	border-left: 4px solid transparent;
	border-right: 4px solid transparent;
	border-top: 4px solid currentColor;
	vertical-align: middle;
	transition: transform 0.3s ease;
}

.primary-menu .menu-item-has-children:hover > a::after,
.primary-menu .menu-item-has-children:focus-within > a::after {
	transform: rotate(180deg);
}

.primary-menu .sub-menu {
	position: fixed;
	top: 80px;
	left: 0;
	right: 0;
	width: 100%;
	background: white;
	box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
	border-top: 1px solid #EFE6DD;
	padding: 30px 0;
	list-style: none;
	margin: 0;
	opacity: 0;
	visibility: hidden;
	transform: translateY(-10px);
	transition: opacity 0.3s ease, transform 0.3s ease, visibility 0.3s;
	z-index: 998;
	max-height: calc(100vh - 80px);
	overflow-y: auto;
}

.primary-menu .menu-item-has-children:hover > .sub-menu,
.primary-menu .menu-item-has-children:focus-within > .sub-menu {
	opacity: 1;
	visibility: visible;
	transform: translateY(0);
}

/* Center submenu content */
.primary-menu .sub-menu > li {
	max-width: 1224px;
	margin: 0 auto;
	padding: 0 20px;
}

.primary-menu .sub-menu li {
	margin: 0;
	padding: 0;
}

.primary-menu .sub-menu a {
	padding: 12px 20px;
	display: block;
	border-radius: 4px;
	transition: background-color 0.2s ease;
}

.primary-menu .sub-menu a:hover {
	background-color: #EFE6DD;
	opacity: 1;
}

/* Block Area in Full-Width Dropdowns */
.primary-menu .sub-menu .block-area,
.primary-menu .sub-menu .menu-block-area {
	padding: 20px 0;
	border-top: 1px solid #EFE6DD;
	margin-top: 15px;
	max-width: 1224px;
	margin-left: auto;
	margin-right: auto;
	padding-left: 20px;
	padding-right: 20px;
}

.primary-menu .sub-menu .menu-block-area {
	padding: 20px;
}

.primary-menu .sub-menu .menu-block-area p:last-child {
	margin-bottom: 0;
}

/* Menu Description with Shortcodes */
.primary-menu .sub-menu .menu-description {
	border-top: 1px solid #EFE6DD;
	margin-top: 15px;
	padding-top: 20px;
}

.primary-menu .sub-menu li:first-child .menu-description {
	border-top: none;
	margin-top: 0;
	padding-top: 0;
}

/* Backdrop overlay when menu is open */
.primary-menu .menu-item-has-children:hover::before,
.primary-menu .menu-item-has-children:focus-within::before {
	content: '';
	position: fixed;
	top: 80px;
	left: 0;
	right: 0;
	bottom: 0;
	background: rgba(0, 0, 0, 0.3);
	z-index: 997;
	pointer-events: none;
}

/* No Overlay Template - Add 180px top spacing so content doesn't get overlaid */
.no-overlay-template .site-inner {
	padding-top: 187px;
}

/* Mobile Menu Button and Overlay - Hidden by default (above 950px) */
.mobile-menu-toggle {
	display: none;
}

.mobile-menu-overlay {
	display: none;
}

/* Keyframe Animation for Mobile Menu Items */
@keyframes slideInFromLeft {
	from {
		opacity: 0;
		transform: translateX(-80px);
	}
	to {
		opacity: 1;
		transform: translateX(0);
	}
}

@media (max-width:1280px) {
	.main-nav-container {
		max-width:95%;
	}
}
/* Responsive Styles */
@media (max-width: 1024px) {
	.main-nav-container {
		gap:10px;
	}
	.primary-menu a {
		font-size:14px;
	}
}

/* Mobile Menu Styles - 950px and below */
@media (max-width: 950px) {
	/* Hide desktop navigation */
	.nav-primary {
		display: none;
	}
	.no-overlay-template .site-inner {
    padding-top: 147px;
	}
	.main-navigation-bar {
		padding-top:20px;
	}
	/* Mobile Menu Button */
	.mobile-menu-toggle {
		display: flex;
		align-items: center;
		justify-content: center;
		background: transparent;
		border: none;
		cursor: pointer;
		padding: 0;
		position: relative;
		width: 95px;
		height: 24px;
		z-index: 10002;
	}
	
	.mobile-menu-toggle .menu-button-icon {
		display: block;
		width: auto;
		height: auto;
		max-width: 100%;
	}
	
	/* Mobile Menu Overlay */
	.mobile-menu-overlay {
		display: block;
		position: fixed;
		top: 0;
		left: 0;
		width: 100%;
		height: 100vh;
		background: rgba(0, 0, 0, 0.5);
		z-index: 10000;
		opacity: 0;
		visibility: hidden;
		transition: opacity 0.3s ease, visibility 0.3s ease;
		overflow-y: auto;
	}
	
	.mobile-menu-overlay.active {
		opacity: 1;
		visibility: visible;
	}
	
	.mobile-menu-container {
		position: fixed;
		top: 0;
		left: 0;
		width: 100%;
		max-width: 100%;
		height: 100vh;
		background: #F8F2DF;
		opacity: 0;
		transition: opacity 0.2s ease;
		overflow-y: auto;
		display: flex;
		flex-direction: column;
	}
	
	.mobile-menu-overlay.active .mobile-menu-container {
		opacity: 1;
	}
	
	/* Mobile Menu Header */
	.mobile-menu-header {
		display: flex;
		align-items: center;
		justify-content: space-between;
		padding: 20px;
		flex-shrink: 0;
	}
	
	.mobile-menu-logo {
		flex: 1;
	}
	
	.mobile-menu-logo .logo-img {
		width: 110px;
		max-width: 100%;
		height: auto;
	}
	/* Footer logo is used directly for light-menu-template mobile menu, no filter needed */
	.mobile-menu-close {
		background: transparent;
		border: none;
		cursor: pointer;
		padding: 10px;
		margin: -10px;
		width: auto;
		height: auto;
		display: flex;
		align-items: center;
		justify-content: center;
		transition: opacity 0.2s ease;
	}
	
	.mobile-menu-close:hover {
		opacity: 0.7;
	}
	
	.mobile-menu-close img {
		display: block;
		width: auto;
		height: auto;
		max-width: 100%;
		width: 30px;
	}
	
	/* Mobile Menu Content */
	.mobile-menu-content {
		flex: 1;
		padding: 0 6%;
		display: flex;
		flex-direction: column;
		align-items: center;
	}
	
	/* Mobile Navigation Menu */
	.mobile-nav {
		width: 100%;
		margin-bottom: 40px;
	}
	
	.mobile-menu {
		list-style: none;
		margin: 0;
		padding: 0;
		display: flex;
		flex-direction: column;
		align-items: center;
		gap: 0;
	}
	
	.mobile-menu li {
		margin: 0;
		padding: 0;
		width: 100%;
		text-align: center;
		opacity: 0;
		transform: translateX(-80px);
	}
	
	.mobile-menu-overlay.active .mobile-menu li:nth-child(1) {
		animation: slideInFromLeft 0.5s cubic-bezier(0.25, 0.46, 0.45, 0.94) 0.1s forwards;
	}
	
	.mobile-menu-overlay.active .mobile-menu li:nth-child(2) {
		animation: slideInFromLeft 0.5s cubic-bezier(0.25, 0.46, 0.45, 0.94) 0.2s forwards;
	}
	
	.mobile-menu-overlay.active .mobile-menu li:nth-child(3) {
		animation: slideInFromLeft 0.5s cubic-bezier(0.25, 0.46, 0.45, 0.94) 0.3s forwards;
	}
	
	.mobile-menu-overlay.active .mobile-menu li:nth-child(4) {
		animation: slideInFromLeft 0.5s cubic-bezier(0.25, 0.46, 0.45, 0.94) 0.4s forwards;
	}
	
	.mobile-menu-overlay.active .mobile-menu li:nth-child(5) {
		animation: slideInFromLeft 0.5s cubic-bezier(0.25, 0.46, 0.45, 0.94) 0.5s forwards;
	}
	
	.mobile-menu-overlay.active .mobile-menu li:nth-child(6) {
		animation: slideInFromLeft 0.5s cubic-bezier(0.25, 0.46, 0.45, 0.94) 0.6s forwards;
	}
	
	.mobile-menu-overlay.active .mobile-menu li:nth-child(7) {
		animation: slideInFromLeft 0.5s cubic-bezier(0.25, 0.46, 0.45, 0.94) 0.7s forwards;
	}
	
	.mobile-menu-overlay.active .mobile-menu li:nth-child(8) {
		animation: slideInFromLeft 0.5s cubic-bezier(0.25, 0.46, 0.45, 0.94) 0.8s forwards;
	}
	
	.mobile-menu-overlay.active .mobile-menu li:nth-child(9) {
		animation: slideInFromLeft 0.5s cubic-bezier(0.25, 0.46, 0.45, 0.94) 0.9s forwards;
	}
	
	.mobile-menu-overlay.active .mobile-menu li:nth-child(10) {
		animation: slideInFromLeft 0.5s cubic-bezier(0.25, 0.46, 0.45, 0.94) 1s forwards;
	}
	
	.mobile-menu a {
		color: #4C4C3B;
		text-decoration: none;
		font-size: 16px;
		font-family: 'Sunrider';
		font-weight: 100;
		text-transform: uppercase;
		display: block;
		padding: 10px 0;
		letter-spacing: 0;
		transition: opacity 0.2s ease;
		text-align: left;
	}
	
	.mobile-menu a:hover {
		opacity: 0.7;
	}
	
	.mobile-menu .sub-menu {
		display: none;
	}
	
	/* Mobile Social Links */
	.mobile-menu-social {
		margin-bottom: 20px;
	}
	
	.mobile-social-links {
		list-style: none;
		margin: 0;
		padding: 0;
		display: flex;
		align-items: center;
		justify-content: center;
		gap: 20px;
	}
	
	.mobile-social-links li {
		margin: 0;
		padding: 0;
	}
	
	.mobile-social-links a {
		color: #4C4C3B;
		font-size: 24px;
		text-decoration: none;
		display: flex;
		align-items: center;
		justify-content: center;
		transition: opacity 0.2s ease;
	}
	
	.mobile-social-links a:hover {
		color:#D4B055;
	}
	
	/* Mobile Contact Button */
	.mobile-menu-contact {
		width: 100%;
		max-width: 300px;
	}
	
	.mobile-contact-button {
		display: block;
		width: 100%;
		padding: 2px 0;
		background: #D4B055;
		color: #4C4C3B;
		text-decoration: none;
		font-family: var(--wp--preset--font-family--sunrider);
		font-weight: 100;
		font-size: 15px;
		text-transform: uppercase;
		text-align: center;
		border: 2px solid #4C4C3B;
		border-radius: 7px;
		transition: opacity 0.2s ease, background-color 0.2s ease;
		width: 126px;
		height: 29px;
		margin: 0 auto;
	}
	
	.mobile-contact-button:hover {
		opacity: 0.9;
		background-color: #c5a04a;
	}
}

@media (max-width: 768px) {
	.primary-menu {
		gap: 15px;
	}
	
	.primary-menu a {
		font-size: 14px;
	}
	
	/* Mobile mega menu adjustments */
	.primary-menu .sub-menu {
		padding: 15px 0;
		top: 120px;
	}
	
	.primary-menu .sub-menu > li {
		padding: 0 10px;
	}
	
	.primary-menu .sub-menu .menu-block-area {
		padding: 15px 10px;
	}
	
	.primary-menu .menu-item-has-children:hover::before,
	.primary-menu .menu-item-has-children:focus-within::before {
		top: 120px;
	}
}

@media (max-width: 500px) {
	.logo-img, .mobile-menu-logo .logo-img {
		width: 75px;
	}
	.mobile-menu-toggle {
		width:85px;
	}
	.main-navigation-bar {
        padding-top: 10px;
    }
	.no-overlay-template .site-inner {
        padding-top: 95px;
    }
	.mobile-menu-close img {
		width:25px;
	}
	.main-nav-container {
        gap: 0px;
        padding: 0;
    }
	.mobile-menu-close {
		padding:0;
		margin: -3px 0 0;
	}
	.mobile-menu-header {
		padding: 10px 0;
		max-width: 95%;
		margin: 0 auto;
		width: 95%;
	}
}
