/* ================================================
   HEADER COMPONENT STYLES - OPTIMIZED
   Clean, maintainable, production-ready code
   ================================================ */

/* CSS Variables */
 
:root {
	--org: #F26122;
	--menu: #33334C;
	--transition-speed: 0.3s;
	--header-height: 80px;
}

/* Container - Responsive width control */
.container {
	width: 100%;
	max-width: 1200px;
	margin: 0 auto;
	padding-left: clamp(0.9375rem, 2vw, 1.875rem);
	padding-right: clamp(0.9375rem, 2vw, 1.875rem);
}

/* List Modifier - Required for menu layouts */
.li_m ul {
	padding-left: 0;
	margin-bottom: 0;
	display: flex;
	align-items: center;
}

.li_m li {
	display: inline-block;
	list-style: none;
}

.li_m li a {
	display: inline-block;
	text-decoration: none;
	font-family: "DM Sans", sans-serif;
}

/* Header Container */
.header {
	border-bottom: 1px solid #EAEAEA;
	background: #fff;
	position: relative;
	overflow: visible;
}

.top_head {
	padding: 0.9375rem 0;
}

.flex-container {
	display: flex;
	gap: 1rem;
}

.top_head .flex-container {
	justify-content: space-between;
	align-items: center;
}

/* Logo - Fully Responsive */
.logo {
	cursor: pointer;
	flex-shrink: 0;
	transition: transform 0.2s ease;
}

@media (hover: hover) and (pointer: fine) {
	.logo:hover {
		transform: scale(1.02);
	}
}

.logo img {
	width: 14.375rem;
	max-width: 230px;
	height: auto;
	display: block;
	object-fit: contain;
}

/* Top Right Menu */
.top_right_menu {
	flex: 1;
	display: flex;
	justify-content: flex-end;
}

.top_right_menu li {
	margin: 0 0.9375rem;
	padding: 0.75rem 0;
}

.top_right_menu li a {
	color: var(--menu);
	font-size: 1rem;
	line-height: 1.3;
	font-weight: 400;
	letter-spacing: 0.01875rem;
	transition: color var(--transition-speed) ease;
	white-space: nowrap;
}

@media (hover: hover) and (pointer: fine) {
	.top_right_menu li a:hover {
		color: var(--org);
	}
}

.top_right_menu li a i {
	margin-left: 0.3125rem;
	font-size: 0.75rem;
}

.top_right_menu.li_m li {
	text-transform: uppercase;
}

/* Menu Button */
.top_right_menu .menu_button a {
	background: var(--org);
	color: #fff;
	border: 1px solid var(--org);
	font-size: 0.875rem;
	border-radius: 0.3125rem;
	padding: 0.5625rem 1rem;
	transition: all var(--transition-speed) ease;
	font-weight: 500;
}

@media (hover: hover) and (pointer: fine) {
	.top_right_menu .menu_button a:hover {
		background: #fff;
		color: var(--org);
	}
}

/* Menu Icon */
.top_right_menu .menu_icon {
	padding: 0;
	vertical-align: middle;
	margin-left: 0.25rem;
}

.top_right_menu .menu_icon a {
	display: inline-flex;
	align-items: center;
}

.top_right_menu .menu_icon a i {
	font-size: 1.875rem;
	transition: color var(--transition-speed) ease;
	margin-left: -0.25rem;
}

@media (hover: hover) and (pointer: fine) {
	.top_right_menu .menu_icon a:hover i {
		color: var(--org);
	}
}

/* Menu Cart */
.menu_cart a {
	border: 1px solid var(--org);
	font-size: 0.875rem;
	border-radius: 0.3125rem;
	padding: 0.5625rem 1rem;
	color: var(--org);
	letter-spacing: 0;
	transition: all var(--transition-speed) ease;
}

@media (hover: hover) and (pointer: fine) {
	.menu_cart a:hover {
		background: var(--org);
		color: #fff;
	}
}

.menu_cart a i {
	margin-left: 0;
}

.menu_cart a span {
	margin-right: -0.1875rem;
	font-size: 0.75rem;
	vertical-align: middle;
}

/* Menu Bar (Mobile Toggle) */
.menu_bar a {
	border: none;
	padding: 0.25rem;
	color: var(--org) !important;
	letter-spacing: 0;
	display: inline-flex;
	align-items: center;
	justify-content: center;
}

.menu_bar a i {
	margin-left: 0 !important;
	font-size: 1.75rem;
	color: var(--org) !important;
	transition: transform 0.2s ease;
}

