/**
 * EHERO Woo Menu - Frontend Mega Menu Styles
 * v2.0 — Edge detection, hover intent, ARIA, animations
 */

:root {
	--ehero-menu-bg: #ffffff;
	--ehero-menu-text: #333333;
	--ehero-menu-hover-bg: #f5f5f5;
	--ehero-menu-hover-text: #017cba;
	--ehero-menu-active-bg: #017cba;
	--ehero-menu-active-text: #ffffff;
	--ehero-mega-bg: #ffffff;
	--ehero-mega-shadow: 0 10px 40px rgba(0,0,0,0.12);
	--ehero-menu-radius: 0;
	--ehero-menu-font: inherit;
	--ehero-menu-font-size: 14px;
	--ehero-transition: 0.3s cubic-bezier(.22,.68,0,1);
	--ehero-panel-top-spacing: 0px;
}

/* Nav Container */
.ehero-menu-container {
	position: relative;
	z-index: 9999;
}

.ehero-menu-horizontal {
	background: var(--ehero-menu-bg);
	box-shadow: 0 2px 8px rgba(0,0,0,0.06);
}

/* Sticky */
.ehero-menu-sticky {
	position: sticky;
	top: 0;
	z-index: 99999;
	transition: box-shadow var(--ehero-transition);
}

.ehero-menu-sticky.is-scrolled {
	box-shadow: 0 4px 20px rgba(0,0,0,0.1);
}

/* Main Menu List */
.ehero-mega-menu {
	display: flex;
	list-style: none;
	margin: 0;
	padding: 0;
	font-family: var(--ehero-menu-font);
	font-size: var(--ehero-menu-font-size);
}

.ehero-mega-menu--horizontal {
	flex-direction: row;
	align-items: stretch;
}

.ehero-mega-menu--vertical {
	flex-direction: column;
}

/* Menu Items */
.ehero-mega-menu > .menu-item {
	position: relative;
}

.ehero-mega-menu--horizontal > .menu-item {
	display: flex;
	align-items: stretch;
}

/* Menu Links */
.ehero-menu-link {
	display: flex;
	align-items: center;
	gap: 8px;
	padding: 14px 18px;
	color: var(--ehero-menu-text);
	text-decoration: none;
	font-weight: 500;
	white-space: nowrap;
	transition: all var(--ehero-transition);
	position: relative;
}

.ehero-menu-link:hover,
.ehero-menu-link:focus {
	color: var(--ehero-menu-hover-text);
	background: var(--ehero-menu-hover-bg);
}

.ehero-menu-link--top::after {
	content: '';
	position: absolute;
	bottom: 0;
	left: 50%;
	width: 0;
	height: 3px;
	background: var(--ehero-menu-hover-text);
	transition: all var(--ehero-transition);
	transform: translateX(-50%);
	border-radius: 3px 3px 0 0;
}

.menu-item:hover > .ehero-menu-link--top::after,
.menu-item.current-menu-item > .ehero-menu-link--top::after {
	width: 60%;
}

.menu-item.current-menu-item > .ehero-menu-link {
	color: var(--ehero-menu-hover-text);
	font-weight: 600;
}

/* Menu Icon */
.ehero-menu-icon {
	font-size: 16px;
	line-height: 1;
	flex-shrink: 0;
}

.ehero-menu-icon--img {
	width: 20px;
	height: 20px;
	object-fit: contain;
}

/* Menu Badge */
.ehero-menu-badge {
	display: inline-flex;
	align-items: center;
	padding: 2px 8px;
	border-radius: 10px;
	font-size: 10px;
	font-weight: 700;
	color: white;
	text-transform: uppercase;
	letter-spacing: 0.5px;
	line-height: 1.4;
	margin-left: 4px;
}

/* Arrow */
.ehero-menu-arrow {
	display: inline-block;
	width: 0;
	height: 0;
	border-left: 4px solid transparent;
	border-right: 4px solid transparent;
	border-top: 5px solid currentColor;
	margin-left: 4px;
	transition: transform var(--ehero-transition);
	opacity: 0.6;
}

.menu-item:hover > .ehero-menu-link .ehero-menu-arrow {
	transform: rotate(180deg);
	opacity: 1;
}

