/**
 * BAANNNG · Vini Mega Menu
 * Frontend Styles - v4.0
 *
 * Transições controladas por JavaScript
 * CSS apenas define estilos estáticos
 */

/* Color Set */
:root {
	--vmm-red: #BA2229;
	--vmm-black: #1A1919;
	--vmm-white: #FFFFFF;
}

@import url('https://fonts.googleapis.com/css2?family=Exo+2:ital,wght@0,100..900;1,100..900&family=Inter:ital,opsz,wght@0,14..32,100..900;1,14..32,100..900&display=swap');


/* ============================================
   HEADER CONTAINER - BASE
   ============================================ */

.bglbc-headercontainer {
	min-height: 176px;
	transition: min-height 0.2s ease-in-out, padding 0.2s ease-in-out, box-shadow 0.2s ease-in-out;
	box-shadow: none;
	position: relative;
	z-index: 100;
}

.bglbc-headercontainer.shrink {
	min-height: 120px;
	box-shadow: 0 10px 32px 0 rgb(0 0 0 / 10%);
}

.bglbc-header-logo {
	width: 100%;
}

.bglbc-header-logotop {
	display: flex;
	align-items: center;
	justify-content: start;
	height: 100%;
	width: 100%;
}

.bglbc-header-logotop img,
.bglbc-header-logotop svg {
	margin: 0 auto;
	transition: max-width 0.2s ease-in-out, height 0.2s ease-in-out;
	max-width: 279px !important;
	width: auto;
	height: auto;
	display: block;
}

.bglbc-headercontainer.shrink .bglbc-header-logotop img,
.bglbc-headercontainer.shrink .bglbc-header-logotop svg {
	max-width: 200px !important;
}

.bglbc-header-primeiralinha {
	position: relative;
}

.bglbc-header-primeiralinha::after {
	content: "";
	position: absolute;
	left: 0;
	bottom: 0;
	width: 100%;
	height: 1px;
	background: #e7e7e7;
	opacity: 0;
	pointer-events: none;
	transition: opacity 0.2s ease-in-out;
}

.bglbc-headercontainer.shrink .bglbc-header-primeiralinha::after {
	opacity: 1;
}

.bglbc-reserved-area-text {
	margin-bottom: 0px!important;
	color: #9e9e9e;
}

.bglbc-hh-reserved-area-text {
	color: #9e9e9e;
}

.bglbc-registerlink,
.bglbc-registerlink a,
.bglbc-registerlink a:hover {
	text-decoration: none!important;
	font-weight: 600 !important;
}
.bglbc-registerlink:hover {
	color: #BA2229 !important;
}

.bglbc-entrar-button {
	font-size: 18px;
	line-height: 18px;
	transition: background 0.2s, color 0.2s, border 0.2s;
}
.bglbc-entrar-button > a ,
.bglbc-entrar-button > a:hover {
	 text-decoration: none!important ;
}
/* .bglbc-entrar-button > a:hover {
	background: #BA2229!important;
	color: #fff !important;
} */


/* ============================================
   ESTILO WHITE - Header Branco
   ============================================ */

body.menu-white .bglbc-headercontainer {
	background: #fff;
}

body.menu-white .bglbc-header-logotop img,
body.menu-white .bglbc-header-logotop svg {
	filter: brightness(0);
}


/* ============================================
   ESTILO TRANSPARENTE - Header Transparente
   Cores controladas por JavaScript
   ============================================ */

body.menu-transparente .bglbc-headercontainer {
	background: transparent !important;
	background-color: transparent !important;
}

body.menu-transparente .bglbc-headercontainer.shrink {
	background: transparent; /* JS controla o fundo via .vmm-header-bg */
}

body.menu-transparente .bglbc-header-primeiralinha {
	background: rgba(255,255,255,0);
	box-shadow: inset 0px -1px 0px rgba(255, 255, 255, 0.2);
}
body.menu-transparente .bglbc-entrar-button > a {
	text-decoration: none;
	color: black!important;
	transition: all 0.3s ease-in-out!important;
	border: 1px solid var(--black);
}
body.menu-transparente .bglbc-entrar-button:hover > a {
	background: var(--vmm-red)!important;
	border-radius: 4px;
	color: white!important;
	border: 1px solid var(--vmm-red);
}

body.menu-transparente .bglbc-pesquisar svg {
	width: 24px;
	height: 24px;
}

body.menu-transparente .bglbc-WPML-switcher {
	padding: 4px 12px;
	border-radius: 16px;
	font-weight: 600;
	display: flex;
	align-items: center;
}


/* ============================================
   MEGAMENU ABERTO - Estado do Header
   Controlado por JavaScript
   ============================================ */


