/* Mega menu (Models) overlay */

.site-header {
	/* Keep navbar/logo above the mega submenu (logo can overflow below header). */
	z-index: 10000;
}

.morelo-mega {
	position: fixed;
	/* Do not cover the navbar; start below the sticky header */
	top: var(--morelo-header-h);
	left: 0;
	right: 0;
	bottom: 0;
	z-index: 9000;
	display: block;
	opacity: 0;
	visibility: hidden;
	pointer-events: none;
	transition: opacity 260ms cubic-bezier(0.2, 0.8, 0.2, 1);
	will-change: opacity;
}

.morelo-mega.is-open {
	opacity: 1;
	visibility: visible;
	pointer-events: auto;
}

.site-nav .menu-item-has-children.morelo-has-mega > .sub-menu {
	/* Replace classic dropdown with mega overlay (desktop only). */
	display: none !important;
}

.site-nav .menu-item-has-children.morelo-has-mega::after {
	/* Hover bridge not needed when we don't show dropdown */
	display: none;
}

.site-nav .menu-item-has-children.morelo-has-mega > a::after {
	content: "▾";
	font-size: 0.8em;
	margin-left: 8px;
	opacity: 0.8;
}

.morelo-mega-backdrop {
	position: absolute;
	inset: 0;
	/* Black backdrop under the dropdown */
	background: rgba(0, 0, 0, 0.94);
	opacity: 0;
	transition: opacity 260ms cubic-bezier(0.2, 0.8, 0.2, 1);
}

.morelo-mega.is-open .morelo-mega-backdrop {
	opacity: 1;
}

.morelo-mega-panel {
	position: absolute;
	/* Half-screen dropdown under the header */
	top: 18px;
	bottom: 18px;
	left: 50%;
	transform: translateX(-50%);
	width: min(1100px, calc(100vw - 80px));
	height: min(520px, 50vh);
	/* Ensure it never overflows the viewport (header + margins) */
	max-height: calc(100dvh - var(--morelo-header-h) - 36px);
	display: grid;
	grid-template-rows: 1fr auto;
	gap: 18px;
	padding: 16px;
	overflow: hidden;
	transform: translate(-50%, -6px);
	transition: transform 260ms cubic-bezier(0.2, 0.8, 0.2, 1);
}

.morelo-mega.is-open .morelo-mega-panel {
	transform: translate(-50%, 0);
}

.morelo-mega-close {
	position: absolute;
	right: 18px;
	top: 14px;
	width: 44px;
	height: 44px;
	border-radius: 999px;
	border: 1px solid rgba(255, 255, 255, 0.18);
	background: rgba(255, 255, 255, 0.04);
	color: #fff;
	cursor: pointer;
	font-size: 26px;
	line-height: 1;
	display: grid;
	place-items: center;
	z-index: 2;
}

.morelo-mega-grid {
	display: grid;
	grid-template-columns: 260px 1fr;
	gap: 36px;
	align-items: stretch;
	min-height: 0; /* allow children to shrink + scroll */
}

.morelo-mega-list {
	display: flex;
	flex-direction: column;
	gap: 18px;
	padding: 0;
	margin: 0;
	align-self: center;
	min-height: 0;
	overflow: auto;
	align-items: flex-end;
}

.morelo-mega-item {
	appearance: none;
	border: 0;
	background: transparent;
	text-align: right;
	color: rgba(255, 255, 255, 0.62);
	font-size: 0.85rem;
	letter-spacing: 0.6px;
	text-transform: uppercase;
	cursor: pointer;
	padding: 4px 0;
	transition: color 200ms ease, opacity 200ms ease;
}

.morelo-mega-item.is-active {
	color: #fff;
	font-weight: 700;
}

.morelo-mega-media {
	position: relative;
	background: rgba(255, 255, 255, 0.06);
	overflow: hidden;
	min-height: 0;
}

.morelo-mega-media img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
	opacity: 1;
	transition: opacity 340ms cubic-bezier(0.2, 0.8, 0.2, 1);
	will-change: opacity;
}

.morelo-mega-media.is-switching img {
	opacity: 0;
}

.morelo-mega-bottom {
	display: grid;
	grid-template-columns: 220px 1fr;
	gap: 18px;
	align-items: center;
}

.morelo-mega-cta {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 12px;
	padding: 18px 20px;
	color: #fff;
	text-decoration: none;
	position: relative;
	isolation: isolate;
}

.morelo-mega-cta::before {
	content: "";
	position: absolute;
	/* Keep the skewed outline inside the button so it doesn't get clipped */
	inset: 2px 6px;
	border: 2px solid rgba(255, 255, 255, 0.85);
	transform: skewX(-16deg);
	z-index: -1;
}

.morelo-mega-specs {
	display: grid;
	grid-template-columns: repeat(5, minmax(0, 1fr));
	gap: 0;
	border: 1px solid rgba(255, 255, 255, 0.26);
}

.morelo-mega-spec {
	padding: 12px 14px;
	color: #fff;
	position: relative;
}

.morelo-mega-spec + .morelo-mega-spec {
	border-left: 1px solid rgba(255, 255, 255, 0.22);
}

.morelo-mega-spec-label {
	display: block;
	font-size: 0.75rem;
	opacity: 0.75;
	text-transform: uppercase;
	letter-spacing: 0.6px;
}

.morelo-mega-spec-value {
	display: block;
	margin-top: 4px;
	font-weight: 800;
}

@media (max-width: 1100px) {
	.morelo-mega-panel {
		width: min(980px, calc(100vw - 36px));
		height: min(480px, 52vh);
		max-height: calc(100dvh - var(--morelo-header-h) - 32px);
	}
	.morelo-mega-grid {
		grid-template-columns: 210px 1fr;
		gap: 18px;
	}
	.morelo-mega-specs {
		grid-template-columns: repeat(3, minmax(0, 1fr));
	}
}

@media (max-width: 980px) {
	/* Disable the mega overlay on mobile/tablet; keep classic menu. */
	.morelo-mega {
		display: none !important;
	}
}