/* Standard Sub-menu */
.ehero-sub-menu {
	position: absolute;
	top: 100%;
	left: 0;
	background: var(--ehero-menu-bg);
	min-width: 220px;
	list-style: none;
	margin: 0;
	padding: 8px 0;
	border-radius: 0 0 8px 8px;
	box-shadow: var(--ehero-mega-shadow);
	opacity: 0;
	visibility: hidden;
	transform: translateY(10px);
	transition: all var(--ehero-transition);
	z-index: 100;
}

.menu-item:hover > .ehero-sub-menu {
	opacity: 1;
	visibility: visible;
	transform: translateY(0);
}

.ehero-sub-menu .menu-item { display: block; }

.ehero-sub-menu .ehero-menu-link {
	padding: 10px 18px;
	font-size: 13px;
	font-weight: 400;
}

.ehero-sub-menu .ehero-sub-menu {
	top: -8px;
	left: 100%;
	border-radius: 0 8px 8px 0;
}

/* ─── Mega Panel ─── */
.ehero-mega-panel {
	position: absolute;
	top: calc(100% + var(--ehero-panel-top-spacing, 0px));
	left: 0;
	background: var(--ehero-mega-bg);
	box-shadow: var(--ehero-mega-shadow);
	border-radius: 0 0 12px 12px;
	opacity: 0;
	visibility: hidden;
	pointer-events: none;
	transform: translateY(8px);
	transition:
		opacity 0.28s cubic-bezier(.22,.68,0,1),
		transform 0.28s cubic-bezier(.22,.68,0,1),
		visibility 0s 0.28s;
	z-index: 100;
}

/* Width variants */
.ehero-mega-panel--full {
	left: 0;
	right: 0;
	width: 100vw;
	margin-left: calc(-50vw + 50%);
	border-radius: 0 0 0 0;
}

.ehero-mega-panel--wide {
	min-width: 800px;
	max-width: 1200px;
}

.ehero-mega-panel--auto {
	min-width: 500px;
}

.ehero-mega-panel--boxed {
	width: min(1200px, 95vw);
	max-width: 1200px;
}

.ehero-mega-panel--custom {
	/* width set via inline style */
}

/* Open state (JS driven via .is-open, replaces pure :hover) */
.menu-item.is-open > .ehero-mega-panel,
.ehero-mega-item.is-open > .ehero-mega-panel {
	opacity: 1;
	visibility: visible;
	pointer-events: auto;
	transform: translateY(0);
	transition:
		opacity 0.28s cubic-bezier(.22,.68,0,1),
		transform 0.28s cubic-bezier(.22,.68,0,1),
		visibility 0s 0s;
}

/* CSS :hover fallback when JS not loaded */
.no-js .ehero-mega-item:hover > .ehero-mega-panel {
	opacity: 1;
	visibility: visible;
	pointer-events: auto;
	transform: translateY(0);
}

/* Edge detection helper classes */
.ehero-mega-panel--edge-right {
	left: auto !important;
	right: 0 !important;
}

.ehero-mega-panel--edge-left {
	right: auto !important;
}

.ehero-mega-panel--anchored {
	border-radius: 0 0 8px 8px;
}

/* Loading state */
.ehero-mega-panel.is-loading {
	min-height: 100px;
}

.ehero-mega-panel.is-loading::after {
	content: '';
	position: absolute;
	top: 50%;
	left: 50%;
	width: 32px;
	height: 32px;
	margin: -16px 0 0 -16px;
	border: 3px solid #e5e7eb;
	border-top-color: var(--ehero-menu-hover-text);
	border-radius: 50%;
	animation: eheroSpin 0.6s linear infinite;
}

@keyframes eheroSpin {
	to { transform: rotate(360deg); }
}

.ehero-mega-panel__inner {
	max-width: 1200px;
	margin: 0 auto;
	padding: 25px 30px;
}

/* Mega Grid */
.ehero-mega-submenu-wrap {
	display: flex;
	flex-wrap: wrap;
	gap: 0;
}

