.menu-topo {
	position: relative;
	z-index: 1030;
	width: 100%;
	overflow: visible;
}

.menu-topo-modern {
	min-height: 84px;
	padding: 14px 0;
	background: rgba(15, 23, 42, 0.94) !important;
	box-shadow: 0 18px 45px rgba(15, 23, 42, 0.16);
	position: sticky;
	top: 0;
	z-index: 1030;
	border-bottom: 1px solid rgba(255, 255, 255, 0.08);
	backdrop-filter: blur(18px);
	overflow: visible;
}

.menu-topo-modern .container {
	position: relative;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 26px;
	overflow: visible;
}

.menu-brand-area {
	position: relative;
	z-index: 4;
	display: inline-flex;
	align-items: center;
	min-width: 0;
	text-decoration: none;
}

.menu-brand-area:hover {
	text-decoration: none;
}

.menu-brand-logo-img {
	display: block;
	height: 52px;
	width: auto;
	max-width: 260px;
	object-fit: contain;
	filter: drop-shadow(0 10px 22px rgba(14, 165, 233, 0.18));
}

.menu-collapse {
	align-items: center;
	gap: 18px;
}

.menu-links {
	display: flex;
	align-items: center;
	gap: 14px;
	margin: 0;
}

.menu-nav-link {
	color: rgba(226, 232, 240, 0.88) !important;
	font-size: 15px;
	font-weight: 850;
	padding: 11px 16px !important;
	border-radius: 999px;
	transition: all 0.22s ease;
}

.menu-nav-link:hover,
.menu-nav-link.active {
	background: rgba(255, 255, 255, 0.10);
	color: #ffffff !important;
}

.menu-cta-button {
	border: none;
	background: linear-gradient(135deg, #22c55e, #16a34a);
	color: #ffffff;
	padding: 13px 20px;
	border-radius: 999px;
	font-size: 14px;
	font-weight: 900;
	text-decoration: none;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 9px;
	white-space: nowrap;
	box-shadow: 0 16px 32px rgba(34, 197, 94, 0.22);
	transition: all 0.22s ease;
}

.menu-cta-button:hover {
	transform: translateY(-2px);
	box-shadow: 0 20px 38px rgba(34, 197, 94, 0.30);
	color: #ffffff;
	text-decoration: none;
}

.menu-toggler {
	position: relative;
	z-index: 4;
	width: 42px;
	height: 42px;
	border-radius: 14px;
	border: 1px solid rgba(255, 255, 255, 0.14);
	background: rgba(255, 255, 255, 0.08);
	color: #ffffff;
	display: none;
	align-items: center;
	justify-content: center;
	font-size: 16px;
	transition: all 0.22s ease;
	text-decoration: none;
	padding: 0;
}

.menu-toggler:hover,
.menu-toggler:focus {
	background: rgba(255, 255, 255, 0.14);
	transform: translateY(-2px);
	color: #ffffff;
	text-decoration: none;
	box-shadow: none;
	outline: none;
}

.menu-toggler i {
	color: #ffffff;
}

.top-message-box {
	position: fixed;
	right: 16px;
	bottom: 16px;
	width: min(420px, calc(100% - 32px));
	border-radius: 18px;
	overflow: hidden;
	z-index: 9999;
	box-shadow: 0 18px 40px rgba(15, 23, 42, 0.28);
	border: 1px solid rgba(0, 0, 0, 0.06);
	backdrop-filter: blur(12px);
}

.top-message-header {
	padding: 14px 16px;
	display: flex;
	align-items: center;
	justify-content: space-between;
	font-size: 16px;
	font-weight: 800;
}

.top-message-header button {
	border: none;
	background: rgba(255, 255, 255, 0.18);
	color: inherit;
	width: 34px;
	height: 34px;
	border-radius: 12px;
	display: flex;
	align-items: center;
	justify-content: center;
	transition: all 0.2s ease;
}

.top-message-header button:hover {
	background: rgba(255, 255, 255, 0.28);
}

.top-message-body {
	background: #ffffff;
	color: #334155;
	padding: 16px;
	font-size: 15px;
	line-height: 1.5;
	text-align: center;
}

@media (max-width: 991px) {
	.menu-topo,
	.menu-topo-modern,
	.menu-topo-modern .container {
		overflow: visible !important;
	}

	.menu-topo-modern {
		min-height: 84px;
		position: sticky;
		top: 0;
		z-index: 9999;
	}

	.menu-topo-modern .container {
		display: flex;
		align-items: center;
		justify-content: space-between;
	}

	.menu-toggler {
		display: inline-flex;
	}

	#navbarDepuraSoft.menu-collapse {
		position: absolute;
		top: calc(100% + 12px);
		left: 12px;
		right: 12px;
		width: auto;
		z-index: 3;
		background: #ffffff;
		border-radius: 22px;
		padding: 16px;
		box-shadow: 0 24px 55px rgba(15, 23, 42, 0.22);
		border: 1px solid rgba(15, 23, 42, 0.08);
	}

	#navbarDepuraSoft.collapse:not(.show) {
		display: none !important;
	}

	#navbarDepuraSoft.collapse.show,
	#navbarDepuraSoft.collapsing {
		display: block !important;
		visibility: visible !important;
		opacity: 1 !important;
		height: auto !important;
		overflow: visible !important;
	}

	#navbarDepuraSoft .menu-links {
		display: flex !important;
		flex-direction: column !important;
		align-items: stretch !important;
		gap: 6px;
		width: 100%;
		margin: 0;
	}

	#navbarDepuraSoft .menu-nav-link {
		display: block;
		width: 100%;
		color: #334155 !important;
		border-radius: 14px;
		padding: 12px 14px !important;
		text-align: left;
	}

	#navbarDepuraSoft .menu-nav-link:hover,
	#navbarDepuraSoft .menu-nav-link.active {
		background: #eff6ff;
		color: #2563eb !important;
	}

	#navbarDepuraSoft .menu-cta-button {
		width: 100%;
		margin-top: 12px;
	}

	.menu-brand-area,
	.menu-toggler {
		position: relative;
		z-index: 5;
	}
}

