/* ============================
        NG-FECHOS HEADER
   ============================ */
/* ====== Root Variables ======= */
:root {
  --ng-bordo: #A32120;
  --menu-font: clamp(14px, 1.25vw, 22px);
	--tools-font: clamp(13px, 1.15vw, 20px);
	--icons-font: clamp(15px, 1.25vw, 24px);
  --submenu-title-font: clamp(13px, 1.2vw, 20px);
  --submenu-item-font: clamp(12px, 1.1vw, 18px);
	--ng-tool-h: clamp(20px, 3.3vw, 45px)
}


/* ===============================
     ESTRUTURA + ALINHAMENTO
=============================== */
/* ====== Base + Estados ======= */
/* Estado inicial (topo) */
.ng-header-wrapper {
  transition: all 0.3s ease;
}

/* Sticky ativo: largura sempre correta */
header .ng-header-wrapper.elementor-sticky--active{
  width: 100vw !important;
}

body {
	overflow-x: hidden;
}

/* Sticky após scroll */
header .ng-header-wrapper.elementor-sticky.elementor-sticky--effects {
  background: #FFFFFF;
  box-shadow: 0 0px 10px -5px rgba(0,0,0,0.8);
}

/* ====== CONTAINER INNER ====== */
.ng-header-inner {
  margin: 0;
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 5px 10px 5px 10px;
  box-sizing: border-box;
}


/* ==== CONTAINER ESQUERDO ==== */
.ng-header-left {
  display: flex;
  align-items: center;
  justify-content: flex-start;
	flex: 0 0 auto !important;
	width: auto; 
	max-width: none;
  height: auto;
	line-height: 0;
}

/*         === LOGOS ===         */
.logo-light { 
  display: block; 
  transition: opacity 0.3s ease;
}
.logo-dark  { 
  display: none;  
  transition: opacity 0.3s ease;
}

/* Tamanho */
.logo-light img,
.logo-dark img {
	height: clamp(45px, 4vw, 100px);
  width: auto;
  display: block;
}

/* Sticky */
header .ng-header-wrapper.elementor-sticky.elementor-sticky--effects .logo-light { 
  display: none; 
}
header .ng-header-wrapper.elementor-sticky.elementor-sticky--effects .logo-dark  { 
  display: block; 
}


/* ===== CONTAINER DIREITO ===== */
.ng-header-right {
  flex: 1 1 auto;
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: nowrap;
  box-sizing: border-box;
}

/*          === MENU ===         */
.ng-menu-container {
  flex: 1 1 auto !important;
  min-width: 0 !important;
}

.ng-main-menu ul.elementor-nav-menu {
  display: flex;
  align-items: center;
  flex-wrap: nowrap !important;
  white-space: nowrap !important;
}
/* Tipografia Geral (menu + sub)*/
.ng-main-menu a.elementor-item,
.ng-main-menu a.elementor-sub-item {
  font-weight: 700 !important;
  letter-spacing: 0.3px;
  line-height: 1.6;
}

/* Tamanho e Tipografia */
.ng-main-menu .elementor-nav-menu--main > ul > li > a.elementor-item {
  display: flex !important;
  align-items: center !important;
  height: clamp(45px, 4vw, 100px) !important;
  padding: 0 1.2vw !important;
	margin: 0 2px;
	font-size: var(--menu-font);
}

/* Estado: Topo */
.ng-main-menu a.elementor-item {
  color: #FFFFFF !important;
  position: relative;
  transition: color 0.25s ease;
}

/* Hover: Topo */
.ng-main-menu a.elementor-item:hover {
  color: #FFFFFF !important;
}

/* Underline cola ao fundo */
.ng-main-menu .elementor-nav-menu--main.e--pointer-underline > ul > li > a.elementor-item::before,
.ng-main-menu .elementor-nav-menu--main.e--pointer-underline > ul > li > a.elementor-item::after {
	bottom: -5px !important;
  height: 3px !important;
  background: var(--ng-bordo);
}