.ehero-mega-submenu-wrap > .sub-menu {
	display: flex;
	flex-wrap: wrap;
	gap: 0;
	list-style: none;
	padding: 0;
	margin: 0;
	width: 100%;
}

.ehero-mega-submenu-wrap > .sub-menu > .menu-item {
	flex: 1;
	min-width: 200px;
	padding: 0 15px;
}

.ehero-mega-submenu-wrap > .sub-menu > .menu-item > .ehero-menu-link {
	font-weight: 600;
	font-size: 15px;
	color: var(--ehero-menu-text);
	padding: 8px 0;
	border-bottom: 2px solid var(--ehero-menu-hover-text);
	margin-bottom: 8px;
}

.ehero-mega-submenu-wrap > .sub-menu > .menu-item > .sub-menu {
	list-style: none;
	padding: 0;
	margin: 0;
	position: static;
	opacity: 1;
	visibility: visible;
	transform: none;
	box-shadow: none;
	background: transparent;
}

.ehero-mega-submenu-wrap > .sub-menu > .menu-item > .sub-menu .ehero-menu-link {
	padding: 6px 0;
	font-size: 13px;
	color: var(--ehero-menu-text);
}

.ehero-mega-submenu-wrap > .sub-menu > .menu-item > .sub-menu .ehero-menu-link:hover {
	color: var(--ehero-menu-hover-text);
	background: transparent;
	padding-left: 8px;
}

/* Mega Columns Grid */
.ehero-mega-columns {
	display: grid;
	gap: 20px;
}

.ehero-mega-col {
	min-width: 0;
}

/* Mega Blocks */
.ehero-mega-block {
	margin-bottom: 16px;
}

.ehero-mega-block:last-child {
	margin-bottom: 0;
}

/* Mega Custom Content */
.ehero-mega-custom-content {
	margin-bottom: 20px;
}

/* Category Cards */
.ehero-mega-categories__grid,
.ehero-mega-brands__grid {
	display: grid;
	gap: 10px;
}

.ehero-mega-cat-card,
.ehero-mega-brand-card {
	display: flex;
	align-items: center;
	gap: 10px;
	padding: 10px;
	border-radius: 8px;
	text-decoration: none;
	color: var(--ehero-menu-text);
	background: #f9fafb;
	border: 1px solid #f3f4f6;
	transition: all var(--ehero-transition);
}

.ehero-mega-cat-card:hover,
.ehero-mega-brand-card:hover {
	background: #f0f7ff;
	border-color: var(--ehero-menu-hover-text);
	transform: translateY(-2px);
	box-shadow: 0 4px 12px rgba(0,0,0,.06);
}

.ehero-mega-cat-card__img,
.ehero-mega-brand-card__img {
	width: 44px;
	height: 44px;
	border-radius: 8px;
	overflow: hidden;
	flex-shrink: 0;
}

.ehero-mega-cat-card__img img,
.ehero-mega-brand-card__img img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.ehero-mega-cat-card__info {
	display: flex;
	flex-direction: column;
	gap: 2px;
	min-width: 0;
}

.ehero-mega-cat-card__name,
.ehero-mega-brand-card__name {
	font-size: 13px;
	font-weight: 600;
	line-height: 1.3;
}

.ehero-mega-cat-card__count {
	font-size: 11px;
	color: #9ca3af;
}

/* Banner */
.ehero-mega-banner {
	border-radius: 6px;
	overflow: hidden;
}

.ehero-mega-banner img {
	display: block;
	width: 100%;
	height: auto;
	border-radius: 6px;
}

/* Text block */
.ehero-mega-text {
	font-size: 13px;
	line-height: 1.6;
	color: var(--ehero-menu-text);
}

/* Video */
.ehero-mega-video {
	border-radius: 6px;
	overflow: hidden;
}

/* Mega Products Grid */
.ehero-mega-products {
	/* No extra margin/border when inside columns */
}

.ehero-mega-products__grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(150px, 1fr));
	gap: 15px;
}

.ehero-mega-product {
	text-align: center;
	transition: transform var(--ehero-transition);
}

.ehero-mega-product:hover { transform: translateY(-3px); }

.ehero-mega-product__link {
	text-decoration: none;
	color: inherit;
	display: block;
}