@media (max-width: 576px) {
	.menu-topo-modern {
		min-height: 70px;
		padding: 10px 0;
	}

	.menu-brand-logo-img {
		height: 42px;
		max-width: 210px;
	}

	#navbarDepuraSoft.menu-collapse {
		top: calc(100% + 10px);
		left: 10px;
		right: 10px;
		border-radius: 20px;
		padding: 14px;
	}
}

@media (max-width: 991px) {
	.menu-topo,
	.menu-topo-modern,
	.menu-topo-modern .container {
		overflow: visible !important;
	}

	.menu-topo-modern .container {
		position: relative;
		display: flex;
		align-items: center;
		justify-content: space-between;
		flex-wrap: nowrap !important;
	}

	.menu-brand-area {
		display: inline-flex !important;
		align-items: center;
		flex: 0 0 auto !important;
		position: relative;
		z-index: 50 !important;
		visibility: visible !important;
		opacity: 1 !important;
	}

	.menu-brand-logo-img {
		display: block !important;
		height: 42px;
		width: auto !important;
		max-width: 210px;
		visibility: visible !important;
		opacity: 1 !important;
	}

	.menu-toggler {
		display: inline-flex !important;
		flex: 0 0 auto !important;
		position: relative;
		z-index: 60 !important;
	}

	#navbarDepuraSoft.menu-collapse {
		position: absolute !important;
		top: calc(100% + 10px);
		left: 0;
		right: 0;
		width: auto !important;
		flex: 0 0 auto !important;
		flex-basis: auto !important;
		flex-grow: 0 !important;
		z-index: 40 !important;
		background: #ffffff;
		border-radius: 22px;
		padding: 16px;
		box-shadow: 0 24px 55px rgba(15, 23, 42, 0.22);
		border: 1px solid rgba(15, 23, 42, 0.08);
	}

	#navbarDepuraSoft.collapse:not(.show) {
		display: none !important;
	}

	#navbarDepuraSoft.collapse.show {
		display: block !important;
		height: auto !important;
		overflow: visible !important;
		visibility: visible !important;
		opacity: 1 !important;
	}

	#navbarDepuraSoft.collapsing {
		display: block !important;
		height: auto !important;
		overflow: hidden !important;
	}

	#navbarDepuraSoft .menu-links {
		display: flex !important;
		flex-direction: column !important;
		align-items: stretch !important;
		gap: 6px;
		width: 100%;
		margin: 0;
	}

	#navbarDepuraSoft .menu-nav-link {
		color: #334155 !important;
		border-radius: 14px;
		padding: 12px 14px !important;
	}

	#navbarDepuraSoft .menu-cta-button {
		width: 100%;
		margin-top: 12px;
	}
}
