/*==============================================/
   MENUS GERAL
*/
ul.mod-menu,
ul.menu-vertical {
  display: inline-flex;
  flex-wrap: wrap;
  flex-direction: column;
  justify-content: center;
  list-style: none;
  margin: 0;
  padding: 0;
}
ul.menu-horizontal {
  display: inline-flex;
  flex-wrap: wrap;
  flex-direction: row;
  justify-content: center;
  list-style: none;
  margin: 0;
  padding: 0;
}
ul li.nav-item {
  list-style-type: none;
  position: relative;
}
ul > li > a {
  display: block; /*"a" Ocupa todo o tamanho de li*/
  font-size: 0.9rem;
  font-family: inherit;
  font-weight: normal;
  /* letter-spacing: 0.05rem; */
  /* word-spacing: -0.30em; */
  text-decoration: none;
}
ul.mod-menu li > a,
ul.mod-menu li > span {
  display: block;
  cursor: pointer;
  padding: 0.2rem 0.8rem;
}

/*==============================================/
 MENU PRINCIPAL
*/
/*No modulo de menu colocar a ID: main-menu 
esta é aplicada no primeiro "ul" da estrutura:
 1º nivel <ul id="main-menu" clas="mod-menu">
 2º nivel <ul clas="mod-menu__sub">
 3º nivel <ul clas="mod-menu__sub">
*/

/*...................
 Menu Links Geral 
 */
UL#main-menu {
  padding-bottom: 10px;
} 
/* @media (max-width: 992px) {
  ul#main-menu {
    display: none;
  }
} */
ul#main-menu li {
  color: inherit;
}
ul#main-menu a,
ul#main-menu span {
  font-size: 0.87rem;
  font-weight: normal;
  letter-spacing: 0.05rem;
  word-spacing: 0em;
}
ul#main-menu li > a,
ul#main-menu li > span {
  display: block; /*Ocupa todo o tamanho de li*/
  color: inherit;
}
ul#main-menu li:hover > a,
ul#main-menu li:hover > span {
  color: inherit;
}

/*...................
 Links level-01 
 */
ul#main-menu > li {
  width: max-content;
  margin-left: 15px;
}
ul#main-menu > li > a,
ul#main-menu > li > span {
  color: #333;
  line-height: 60px;
  text-transform: uppercase;
  padding: 0 0.2rem;
  transition: color 400ms, background-color 400ms;
}
/* ul#main-menu > li:hover > a,
ul#main-menu > li:hover > span {
  color: #00AFEA;

}
ul#main-menu > li > a:focus {
  color: inherit;
}
ul#main-menu > li.active > a,
ul#main-menu > li.active > span {
  color: #00AFEA;
}
ul#main-menu > li.active:hover > a,
ul#main-menu > li.active > a:focus,
ul#main-menu > li.active:hover > a:focus {
  color: var(--dark-color);
}
ul#main-menu > li:hover > a,
ul#main-menu > li:hover > span,
ul#main-menu > li.active > a,
ul#main-menu > li.active > span {
  color: #00AFEA;
} */

/*Cria uma barra de cor no link sem ocupar toda a zona do link*/
ul#main-menu > li > a::before,
ul#main-menu > li > span::before {
  content:"";
   position: absolute;
   width: 0;
   height: 0.085rem;
   background-color: #333;
   left: 50%;
   bottom: 10px;
   transition: 0.2s all ease-in-out;
}
ul#main-menu > li:hover > a::before,
ul#main-menu > li:hover > span::before {
  width: 100%;
  left: 0;
}
ul#main-menu > li.active > a::before,
ul#main-menu > li.active > span::before {
  width: 100%;
  left: 0;
}

/*Navegação por Tabs*/
ul#main-menu li > a:focus-visible {
  background-color: rgba(217, 221, 225, 1);
  outline: none;
}
ul#main-menu > li > a:focus-visible {
  background-color: rgba(98, 154, 200, 0.2);
  outline: none;
}
/*.......................................
   LINKS LEVEL-02 &(>)
 */