.ehero-mega-product__image {
	position: relative;
	border-radius: 8px;
	overflow: hidden;
	margin-bottom: 8px;
	aspect-ratio: 1;
}

.ehero-mega-product__image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.ehero-mega-product__sale {
	position: absolute;
	top: 8px;
	left: 8px;
	background: #e74c3c;
	color: white;
	padding: 2px 8px;
	border-radius: 4px;
	font-size: 10px;
	font-weight: 700;
	text-transform: uppercase;
}

.ehero-mega-product__title {
	font-size: 13px;
	font-weight: 500;
	margin: 0 0 4px;
	line-height: 1.3;
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
}

.ehero-mega-product__price {
	font-size: 14px;
	font-weight: 600;
	color: var(--ehero-menu-hover-text);
}

.ehero-mega-product__price del {
	color: #999;
	font-weight: 400;
	font-size: 12px;
}

.ehero-mega-product__price ins {
	text-decoration: none;
	color: #e74c3c;
}

/* Visibility helpers */
.ehero-hide-mobile { }
.ehero-hide-desktop { }

/* Vertical Menu */
.ehero-menu-vertical .ehero-mega-menu--vertical {
	width: 100%;
}

.ehero-mega-menu--vertical > .menu-item {
	border-bottom: 1px solid #f0f0f0;
}

.ehero-mega-menu--vertical > .menu-item:last-child { border-bottom: none; }

.ehero-mega-menu--vertical .ehero-sub-menu {
	position: static;
	opacity: 1;
	visibility: visible;
	transform: none;
	box-shadow: none;
	border-radius: 0;
	padding-left: 20px;
	max-height: 0;
	overflow: hidden;
	transition: max-height var(--ehero-transition);
}

.ehero-mega-menu--vertical .menu-item.is-open > .ehero-sub-menu {
	max-height: 1000px;
}

.ehero-mega-menu--vertical .ehero-menu-arrow {
	margin-left: auto;
}

.ehero-mega-menu--vertical .ehero-mega-panel {
	position: static;
	width: 100%;
	opacity: 1;
	visibility: visible;
	transform: none;
	box-shadow: none;
	border-radius: 0;
	max-height: 0;
	overflow: hidden;
	transition: max-height var(--ehero-transition);
}

.ehero-mega-menu--vertical .menu-item.is-open > .ehero-mega-panel {
	max-height: 2000px;
}

/* Style Presets */

/* Modern */
.ehero-style-modern .ehero-menu-link { font-weight: 600; letter-spacing: 0.3px; }
.ehero-style-modern .ehero-mega-panel { border-top: 3px solid var(--ehero-menu-hover-text); }

/* Minimal */
.ehero-style-minimal .ehero-menu-link { padding: 12px 16px; }
.ehero-style-minimal .ehero-menu-link--top::after { display: none; }
.ehero-style-minimal .menu-item:hover > .ehero-menu-link { background: transparent; }

/* Dark */
.ehero-style-dark {
	--ehero-menu-bg: #1a1a2e;
	--ehero-menu-text: #e0e0e0;
	--ehero-menu-hover-bg: #16213e;
	--ehero-menu-hover-text: #22d3ee;
	--ehero-mega-bg: #1a1a2e;
}

/* Transparent */
.ehero-style-transparent {
	--ehero-menu-bg: transparent;
	--ehero-menu-hover-bg: rgba(255,255,255,0.1);
	--ehero-menu-text: #ffffff;
	--ehero-menu-hover-text: #ffffff;
}

.ehero-style-transparent .ehero-menu-link--top::after {
	background: #ffffff;
}

/* ─── Animations ─── */
@keyframes eheroFadeIn {
	from { opacity: 0; transform: translateY(8px); }
	to   { opacity: 1; transform: translateY(0); }
}

@keyframes eheroSlideDown {
	from { opacity: 0; transform: translateY(-4px); }
	to   { opacity: 1; transform: translateY(0); }
}

@keyframes eheroZoomIn {
	from { opacity: 0; transform: scale(0.96) translateY(4px); }
	to   { opacity: 1; transform: scale(1) translateY(0); }
}