@media (hover: hover) and (pointer: fine) {
	.menu_bar a:hover i {
		transform: scale(1.1);
	}
}

.menu_bar .fa-xmark {
	display: none;
}

.menu_bar.activeBar .fa-bars {
	display: none;
}

.menu_bar.activeBar .fa-xmark {
	display: inline;
}

.menu_bar.activeBar {
	position: relative;
}

/* Dropdown Styles */
.has_dropdown {
	position: relative;
	display: inline-block;
}

.has_dropdown .dropdown-menu {
	position: absolute;
	top: 100%;
	left: 0;
	background-color: #fff;
	min-width: 10rem;
	box-shadow: 0 0.5rem 1rem rgba(0, 0, 0, 0.15);
	z-index: 999999;
	padding: 0.375rem 0;
	margin: 0;
	border-radius: 0.3125rem;
	border: 1px solid rgba(0, 0, 0, 0.05);
	visibility: hidden;
	opacity: 0;
	transform: translateY(-0.625rem);
	transition: opacity 0.25s ease, transform 0.25s ease, visibility 0s 0.25s;
	display: block;
	flex-direction: column;
}

.has_dropdown .dropdown-menu li {
	padding: 0;
	list-style: none;
	display: block;
	margin: 0;
}

.has_dropdown .dropdown-menu li a {
	color: #333;
	text-decoration: none;
	display: block;
	font-size: 0.875rem;
	padding: 0.5rem 0.8125rem;
	transition: none;
	border-left: 4px solid transparent;
	font-weight: 400;
	background: transparent;
	white-space: nowrap;
}

@media (hover: hover) and (pointer: fine) {
	.has_dropdown .dropdown-menu li a:hover {
		background: linear-gradient(to right, rgba(242, 97, 34, 0.2), rgba(255, 255, 255, 0.2));
		border-left: 4px solid #f26122;
		color: #f26122;
	}
}

/* Click toggle - works on all screen sizes */
.has_dropdown.mobile-open .dropdown-menu {
	visibility: visible;
	opacity: 1;
	transform: translateY(0);
	transition: opacity 0.25s ease, transform 0.25s ease;
}

.has_dropdown.mobile-closed .dropdown-menu {
	visibility: hidden;
	opacity: 0;
	transform: translateY(-0.625rem);
	transition: opacity 0.25s ease, transform 0.25s ease, visibility 0s 0.25s;
}

/* Dropdown Icon */
.dropdown-icon {
	margin-left: 0.3125rem;
	font-size: 0.75rem;
	transition: transform var(--transition-speed) ease;
	display: inline-block;
}

.has_dropdown.mobile-open .dropdown-icon {
	transform: rotate(180deg);
}

/* Hover - only works on devices with mouse/trackpad */
@media (hover: hover) and (pointer: fine) {
	.has_dropdown:not(.mobile-open):not(.mobile-closed):hover .dropdown-menu {
		visibility: visible;
		opacity: 1;
		transform: translateY(0);
		transition: opacity 0.25s ease, transform 0.25s ease;
	}
	
	.has_dropdown:hover .dropdown-icon {
		transform: rotate(180deg);
	}
}

.has_dropdown.mobile-closed .dropdown-icon {
	transform: rotate(0deg);
}

/* Login icon dropdown - right-aligned */
.last_header_menu .dropdown-menu {
	left: auto;
	right: 0;
	min-width: 12rem;
	width: max-content;
}

/* Mobile/Desktop Visibility */
.only_mobile {
	display: none !important;
}

.side_menu {
	display: flex;
}

/* Large Desktop (above 1200px) - Lock max sizes */
@media (min-width: 1200px) {
	.container {
		max-width: 1200px;
		padding-left: 1.875rem;
		padding-right: 1.875rem;
	}
	
	.top_head {
		padding: 0.9375rem 0;
	}
	
	.top_right_menu li {
		margin: 0 0.9375rem;
	}
	
	.top_right_menu li a {
		font-size: 1rem;
	}
}