/* Estado: Sticky */
header .ng-header-wrapper.elementor-sticky.elementor-sticky--effects 
.ng-main-menu a.elementor-item {
  color: var(--ng-bordo) !important;
}

/* Hover: Sticky */
header .ng-header-wrapper.elementor-sticky.elementor-sticky--effects 
.ng-main-menu a.elementor-item:hover {
  color: var(--ng-bordo) !important;
}

/* Seta no Estado Topo */
.ng-main-menu .sub-arrow svg {
  fill: #FFFFFF !important;
  transition: fill 0.3s ease, transform 0.3s ease;
}

/* Seta no Hover topo */
.ng-main-menu li:hover > a .sub-arrow svg {
  fill: var(--ng-bordo) !important;
  transform: rotate(180deg);
}

/* Seta no Estado Sticky */
header .ng-header-wrapper.elementor-sticky.elementor-sticky--effects 
.ng-main-menu .sub-arrow svg {
  fill: var(--ng-bordo) !important;
}

/* Seta no Hover Sticky */
header .ng-header-wrapper.elementor-sticky.elementor-sticky--effects 
.ng-main-menu li:hover > a .sub-arrow svg {
  fill: #444444 !important;
  transform: rotate(180deg);
}

/*   === Dropdown Produtos ===   */
/* Posicionamento */
.ng-main-menu li.mm-produtos {
    position: relative !important;
}

.ng-main-menu li.mm-produtos > ul.sub-menu {
  position: absolute !important;
  top: clamp(52px, 4.7vw, 108px) !important;
  transform: translateX(-44%) !important;
	
  width: min(50vw) !important;
  padding: 1.5vw !important;
	
  display: grid !important;
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
	gap: 0.5vw !important;
	
  background: rgba(255, 255, 255, 0.83) !important;
  backdrop-filter: blur(8px) !important;
  border-radius: 2vw !important;
  box-shadow: 0 0 10px -5px rgba(0,0,0,0.5) !important;

  opacity: 0 !important;
  visibility: hidden !important;
  pointer-events: none !important;
  z-index: 50010 !important;
}

/* Ponte invisível */
.ng-main-menu li.mm-produtos > ul.sub-menu::before {
  content: "";
  position: absolute;
  top: -14px;
  left: 0;
  width: 100%;
  height: 25px;
  background: transparent;
  pointer-events: auto;
}

/* Abre Dropdown */
.ng-main-menu li.mm-produtos:hover > ul.sub-menu,
.ng-main-menu li.mm-produtos:focus-within > ul.sub-menu,
.ng-main-menu li.mm-produtos > ul.sub-menu:hover {
  opacity: 1 !important;
  visibility: visible !important;
  pointer-events: auto !important;
}

/* Limpar caixas brancas/sombras */
.elementor-nav-menu--dropdown,
.elementor-nav-menu--dropdown li,
.elementor-nav-menu--dropdown a,
.elementor-nav-menu--dropdown .elementor-item,
.elementor-nav-menu--dropdown .elementor-sub-item {
  background: transparent !important;
  box-shadow: none !important;
  border: 0 !important;
}

/*         Coluna 1 e 2         */
.ng-main-menu li.mm-produtos > ul.sub-menu > li > a,
.ng-main-menu li.mm-produtos > ul.sub-menu > li.mm-col3 > ul.sub-menu > li > a {
  font-size: var(--submenu-title-font);
  line-height: 1.2 !important;
  color: var(--ng-bordo) !important;
  padding: 0.3vw 1vw !important;
  margin: 0 0vw 0.6vw 0 !important;
  position: relative !important;
	text-decoration: none !important;
	white-space: nowrap !important;
}

/* Underline títulos */
.ng-main-menu li.mm-produtos > ul.sub-menu > li > a::after,
.ng-main-menu li.mm-produtos > ul.sub-menu > li.mm-col3 > ul.sub-menu > li > a::after {
  content: "";
  position: absolute;
  left: 0; right: 0;
  bottom: -0.2vw;
	height: 2px;
  background: var(--ng-bordo);
  transform: scaleX(0);
	transform-origin: left;
  transition: transform 0.25s ease;
}

