/* ================================================================
   BM Mega Menu - Front-end Styles
   Version: 2.0.18
   ================================================================ */

#site-navigation-wrap,
#site-navigation,
ul.wpex-navbar,
.navbar-style-one > ul {
	overflow: visible !important;
}

li.menu-item.has-mega-menu {
	position: static !important;
}

.bm-mega-menu-container {
	--bm-mega-accent: #1cbcff;
	--bm-mega-accent-strong: #07a7ee;
	--bm-mega-accent-soft: #ecf8ff;
	--bm-mega-rail: #e6f7ff;
	--bm-mega-surface: #ffffff;
	--bm-mega-card: #fbfdff;
	--bm-mega-card-border: #edf3f8;
	--bm-mega-text: #1f2028;
	--bm-mega-muted: #808997;
	--bm-mega-shadow: 0 24px 58px rgba(17, 39, 53, 0.14), 0 8px 18px rgba(17, 39, 53, 0.06);
	display: none;
	position: absolute;
	top: calc(100% - 8px);
	left: 0;
	right: 0;
	z-index: 99999;
	padding: 0 8px 0;
	background: transparent;
	border: 0;
	box-shadow: none;
}

.bm-mega-backdrop {
	position: fixed;
	left: 0;
	right: 0;
	bottom: 0;
	top: 0;
	z-index: 80;
	opacity: 0;
	visibility: hidden;
	pointer-events: none;
	background: rgba(0, 0, 0, 0.62);
	backdrop-filter: blur(10px);
	-webkit-backdrop-filter: blur(10px);
	transition: opacity 0.2s ease, visibility 0.2s ease;
}

.bm-mega-backdrop.is-visible {
	opacity: 1;
	visibility: visible;
	pointer-events: auto;
}

li.menu-item.has-mega-menu > ul.sub-menu.bm-mega-native-submenu-hidden {
	display: none !important;
	visibility: hidden !important;
	opacity: 0 !important;
	pointer-events: none !important;
}

body:not(.bm-mega-menu-js) li.menu-item.has-mega-menu:hover > .bm-mega-menu-container,
li.menu-item.has-mega-menu.bm-mega-active > .bm-mega-menu-container {
	display: block;
	animation: bmMegaIn 0.22s ease forwards;
}

@keyframes bmMegaIn {
	from {
		opacity: 0;
		transform: translateY(10px);
	}

	to {
		opacity: 1;
		transform: translateY(0);
	}
}

.bm-mega-menu-wrap {
	position: relative;
	z-index: 2;
	display: grid;
	grid-template-columns:
		minmax(0, var(--bm-mega-col-software, 49%))
		minmax(220px, var(--bm-mega-col-ecommerce, 23%))
		minmax(295px, var(--bm-mega-col-cta, 28%));
	align-items: stretch;
	gap: 0;
	width: min(1210px, calc(100vw - 18px));
	margin: 0 auto;
	background: var(--bm-mega-surface);
	border-radius: 16px;
	box-shadow: var(--bm-mega-shadow);
	overflow: hidden;
	isolation: isolate;
}