/* Tablet Responsive (701-991px) */
@media (max-width: 991px) and (min-width: 701px) {
	.top_head {
		padding: 0.625rem 0;
	}
	
	.logo img {
		width: clamp(10rem, 14vw, 12rem);
		max-width: 192px;
	}
	
	.top_right_menu li {
		margin: 0 clamp(0.375rem, 0.8vw, 0.625rem);
		padding: 0.5rem 0;
	}
	
	.top_right_menu li a {
		font-size: clamp(0.8125rem, 0.95vw, 0.9375rem);
	}
	
	.top_right_menu .menu_button a,
	.menu_cart a {
		font-size: 0.8125rem;
		padding: 0.4375rem 0.75rem;
	}
	
	.has_dropdown .dropdown-menu {
		min-width: 8.5rem;
	}
	
	.has_dropdown .dropdown-menu li a {
		font-size: 0.8125rem;
		padding: 0.375rem 0.625rem;
	}
}

/* Mobile Responsive (below 701px) */
@media (max-width: 700px) {
	.only_mobile {
		display: block !important;
	}
	
	.header {
		position: relative;
	}
	
	.top_head {
		padding: 0.5rem 0;
	}
	
	.top_head .flex-container {
		gap: 0.5rem;
	}
	
	.logo img {
		width: clamp(8.5rem, 25vw, 10rem);
		max-width: 160px;
	}
	
	.top_right_menu {
		justify-content: flex-end;
	}
	
	.top_right_menu li {
		margin: 0 0.25rem;
		padding: 0.375rem 0;
	}
	
	.menu_bar a {
		padding: 0.375rem;
		min-width: 2rem;
		min-height: 2rem;
		-webkit-tap-highlight-color: transparent;
		pointer-events: auto;
		touch-action: manipulation;
		user-select: none;
		-webkit-user-select: none;
	}
	
	.menu_bar a i {
		font-size: clamp(1.5rem, 4.5vw, 1.85rem) !important;
		color: var(--org) !important;
		pointer-events: none;
	}
	
	/* Disable all hover effects on mobile */
	.menu_bar a:hover,
	.menu_bar a:hover i {
		transform: none !important;
	}
	
	/* Hide desktop menu on mobile, prepare for slide-in */
	.side_menu {
		width: clamp(12rem, 18vw, 16.875rem); /* Responsive width: 192px to 270px */
		position: fixed !important;
		background: white;
		top: 0 !important;
		left: clamp(-16.875rem, -18vw, -12rem); /* Responsive left position */
		height: 100vh;
		z-index: 999;
		box-shadow: 0 0.625rem 1.25rem 0.625rem rgba(0, 0, 0, 0.1);
		transition: left 0.5s ease;
		padding: 1.5625rem;
		display: flex;
		flex-direction: column;
		overflow-y: auto;
		pointer-events: auto;
		transform: translateZ(0) !important; /* Prevent scrolling with navbar */
		will-change: transform; /* Optimize for transforms */
		/* Prevent any scroll inheritance */
		position: fixed !important;
		top: 0 !important;
		left: clamp(-16.875rem, -18vw, -12rem) !important;
	}
	
	/* ONLY open menu when activepanel class is added via JavaScript */
	.side_menu.activepanel {
		left: 0 !important;
		transform: translateZ(0) !important;
		position: fixed !important;
		top: 0 !important;
		display: flex !important;
		visibility: visible !important;
		opacity: 1 !important;
		z-index: 999 !important;
	}
	
	.side_menu:hover {
		left: clamp(-16.875rem, -18vw, -12rem) !important; /* Responsive left position */
	}
	
	.side_menu.activepanel:hover {
		left: 0 !important;
	}
	
	/* Menu Backdrop */
	.menu-backdrop {
		display: none;
		position: fixed;
		top: 0;
		left: 0;
		right: 0;
		bottom: 0;
		width: 100vw;
		height: 100vh;
		background: rgba(0, 0, 0, 0.6);
		z-index: 998;
	}
	
	.menu-backdrop.active {
		display: block;
	}
	
	.side_menu li {
		width: 100%;
		margin: 0.625rem 0;
		padding: 0.3125rem 0;
		border-bottom: 1px solid #f0f0f0;
	}
	
	.side_menu li:last-child {
		border-bottom: none;
	}
	
	.side_menu li a {
		font-size: 0.875rem;
		padding: 0.5rem 0;
		padding-left: 1rem;
		display: block;
		width: 100%;
		transition: background-color 0.2s ease, padding-left 0.2s ease;
	}
	
	/* Active state effect on click */
	.side_menu li a:active,
	.side_menu li a.clicked {
		background: linear-gradient(to right, rgba(242, 97, 34, 0.15), transparent);
		padding-left: 1.5rem;
	}
	
	/* Mobile dropdown menus */
	.side_menu .has_dropdown .dropdown-menu {
		position: static;
		box-shadow: none;
		background: #f9f9f9;
		margin-top: 0.5rem;
		margin-left: 1rem;
		min-width: 100%;
		border: none;
		padding: 0.5rem 0;
		display: none;
		opacity: 0;
		max-height: 0;
		overflow: hidden;
		transition: max-height 0.3s ease, opacity 0.3s ease;
	}
	
	.side_menu .has_dropdown.mobile-open .dropdown-menu {
		display: block;
		opacity: 1;
		max-height: 1000px;
	}
	
	.side_menu .dropdown-menu li {
		border-bottom: none;
		margin: 0;
		padding: 0;
	}
	
	.side_menu .dropdown-menu li a {
		font-size: 0.8125rem;
		padding: 0.4375rem 1rem;
		padding-left: 1.75rem;
		color: #666;
		transition: background-color 0.2s ease, padding-left 0.2s ease, color 0.2s ease;
	}
	
	/* Active state for dropdown items */
	.side_menu .dropdown-menu li a:active,
	.side_menu .dropdown-menu li a.clicked {
		background: linear-gradient(to right, rgba(242, 97, 34, 0.2), transparent);
		padding-left: 2.25rem;
		color: var(--org);
	}
	
	.side_menu .dropdown-icon {
		transition: transform 0.3s ease;
	}
	
	.side_menu .has_dropdown.mobile-open .dropdown-icon {
		transform: rotate(180deg);
	}
	
	/* Style menu_button in mobile menu */
	.side_menu .menu_button a {
		background: var(--org);
		color: #fff;
		border-radius: 0.3125rem;
		padding: 0.625rem 1rem;
		margin: 0.5rem 0;
		margin-left: 1rem;
		display: inline-block;
		width: auto;
		font-weight: 500;
		text-align: center;
	}
	
	.side_menu .menu_button a:active,
	.side_menu .menu_button a.clicked {
		background: #fff;
		color: var(--org);
		border: 1px solid var(--org);
		padding-left: 1rem;
	}
	
	.menu_button a,
	.menu_cart a {
		font-size: 0.8125rem;
		padding: 0.4375rem 0.75rem;
	}
}