.ng-main-menu li.mm-produtos > ul.sub-menu > li > a:hover::after,
.ng-main-menu li.mm-produtos > ul.sub-menu > li.mm-col3 > ul.sub-menu > li > a:hover::after {
  transform: scaleX(1);
}

/* Remover setas */
.ng-main-menu li.mm-produtos > ul.sub-menu > li > a .sub-arrow {
  display: none !important;
}

/*          Sub-Itens          */
/* Layout Base */
.ng-main-menu li.mm-produtos ul.sub-menu ul.sub-menu {
	position: static !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 0.3vw !important;
}

.ng-main-menu li.mm-produtos ul.sub-menu ul.sub-menu > li {
  width: 100% !important;
}

.ng-main-menu li.mm-produtos ul.sub-menu ul.sub-menu > li > a {
	font-size: var(--submenu-item-font) !important;
  padding: 0.6vw 0.8vw !important;
  background: transparent !important;
  color: #444444 !important;
  border-radius: 0 !important;
  white-space: nowrap !important;
	transition: background .3s ease, color .3s ease;
}

/* Pill Hover */
.ng-main-menu li.mm-produtos ul.sub-menu ul.sub-menu > li > a:hover {
  background: var(--ng-bordo) !important;
  color: #FFFFFF !important;
}
.elementor-nav-menu--dropdown {
  min-width: unset !important;
  width: auto !important;
}

/*           Coluna 3           */
/* Esconder o título  */
.ng-main-menu li.mm-produtos > ul.sub-menu > li.mm-col3 > a.elementor-sub-item {
  display: none !important;
}

/* Tipografia */
.ng-main-menu li.mm-produtos > ul.sub-menu > li.mm-col3 > ul.sub-menu > li > a {
  display: block !important;
  font-size: var(--submenu-title-font) !important;
	line-height: 1.2 !important;
  color: var(--ng-bordo) !important;
  padding: 0.3vw 1vw!important;
  margin: 0 0 0.6vw 0  !important;
  position: relative;
	white-space: nowrap !important;
}

/* Underline */
.ng-main-menu li.mm-produtos > ul.sub-menu > li.mm-col3 > ul.sub-menu > li > a::after {
  content: "";
  position: absolute;
  left: 0; right: 0;
  bottom: -0.2vw;
  height: 2px;
  background: var(--ng-bordo);
  transform: scaleX(0);
  transform-origin: left;
  transition: transform .25s ease;
}
.ng-main-menu li.mm-produtos > ul.sub-menu > li.mm-col3 > ul.sub-menu > li > a:hover::after {
  transform: scaleX(1);
}

/* Remover pill */
.ng-main-menu li.mm-produtos > ul.sub-menu > li.mm-col3 > ul.sub-menu > li > a:hover {
  background: transparent !important;
  color: var(--ng-bordo) !important;
}

/* Distribuir os 2 títulos */
.ng-main-menu li.mm-produtos > ul.sub-menu > li.mm-col3 > ul.sub-menu {
  display: flex !important;
  flex-direction: column !important;
  justify-content: space-between !important;
  height: 14.5vw !important;
}

/* Reset de margens/paddings */
.ng-main-menu li.mm-produtos > ul.sub-menu > li.mm-col3 > ul.sub-menu > li {
  margin: 0 !important;
}

/* ====== Container Tools ====== */
.ng-tools-container {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 20px;
	max-width: fit-content;
	
}

/*   === Botão "Contactar" ===   */
/* Topo normal */
.ng-desktop-contact .elementor-button {
	display: inline-flex;
  align-items: center;
  justify-content: center;
	
	height: calc( var(--ng-tool-h) + 0.05vw);
	padding: 0 clamp(15px, 3.5vw, 30px);
	
  background: transparent;
  border: clamp(1px, 0.2vw, 2.2px) solid #FFFFFF;
  border-radius: 0;
	
	color: #FFFFFF;
	font-size: var(--tools-font) !important;
  font-weight: 650 !important;
	
	transition: all 0.3s ease-in-out;
}