ul#main-menu ul > li {
  background-color: #f8f8f8;
  background-color: #eee;
  border-bottom: 1px dotted gray;
}
ul#main-menu ul > li:last-child {
  border-bottom: none;
}
ul#main-menu ul > li > a,
ul#main-menu ul > li > span {
  color: #666;
  line-height: 3.5rem;
  position: relative;
  /* width: max-content; */
  padding: 0 10px;
  z-index: 999;
}
ul#main-menu ul > li:hover {
  color: #777;
  background-color: #eee;
}
ul#main-menu ul > li.active {
  color: #5c686f;
  background-color: #eee;
}
ul#main-menu ul > li.active:hover {
  color: #5c686f;
  background-color: #eee;
}
/*barrinha debaixo do menu*/
ul#main-menu ul > li > a span {
  position: relative;
  width: max-content;
  display: inline-block;
  padding: 0 4px;
}
ul#main-menu ul > li > a span::after {
  color: #5c686f;
  position: absolute;
  height: 10px;
  width: 0%;
  left: 0;
  bottom: 15px;
  z-index: -1;
  transform: rotateZ(0deg);
  content: "";
  display: inline-block;
  background: #ffa57c;
  transition: all 200ms ease-in-out;
}
ul#main-menu ul > li:hover > a span::after {
  width: 90%;
  height: 10px;
}
ul#main-menu ul > li.active > a span::after {
  width: 90%;
}
ul#main-menu ul > li.active:hover > a span::after {
  background: #ff854d;
  transform: rotateZ(1deg);
}

/*Ul > nivel 3 e adiante*/

ul#main-menu ul {
  position: absolute;
  left: -10px;
  top: calc(100%);
  width: max-content;
  min-width: 200px;
  padding: 5px;
  margin-bottom: 0;
  background-color: #fff;
  box-shadow: 0 5px 15px rgb(0 0 0 / 10%);
  pointer-events: auto;
  z-index: 999;
  visibility: hidden;
  opacity: 0;
  transform: translateY(-10px);
  transition: all 200ms ease-in-out;
}
ul#main-menu > li:last-child ul {
  right: -20px;
  left: auto;
}
ul#main-menu ul > li ul {
  position: absolute;
  left: calc(100%);
  top: 0;
}
ul#main-menu li:last-child ul > li ul {
  position: absolute;
  right: calc(100%);
  top: 0;
}
ul#main-menu a.show.focus + ul {
  visibility: visible;
  opacity: 1;
  transform: translateY(0px);
}
ul#main-menu li.parent > a.show.focus:focus-visible + ul,
ul#main-menu li.parent > a.show.focus:focus-within + ul,
ul#main-menu li.parent > a.show.focus:focus + ul,
ul#main-menu li.parent:hover > a + ul,
ul#main-menu li.parent:hover > span + ul {
  visibility: visible;
  opacity: 1;
  transform: translateY(0px);
}

/*...................
 Dropdown Icon 
 */
ul#main-menu li.parent > a,
ul#main-menu li.parent > span {
  width: 100%;
  padding-right: 30px;
}
ul#main-menu li.parent > a::after,
ul#main-menu li.parent > span::after {
  content: "\f105";
  font-family: "Font Awesome 6 Free";
  /* content: ">"; */
  font-weight: 900;
  position: absolute;
  transition: 0.3s ease;
  padding: 0 9px;
  transform: rotate(0deg);
}
ul#main-menu > li.parent > a::after,
ul#main-menu > li.parent > span::after {
  transform: rotate(90deg);
}
ul#main-menu > li.parent > a.show::after {
  transform: rotate(0deg);
}
/*l-02 &(>)*/
ul#main-menu ul li.parent > a::after {
  right: 5px;
  padding: 0 10px;
}
ul#main-menu ul li.parent > a.show::after {
  transform: rotate(0deg);
}



/*==============================================/
    OFFCANVAS Toogler
 */
/*É necessário criar um modulo HTML*/
.toogler-area {
  padding: 0 20px 0 0;
  /* background-color: aqua; */
}
.toogler-area #mobile-cta {
  color: #534361;
  font-size: 32px;
  cursor: pointer;
  background-color: transparent;
  border: none;
}
.toogler-area #mobile-cta:hover {
  color: #2c2631;
  font-weight: bold;
}
.toogler {
  cursor: pointer;
}
@media (min-width: 1200px) {
  .module.toogler-menu {
    display: none;
  }
}

/*==============================================/
    OFFCANVAS 
 */
.overflow {
  overflow: hidden;
}
#overlay.display {
  position: fixed;
  z-index: 9980;
  width: 100%;
  right: 0;
  top: 0;
  background-color: rgba(23, 23, 27, 0.85);
  backdrop-filter: blur(1px);
  height: 100vh;
  overflow: hidden;
}
/*==============================================/
    OFFCANVAS 
 */
/*Offcanvas body*/
#offcanvas {
  color: var(--grey-dark-color);
  position: fixed;
  display: block;
  height: 100vh;
  width: 350px;
  overflow-y: auto;
  overflow-x: hidden;  
  background: #fff;
  backdrop-filter: blur(1rem);
  padding: 1em;
  z-index: 9999;
  top: 0;
  opacity: 1;
  transition: transform 350ms ease-out, opacity 350ms ease-out;  
}
#offcanvas {
  right: 0;
  transform: translateX(100%);
}
/* #offcanvas {
  left: 0;
  transform: translateX(-100%);
} */