/* ============================================
   MEGA MENU - Links Nível 0 (White)
   ============================================ */

body.menu-white .bglbc-menu * {
	color: var(--vmm-black) !important;
	transition: color 0.2s;
}

body.menu-white .bglbc-menu *:hover {
	color: var(--vmm-red) !important;
	cursor: pointer;
}

body.menu-white .bglbc-menu .active,
body.menu-white .bglbc-menu .current,
body.menu-white .bglbc-menu .current-menu-item,
body.menu-white .bglbc-menu .current_page_item {
	color: var(--vmm-red) !important;
}


/* ============================================
   MEGA MENU - Links Nível 0 (Transparente)
   Cores base controladas por JavaScript
   Hover vermelho com transição CSS
   ============================================ */

body.menu-transparente .bglbcvmm_menu > ul > li > a {
	transition: color 0.3s ease-in-out;
}

body.menu-transparente .bglbcvmm_menu > ul > li > a:hover {
	color: var(--vmm-red) !important;
	cursor: pointer;
}


/* ============================================
   MEGA MENU - Estrutura e Layout
   ============================================ */

.bglbcvmm_menu {
	position: relative;
}

.bglbcvmm_menu > ul {
	display: flex;
	list-style: none;
	margin: 0;
	padding: 0;
	/* gap: 0; */
	align-items: center;
	justify-content: flex-start;
}

.bglbcvmm_menu > ul > li {
	position: relative;
	margin-right: clamp(1rem, 5vw - 4rem, 64px);
	min-width: fit-content;
}

.bglbcvmm_menu > ul > li > a {
	text-decoration: none;
	font-family: 'Exo 2', sans-serif !important;
	font-size: clamp(1.5rem, 2.5vw - 2rem, 16px);
	font-weight: 500;
	padding: 1rem 0rem;
	display: block;
	text-transform: uppercase;
	letter-spacing: 0.5px;
	color: white;
}


/* ============================================
   MEGA MENU DROPDOWN
   Visibility/opacity controlados por JS
   ============================================ */

.bglbcvmmenu-submenu {
	position: fixed;
	left: 0;
	width: 100%;
	top: 176px;
	background: #fff;
	z-index: 9998;
	/* Estado inicial - JS vai controlar */
	opacity: 0;
	visibility: hidden;
	pointer-events: none;
	box-shadow: 0 40px 30px -30px rgba(0, 0, 0, 0.1);
}


/* ============================================
   MEGA MENU DROPDOWN - Conteúdo
   ============================================ */

.bglbcvmmenu-submenu-inner {
	box-shadow: rgba(0, 0, 0, 0.1) 0px -1px 0px inset,
	            rgba(0, 0, 0, 0.1) 0px 1px 0px inset;
	max-width: 1579px;
	margin: 0 auto;
	width: 90%;
	padding: 40px 0;
	display: grid;
	grid-template-columns: 1fr 3fr;
	gap: 11%;
}

.bglbcvmmenu-desc-wrapper {
	/* Gap já dá espaço */
}

.bglbcvmmenu-desc-title {
	font-size: 24px!important;
	line-height: 24px!important;
	color: #000;
	font-weight: 600;
	margin-bottom: 18px;
	font-family: "Exo 2", sans-serif;
	pointer-events: none;
}

.bglbcvmmenu-desc {
	font-family: "Inter", sans-serif;
	font-style: normal;
	font-weight: 300;
	font-size: 16px;
	line-height: 24px;
	color: #1a1919;
	pointer-events: none;
}

.bglbcvmmenu-submenu-list ul {
	width: auto;
	display: grid;
	gap: 2rem 3rem;
	grid-auto-flow: column;
	grid-template-columns: repeat(auto-fill, minmax(30rem, 1fr));
	grid-template-rows: repeat(3, auto);
	list-style: none;
	margin: 0;
	padding: 0;
}

.bglbcvmmenu-submenu-list ul li {
	margin: 0;
}

.bglbcvmmenu-submenu-list ul li a {
	font-family: "Exo 2", sans-serif !important;
	font-style: normal;
	font-weight: 700;
	font-size: 18px;
	line-height: 24px;
	color: #1a1919;
	text-decoration: none;
	transition: color 0.3s;
	max-width: 25rem;
	display: block;
}

.bglbcvmmenu-submenu-list ul li a:hover {
	color: #ba2229 !important;
	font-family: "Exo 2", sans-serif !important;
	font-weight: 700 !important;
}


/* ============================================
   ESTILO LIGHT - Header Transparente com texto escuro
   Igual ao White mas sem fundo inicial
   ============================================ */