/* Extra Small Screens (below 380px) */
@media (max-width: 380px) {
	.top_head {
		padding: 0.4375rem 0;
	}
	
	.logo img {
		width: clamp(7rem, 35vw, 8.5rem);
		max-width: 136px;
	}
	
	.top_right_menu li {
		margin: 0 clamp(0.125rem, 0.5vw, 0.25rem);
	}
	
	.menu_bar a {
		padding: 0.3125rem;
		min-width: 1.875rem;
		min-height: 1.875rem;
	}
	
	.menu_bar a i {
		font-size: 1.5rem !important;
		color: var(--org) !important;
	}
	
	.side_menu {
		width: 90vw;
		padding: 0.875rem;
	}
	
	.side_menu li {
		margin: 0.375rem 0;
		padding: 0.25rem 0;
	}
	
	.side_menu li a {
		font-size: 0.8125rem;
		padding-left: 0.75rem;
	}
	
	.side_menu .dropdown-menu {
		margin-left: 0.5rem;
	}
	
	.side_menu .dropdown-menu li a {
		font-size: 0.75rem;
		padding: 0.375rem 0.75rem;
		padding-left: 1.25rem;
	}
}

/* Extra small screens (380px and below) - More compact menu */
@media (max-width: 380px) {
	.side_menu {
		width: clamp(10rem, 15vw, 12rem); /* Even smaller: 160px to 192px */
		left: clamp(-12rem, -15vw, -10rem); /* Match the width */
		padding: 0.75rem; /* Reduced padding */
	}
	
	.side_menu:hover {
		left: clamp(-12rem, -15vw, -10rem) !important; /* Match the width */
	}
	
	.side_menu li a {
		font-size: 0.75rem; /* Smaller text */
		padding: 0.375rem 0; /* Reduced padding */
		padding-left: 0.75rem;
	}
	
	.side_menu .dropdown-menu li a {
		font-size: 0.6875rem; /* Even smaller dropdown text */
		padding: 0.3125rem 0.5rem;
		padding-left: 1rem;
	}
	
	.side_menu .menu_button a {
		padding: 0.5rem 0.75rem; /* Smaller button */
		font-size: 0.75rem;
	}
}

/* ===== COLLAPSIBLE HEADER FUNCTIONALITY ===== */