/* Hover no topo */
.ng-desktop-contact .elementor-button:hover {
  color: var(--ng-bordo);
  border-color: var(--ng-bordo) ;
}

/* Sticky ativo */
header .ng-header-wrapper.elementor-sticky.elementor-sticky--effects .ng-desktop-contact .elementor-button {
  background: #FFFFFF;
  color: var(--ng-bordo);
  border: 0.2vw solid #A32120;
}

/* Hover no sticky */
header .ng-header-wrapper.elementor-sticky.elementor-sticky--effects .ng-desktop-contact .elementor-button:hover {
  background: var(--ng-bordo);
  color: #FFFFFF;
}

/*      === Search Tool ===      */
/* 		 	    Search  Bar    			 */
.ng-desktop-search {
  display: flex;
  align-items: center !important;
}

.ng-desktop-search .e-search-form {
	height: var(--ng-tool-h);
}

/* Campo de pesquisa */
.ng-desktop-search .e-search-input {
  font-size: clamp(8px, 0.96vw, 14px);
  background: rgba(255, 255, 255, 0.85);
	width: clamp(100px, 12vw, 500px);
  min-height: 0 !important;
  line-height: 1.2 !important;
  transition: all 0.3s ease;
}

/* Focus (ativa) */
.ng-desktop-search .e-search-input:focus {
  background: #FFFFFF;
	width: clamp(200px, 15vw, 700px);
}

/* Remover borda preta do Chrome no foco */
.ng-desktop-search .e-search-input:focus {
  border: 1px solid #cccccc !important;
}

/* 					   Ícone    		     */
/* Botão da lupa */
.ng-desktop-search .e-search-submit {
  display: flex;
  align-items: center;
  justify-content: center;
  height: var(--ng-tool-h);
  width: var(--ng-tool-h) !important;
  margin: 0 !important;
  padding: 0 !important;
  background: transparent !important;
  transition: background .25s ease, border-color .25s ease, transform .25s ease;
}

/* Ícone SVG responsivo */
.ng-desktop-search .e-search-submit svg {
  height: var(--icons-font) !important;
  fill: #fff !important;
  transition: transform .3s ease, fill .3s ease;
}

/* Hover: Topo */
.ng-desktop-search .e-search-submit:hover svg {
  fill: var(--ng-bordo) !important;  transform: scale(1.35);
}

/* Estado: Sticky */
header .ng-header-wrapper.elementor-sticky.elementor-sticky--effects .ng-desktop-search .e-search-submit svg {
  fill: var(--ng-bordo) !important;
}

/* Hover: Sticky */
header .ng-header-wrapper.elementor-sticky.elementor-sticky--effects .ng-desktop-search .e-search-submit:hover {
  background: var(--ng-bordo) !important;
}
header .ng-header-wrapper.elementor-sticky.elementor-sticky--effects .ng-desktop-search .e-search-submit:hover svg {
  fill: #FFFFFF !important;
  transform: scale(1.2);
}

/*   === Language Switcher ===   */
.ng-desktop-lang {
  position: relative;
  display: flex;
  align-items: center;
  cursor: pointer;
	height: clamp(45px, 4vw, 100px);
	padding-right: 0.7vw; 
}

/*            Ícones            /* 
/* Globo */
.ng-desktop-lang::before {
  content: "🌐";
  font-size: var(--icons-font);
  transition: 0.3s;
}

/* Seta*/
/* Ir buscar ao Elementor */
.ng-desktop-lang::after {
  content: "";
  width: 1.1vw; height: 1.1vw;
  background: currentColor;
  -webkit-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 320 512'%3E%3Cpath d='M31.3 192h257.3c17.8 0 26.7 21.5 14.1 34.1L174.1 354.8c-7.8 7.8-20.5 7.8-28.3 0L17.2 226.1C4.6 213.5 13.5 192 31.3 192z'/%3E%3C/svg%3E") no-repeat center / contain;
  mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 320 512'%3E%3Cpath d='M31.3 192h257.3c17.8 0 26.7 21.5 14.1 34.1L174.1 354.8c-7.8 7.8-20.5 7.8-28.3 0L17.2 226.1C4.6 213.5 13.5 192 31.3 192z'/%3E%3C/svg%3E") no-repeat center / contain;
	color: #FFFFFF;
  transition: transform 0.3s ease, color 0.3s ease;
}