body.menu-light .bglbc-headercontainer {
	background: transparent !important;
	background-color: transparent !important;
	transition: background 0.2s ease-in-out, background-color 0.2s ease-in-out;
}

body.menu-light .bglbc-headercontainer.shrink {
	background: #fff !important;
	background-color: #fff !important;
}

/* Fundo branco quando megamenu está aberto */
body.menu-light .bglbc-headercontainer.megamenu-open {
	background: #fff !important;
	background-color: #fff !important;
}

body.menu-light .bglbc-header-logotop img,
body.menu-light .bglbc-header-logotop svg {
	filter: brightness(0);
}

body.menu-light .bglbc-menu * {
	color: var(--vmm-black) !important;
	transition: color 0.2s;
}

body.menu-light .bglbc-menu *:hover {
	color: var(--vmm-red) !important;
	cursor: pointer;
}

body.menu-light .bglbc-menu .active,
body.menu-light .bglbc-menu .current,
body.menu-light .bglbc-menu .current-menu-item,
body.menu-light .bglbc-menu .current_page_item {
	color: var(--vmm-red) !important;
}

body.menu-light .bglbc-registerlink {
	color: var(--vmm-black);
}

body.menu-light .bglbc-entrar-button > a {
	text-decoration: none;
	/* color: var(--vmm-black) !important; */
	background: #fff;
}

body.menu-light .bglbc-entrar-button:hover > a {
	background: var(--vmm-red) !important;
	border-radius: 4px;
	color: white !important;
}

body.menu-light .bglbc-pesquisar svg {
	fill: var(--vmm-black);
}

body.menu-light .bglbc-WPML-switcher {
	background: transparent;
	color: var(--vmm-black);
	border-color: var(--vmm-black);
}


/* ============================================
   RESPONSIVIDADE - BREAKPOINTS
   Gap entre menus usa clamp() com ajuste agressivo
   1381px-: segundo nível de compressão
   1200px-: hamburger menu
   ============================================ */

/* Último item sem margin */
.bglbcvmm_menu > ul > li:last-child {
	margin-right: 0;
}

/* 1381px e abaixo: compressão extra */
@media (max-width: 1381px) {
	.bglbcvmm_menu > ul > li {
		margin-right: clamp(0.5rem, 2.5vw - 2rem, 3rem);
	}
}


/* ============================================
   HAMBURGER MENU - Base (escondido em desktop)
   ============================================ */

.bglbc-humb {
	display: none;
	align-items: center;
	gap: 0.5rem;
	cursor: pointer;
	transition: opacity 0.3s ease-in-out;
}

.bglbc-humbicon svg {
	width: 24px;
	height: 24px;
	stroke: currentColor;
	stroke-width: 1.5;
	transition: stroke 0.2s ease-in-out;
}

.bglbc-humbmenuword {
	font-family: "Inter", sans-serif;
	font-size: 1.2rem;
	font-weight: 600;
	text-transform: uppercase;
	transition: color 0.2s ease-in-out;
}

/* Hamburger - Hover Animation */
.bglbc-humb {
	transition: transform 0.2s ease-in-out;
}

.bglbc-humb:hover {
	transform: scale(1.03);
}

.bglbc-humbicon svg .humb-line {
	transition: transform 0.2s ease-in-out;
}

.bglbc-humb:hover .humb-line-top {
	transform: translateY(-2px);
}

.bglbc-humb:hover .humb-line-bottom {
	transform: translateY(2px);
}

/* Hamburger - Menu White (sempre preto) */
body.menu-white .bglbc-humb {
	color: var(--vmm-black);
}

body.menu-white .bglbc-humbicon svg {
	stroke: var(--vmm-black);
}

/* Hamburger - Menu Light (sempre preto) */
body.menu-light .bglbc-humb {
	color: var(--vmm-black);
}

body.menu-light .bglbc-humbicon svg {
	stroke: var(--vmm-black);
}

/* Hamburger - Menu Transparente (branco, preto no shrink - JS controla) */
body.menu-transparente .bglbc-humb {
	color: var(--vmm-white);
}

body.menu-transparente .bglbc-humbicon svg {
	stroke: var(--vmm-white);
}


/* ============================================
   1200px e abaixo: HAMBURGER MENU ACTIVO
   ============================================ */

@media (max-width: 1200px) {
	/* Esconder menu desktop com fade */
	.bglbcvmm_menu {
		display: none;
	}

	/* Esconder submenus */
	.bglbcvmmenu-submenu {
		display: none;
	}

	/* Mostrar hamburger */
	.bglbc-humb {
		display: flex;
		margin-left: -10rem;
		margin-top: 8px;
	}
}
