/* ==========================================================================
   Layout — Topbar, Header, Nav, Footer
   ========================================================================== */

/* ============== TOPBAR ============== */
.bn-topbar {
	background: linear-gradient(90deg, #050505 0%, var(--bg-elevated) 100%);
	border-bottom: 1px solid var(--border);
	font-size: var(--fs-sm);
	color: var(--text-muted);
}
.bn-topbar__inner {
	max-width: var(--container-max);
	margin: 0 auto;
	padding: 10px var(--container-pad);
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: var(--space-4);
	flex-wrap: wrap;
}
.bn-topbar__contact {
	display: flex;
	gap: var(--space-6);
	flex-wrap: wrap;
}
.bn-topbar__link {
	display: inline-flex;
	align-items: center;
	gap: var(--space-2);
	color: var(--text-muted);
	font-size: var(--fs-sm);
	transition: color var(--dur);
}
.bn-topbar__link:hover { color: var(--em-400); }
.bn-topbar__link svg { flex-shrink: 0; }

.bn-topbar__meta {
	display: flex;
	align-items: center;
	gap: var(--space-2);
	font-family: var(--font-mono);
	font-size: var(--fs-xs);
	color: var(--em-400);
	text-transform: uppercase;
	letter-spacing: 0.12em;
}
.bn-pulse {
	width: 8px; height: 8px;
	background: var(--em-500);
	border-radius: 50%;
	box-shadow: 0 0 12px var(--em-500);
	animation: bn-pulse 2s ease-in-out infinite;
}
@keyframes bn-pulse { 0%, 100% { opacity: 1; } 50% { opacity: 0.4; } }


/* ============== HEADER ============== */
.bn-header {
	background: var(--bg-overlay);
	backdrop-filter: blur(14px);
	-webkit-backdrop-filter: blur(14px);
	border-bottom: 1px solid var(--border);
	position: sticky;
	top: 0;
	z-index: var(--z-header);
}
.bn-header.is-scrolled {
	background: rgba(5, 5, 5, 0.95);
	box-shadow: 0 4px 24px rgba(0,0,0,0.40);
}

.bn-header__inner {
	max-width: var(--container-max);
	margin: 0 auto;
	padding: var(--space-4) var(--container-pad);
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: var(--space-6);
}

.bn-header__logo {
	display: flex;
	align-items: center;
	gap: var(--space-3);
	color: var(--text);
	flex-shrink: 0;
}
.bn-header__logo:hover { color: var(--text); }
.bn-header__logo-mark { width: 40px; height: 40px; }
.bn-header__logo-text { display: flex; flex-direction: column; line-height: 1.1; }
.bn-header__logo-text strong { font-weight: 700; font-size: var(--fs-md); color: var(--text); }
.bn-header__logo-text span {
	font-size: 11px;
	color: var(--em-400);
	text-transform: uppercase;
	letter-spacing: 0.15em;
	font-family: var(--font-mono);
	margin-top: 2px;
}

/* Logo PNG Mateo — recortado a 305x93 (proporción ~3.3:1).
   Tamaño grande tanto en desktop como en mobile. */
.bn-header__logo--img {
	display: inline-flex;
	align-items: center;
}
.bn-header__logo-img {
	height: 79px;
	width: auto;
	max-width: 285px;
	display: block;
	object-fit: contain;
}
.bn-drawer .bn-header__logo-img { height: 76px; max-width: 260px; }

/* Tablet/laptop chico */
@media (max-width: 1100px) {
	.bn-header__logo-img { height: 79px; max-width: 285px; }
}
@media (max-width: 900px) {
	.bn-header__logo-img { height: 88px; max-width: 305px; }
}
/* Mobile — 92px */
@media (max-width: 640px) {
	.bn-header__logo-img { height: 92px; max-width: 315px; }
}
@media (max-width: 420px) {
	.bn-header__logo-img { height: 84px; max-width: 285px; }
}


/* ============== NAV PRINCIPAL (cascading desktop) ============== */
.bn-nav {
	flex: 1;
	display: flex;
	justify-content: center;
}
.bn-nav__list {
	list-style: none;
	margin: 0; padding: 0;
	display: flex;
	gap: 2px;
	flex-wrap: nowrap;
}
.bn-nav__list > li { position: relative; }

.bn-nav__list a {
	display: inline-flex;
	align-items: center;
	gap: 4px;
	padding: var(--space-2) var(--space-3);
	color: var(--text-2);
	font-weight: 500;
	font-size: 14px;
	border-radius: var(--radius);
	transition: all var(--dur) var(--ease-out);
	white-space: nowrap;
	line-height: 1.2;
}
/* En pantallas medianas, padding más chico */
@media (max-width: 1200px) {
	.bn-nav__list a { padding: var(--space-2) 10px; font-size: 13px; }
	.bn-nav__list { gap: 0; }
}
.bn-nav__list a:hover, .bn-nav__list .current-menu-item > a {
	color: var(--em-400);
	background: rgba(4, 120, 87, 0.08);
}

.bn-nav__caret {
	width: 10px; height: 10px;
	transition: transform var(--dur);
}
.bn-nav__list li:hover > a .bn-nav__caret { transform: rotate(180deg); }

/* ============== Dropdown depth 1 — MEGA MENU CHEVERE ============== */
.bn-nav__dropdown {
	position: absolute;
	top: 100%;
	left: 50%;
	transform: translateX(-50%) translateY(-8px);
	min-width: 540px;
	max-width: 640px;
	background: linear-gradient(180deg, #14171F 0%, #0F1216 100%);
	border: 1px solid var(--border);
	border-radius: var(--radius-md);
	padding: var(--space-4);
	margin-top: var(--space-3);
	box-shadow:
		0 24px 48px rgba(0, 0, 0, 0.55),
		0 0 0 1px var(--border-em);
	list-style: none;
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: var(--space-2);
	opacity: 0;
	visibility: hidden;
	transition: opacity var(--dur) var(--ease-out), transform var(--dur) var(--ease-out), visibility 0s linear var(--dur);
	z-index: var(--z-dropdown);
}
.bn-nav__list li:hover > .bn-nav__dropdown,
.bn-nav__list li:focus-within > .bn-nav__dropdown {
	opacity: 1;
	visibility: visible;
	transform: translateX(-50%) translateY(0);
	transition: opacity var(--dur) var(--ease-out), transform var(--dur) var(--ease-out), visibility 0s;
}

/* Glow ring sutil emerald */
.bn-nav__dropdown::after {
	content: '';
	position: absolute;
	inset: -1px;
	border-radius: var(--radius-md);
	background: linear-gradient(135deg, transparent 0%, rgba(4,120,87,0.30) 50%, transparent 100%);
	-webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
	-webkit-mask-composite: xor;
	mask-composite: exclude;
	padding: 1px;
	pointer-events: none;
	opacity: 0.6;
}

/* Bridge invisible para no perder hover */
.bn-nav__dropdown::before {
	content: '';
	position: absolute;
	top: -14px; left: 0; right: 0;
	height: 14px;
}

/* Item del dropdown — card con icono + título + descripción */
.bn-nav__dropdown > li {
	margin: 0;
	border-radius: var(--radius);
	overflow: hidden;
}
.bn-nav__dropdown > li > a {
	display: grid;
	grid-template-columns: 36px 1fr;
	gap: var(--space-3);
	align-items: start;
	padding: var(--space-3);
	border-radius: var(--radius);
	color: var(--text);
	font-weight: 600;
	font-size: var(--fs-sm);
	line-height: 1.3;
	background: transparent;
	transition: all var(--dur) var(--ease-out);
	position: relative;
}
.bn-nav__dropdown > li > a::before {
	content: '';
	grid-row: 1 / 3;
	width: 36px;
	height: 36px;
	border-radius: var(--radius);
	background:
		linear-gradient(135deg, rgba(4,120,87,0.20) 0%, rgba(52,211,153,0.10) 100%);
	box-shadow: inset 0 0 12px rgba(4,120,87,0.15);
	flex-shrink: 0;
	display: block;
}
.bn-nav__dropdown > li > a > .bn-nav-desc {
	display: block;
	font-weight: 400;
	font-size: var(--fs-xs);
	color: var(--text-muted);
	margin-top: 2px;
	line-height: 1.4;
}
.bn-nav__dropdown > li > a:hover,
.bn-nav__dropdown > li > a:focus {
	background: rgba(4, 120, 87, 0.10);
	color: var(--em-300);
}
.bn-nav__dropdown > li > a:hover .bn-nav-desc {
	color: var(--text-2);
}

/* Header de sección dentro del dropdown */
.bn-nav__dropdown-head {
	grid-column: 1 / -1;
	padding: 0 var(--space-3) var(--space-2);
	font-family: var(--font-mono);
	font-size: 11px;
	color: var(--em-400);
	text-transform: uppercase;
	letter-spacing: 0.15em;
	border-bottom: 1px solid var(--border);
	margin-bottom: var(--space-2);
}

/* Footer del dropdown con CTA */
.bn-nav__dropdown-cta {
	grid-column: 1 / -1;
	margin-top: var(--space-3);
	padding-top: var(--space-3);
	border-top: 1px solid var(--border);
	display: flex;
	justify-content: space-between;
	align-items: center;
}
.bn-nav__dropdown-cta .bn-nav-cta-link {
	display: inline-flex;
	align-items: center;
	gap: var(--space-2);
	padding: var(--space-2) var(--space-4);
	font-family: var(--font-mono);
	font-size: var(--fs-xs);
	color: var(--em-400);
	text-transform: uppercase;
	letter-spacing: 0.1em;
	border: 1px solid var(--border-em);
	border-radius: var(--radius-pill);
	transition: all var(--dur);
}
.bn-nav__dropdown-cta .bn-nav-cta-link:hover {
	background: rgba(4,120,87,0.10);
	color: var(--em-300);
	border-color: var(--em-500);
}

/* Sub-dropdown depth 2 (fly-out lateral) */
.bn-nav__sub-dropdown {
	position: absolute;
	left: 100%;
	top: -8px;
	min-width: 240px;
	background: var(--bg-elevated);
	border: 1px solid var(--border);
	border-radius: var(--radius-md);
	padding: var(--space-2);
	margin-left: var(--space-2);
	list-style: none;
	box-shadow: var(--shadow);
	opacity: 0;
	visibility: hidden;
	transform: translateX(-8px);
	transition: all var(--dur) var(--ease-out);
}
.bn-nav__dropdown li:hover > .bn-nav__sub-dropdown,
.bn-nav__dropdown li:focus-within > .bn-nav__sub-dropdown {
	opacity: 1;
	visibility: visible;
	transform: translateX(0);
}


/* ============== HEADER ACTIONS ============== */
.bn-header__actions {
	display: flex;
	gap: var(--space-3);
	align-items: center;
	flex-shrink: 0;
}

/* Burger button */
.bn-burger {
	display: none;
	width: 44px; height: 44px;
	background: transparent;
	border: 1px solid var(--border-strong);
	border-radius: var(--radius);
	cursor: pointer;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	gap: 4px;
	padding: 0;
	transition: border-color var(--dur);
}
.bn-burger:hover { border-color: var(--em-500); }
.bn-burger span {
	display: block;
	width: 18px; height: 2px;
	background: var(--text);
	border-radius: 1px;
	transition: all var(--dur) var(--ease-out);
}
.bn-burger[aria-expanded="true"] span:nth-child(1) { transform: rotate(45deg) translate(4px, 4px); }
.bn-burger[aria-expanded="true"] span:nth-child(2) { opacity: 0; }
.bn-burger[aria-expanded="true"] span:nth-child(3) { transform: rotate(-45deg) translate(4px, -4px); }


/* ============== MOBILE DRAWER ============== */
.bn-drawer-backdrop {
	position: fixed;
	inset: 0;
	background: rgba(5, 5, 5, 0.85);
	backdrop-filter: blur(8px);
	-webkit-backdrop-filter: blur(8px);
	opacity: 0;
	visibility: hidden;
	transition: all var(--dur);
	z-index: var(--z-drawer);
}
.bn-drawer-backdrop.is-open { opacity: 1; visibility: visible; }

.bn-drawer {
	position: fixed;
	top: 0; right: 0;
	width: min(380px, 90vw);
	height: 100vh;
	background: var(--bg-deep);
	border-left: 1px solid var(--border);
	transform: translateX(100%);
	transition: transform var(--dur-slow) var(--ease-out);
	z-index: calc(var(--z-drawer) + 1);
	overflow-y: auto;
	display: flex;
	flex-direction: column;
}
.bn-drawer.is-open { transform: translateX(0); }

.bn-drawer__header {
	padding: var(--space-4) var(--space-6);
	border-bottom: 1px solid var(--border);
	display: flex;
	justify-content: space-between;
	align-items: center;
}
.bn-drawer__close {
	width: 40px; height: 40px;
	background: transparent;
	border: 1px solid var(--border-strong);
	border-radius: var(--radius);
	color: var(--text-2);
	cursor: pointer;
}

.bn-drawer__nav {
	padding: var(--space-4) var(--space-6);
	flex: 1;
}
.bn-drawer__nav > ul {
	list-style: none;
	margin: 0; padding: 0;
}
.bn-drawer__nav li { border-bottom: 1px solid var(--border); }
.bn-drawer__nav a {
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding: var(--space-4) 0;
	color: var(--text);
	font-weight: 500;
	font-size: var(--fs-md);
}
.bn-drawer__nav .bn-nav__dropdown,
.bn-drawer__nav .bn-nav__sub-dropdown {
	position: static;
	opacity: 1; visibility: visible;
	transform: none;
	background: transparent;
	border: 0;
	box-shadow: none;
	margin: 0; padding-left: var(--space-4);
	max-height: 0;
	overflow: hidden;
	transition: max-height var(--dur) var(--ease-out);
}
.bn-drawer__nav li.is-open > .bn-nav__dropdown,
.bn-drawer__nav li.is-open > .bn-nav__sub-dropdown {
	max-height: 800px;
}

.bn-drawer__footer {
	padding: var(--space-6);
	border-top: 1px solid var(--border);
	display: flex;
	flex-direction: column;
	gap: var(--space-3);
}


/* ============== FOOTER ============== */
.bn-footer {
	background: var(--bg-footer);
	border-top: 1px solid var(--border);
	padding: var(--space-16) var(--container-pad) var(--space-8);
	margin-top: var(--space-20);
}
.bn-footer__inner { max-width: var(--container-max); margin: 0 auto; }

.bn-footer__grid {
	display: grid;
	grid-template-columns: 1.6fr 1fr 1fr 1fr 1fr;
	gap: var(--space-8);
	margin-bottom: var(--space-12);
}
@media (max-width: 1024px) {
	.bn-footer__grid { grid-template-columns: 1fr 1fr 1fr; gap: var(--space-6); }
	.bn-footer__brand { grid-column: 1 / -1; margin-bottom: var(--space-4); }
}
@media (max-width: 640px) {
	.bn-footer__grid { grid-template-columns: 1fr 1fr; }
	.bn-footer__brand { grid-column: 1 / -1; }
}

.bn-footer__brand img { max-width: 180px; margin-bottom: var(--space-4); }
.bn-footer__logo {
	display: inline-block;
	margin-bottom: var(--space-4);
	text-decoration: none;
}
.bn-footer__logo-img {
	height: 110px;
	width: auto;
	max-width: 380px;
	display: block;
	object-fit: contain;
	margin-bottom: 0 !important;
}
@media (max-width: 640px) {
	.bn-footer__logo-img { height: 80px; max-width: 290px; }
}
.bn-footer__brand p {
	color: var(--text-muted);
	font-size: var(--fs-sm);
	max-width: 320px;
	line-height: var(--lh-relaxed);
}
.bn-footer__brand .bn-mono {
	font-family: var(--font-mono);
	font-size: var(--fs-xs);
	color: var(--text-dim);
	margin-top: var(--space-4);
	line-height: 1.6;
}

.bn-footer h4 {
	font-size: var(--fs-xs);
	text-transform: uppercase;
	letter-spacing: 0.15em;
	color: var(--em-400);
	margin-bottom: var(--space-4);
	font-weight: 500;
	font-family: var(--font-mono);
}
.bn-footer ul {
	list-style: none;
	display: flex;
	flex-direction: column;
	gap: var(--space-2);
	padding: 0;
	margin: 0;
}
.bn-footer ul a {
	color: var(--text-muted);
	font-size: var(--fs-sm);
}
.bn-footer ul a:hover { color: var(--em-400); }

.bn-footer__legal {
	color: var(--text-dim);
	font-size: var(--fs-xs);
	padding-top: var(--space-6);
	border-top: 1px solid var(--border);
	display: flex;
	justify-content: space-between;
	gap: var(--space-4);
	flex-wrap: wrap;
}
.bn-footer__legal a {
	color: var(--text-dim);
	margin-left: var(--space-3);
}
.bn-footer__legal a:hover { color: var(--em-400); }

.bn-footer__social {
	display: flex;
	gap: var(--space-2);
	margin-top: var(--space-4);
}
.bn-footer__social a {
	width: 36px; height: 36px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	background: var(--bg-elevated);
	border: 1px solid var(--border);
	border-radius: var(--radius);
	color: var(--text-muted);
	transition: all var(--dur);
}
.bn-footer__social a:hover {
	border-color: var(--em-500);
	color: var(--em-400);
	transform: translateY(-2px);
}

/* ==========================================================================
   CTA Tooltip mobile — explica qué hace el botón verde redondo
   ========================================================================== */
.bn-header__cta-wrap {
	position: relative;
	display: inline-flex;
	align-items: center;
}
.bn-header__cta-mobile-icon {
	display: none;
	align-items: center;
	justify-content: center;
	color: #ffffff;
}
.bn-cta-tooltip {
	position: absolute;
	top: calc(100% + 12px);
	right: 0;
	width: min(320px, 88vw);
	background: var(--bg-elevated, #14181f);
	color: var(--text, #f1f5f9);
	border: 1px solid var(--em-700, #047857);
	border-radius: 14px;
	padding: 16px 18px 14px 18px;
	box-shadow: 0 12px 40px rgba(0, 0, 0, 0.45), 0 0 0 4px rgba(16, 185, 129, 0.10);
	z-index: 1000;
	opacity: 0;
	transform: translateY(-6px) scale(0.96);
	pointer-events: none;
	transition: opacity 220ms ease, transform 220ms cubic-bezier(0.34, 1.56, 0.64, 1);
	display: flex;
	flex-direction: column;
	gap: 6px;
}
.bn-cta-tooltip.is-open {
	opacity: 1;
	transform: translateY(0) scale(1);
	pointer-events: auto;
}
.bn-cta-tooltip::before {
	content: '';
	position: absolute;
	top: -8px;
	right: 24px;
	width: 14px;
	height: 14px;
	background: var(--bg-elevated, #14181f);
	border-top: 1px solid var(--em-700, #047857);
	border-left: 1px solid var(--em-700, #047857);
	transform: rotate(45deg);
}
.bn-cta-tooltip strong {
	color: var(--em-400, #34d399);
	font-size: 14px;
	font-weight: 700;
	letter-spacing: 0.01em;
	padding-right: 26px;
}
.bn-cta-tooltip > span {
	color: var(--text-muted, #a3afc7);
	font-size: 13px;
	line-height: 1.5;
}
.bn-cta-tooltip__cta {
	display: inline-block;
	margin-top: 4px;
	padding: 8px 0 0 0;
	color: var(--em-400, #34d399);
	font-weight: 600;
	font-size: 13px;
	text-decoration: none;
	border-top: 1px solid rgba(16, 185, 129, 0.18);
}
.bn-cta-tooltip__cta:hover { color: #ffffff; }
.bn-cta-tooltip__close {
	position: absolute;
	top: 8px;
	right: 8px;
	background: transparent;
	border: 0;
	color: var(--text-muted, #a3afc7);
	width: 28px; height: 28px;
	border-radius: 8px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	cursor: pointer;
	transition: background 160ms, color 160ms;
}
.bn-cta-tooltip__close:hover {
	background: rgba(255,255,255,0.06);
	color: #ffffff;
}

/* En desktop el tooltip NO se muestra (botón ya tiene texto claro) */
@media (min-width: 769px) {
	.bn-cta-tooltip { display: none !important; }
}

/* En mobile, el botón se ve solo con flecha + tooltip educa */
@media (max-width: 768px) {
	.bn-header__cta-text { display: none; }
	.bn-header__cta-mobile-icon { display: inline-flex; }
	.bn-header__cta {
		min-width: 44px;
		min-height: 44px;
		padding: 0 14px !important;
	}
}

/* ==========================================================================
   MEGA-MENU — Soluciones, Para tu Giro, Herramientas
   ========================================================================== */
.bn-nav__list li.has-megamenu { position: static; }
.bn-megamenu {
	position: absolute;
	top: 100%;
	left: 50%;
	transform: translateX(-50%) translateY(0);
	width: min(1080px, calc(100vw - 32px));
	background: var(--bg-elevated, #14181f);
	border: 1px solid var(--border, #1f2a25);
	border-radius: 14px;
	box-shadow: 0 24px 60px rgba(0, 0, 0, 0.55);
	padding: 24px 28px;
	opacity: 0;
	visibility: hidden;
	pointer-events: none;
	transition: opacity .25s ease, transform .25s cubic-bezier(.34, 1.1, .64, 1);
	z-index: 100;
}
/* Zona buffer invisible entre el item y el dropdown (16px) para que el hover no se pierda */
.bn-nav__list li.has-megamenu > a::after {
	content: '';
	position: absolute;
	left: -10px;
	right: -10px;
	top: 100%;
	height: 16px;
	background: transparent;
}
.bn-megamenu::before {
	content: '';
	position: absolute;
	top: -8px;
	left: 50%;
	transform: translateX(-50%);
	width: 16px; height: 16px;
	background: var(--bg-elevated, #14181f);
	border-top: 1px solid var(--border, #1f2a25);
	border-left: 1px solid var(--border, #1f2a25);
	transform: translateX(-50%) rotate(45deg);
}
.bn-nav__list li.has-megamenu.is-open > .bn-megamenu,
.bn-nav__list li.has-megamenu:focus-within > .bn-megamenu {
	opacity: 1;
	visibility: visible;
	pointer-events: auto;
	transform: translateX(-50%) translateY(0);
}

.bn-megamenu__inner {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 28px;
	margin-bottom: 18px;
}
.bn-megamenu__inner--4col {
	grid-template-columns: repeat(4, 1fr);
	gap: 20px;
}

.bn-megamenu__col h3 {
	display: flex;
	align-items: center;
	gap: 8px;
	margin: 0 0 6px;
	font-size: 13px;
	font-weight: 700;
	color: var(--em-400, #34d399);
	font-family: var(--font-mono, monospace);
	text-transform: uppercase;
	letter-spacing: 0.1em;
}
.bn-megamenu__col h3 .bn-icon {
	color: var(--em-400, #34d399);
}
.bn-megamenu__col p {
	font-size: 12px;
	color: var(--text-muted, #a3afc7);
	margin: 0 0 12px;
	line-height: 1.5;
}
.bn-megamenu__col ul {
	list-style: none;
	margin: 0 0 12px;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: 2px;
}
.bn-megamenu__col li a {
	display: flex !important;
	align-items: center;
	gap: 8px;
	padding: 8px 10px !important;
	border-radius: 6px;
	color: var(--text, #f1f5f9) !important;
	font-size: 13px !important;
	font-weight: 500 !important;
	text-decoration: none;
	transition: background .15s, color .15s;
}
.bn-megamenu__col li a .bn-icon {
	color: var(--text-muted, #a3afc7);
	flex-shrink: 0;
}
.bn-megamenu__col li a:hover {
	background: rgba(4, 120, 87, 0.10) !important;
	color: var(--em-400, #34d399) !important;
}
.bn-megamenu__col li a:hover .bn-icon {
	color: var(--em-400, #34d399);
}
.bn-megamenu__col li a span {
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}
.bn-megamenu__more {
	display: inline-block;
	padding: 6px 0 !important;
	font-size: 12px !important;
	color: var(--em-400, #34d399) !important;
	font-weight: 600 !important;
	border-top: 1px solid rgba(255,255,255,0.06);
	margin-top: 4px;
}

.bn-megamenu__cta {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 16px;
	padding: 14px 16px;
	background: rgba(4, 120, 87, 0.08);
	border-radius: 10px;
	border: 1px solid rgba(16, 185, 129, 0.18);
}
.bn-megamenu__cta span { font-size: 13px; color: var(--text, #f1f5f9); }

/* Sectores: grid 4 columnas */
.bn-megamenu--sectores .bn-megamenu__head {
	margin-bottom: 16px;
}
.bn-megamenu--sectores .bn-megamenu__head h3 {
	font-size: 13px;
	color: var(--em-400, #34d399);
	margin: 0 0 4px;
	font-family: var(--font-mono, monospace);
	text-transform: uppercase;
	letter-spacing: 0.1em;
}
.bn-megamenu--sectores .bn-megamenu__head p {
	font-size: 13px;
	color: var(--text-muted, #a3afc7);
	margin: 0;
}
.bn-megamenu__grid {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 6px;
}
.bn-megamenu__sector {
	display: flex !important;
	align-items: center;
	gap: 8px;
	padding: 10px 12px !important;
	background: var(--bg-deep, #0a0a0a);
	border: 1px solid var(--border, #1f2a25);
	border-radius: 8px;
	color: var(--text, #f1f5f9) !important;
	font-size: 12px !important;
	font-weight: 500 !important;
	text-decoration: none;
	transition: all .15s;
}
.bn-megamenu__sector .bn-icon {
	color: var(--em-400, #34d399);
	flex-shrink: 0;
}
.bn-megamenu__sector:hover {
	border-color: var(--em-500, #10b981);
	background: rgba(4, 120, 87, 0.10) !important;
	transform: translateY(-1px);
}

/* Mobile: ocultar megamenu (se usa drawer) */
@media (max-width: 1024px) {
	.bn-megamenu { display: none; }
}

/* ── Mobile drawer: dropdowns visibles al tap (controlados por JS .is-mobile-open) ── */
@media (max-width: 1024px) {
	.bn-drawer .bn-megamenu,
	.bn-drawer .bn-nav__dropdown {
		display: none;
		position: static !important;
		width: 100% !important;
		max-width: 100% !important;
		transform: none !important;
		opacity: 1 !important;
		visibility: visible !important;
		pointer-events: auto !important;
		box-shadow: none !important;
		border: 0 !important;
		background: rgba(255,255,255,0.02) !important;
		padding: 8px 6px !important;
		margin: 2px 0 4px !important;
		border-radius: 8px !important;
		z-index: 1;
		box-sizing: border-box !important;
	}
	.bn-drawer li.is-mobile-open > .bn-megamenu,
	.bn-drawer li.is-mobile-open > .bn-nav__dropdown {
		display: block;
	}
	.bn-drawer .bn-megamenu__inner,
	.bn-drawer .bn-megamenu__grid {
		grid-template-columns: 1fr !important;
		gap: 8px !important;
	}
	.bn-drawer .bn-megamenu__col {
		padding: 4px 2px;
	}
	.bn-drawer .bn-megamenu__col h3 {
		margin: 6px 0 2px;
		font-size: 11px !important;
	}
	.bn-drawer .bn-megamenu__col p {
		font-size: 11px !important;
		margin-bottom: 6px;
	}
	.bn-drawer .bn-megamenu__col li a,
	.bn-drawer .bn-megamenu__sector {
		padding: 9px 10px !important;
		font-size: 13px !important;
		gap: 10px !important;
		justify-content: flex-start !important;
		text-align: left !important;
	}
	.bn-drawer .bn-megamenu__col li a .bn-icon,
	.bn-drawer .bn-megamenu__sector .bn-icon {
		flex-shrink: 0 !important;
	}
	.bn-drawer .bn-megamenu__col li a span,
	.bn-drawer .bn-megamenu__sector span {
		white-space: normal !important;
		overflow: visible !important;
		text-overflow: clip !important;
		line-height: 1.35 !important;
		word-wrap: break-word;
		text-align: left !important;
		flex: 1;
	}
	/* Headers (h3) y descripciones (p) también a la izquierda */
	.bn-drawer .bn-megamenu__col h3,
	.bn-drawer .bn-megamenu__col p,
	.bn-drawer .bn-megamenu__head h3,
	.bn-drawer .bn-megamenu__head p,
	.bn-drawer .bn-megamenu__more {
		text-align: left !important;
		justify-content: flex-start !important;
	}
	/* Lista UL del megamenu sin centrado */
	.bn-drawer .bn-megamenu__col ul,
	.bn-drawer .bn-megamenu__grid {
		text-align: left !important;
	}
	.bn-drawer .bn-megamenu__col ul li {
		text-align: left !important;
	}
	.bn-drawer .bn-megamenu__more {
		font-size: 11px !important;
		padding: 4px 0 !important;
	}
	.bn-drawer .bn-megamenu__head {
		margin-bottom: 6px;
	}
	.bn-drawer .bn-megamenu__head h3 { font-size: 11px !important; }
	.bn-drawer .bn-megamenu__head p { font-size: 11px !important; }

	.bn-drawer li.is-mobile-open > a .bn-nav__caret {
		transform: rotate(180deg);
	}
	.bn-drawer .bn-megamenu__cta { display: none !important; }
}