@keyframes eheroSlideUp {
	from { opacity: 0; transform: translateY(12px); }
	to   { opacity: 1; transform: translateY(0); }
}

.ehero-anim-fade .menu-item.is-open > .ehero-mega-panel,
.ehero-anim-fade .menu-item.is-open > .ehero-sub-menu {
	animation: eheroFadeIn 0.3s cubic-bezier(.22,.68,0,1) forwards;
}

.ehero-anim-slide .menu-item.is-open > .ehero-mega-panel,
.ehero-anim-slide .menu-item.is-open > .ehero-sub-menu {
	animation: eheroSlideDown 0.32s cubic-bezier(.22,.68,0,1) forwards;
}

.ehero-anim-zoom .menu-item.is-open > .ehero-mega-panel,
.ehero-anim-zoom .menu-item.is-open > .ehero-sub-menu {
	animation: eheroZoomIn 0.3s cubic-bezier(.22,.68,0,1) forwards;
}

.ehero-anim-slideup .menu-item.is-open > .ehero-mega-panel,
.ehero-anim-slideup .menu-item.is-open > .ehero-sub-menu {
	animation: eheroSlideUp 0.3s cubic-bezier(.22,.68,0,1) forwards;
}

/* Fullscreen Menu */
.ehero-menu-fullscreen {
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background: rgba(0,0,0,0.95);
	z-index: 999999;
	display: flex;
	align-items: center;
	justify-content: center;
	opacity: 0;
	visibility: hidden;
	transition: all 0.4s ease;
}

.ehero-menu-fullscreen.is-open {
	opacity: 1;
	visibility: visible;
}

.ehero-menu-fullscreen .ehero-mega-menu {
	flex-direction: column;
	align-items: center;
	gap: 10px;
}

.ehero-menu-fullscreen .ehero-menu-link {
	color: white;
	font-size: 24px;
	font-weight: 600;
	padding: 12px 30px;
}

.ehero-menu-fullscreen .ehero-menu-link:hover {
	color: var(--ehero-menu-hover-text);
	background: transparent;
}

/* Rollup */
.ehero-rollup-more {
	cursor: pointer;
}

.ehero-rollup-more .ehero-menu-text::after {
	content: ' ...';
}

.ehero-rollup-hidden {
	display: none !important;
}

.ehero-rollup-dropdown {
	position: absolute;
	top: 100%;
	right: 0;
	background: var(--ehero-menu-bg);
	box-shadow: var(--ehero-mega-shadow);
	border-radius: 0 0 8px 8px;
	min-width: 200px;
	list-style: none;
	padding: 8px 0;
	margin: 0;
}

/* ─── Icon Positioning ─── */
.ehero-link-inner {
	display: inline-flex;
	align-items: center;
	gap: 6px;
}

.ehero-link-inner.ehero-icon-pos-top,
.ehero-link-inner.ehero-icon-pos-bottom {
	flex-direction: column;
	align-items: center;
	gap: 2px;
}

.ehero-link-inner.ehero-icon-pos-bottom {
	flex-direction: column-reverse;
}

.ehero-menu-icon--fa {
	font-size: 1em;
	width: auto;
	line-height: 1;
}

/* ─── Accessibility ─── */
.ehero-menu-link:focus-visible {
	outline: 2px solid var(--ehero-menu-hover-text);
	outline-offset: -2px;
	border-radius: 2px;
}

.ehero-mega-panel:focus-within {
	opacity: 1;
	visibility: visible;
	pointer-events: auto;
	transform: translateY(0);
}

/* Screen reader only */
.ehero-sr-only {
	position: absolute;
	width: 1px;
	height: 1px;
	padding: 0;
	margin: -1px;
	overflow: hidden;
	clip: rect(0,0,0,0);
	white-space: nowrap;
	border: 0;
}

/* Arrow rotation on open */
.menu-item.is-open > .ehero-menu-link .ehero-menu-arrow {
	transform: rotate(180deg);
	opacity: 1;
}

/* ─── Responsive ─── */
@media (max-width: 1024px) {
	.ehero-hide-mobile { display: none !important; }
}

@media (min-width: 1025px) {
	.ehero-hide-desktop { display: none !important; }
}