/* Hover: Topo */
.ng-desktop-lang:hover::before,
.ng-desktop-lang:hover::after {
  color: var(--ng-bordo);
}
.ng-desktop-lang:hover::after {
  transform: rotate(180deg);
}

/* Estado: Sticky */
header .ng-header-wrapper.elementor-sticky.elementor-sticky--effects .ng-desktop-lang::before,
header .ng-header-wrapper.elementor-sticky.elementor-sticky--effects .ng-desktop-lang::after{ 
	color:var(--ng-bordo); 
}

header .ng-header-wrapper.elementor-sticky.elementor-sticky--effects .ng-desktop-lang:hover::before,
header .ng-header-wrapper.elementor-sticky.elementor-sticky--effects .ng-desktop-lang:hover::after {
  color: #444444;
}

/* Dropdown */
/* Wrapper */
.ng-desktop-lang .gtranslate_wrapper {
  position: absolute;
	display: flex;
  flex-direction: column;
  align-items: center;
	
  top: clamp(52px, 4.7vw, 106px);
	left: 30%;
	padding: 0.55vw;
	width: max-content;

  background: rgba(255, 255, 255, 0.85);
	backdrop-filter: blur(10px) !important;
  box-shadow: 0 0 10px -5px rgba(0, 0, 0, 0.5);
  border-radius: 0.8vw;
  opacity: 0;
	visibility: hidden;
  pointer-events: none;
  transition:opacity .2s ease, transform .2s ease, visibility 0s linear .2s;
  z-index: 9999;
}

/* Links das Línguas */
.ng-desktop-lang .gtranslate_wrapper a.glink {
  display: flex !important;
	align-items: center;
  padding: 0.8vw 1vw;
	white-space: nowrap;
  transition: background 0.2s ease, color 0.2s ease;
}

/* Bandeiras */
.ng-desktop-lang .gtranslate_wrapper img {
  width: clamp(16px, 1.2vw, 100px);
  border-radius: 2px;
}

/* Hover nas Bandeiras */
.ng-desktop-lang .gtranslate_wrapper a:hover {
  background: rgba(163,33,32,0.9);
  color: #FFFFFF !important;
}

/* Bandeira Selecionada */
.ng-desktop-lang .gtranslate_wrapper .gt-current-lang {
  background: rgba(163,33,32,0.3);
}

/* Hover Bridge */
.ng-desktop-lang .ng-lang-bridge{
  position:absolute;
  left:50%; top:100%;
  transform:translateX(-50%);
  width:180px;
	height:30px;
}

/* Mostrar dropdown quando:
   - pairas no trigger
   - pairas na ponte
   - pairas no próprio dropdown */
.ng-desktop-lang:hover .gtranslate_wrapper,
.ng-desktop-lang .ng-lang-bridge:hover + .gtranslate_wrapper,
.ng-desktop-lang .gtranslate_wrapper:hover{
  opacity:1; 
	visibility:visible;
	pointer-events:auto;
  transform:translate(-50%, 0);
  transition:opacity .2s ease, transform .2s ease, visibility 0s;
}


/* =============================
					FOOTER
============================== */
.grecaptcha-badge {
    visibility: hidden !important;
    opacity: 0 !important;
}

.recaptcha-footer{
  font-size: 12px;
  color: #222222;
  font-family: "Exo 2", sans-serif;
  text-align: center;
  margin-top: 5px;
	line-height: 1.1;
  margin-bottom: 8px !important;
  padding-bottom: 0 !important;
}

.recaptcha-footer a{
  color: #222222;
  text-decoration: underline;
  transition: color .6s ease;
}

.recaptcha-footer a:hover{
  color: #000747;
  text-decoration: underline;
}

/* =============================
					COOKIES
============================== */
.cmplz-btn {
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.35) !important;
}