/* Prevent header from hiding when side menu is open */
.header.side-menu-open {
	transform: translateY(0) !important;
	opacity: 1 !important;
	visibility: visible !important;
	display: block !important;
	position: fixed !important;
	top: 0 !important;
	z-index: 1000 !important;
}

/* Also prevent main header from hiding */
#mainHeader.side-menu-open {
	transform: translateY(0) !important;
	opacity: 1 !important;
	visibility: visible !important;
	display: block !important;
}

/* Header base styles - more conservative positioning */
.header {
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	z-index: 1000;
	transition: transform 0.3s cubic-bezier(0.4, 0, 0.2, 1);
	transform: translateY(0);
	background: #fff;
	box-shadow: 0 2px 10px rgba(0,0,0,0.1); /* Add subtle shadow */
}

/* Header states */
.header-visible {
	transform: translateY(0);
}

.header-hidden {
	transform: translateY(-100%);
}

/* Toggle button - Orange triangle */
.header-toggle {
	position: fixed;
	top: -7px;
	right: 2px;
	width: 30px;
	height: 30px;
	background: transparent;
	border: none;
	display: flex;
	align-items: center;
	justify-content: center;
	cursor: pointer;
	z-index: 1001;
	transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
	opacity: 0;
	visibility: hidden;
	transform: scale(0.8);
}

.header-toggle:hover {
	transform: scale(1.1);
}

/* Toggle button states */
.toggle-hidden {
	opacity: 0;
	visibility: hidden;
	transform: scale(0.8);
}

.toggle-visible {
	opacity: 1;
	visibility: visible;
	transform: scale(1);
}

/* Orange triangle inside toggle - 40% bigger */
.toggle-triangle {
	width: 0;
	height: 0;
	border-left: 8px solid transparent;
	border-right: 8px solid transparent;
	border-bottom: 14px solid var(--org);
	transition: transform 0.3s ease;
	transform: rotate(0deg); /* Default: pointing down */
}

/* Triangle points up when toggle is visible (header is hidden) */
.header-toggle.toggle-visible .toggle-triangle:not(.point-up) {
	transform: rotate(180deg) !important; /* Pointing up */
}

/* Triangle points down when toggle is visible (header is visible) */
.header-toggle.toggle-visible .toggle-triangle.point-up {
	transform: rotate(0deg) !important; /* Pointing down */
}

/* Direct triangle class targeting */
.toggle-triangle.point-up {
	transform: rotate(0deg) !important; /* Pointing down */
}

.header-toggle:hover .toggle-triangle {
	transform: translateY(-1px);
}

/* Responsive adjustments for toggle button */
@media (max-width: 767px) {
	.header-toggle {
		width: 30px;
		height: 30px;
		top: -7px;
		right: 2px;
	}
	
	.toggle-triangle {
		border-left: 7px solid transparent;
		border-right: 7px solid transparent;
		border-bottom: 11px solid var(--org);
	}
}

/* Temporarily disable body padding changes to test */
/* body {
	transition: padding-top 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

body:not(.header-hidden) {
	padding-top: var(--header-height);
}

body.header-hidden {
	padding-top: 0;
} */

/* Smooth transitions for all header elements */
.header * {
	transition: all 0.3s ease;
}

/* ===== MISSING TOGGLE TRIANGLE BEHAVIOR ===== */

/* Toggle triangle should stay visible when header is open */
.header-toggle {
	opacity: 1 !important;
	visibility: visible !important;
	transform: scale(1) !important;
}

/* Triangle points down when header is visible (open) */
.header-toggle .toggle-triangle {
	transform: rotate(0deg) !important; /* Pointing down */
}

/* Triangle points up when header is hidden (closed) */
.header-toggle.toggle-visible .toggle-triangle {
	transform: rotate(180deg) !important; /* Pointing up */
}

/* ===== MISSING PAGE CONTENT MOVEMENT ===== */

/* Enable body padding changes for page movement */
body {
	transition: padding-top 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

body:not(.header-hidden) {
/*	padding-top: var(--header-height);*/
}

body.header-hidden {
	padding-top: 0;
}

/* Page movement functionality */
.main_content {
    transition: padding 0.3s ease;
}

body.header-hidden .main_content {
    padding: 6.25rem 0 1.25rem 0;  /* 100px top, 20px bottom */
}

/* Ensure header height variable is defined */
:root {
	--header-height: 80px; /* Adjust this to match your header height */
}