#offcanvas a {
  color: var(--grey-dark-color);
}
#offcanvas a:hover {
  color: var(--dark-color);
}
#offcanvas * {
  visibility: hidden;
  /* visibility: visible; */
}
#offcanvas.show {
  transform: translateX(0%);
  opacity: 1;
  visibility: visible;
}
#offcanvas.show * {
  visibility: visible;
}
/*Toggler*/
#mobile-exit {
  font-size: 30px;
  font-weight: normal;
  cursor: pointer;
  z-index: 999;
  position: absolute;
  right: 15px;
  background-color: transparent;
  border: none;
  color: #777;
  transition: all 0.3s ease-in-out;
  border-radius: 100%;
  padding: 5px;
}
#mobile-exit:hover {
  /* color: #57c7ff; */
  /* transform: rotate(0deg); */
  /* transform: rotate(0deg); */
  color: #333;
  background-color: #ebebeb;
}

/*==============================================/
    OFFCANVAS MENU 
 */
 
 /*  Module advanced options / Menu Tag ID: offcanvas-menu */

#menu-offcanvas {
  background-color: transparent;
  margin-top: 40px;
  padding: 0px;
}
#menu-offcanvas li {
  position: relative;
}
/*...................
 Menu Links Geral 
 */
#menu-offcanvas li > span,
#menu-offcanvas li > a {
  color: var(--grey-dark-color);
  display: block;
  padding-left: 20px;
  -webkit-transition: all 0.25s ease;
  -o-transition: all 0.25s ease;
  transition: all 0.25s ease;
  cursor: pointer;
}
#menu-offcanvas li:hover > a,
#menu-offcanvas li:hover > span,
#menu-offcanvas li.parent a.show {
  color: var(--dark-color);
  cursor: pointer;
}
/*...................
 Links level-01 
 */
#menu-offcanvas > li > a,
#menu-offcanvas > li > span {
  color: #738188;
  line-height: 3.5rem;
  font-weight: bold;
  text-transform: uppercase;
}
#menu-offcanvas > li.parent > a.show,
#menu-offcanvas > li.parent > a.show:hover {
  color: #333;
}

/*...................
 Links level-02 &(>)
 */
#menu-offcanvas ul > li > span,
#menu-offcanvas ul > li > a {
  color: #777;
  line-height: 3rem;
  background-color: rgb(243, 243, 240);
  border-bottom: 1px dotted rgb(200, 200, 200);
}
#menu-offcanvas ul > li:hover > span,
#menu-offcanvas ul > li:hover > a {
  /* color: #738188; */
  background-color: rgb(235, 235, 235);
}
#menu-offcanvas ul > li:last-child > span,
#menu-offcanvas ul > li:last-child > a {
  border-bottom: none;
}

/*Navegação por Tabs*/
#menu-offcanvasli > a:focus-visible {
  background-color: rgba(45, 48, 68, 0.5);
  outline: none;
}
#menu-offcanvas > li > a:focus-visible {
  background-color: #ebebeb;
  outline: none;
}
/*Padings dos links 2 e 3 nível*/
#menu-offcanvas li > ul a {
  padding-left: 20px;
}
#menu-offcanvas ul > li > ul a {
  padding-left: 50px;
}
/**/
#menu-offcanvas ul {
  list-style: none;
  position: static;
  overflow: hidden;
  margin-bottom: 0;
}
#menu-offcanvas ul {
  max-height: 0;
  -webkit-transition: max-height 0.3s ease-in-out;
  transition: max-height 0.3s ease-in-out;
}
#menu-offcanvas li.parent a:not(.show) + ul {
  max-height: 0;
}
#menu-offcanvas li.parent a.show + ul {
  height: auto;
  max-height: 550px;
}
#menu-offcanvas li.parent a:not(.show) + ul a {
  opacity: 0;
  visibility: hidden;
  -webkit-transition: all 1s ease-in-out;
  transition: all 1s ease-in-out;
}
#menu-offcanvas li.parent a.show + ul a {
  opacity: 1;
}

/*...................
 Dropdown Icon 
 */
#menu-offcanvas li.parent > a::after {
  content: "\f105";
  font-family: "Font Awesome 5 Free";
  font-weight: 900;
  position: absolute;
  right: 0;
  margin: 0 20px;
  transition: 0.3s ease;
}
#menu-offcanvas li.parent > a.show::after {
  transform: rotate(90deg);
}