.bm-mega-menu-wrap::after {
	content: "";
	position: absolute;
	left: 0;
	right: 0;
	bottom: 0;
	height: 10px;
	background: linear-gradient(90deg, #67cff1 0%, #53c8ef 100%);
	z-index: 3;
}

.bm-mega-col {
	position: relative;
	min-width: 0;
	padding: 20px 22px 24px;
	z-index: 1;
}

.bm-mega-col--software {
	background: #ffffff;
}

.bm-mega-col--software .bm-mega-col__title {
	max-width: 540px;
}

.bm-mega-col--ecommerce {
	background: #ffffff;
	padding-left: 30px;
}

.bm-mega-col--ecommerce::before {
	content: "";
	position: absolute;
	left: 0;
	top: 20px;
	bottom: 24px;
	width: 1px;
	background: #75d9ff;
}

.bm-mega-col--cta {
	display: flex;
	padding: 20px 18px 24px;
	background: var(--bm-mega-rail);
}

.bm-mega-col__title {
	display: block !important;
	margin: 0 0 14px !important;
	padding: 0 !important;
	border: 0 !important;
	font-size: clamp(18px, 1.45vw, 22px) !important;
	font-weight: 700 !important;
	line-height: 1.12 !important;
	letter-spacing: -0.02em !important;
	text-transform: none !important;
	color: var(--bm-mega-text) !important;
	font-family: 'Raleway';
}

.bm-mega-links-grid {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 10px;
}

.bm-mega-links-list {
	display: grid;
	grid-template-columns: 1fr;
	gap: 10px;
	align-content: start;
}

.bm-mega-link {
	position: relative;
	display: block !important;
	min-height: 0;
	padding: 13px 16px !important;
	border: 1px solid transparent !important;
	border-radius: 10px !important;
	background-clip: padding-box !important;
	box-shadow: 0 0 0 rgba(0, 0, 0, 0);
	color: inherit !important;
	text-decoration: none !important;
	white-space: normal !important;
	transition: transform 0.18s ease, box-shadow 0.18s ease, background 0.18s ease, border-color 0.18s ease !important;
}

.bm-mega-link:hover,
.bm-mega-link:focus-visible {
	transform: translateY(-2px);
	border-color: rgba(28, 188, 255, 0.6) !important;
	background: var(--bm-mega-accent-soft) !important;
	outline: none;
}

.bm-mega-link__icon {
	display: none !important;
}

.bm-mega-link__text {
	display: flex;
	flex-direction: column;
	gap: 3px;
	white-space: normal !important;
}

.bm-mega-link__title {
	display: block !important;
	margin: 0 !important;
	font-size: 14px !important;
	font-weight: 600 !important;
	line-height: 1.24 !important;
	letter-spacing: -0.01em !important;
	color: var(--bm-mega-text) !important;
	white-space: normal !important;
	overflow: visible !important;
	text-overflow: clip !important;
	overflow-wrap: anywhere !important;
	transition: color 0.18s ease !important;
	font-family: 'Raleway';
}

.bm-mega-link:hover .bm-mega-link__title,
.bm-mega-link:focus-visible .bm-mega-link__title {
	color: var(--bm-mega-accent-strong) !important;
}

.bm-mega-link__desc {
	display: block !important;
	margin: 0 !important;
	font-size: 10px !important;
	font-weight: 400 !important;
	line-height: 1.34 !important;
	color: var(--bm-mega-muted) !important;
	white-space: normal !important;
	overflow: visible !important;
	text-overflow: clip !important;
	overflow-wrap: anywhere !important;
}

.bm-mega-cta-card {
	display: flex;
	flex-direction: column;
	gap: 10px;
	width: 100%;
	padding: 0;
	background: transparent;
	color: var(--bm-mega-text);
	box-sizing: border-box;
}

.bm-mega-cta-badge {
	display: inline-flex;
	align-items: center;
	padding: 4px 9px;
	border-radius: 999px;
	background: #ffffff;
	box-shadow: 0 10px 24px rgba(17, 39, 53, 0.08);
	font-size: 10px;
	font-weight: 600;
	line-height: 1;
	color: var(--bm-mega-accent-strong);
	white-space: nowrap;
}

.bm-mega-cta-video {
	position: relative;
	width: 100%;
	height: auto;
	aspect-ratio: 16 / 9;
	overflow: hidden;
	border-radius: 12px;
	background: #20252d;
	box-shadow: 0 12px 22px rgba(17, 39, 53, 0.12);
}

.bm-mega-cta-video iframe,
.bm-mega-cta-video video {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	border: 0;
	border-radius: 12px;
}

.bm-mega-video-preview {
	position: absolute;
	inset: 0;
	display: block;
	width: 100%;
	height: 100%;
	padding: 0;
	border: 0;
	background: #12161d;
	cursor: pointer;
	overflow: hidden;
}

.bm-mega-video-preview__img {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: cover;
	transform: scale(1.01);
	transition: transform 0.24s ease;
}

.bm-mega-video-preview__overlay {
	position: absolute;
	inset: 0;
	background: linear-gradient(180deg, rgba(7, 12, 18, 0.1) 0%, rgba(7, 12, 18, 0.18) 100%);
}

.bm-mega-video-preview__play {
	position: absolute;
	top: 50%;
	left: 50%;
	width: 42px;
	height: 30px;
	border-radius: 9px;
	background: rgba(255, 0, 0, 0.92);
	box-shadow: 0 7px 12px rgba(0, 0, 0, 0.18);
	transform: translate(-50%, -50%);
}

.bm-mega-video-preview__play::before {
	content: "";
	position: absolute;
	top: 50%;
	left: 50%;
	margin-left: 1px;
	border-top: 6px solid transparent;
	border-bottom: 6px solid transparent;
	border-left: 10px solid #ffffff;
	transform: translate(-50%, -50%);
}

.bm-mega-video-preview:hover .bm-mega-video-preview__img,
.bm-mega-video-preview:focus-visible .bm-mega-video-preview__img {
	transform: scale(1.05);
}

.bm-mega-video-preview:focus-visible {
	outline: 2px solid rgba(255, 255, 255, 0.9);
	outline-offset: -4px;
}

.bm-mega-cta-heading {
	margin: 0 !important;
	padding: 0 !important;
	font-size: 13px !important;
	font-weight: 600 !important;
	line-height: 1.28 !important;
	color: var(--bm-mega-text) !important;
	white-space: normal !important;
	overflow: visible !important;
	text-overflow: clip !important;
	overflow-wrap: anywhere !important;
	font-family: 'Raleway';
}

.bm-mega-cta-sub {
	margin: -2px 0 0 !important;
	font-size: 11px !important;
	font-weight: 400 !important;
	line-height: 1.32 !important;
	color: var(--bm-mega-muted) !important;
	white-space: normal !important;
	overflow: visible !important;
	text-overflow: clip !important;
	overflow-wrap: anywhere !important;
}

.bm-mega-cta-btn {
	display: inline-flex !important;
	align-items: center;
	justify-content: center;
	gap: 6px;
	width: 100%;
	margin-top: 4px !important;
	padding: 10px 14px !important;
	border: 0 !important;
	border-radius: 8px !important;
	background: #8cc63f !important;
	box-shadow: 0 12px 22px rgba(140, 198, 63, 0.2);
	color: #ffffff !important;
	font-size: 12px !important;
	font-weight: 700 !important;
	font-family: 'Raleway';
	line-height: 1.2 !important;
	text-decoration: none !important;
	white-space: normal !important;
	overflow-wrap: anywhere !important;
	transition: background 0.18s ease, transform 0.15s ease, box-shadow 0.18s ease !important;
}

.bm-mega-cta-btn::after {
	content: "\f344";
	font-size: 1.35em;
	font-family: dashicons;
	line-height: 1;
	flex-shrink: 0;
	font-weight: 100;
}

.bm-mega-cta-btn:hover,
.bm-mega-cta-btn:focus-visible {
	background: #80bb35 !important;
	box-shadow: 0 18px 32px rgba(128, 187, 53, 0.28);
	color: #ffffff !important;
	text-decoration: none !important;
	transform: translateY(-1px);
	outline: none;
}

@media (max-width: 1400px) {

	.bm-mega-menu-container {
		padding-left: 6px;
		padding-right: 6px;
	}

	.bm-mega-menu-wrap {
		width: min(1180px, calc(100vw - 12px));
	}

	.bm-mega-col {
		padding: 18px 18px 22px;
	}

	.bm-mega-col--ecommerce {
		padding-left: 24px;
	}

	.bm-mega-col--ecommerce::before {
		top: 18px;
		bottom: 22px;
	}
}

@media (max-width: 1199px) {

	.bm-mega-menu-wrap {
		width: calc(100vw - 12px);
		grid-template-columns: minmax(0, 1fr) minmax(250px, 0.88fr);
		border-radius: 16px;
	}

	.bm-mega-col {
		padding: 18px 16px 22px;
	}

	.bm-mega-col--ecommerce {
		padding-left: 20px;
	}

	.bm-mega-col--ecommerce::before {
		top: 18px;
		bottom: 22px;
	}

	.bm-mega-col--cta {
		padding-left: 16px;
		padding-right: 16px;
	}

	.bm-mega-cta-card {
		max-width: none;
	}
}

@media (max-width: 991px) {

	.bm-mega-menu-wrap {
		width: calc(100vw - 24px);
		grid-template-columns: 1fr;
	}

	.bm-mega-col {
		padding: 20px 18px 26px;
	}

	.bm-mega-col__title {
		margin-bottom: 16px !important;
		font-size: 20px !important;
	}

	.bm-mega-col--ecommerce {
		padding-top: 0;
		padding-left: 18px;
	}

	.bm-mega-col--ecommerce::before {
		left: 18px;
		right: 18px;
		top: 0;
		bottom: auto;
		width: auto;
		height: 1px;
	}

	.bm-mega-col--cta {
		padding-top: 18px;
	}

	.bm-mega-links-grid {
		grid-template-columns: 1fr;
	}
}

@media (max-width: 767px) {

	/* ── Keep display:block so max-height transition works ─────── */
	body:not(.bm-mega-menu-js) li.menu-item.has-mega-menu:hover > .bm-mega-menu-container,
	.bm-mega-menu-container {
		display: block !important;
		position: static !important;
		padding: 0 !important;
		max-height: 0;
		overflow: hidden;
		transition: max-height 0.38s cubic-bezier(0.4, 0, 0.2, 1);
	}

	/* Slide open when active */
	li.menu-item.has-mega-menu.bm-mega-active > .bm-mega-menu-container {
		max-height: 1600px;
		animation: none !important;
	}

	/* Never show the backdrop inline */
	.bm-mega-backdrop {
		display: none !important;
	}

	/* ── Wrap — no borders/shadows, flush like sidr ───────────── */
	.bm-mega-menu-wrap {
		width: 100%;
		grid-template-columns: 1fr;
		border-radius: 0;
		box-shadow: none;
		border-top: none;
	}

	/* Hide the bottom accent stripe on mobile */
	.bm-mega-menu-wrap::after {
		display: none;
	}

	/* ── Columns — flush, no extra backgrounds ─────────────────── */
	.bm-mega-col {
		padding: 0;
	}

	/* Section titles become sidr-style category dividers */
	.bm-mega-col__title {
		margin: 0 !important;
		padding: 0.55em 20px !important;
		font-size: 10px !important;
		font-weight: 700 !important;
		letter-spacing: 0.09em !important;
		text-transform: uppercase !important;
		color: #999 !important;
		background: rgba(0,0,0,0.03);
		border-bottom: 1px solid rgba(0,0,0,0.06) !important;
		border-top: 1px solid rgba(0,0,0,0.06) !important;
	}

	/* eCommerce column — remove the left-border pseudo-element */
	.bm-mega-col--ecommerce {
		padding-top: 0;
		padding-left: 0;
		border-top: none;
	}

	.bm-mega-col--ecommerce::before {
		display: none;
	}

	/* CTA column — plain, no tinted background */
	.bm-mega-col--cta {
		padding-top: 0;
		background: transparent;
		border-top: none;
	}

	/* Hide the video player — too heavy for mobile */
	.bm-mega-cta-video {
		display: none !important;
	}

	/* ── Links — match sidr mobile nav items exactly ───────────── */
	.bm-mega-links-grid,
	.bm-mega-links-list {
		grid-template-columns: 1fr;
		gap: 0;
	}

	/* Strip card styling; match sidr li > a padding */
	.bm-mega-link {
		padding: 0.75em 20px 0.75em 32px !important;
		background: transparent !important;
		border: none !important;
		border-bottom: 1px solid rgba(0, 0, 0, 0.06) !important;
		border-radius: 0 !important;
		box-shadow: none !important;
	}

	/* "–" prefix matching sidr sub-item convention */
	.bm-mega-link::before {
		content: "–";
		display: inline-block;
		margin-right: 0.5em;
		color: #bbb;
		font-weight: 400;
		font-style: normal;
	}

	/* Match sidr hover colour */
	.bm-mega-link:hover,
	.bm-mega-link:focus-visible {
		transform: none;
		background: rgba(0, 194, 255, 0.05) !important;
		border-color: rgba(0, 0, 0, 0.06) !important;
	}

	/* Bold title — same weight as sidr hover state */
	.bm-mega-link__title {
		font-size: 14px !important;
		font-weight: 700 !important;
		color: #222 !important;
	}

	.bm-mega-link:hover .bm-mega-link__title,
	.bm-mega-link:focus-visible .bm-mega-link__title {
		color: var(--bm-mega-accent-strong) !important;
	}

	/* Hide description — nav items show title only */
	.bm-mega-link__desc {
		display: none !important;
	}

	/* ── CTA text + button ─────────────────────────────────────── */
	.bm-mega-cta-card {
		padding: 14px 20px 18px;
	}

	.bm-mega-cta-heading {
		font-size: 13px !important;
	}

	.bm-mega-cta-sub {
		font-size: 11px !important;
	}

	.bm-mega-cta-btn {
		padding: 10px 14px !important;
		font-size: 12px !important;
	}
}

/* ================================================================
   Sidr mobile panel — TotalTheme copies the nav into a sidebar and
   renames every CSS class with a "sidr-class-" prefix.
   These rules mirror the @media (max-width:767px) block above using
   those renamed selectors. JS adds bm-mega-active without renaming.
   ================================================================ */

/* Container: hidden by default, slides open */
.sidr-class-bm-mega-menu-container {
	display: block !important;
	position: static !important;
	padding: 0 !important;
	max-height: 0;
	overflow: hidden;
	transition: max-height 0.38s cubic-bezier(0.4, 0, 0.2, 1);
}

/* JS adds bm-mega-active (no sidr-class- prefix) to the li */
li.bm-mega-active > .sidr-class-bm-mega-menu-container {
	max-height: 1600px;
}

/* Wrap — flush, no shadow */
.sidr-class-bm-mega-menu-wrap {
	width: 100% !important;
	display: block !important;
	border-radius: 0 !important;
	box-shadow: none !important;
	border-top: none !important;
}

.sidr-class-bm-mega-menu-wrap::after {
	display: none !important;
}

/* Columns — no extra padding or backgrounds */
.sidr-class-bm-mega-col {
	padding: 0 !important;
}

/* Category label */
.sidr-class-bm-mega-col__title {
	display: block !important;
	margin: 0 !important;
	padding: 0.55em 20px !important;
	font-size: 10px !important;
	font-weight: 700 !important;
	letter-spacing: 0.09em !important;
	text-transform: uppercase !important;
	color: #999 !important;
	background: rgba(0, 0, 0, 0.03) !important;
	border-bottom: 1px solid rgba(0, 0, 0, 0.06) !important;
	border-top: 1px solid rgba(0, 0, 0, 0.06) !important;
}

.sidr-class-bm-mega-col--ecommerce {
	padding-top: 0 !important;
	padding-left: 0 !important;
	border-top: none !important;
}

.sidr-class-bm-mega-col--ecommerce::before {
	display: none !important;
}

.sidr-class-bm-mega-col--cta {
	padding-top: 0 !important;
	background: transparent !important;
	border-top: none !important;
}

/* Hide video on mobile */
.sidr-class-bm-mega-cta-video {
	display: none !important;
}

/* Links containers — single column */
.sidr-class-bm-mega-links-grid,
.sidr-class-bm-mega-links-list {
	display: block !important;
}

/* Link items — flat, match sidr nav style */
.sidr-class-bm-mega-link {
	display: block !important;
	padding: 0.75em 20px 0.75em 32px !important;
	background: transparent !important;
	border: none !important;
	border-bottom: 1px solid rgba(0, 0, 0, 0.06) !important;
	border-radius: 0 !important;
	box-shadow: none !important;
	color: #222 !important;
	text-decoration: none !important;
	transform: none !important;
	transition: color 0.15s ease, background 0.15s ease !important;
}

.sidr-class-bm-mega-link::before {
	content: "–";
	display: inline-block;
	margin-right: 0.5em;
	color: #bbb;
	font-weight: 400;
	font-style: normal;
}

.sidr-class-bm-mega-link:hover,
.sidr-class-bm-mega-link:focus {
	background: rgba(0, 194, 255, 0.05) !important;
	color: #00c2ff !important;
	transform: none !important;
}

/* Title only — no icon, no description */
.sidr-class-bm-mega-link__icon {
	display: none !important;
}

.sidr-class-bm-mega-link__text {
	display: inline !important;
}

.sidr-class-bm-mega-link__title {
	display: inline !important;
	font-size: 14px !important;
	font-weight: 700 !important;
	color: inherit !important;
}

.sidr-class-bm-mega-link:hover .sidr-class-bm-mega-link__title,
.sidr-class-bm-mega-link:focus .sidr-class-bm-mega-link__title {
	color: inherit !important;
}

.sidr-class-bm-mega-link__desc {
	display: none !important;
}

/* CTA area */
.sidr-class-bm-mega-cta-card {
	padding: 14px 20px 18px !important;
}

.sidr-class-bm-mega-cta-heading {
	font-size: 13px !important;
	font-weight: 600 !important;
	color: #222 !important;
}

.sidr-class-bm-mega-cta-sub {
	font-size: 11px !important;
	color: #808997 !important;
}

.sidr-class-bm-mega-cta-btn {
	display: block !important;
	margin-top: 8px !important;
	padding: 10px 14px !important;
	font-size: 12px !important;
	font-weight: 700 !important;
	background: #8cc63f !important;
	color: #ffffff !important;
	border-radius: 8px !important;
	text-decoration: none !important;
	text-align: center !important;
}

.sidr-class-bm-mega-cta-badge {
	display: none !important;
}
