*{
    box-sizing: border-box;
}
html, body, div, span, applet, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
a, abbr, acronym, address, big, cite, code,
del, dfn, img, ins, kbd, q, s, samp,
small, strike, sub, sup, tt, var,
b, u, i, center, 
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
caption,
article, aside, canvas, details, embed, 
figure, figcaption, footer, header, hgroup, 
menu, nav, output, ruby, section, summary,
time, mark, audio, video {
    margin: 0;
    padding: 0;
    border: 0;
    font-size: 100%;
    font: inherit;
    vertical-align: baseline;
}
ol, ul {margin-left: 18px; list-style: none;}

body {
    zoom: 1;
    word-wrap: break-word;
    word-break: normal;
    overflow-x: hidden;
}
em { 
    margin: 0; 
    padding: 0;
    border: 0;
    font-size: 100%;
    vertical-align: baseline;
}
strong, b {
    font-weight: bold;
}
/* HTML5 display-role reset for older browsers */
article, aside, details, figcaption, figure, 
footer, header, hgroup, menu, nav, section {
    display: block;
}
html,iframe, body {
    width: 100%;
    height: 100%;
}
a:visited, a:link {
    text-decoration: none !important;
}
a:hover {
    text-decoration: none !important;
}
::selection { background: #32325B; color: #fff; } ::-moz-selection { background: #32325B; color: #fff; }
.sucesso {
    border: solid 1px #005937;
    color: #005937;
    background: #fff;
    border-radius: 5px;
    margin-bottom: 20px;
    padding-bottom: 20px;
}
.erro {
    border: solid 1px #b73541;
    color: #b73541;
    background: #ffbfc5;
    border-radius: 5px;
    margin-bottom: 20px;
    padding-bottom: 20px;
}
.full {
    width: 100%;
    margin: 0 auto;
    position: relative;
}

.pdg-0 {
    padding-left: 0px;
    padding-right: 0px;
}
.pdg-tp-60{
	padding-top: 60px;
}
.mrg-0 {
    margin-left: 0px;
    margin-right: 0px;
}
.mrg-bt-30{
	margin-bottom: 30px;
}
.mrg-bt-60{
	margin-bottom: 60px;
}
.white{
	color: #fff !important;
}
.height-full{height: 100%;}
.section{white-space: pre;}
.pos-rel{position: relative;}
.pos-abs{position: absolute;}
.pos-fix{position: fixed;}
.overflow-hidden{overflow: hidden;}
.display-none{display: none !important;}
.display-align {
    display: flex;
    align-items: center;
    justify-content: center;
}
.cursor-pointer{cursor: pointer;}
.outline-none{outline: none !important;}
.border-none{border: none !important;}
.background-full {
    background-repeat: no-repeat;
    background-position: center center;
    -webkit-background-size: cover;
    -moz-background-size: cover;
    -o-background-size: cover;
    background-size: cover;
    transition: all 1s;
}
.slick-initialized {
    visibility: visible;
}
.slick-initialized .slick-slide {
    float: none;
    display: inline-block;
    vertical-align: middle;
}
.slick-initialized .slick-slide {
    outline: none;
}

/* BREADCRUMB */
.breadcrumb {
    background-color: #F5F5F5;
    padding: 50px;
}

.breadcrumb a {
    color: #737373;
}

.breadcrumb span {
    color: #737373;
    font-weight: 900;
}

/* GERAL */
.font-0 {font-size: 0;}

.overlay {
    display: none;
    position: fixed;
    width: 100%; 
    height: 100%;
    left: 100%;
    background: rgba(14, 14, 14, 0.7);
    overflow: hidden; 
    z-index: 1050;
}

.padrao-btn button {
    font-family: "Montserrat", Arial;
    position: relative;
    height: 40px;
    width: 17em;
    font-size: 12px;
    border-radius: 15px;
    letter-spacing: 1px;
    background: transparent;
    border: 2px solid #474747;
    color: #474747;
    text-transform: uppercase;
    cursor: pointer;
    outline: none;
    font-weight: 600;
    transition: all ease 0.5s;
}

.padrao-btn button:hover {
    color: #fff;
    border: 2px solid #271B1B;
    background: #271B1B;
}

.banner-destaque .padrao-btn button {
    border: 2px solid #fff;
    color: #fff;
}

.banner-destaque .padrao-btn button:hover {
    color: #fff;
    background: transparent;
}

.secundario-btn {
    font-family: "Montserrat", Arial;
    position: relative;
    height: 40px;
    width: 17em;
    font-size: 12px;
    border-radius: 15px;
    letter-spacing: 1px;
    background: #C30D18;
    border: 2px solid #C30D18;
    color: #fff;
    text-transform: uppercase;
    cursor: pointer;
    outline: none;
    font-weight: 600;
    transition: all ease 0.5s;
}

.secundario-btn:hover {
    background: transparent;
}

.secundario-btn:hover {
    color: #C30D18;
}

@media (max-width: 1024px) {
    .padrao-btn button {
        width: 10em;
    }
}
@media (max-width: 425px) {
    .padrao-btn {
        text-align: center;
    }
}

/*MODAL*/
.modal {
    top: -30px !important;
}
.modal-dialog {
    margin-top: 0;
}
.modal-content {
    float: left;
    width: 100%;
    top: 20em;
    border-radius: 10px!important;
    backdrop-filter: blur(10px)!important;
    box-shadow: 0 0 40px rgba(8,7,16,0.6)!important;
    padding: 10px 20px 0px 20px;
}
.modal-body {
    float: left;
    width: 100%;
    text-align: justify;
    background-color: #ffffffc9;
    backdrop-filter: blur(10px);
    box-shadow: 0 0 40px rgba(8,7,16,0.6);
}
.modal-body .display-align {
    justify-content: space-between;
}

.button {
    font-family: monospace!important;
    display: inline-block;
    padding: 0.5em 1.0em;
    border-radius: 4px;
    background: #ffffff;
    font-family: Arial;
    font-size: 16px;
    cursor: pointer;
    color: #515151;
    border: 1px solid #515151;
    margin: 10px;
    -webkit-transition: background 0.3s;
    -moz-transition: background 0.3s;
    transition: background 0.3s;
}
  
.button:hover {
    background-color: rgba(0,0,0,0.1);
}
  
.button:active, .button.is-checked {
    background-color: rgba(0,0,0,0.1);
    outline: none;
}
  
.button-group {
    margin: 20px;
    text-align: center;
}
  
.button-group:after {
    content: '';
    display: block;
    clear: both;
}

.grid article {
    float: left;
    margin: 1%;
    width: 23%;
}
  
@media (max-width: 1024px) {
    .grid article {
        width: 31.3%;
    }
}

@media (max-width: 767px) {
    .grid article {
        width: 48%;
    }
}

@media (max-width: 479px) {
    .grid article {
        margin: 2% 0;
        width: 100%;
    }
}

.insta-ref {
    opacity: 0;
    width: 0;
    height: 0;
    overflow: hidden;
}

.conteudo-site {
    max-width: 100%;
    transition: all ease-in-out 0.2s;
}

.pst-center{
	position: relative;
	left: 50%;
	transform: translateX(-50%);
}

body::-webkit-scrollbar{width: 5px; height: 5px;}
body::-webkit-scrollbar-track{background: #f1f1f1;}
body::-webkit-scrollbar-thumb{background: #C30D18;}

body {
    /* Only IE */
    scrollbar-face-color: green; scrollbar-shadow-color: red; scrollbar-highlight-color: red;
    /* Only FireFox */
    scrollbar-color: green red;
    /* View Scrollbar */
    overflow-y: scroll;overflow-x: hidden;
    
    -moz-appearance: none !important;
	margin: 0px !important;
	padding: 0px !important;
	border: 0px !important;
        
    scrollbar-track-color: black;    
    
    font-family: "Manrope", sans-serif;
}


/* HEADER PADRAO */
#descricao-espacamento.display-align {
    flex-direction: column;
    align-items: unset;
    position: relative;
    right: 10%;
}
.bordered-text {
    text-transform: uppercase;
    font-family: "Montserrat", "Outfit", "Archivo Black", "Anton", sans-serif;
    font-weight: 700;
    font-size: 50px;
    color: #fff; 
    text-shadow: 
        1px 1px 0px #271B1B, 
        -1px -1px 0px #271B1B, 
        1px -1px 0px #271B1B, 
        -1px 1px 0px #271B1B; 
}
.header-padrao {
    font-family: "Inter", sans-serif;
    text-transform: uppercase;
    text-align: center;
    letter-spacing: 5px;
    font-size: 55px;
    background-image: linear-gradient(180deg, #500580 50%, #C30D18 100%);
    background-clip: text;
    -webkit-background-clip: text;
    color: transparent;
    font-weight: 600;
}
.header-destaque {
    font-family: "Montserrat", "Outfit", "Archivo Black", "Anton", sans-serif;
    text-transform: uppercase;
    font-size: 35px;
    line-height: 35px;
    color: #474747;
    font-weight: 900;
}
.header-titulo {
	font-family: "Montserrat", "Outfit", "Archivo Black", "Anton", sans-serif;
    text-transform: uppercase;
    /* text-align: center; */
    font-size: 25px;
    line-height: 38px;
    color: #474747;
	font-weight: 800;
    margin-bottom: 30px;
}
.header-titulo a {
    color: #474747;
    text-decoration: underline!important;
}
.navbar-expand-lg .navbar-collapse {
    justify-content: flex-end;
}

@media (max-width: 1199px) {
    .header-padrao {
        font-size: 36px;
    }
    .header-destaque {
        font-size: 25px;
    }
    .header-titulo {
        font-size: 22px;
    }
}
@media (max-width: 768px) {
    .header-padrao {
		font-size: 35px;
	}
    .header-destaque {
        text-align: center;
    }
    .header-titulo {
        font-size: 24px;
    }
    #descricao-espacamento.display-align {
        right: 0;
    }
}
@media (max-width: 425px) {
    .header-titulo {
        font-size: 25px;
    }
}

/* --------------------------------- HEADER --------------------------------- */
.header {
    padding-bottom: 7em;
}
.container-header {
    display: flex;
    justify-content: center;
    position: fixed;
    left: 0;
    z-index: 50;
    border-bottom: solid 1px transparent;
    transition: all 0.5s;
}
.container-header .menu-linha {
    background-color: #000;
    width: 100%;
    border-radius: 0px;
    padding: 0 100px;
    -webkit-box-shadow: none;
    -moz-box-shadow: none;
    box-shadow: none;
    transition: all ease 0.5s;
}
.container-header .menu-linha.principal {
    width: 100%;
    position: absolute;
    top: 40px;
    border-radius: 0;
}
.secundario .info {
    color: #fff;
}
.secundario .info .bi, .rodape-rede .bi {
    color: #C30D18;
}
.secundario .info .bi-geo-alt {
    margin-left: 3em;
}
.container-header .menu-linha.secundario .navbar  {
    padding: 0;
}
.container-header .menu-linha.secundario .nav-menu {
    height: 40px;
}
.navbar {
    width: 100%;
}
.navbar .nav-menu {
    height: 73px;
    position: relative;
    transition: all 0.5s;
}
.nav-brand {
    position: relative;
}
.nav-brand a {
    padding-top: 0;
    padding-bottom: 0;
}
.nav-brand img {
    height: 45px;
    position: relative;
    transition: all 0.5s;
    margin-top: 10px;
    color: #fff;
}
.navbar-toggler {
    border: 2px solid #fff;
    outline: none;
    border-radius: 50%;
    padding: 7px 10px;
}
.navbar-toggler.collapsed .icon-top {
    transform: rotate(0);
}
.navbar-toggler.collapsed .icon-mid {
    opacity: 1;
}
.navbar-toggler.collapsed .icon-bot {
    transform: rotate(0);
}
.navbar-toggler:focus {
    outline: none;
}
.icon-bar {
    width: 21px;
    height: 2px;
    background-color: #C30D18;
    margin: 5px 0;
    transition: all 0.5s;
}
.navbar-toggler .icon-top {
    transform: rotate(-45deg) translate(-5px, 5px);
}
.navbar-toggler .icon-mid {
    opacity: 0;
}
.navbar-toggler .icon-bot {
    transform: rotate(45deg) translate(-3px, -4px);
}

.container-header .nav-menu {
    height: 60px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
}

.menu-item {
    position: relative;
    margin: 0px;
    padding: 0px;
}
.menu-item:last-child {
    padding-right: 0;
}
.menu-item-link {
    font-size: 16px;
    color: #fff;
    font-weight: 600;
    font-family: "Montserrat",Arial;
    cursor: pointer;
    text-transform: uppercase;
    transition: all 0.5s;
    text-transform: uppercase;
}


@media (max-width: 768px) {
    .header {
        padding-bottom: 5em;
    }

    #tela-espera .container-header .menu-linha {
        padding: 15px 50px;
    }

    .container-header .menu-linha.principal {
        top: auto;
    }

    .container-header .menu-linha.secundario {
        display: none;
    }
}

@media (max-width: 425px) {
    #tela-espera .container-header .menu-linha {
        padding: 15px 30px;
    }
}


/*REDE SOCIAL*/
.ul-social {
    position: fixed;
    width: 295px;
    background: #f3f3f3;
    border-radius: 8px;
    z-index: 46;
    box-shadow: 0 0 10px -5px #8c8c8c;
    transition: all ease-in-out .25s;
    transform: scale(0);
    list-style: none;
    margin: 0;
    font-family: 'Montserrat';
    font-weight: 500;
}

.ul-social.shown {
    transform: scale(1);
    bottom: 355px;
    left: 60px;
}

.topo-social {
    color: #fff;
    background: linear-gradient(180deg, #500580 50%, #C30D18 100%);
    padding: 15px 20px;
    border-top-left-radius: 8px;
    border-top-right-radius: 8px;
    text-align: center;
    text-transform: uppercase;
    font-size: .9rem;
}

.social-contato {
    position: fixed;
    bottom: 27em;
    opacity: .45;
    padding: 15px;
    text-align: center;
    transition: all ease-in-out .2s;
    border-radius: 0 10px 10px 0;
    color: #fff;
    cursor: pointer;
    background: linear-gradient(180deg, #500580 50%, #C30D18 100%);
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 45;
}

.social-contato:hover, .social-contato.shown {
    opacity: 1;
}

.social-fale-txt-mob {
    font-size: 16px;
    color: #fff;
    writing-mode: vertical-lr;
    text-orientation: upright;
    letter-spacing: 5px;
}

/*LINKS - REDE SOCIAL*/
.cont-social {
    padding: 10px;
    max-height: 46vh;
    overflow-y: auto;
}

.info-social {
    font-family: "Manrope", sans-serif;
    margin-left: 10px;
    vertical-align: middle;
    display: inline-block;
    position: relative;
}

.info-social p {
    font-size: .8rem;
    color: #6e6e6e;
}

.info-social h2 {
    margin-top: 5px;
    font-size: 1rem;
    color: #797979;
}

.cont-social .img-rede {
    padding: 10px 3px;
    border-radius: 20px;
}

.cont-social .instagram {
    background-color: rgb(225, 48, 108);
}
.cont-social .facebook {
    background-color: rgb(14 76 201);
}
.cont-social .linkedin {
    background-color: rgb(0, 132, 191);
}

.cont-social li {
    padding: 5px;
    transition: all ease 0.5s;
}

.cont-social li:hover {
    box-shadow: 0 0 10px -5px #8c8c8c;
}

.cont-social img {
    left: 2px;
    height: 38px;
    width: auto;
    display: inline-block;
    vertical-align: middle;
    position: relative;
}

.cont-social .img-rede img {
    height: 30px;
    bottom: 1px;
}

/* .social {
    width: 8%;
} */
.social .img-rede {
    padding-bottom: 15px;
    transition: all 0.5s ease-in-out;
}
.social .box-social {
  width: 25px;
  height: 25px;
}
.social img {
  width: 100%;
  height: 100%;
  filter: brightness(0) invert(1);
  transition: all ease 0.5s;
}
.social-list {
  display: flex;
  align-items: center; /* alinha verticalmente */
  gap: 15px; /* espaço entre os ícones */
  list-style: none;
  padding: 0;
  margin: 0;
}

.social-list li {
    display: inline-flex;
    background: #C30D18;
    padding: 5px;
    border-radius: 10px;
    transition: all ease 0.5s;
}

.social-list li:hover  {
    background: #271B1B;
}

.social-list li:hover img {
  transform: scale(1.05);
}

.container-header.fixo {
    top: 0;
}
.container-header.fixo .menu-linha {
    background-color: #0c0c0c;
    border-radius: 0;
    top: 0;
}

.container-header.fixo .menu-linha.secundario {
    display: none;
}

/* busca no menu */
.search-container {
    max-width: 500px;
    width: 500px;
    position: relative;
    background: #fff;
    border-radius: 10px;
}

.form-control.search-input {
    height: 100%;
    border: none;
    border-radius: 10px;
    padding-right: 45px; /* espaço para o botão */
    box-shadow: none;
    background: #fff;
}

.search-btn {
    position: absolute;
    top: 50%;
    right: 5px;
    transform: translateY(-50%);
    background-color: #a0100f;
    border: none;
    border-radius: 8px;
    height: 38px;
    width: 38px;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
}

.search-btn:hover {
    background-color: #800d0c;
}

.search-btn i {
    color: white;
    font-size: 1.1rem;
}

@media (max-width: 1440px) {
    /* .social {
        width: 10%;
    } */
    .social-contato {
        bottom: 20em;
    }
    .ul-social.shown {
        bottom: 244px;
    }
}
@media (max-width: 1024px) {
    .social .img-rede img {
        width: 5%;
    }
    .search-container {
        max-width: 260px;
        width: 260px;
    }
}
@media (max-width: 768px) {
    .container-header {
        position: initial;
    }
}
@media (max-width: 425px) {
    .social .img-rede img {
        width: 10%;
    }
}


.container-header.fixo .navbar .nav-menu {
    position: relative;
}
.container-header.fixo .nav-brand img {
    height: 45px;
    position: relative;
    transition: all 0.5s;
    margin-top: 10px;
	filter: sepia(0);
}

.img-rede-header {
    width: 32px;
    margin-left: 10px;
    border-radius: 50%;
}

#btn-menu-none {
    position: absolute;
    right: 0px;
    width: 37px;
    height: 29px;
    background: transparent;
    border: transparent;
    outline: none;
    display: none;    
}
.a-sair {
    cursor: pointer;
    display: flex;
    border: none;
    background: none;
}
.a-sair img {
    display: flex;
}
.a-sair:hover img {
    filter: drop-shadow(2px 4px 6px black);
}
.a-sair:focus {
    outline: none;
}
.navbar-toggler:not(:disabled):not(.disabled) {
    z-index: 12;
}
#btn-menu-none.mostrar {
    display: block;    
}
.navbar-toggler.collapsed .icon-top {
    transform: rotate(0);
}
.navbar-toggler.collapsed .icon-mid {
    opacity: 1;
}
.navbar-toggler.collapsed .icon-bot {
    transform: rotate(0);
}
.navbar-toggler:focus {
    outline: none;
}
.icon-bar {
    width: 19px;
    height: 1px;
    background-color: #fff;
    margin: 5px 0;
    transition: all 0.5s;
}
.navbar-toggler .icon-top {
    transform: rotate(-45deg) translate(-5px, 5px);
}
.navbar-toggler .icon-mid {
    opacity: 0;
}
.navbar-toggler .icon-bot {
    transform: rotate(45deg) translate(-3px, -4px);
}
.menu-item.login {
    display: flex;
    justify-content: center;
    align-items: center;
}
.menu-responsivo.menu-item.login {
    display: none;
}
.menu-item:last-child {
    padding-right: 0;
}
.menu-item-link {
    font-family: "Bebas Neue", sans-serif;
    font-size: 20px;
    font-weight: 100;
    background: transparent;
    padding: 10px;
    margin: 0 5px;
    border-radius: 20px;
    color: #fff;
    transition: all 0.5s;
}
.menu-items .img-header svg{
    width: 32px!important;
    height: 32px!important;
}
.selected-menu .menu-item-link, .selected-menu span svg path{
    color: #C30D18;
    fill: #C30D18;
}
.noselect-menu .menu-item-link, .noselect-menu span svg path{
    color: #fff;
    transition: all 0.5s;
}
.fixo .noselect-menu .menu-item-link, .fixo .noselect-menu span svg path{
    color: #fff;
    fill: #fff;
}
.menu-item .ativo .menu-item-link, .menu-item .img-fluid:hover , .menu-item .menu-item-link:active, .noselect-menu:hover span svg path, .menu-items:hover .menu-item-link {
    background: #C30D18!important;
    color: #fff !important;
    fill: #fff;
}
.menu-items {
    display: flex;
    align-items: center;
    justify-content: center;
    flex-direction: column;
}
.menu-items span{
    width: 20%;
    margin: 0 auto;
    margin-top: 10px;
}
.menu-item-link.menu {
    font-size: 13px;
    color: #A7A7A7;
    font-weight: 600;
    font-family: "Open-Sans",Arial;
    cursor: pointer;
    transition: all 0.5s;
    display: flex;
}
.rf-destaque-menu {
    transition: all ease 0.5s;
}
.owl-item .rf-destaque-menu {
    width: auto;
}
.owl-carousel .owl-item .menu-items img {
    padding-top: 10px;
    width: 20%!important;
}
.menu-item-login {
    display: flex;
}
.menu-linha-login .container{
    padding: 0!important;
}
.menu-item-img{
    object-fit: contain;
}
.div-rede-header {
    display: inline-block;
    vertical-align: middle;
    transition: all ease 0.5s;
}
.div-rede-header img{
	transition: all .3s;
    margin: 0 10px;
}
.div-rede-header img:hover{
	transform: scale(1.2);
}
.balao .seta {
    margin: 0px 0 0 -39px;
}
.div-rede-header:hover .balao .seta.facebook {
    margin: 50px 0 0 -40px;
}
.div-rede-header:hover .balao .seta.instagram {
    margin: 50px 0 0 -43px;
}
.div-rede-header:hover .balao .seta.linkedin {
    margin: 50px 0 0 -34px;
}
.div-rede-header:hover .balao .seta {
    margin: 50px 0 0 -40px;
    width: 0; 
    height: 0; 
    border-left: 10px solid transparent;
    border-right: 10px solid transparent;
    border-top: 10px solid #5477BB;
    transition: all ease 0.3s;
    left: 0;
    position: relative;
    transform: translateX(-70%);
}
.div-rede-header:hover .balao a{
    display: flex;
    align-items: center;
    /*margin: 15% 15%;*/
}
.div-rede-header:hover .balao .text-balao{
    margin: 15% 6%;
    left: 20%;
    transform: translateX(-15%);
}
.div-rede-header:hover .balao {
    display: flex;
    align-items: center;
    justify-content: center;
    background-color: #C30D18;    
    width: 5em;
    border-radius: 5%;
    margin: 0 auto;
    transition: all ease 0.6s;
}
.img-rede-footer {
    width: 30px;
    margin-right: 10px;
}
@media (min-width: 1024px) {
    .banner-vertical.fixo {
        position: sticky;
        width: 100%;
        top: 0;
        right: 0;
    }
}
@media (max-width: 768px) {
    .menu-item .ativo .menu-item-link, .menu-item .img-fluid:hover , .menu-item .menu-item-link:active, .noselect-menu:hover span svg path, .menu-items:hover .menu-item-link {
        color: #C30D18 !important;
        fill: #C30D18 !important;
        background: transparent!important;
    }
    .selected-menu .menu-item-link, .selected-menu span svg path{
        color: #C30D18!important;
        fill: #C30D18;
    }
    .noselect-menu .menu-item-link, .noselect-menu span svg path, .fixo .noselect-menu .menu-item-link, .fixo .noselect-menu span svg path{
        color: #fff!important;
        fill: #fff;
        transition: all 0.5s;
    }
    .menu-item-login {
        flex-direction: column;
    }
    .logado-mobile {
        text-align: center;
        padding-bottom: 80px;
    }
    .container-header.fixo .navbar .nav-menu, .container-header .navbar .nav-menu {
        justify-content: space-between;
        padding: 0 20px;
    }
    .container-header .nav-menu {
        justify-content: space-between;
    }
    .menu-items .img-header svg {
        width: 40px!important;
        height: 40px!important;
    }
}
.container-header.fixo {
    transition: all ease 0.5s;
    position: fixed;
    width: 100%;
    top: 0;
}
.container-header.fixo a img{
    display: inline;
}
.container-header.fixo .login-txt{
    display: none;
}
.container-header.fixo .menu-item-img{
    margin-right: 20px;
}
.container-header.fixo .menu-linha-login {
    opacity: 1;
    position:initial;
}
.container-header.fixo .nav-brand img {
    position: relative;
    transition: all 0.5s;
	filter: sepia(0);
}

.container-fluid {
    padding: 0 100px;
}

.img-rede-header {
    width: 32px;
    margin-left: 10px;
    border-radius: 50%;
}

@media (max-width: 1024px) {
    .container-fluid {
        padding: 0 15px;
    }
}

@media (max-width: 768px) {
    .header .navbar {
        padding: 0;
    }
    .rf-destaque-menu {
        width: 100%;
        border-right: none;
    }
    .menu-items {
        display: flex;
        align-items: center;
        flex-direction: row-reverse;
    }
    .menu-items span{
        width: 25px;
        margin: 0px;
        margin-top: 10px;
    }
    .menu-item-login .btn-form-contato {
        background-color: #ffffff;
    }
}

@media (max-width: 375px) {
    .navbar-input input {
        margin-left: 0px;
    }
}

.index-1{
	z-index: 1;
}

.index-9{
	z-index: 9;
}

@media (min-width: 992px) AND (max-width: 1199px) {
    .menu-item-link {
        font-size: 17px;
        padding: 5px;
    }
}
@media (max-width: 991.98px) {
    .navbar-expand-lg>.container,
    .navbar-expand-lg>.container-fluid {
        padding-right: 15px;
        padding-left: 15px;
    }
}
@media (max-width: 991px) {
    .container-header .menu-linha-login {     
        display: none;
    }
    .fundo-opacidade {
        position: fixed;
        width: 100%;
        height: 100%;
        left: 0;
        background-color: rgba(0, 0, 0, 0.8);
        transform: translateY(-100%);
        transition: all 0.3s;
    }
    .fundo-opacidade.shown {
        z-index: 10;
        top: 0em;
        transform: translateY(0);
    }
    div#navbarSupportedContent {
        position: absolute;
        left: 0;
        top: 60px;
        width: 100%;
        height: 100vh;
        overflow-y: auto;
        max-height: calc(100vh - 50px);
        z-index: 11;
    }
    .input-group-append .btn, .input-group-prepend .btn {
        position: relative;
        z-index: auto; 
    }
    .container-header {
        position: relative;
        top: 0;
    }
    .container-header .menu-linha{
        background-color: #C30D18;
        -webkit-box-shadow: 0px 2px 5px 0px rgba(0,0,0,0.5);
        -moz-box-shadow: 0px 2px 5px 0px rgba(0,0,0,0.5);
        box-shadow: 0px 2px 5px 0px rgba(0,0,0,0.5);
        padding: 10px 0;
        border-radius: 0;
    }
    .navbar-nav {
        padding-top: 10em;
        margin-left: 0;
    }
    .menu-item {
        padding: 0;
        top: 30px;
        text-align: center;
    }
    .menu-item li {
        position: relative;
    }
    .menu-item a {
        font-size: 18px;
    }
    .nav-menu .menu-item-link {
        padding: 18px 15px;
        color: #fff;
    }
    .menu-item::after {
        display: none;
    }
}
@media (max-width: 520px) {
    .menu-item {
        padding: 0 10px;
    }
    .navbar-nav {
        padding-top: 5em;
    }
}
@media (max-width: 350px) {
    .nav-brand img {
        height: 45px;
    }
    .menu-item {
        padding: 0;
    }
}


/* BOTÕES */
.btn-principal {
    background-color: #fff;
    color: #000;
    font-weight: 600;
    padding: 10px 28px;
    border-radius: 6px;
    border: 1px solid rgba(0,0,0,0.1);
    box-shadow: 0 2px 6px rgba(0, 0, 0, 0.1);
    border: 1px solid #fff;
    margin-right: 30px;

    transition: all 0.3s ease;
}

.btn-principal.vermelho {
    border: 1px solid #d32f2f;
    background-color: #b91c1c; /* vermelho principal */
    color: #fff;
}

.btn-principal.vermelho:hover {
    background-color: #d32f2f; /* tom mais escuro no hover */
    border: 1px solid #d32f2f;
}

.btn-principal:hover {
    background-color: transparent;
    border: 1px solid #f5f5f5;
    color: #f5f5f5;
}

.btn-ver-mais {
    background-color: transparent;
    color: #d32f2f;
    font-weight: 600;
    padding: 10px 28px;
    border-radius: 6px;
    border: 1px solid #d32f2f;
    box-shadow: 0 2px 6px rgba(0, 0, 0, 0.1);
    margin-top: 75px;
    transition: all 0.3s ease;
}

.btn-ver-mais:hover {
    color: #fff;
    background-color: #d32f2f; /* tom mais escuro no hover */
}

@media (max-width: 425px) {
    .btn-ver-mais {
        margin-top: 30px;
    }

    .btn-principal {
        margin-right: 0px;
        margin-bottom: 30px;
    }
}

/* ---------------------------------- HOME ---------------------------------- */
@media (max-width: 768px) {
    .home .inst-linha-mvv {
        padding: 40px 0;
    }
    .home .banner-institucional {
        margin: 0!important;
    }
}

.rsMinW .rsOverflow, .rsMinW .rsSlide, .rsMinW .rsVideoFrameHolder, .rsMinW .rsThumbs {
    background: transparent;
}


.banner-principal {
    width: 100%;
    height: 100%;
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
}

.banner-principal .text-banner {
    font-weight: 900;
}

/* FRAME EXTERNO: o "padding cinza" visível ao redor */
.catalogo-frame{
    position: relative;
    width: 560px;       /* ajuste se quiser maior/menor */
    height: 560px;
    padding: 20px;      /* essa é a "moldura cinza" ao redor */
    border-radius: 22px;
    background: rgba(25,25,25,0.55); /* cinza escuro do padding externo */
    border: 1px solid rgba(255,255,255,0.03);
    box-shadow: 0 6px 30px rgba(0,0,0,0.6);
    overflow: visible;
    display: flex;
    align-items: center;
    justify-content: center;
}

/* ÁREA INTERNA: degradê vermelho que vai para um tom escuro (que combina com a moldura) */
.catalogo-inner{
    width: 100%;
    height: 100%;
    border-radius: 14px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    text-align: center;

    /* degradê vermelho --> para escuro (visual de transição para o cinza externo) */
    background: linear-gradient(135deg,
                rgba(180,30,24,0.55) 0%,
                rgba(110,20,20,0.30) 45%,
                rgba(20,20,20,0.6) 100%);
    backdrop-filter: blur(6px);
    -webkit-backdrop-filter: blur(6px);
    box-shadow: inset 0 0 0 1px rgba(255,255,255,0.01);
    padding: 28px;
}

/* ícone e textos */
.catalogo-icon{
    width: 48px;
    height: 48px;
    margin-bottom: 14px;
    /* se for SVG com stroke use filter ou inline svg para colorir; aqui assumimos a imagem já correta */
}

.catalogo-title{
    margin: 0;
    color: #fff;
    font-weight: 700;
    margin-bottom: 6px;
}

.catalogo-sub{
    margin: 0;
    color: rgba(255,255,255,0.75);
    font-size: 0.9rem;
}

/* círculos decorativos que aparecem nos cantos (parte fora do frame) */
.catalogo-decor{
    position: absolute;
    width: 72px;
    height: 72px;
    border-radius: 50%;
    pointer-events: none;
}

/* círculo vermelho no canto superior direito, parcialmente sobrepondo o frame */
.decor-top-right{
    top: -24px;
    right: -24px;
    background: rgba(200,30,30,0.17);
    box-shadow: 0 6px 18px rgba(0,0,0,0.5);
}

/* círculo translúcido no canto inferior esquerdo */
.decor-bottom-left{
    bottom: -22px;
    left: -22px;
    background: rgba(255,255,255,0.04);
    box-shadow: 0 6px 18px rgba(0,0,0,0.5);
}

/* pequenos ícones à esquerda (features) */
.feature {
    align-items: center;
    gap: 10px;
    margin: 0 20px 20px 0;
}

.feature-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 34px;
  height: 34px;
  border-radius: 8px;
  background: #A0100F; /* leve fundo para destacar o ícone */
  font-size: 18px;
}

.text-danger {
    color: #A0100F!important;
}

#catalogo-interna .text-danger, #catalogo-interna .text-muted {
    font-size: 15px;
    font-weight: 500;
}

/* espaçamento do texto ao lado do ícone */
.feature > div { line-height: 1; }

/* Catalog card interno (mantendo seu frame/degradê anterior) */
.catalogo-icon {
  font-size: 48px;
  color: #A0100F; /* vermelho do ícone grande */
  margin-bottom: 14px;
  line-height: 1;
}

/* RESPONSIVO: reduz tamanho e deixa centralizado em telas menores */
@media (max-width: 1440px) {
    .catalogo-frame{
        height: 440px;
    }
}

@media (max-width: 1024px) {
    .catalogo-frame{
        height: 350px;
    }
    .lead {
        font-size: 1rem;
    }
    .banner-principal .text-banner {
        font-weight: 2.5rem;
    }
}

@media (max-width: 991px){
    .catalogo-frame{
        width: 300px;
        height: 300px;
        padding: 16px;
        border-radius: 18px;
    }
}

@media (max-width: 576px){
    /* aqui você pode querer que o card ocupe 100% e fique abaixo do texto */
    .catalogo-frame{
        width: calc(100% - 40px);
        height: auto;
        padding: 18px;
        margin: 20px auto;
    }
    .catalogo-inner{
        width: 100%;
        height: 220px; /* ou auto, se preferir conteúdo fluido */
    }
}


.banner-content {
    position: absolute;
    display: flex;
    justify-content: center;
    align-content: center;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    text-align: center;
    color: #fff;
    width: 80%;
    height: 100%;
}

#home.banner-destaque .banner-content {
    left: 78%;
}

.banner-content .text-banner {
    display: flex;
    flex-direction: column;
    justify-content: center;
}

.banner-content .rodape-rede {
    position: absolute;
    bottom: 0%;
}

.banner-description, 
.banner-subtitle {
    font-family: "Bebas Neue", sans-serif;
    letter-spacing: 2px;
    color: #fff;
    margin-top: 1em;
}

.banner-description {
    font-size: 2vw;
    margin-bottom: 10px;
}

.banner-subtitle {
    font-size: 1.3vw;
}

.banner-principal .logo-img {
    width: 50%;
}

.banner-interna .rsContent div {
    background-position: center;
    background-size: cover;
}

.rsCaption.titulo {
    font-size: 60px;
    font-weight: 900;
    text-transform: uppercase;
    /*text-shadow: 1px 1px 20px black;*/
}
.rsCaption.descricao, .rsCaption.descricao p {
    font-size: 20px;
    font-weight: 400;
}

.contato-home .container-home-info {
    background-attachment: fixed;
}

.rsMinW .rsBullets {
    right: auto;
    left: 50%;
    transform: translateX(-50%);
    bottom: 15px;
    line-height: normal;
}
.rsMinW .rsBullet span {
    border-radius: 0px;
}
.rsMinW .rsBullet {
    margin: 0 10px;
}
.rsNavItem.rsBullet {
    font-size: 17px;
    color: #fff;
    cursor: pointer;
}
.rsNavItem.rsBullet span {
    background-color: #ffffff;
    width: 10px;
    height: 10px;
}
.rsNavItem.rsBullet.rsNavSelected {
    color: #5477BB;
    text-decoration: underline;
}
.rsNavItem.rsBullet.rsNavSelected span {
    background-color: #5477BB;
}
.rsContent .rsImg {
    margin-top: 0 !important;
}
.rsMinW .rsGCaption {
    position: relative;
    background: none;
    font-family: "Montserrat", "Outfit", "Archivo Black", "Anton", sans-serif;
    bottom: 0;
    left: 0;
    text-align: center;
    transform: translateY(-50%);
}
.banner-institucional.rsMinW .rsGCaption {
    background: none;
    font-family: "Montserrat", Arial;
    font-weight: 500;
    /* font-size: 65px; */
    font-size: 50px;
    top: 55%;
    left: 25%;
    transform: translateX(-50%);
}

@media (max-width: 1024px) {
    .banner-principal .logo-img {
        width: 35%;
    }
}

@media (max-width: 768px) {
    .banner-content .text-banner {
        justify-content: flex-start;
        margin-top: 7%;
    }
    .rsCaption.titulo {
        font-size: 30px;
    }
    .banner-description {
        font-size: 2.5vw;
    }
    .banner-subtitle {
        font-size: 2vw;
    }
    .social .social-list {
        justify-content: center;
    }
    .rodape-rede.mobile .social-list a {
        justify-content: flex-start;
        text-decoration: none !important;
    }
    .rodape-rede.mobile .banner-subtitle {
        color: #474747;
    }
    .banner-principal {
        background-size: cover;
    }
}

@media (max-width: 425px) {
    .banner-content .text-banner {
        margin-top: inherit;
        margin-bottom: 63%;
    }
    .banner-content .rodape-rede {
        position: relative;
    }
    .banner-description, .banner-subtitle {
        font-size: 4vw;
    }
    .banner-content {
        flex-direction: column;
    }
    .banner-principal .logo-img {
        width: 45%;
    }
}

/* BANNER EM VIDEO */
.banner-video {
    position: relative;
    width: 100%;
    font-size: 0;
}
.banner-video-play {
    position: relative;
    width: 100%;
    height: 100%;
}
.banner-video-som {
    position: absolute;
    bottom: 15px;
    right: 15px;
    background-color: #e94f1c;
    font-size: 0;
    z-index: 5;
    padding: 5px;
    cursor: pointer;
}
.banner-video-som svg {
    width: 15px;
    height: 15px;
}

.linha-home-inst {
    position: relative;
    padding-top: 131px;
    padding-bottom: 131px;
}
.linha-commodities {
    display: flex;
    align-items: center;
    position: relative;
    padding-bottom: 131px;
}
.linha-home-servicos {
    padding-bottom: 131px;
}
.inst-home-desc ol, .inst-home-desc ul {
    list-style: auto;
}
.inst-home-chamada, .inst-home-chamada p {
    font-size: 15px;
    color: #555555;
    font-weight: 400;
    font-family: "Montserrat", Arial;
}
.inst-home-desc, .inst-home-desc p {
    font-size: 15px;
    color: #373737;
    position: relative;
    font-family: "Montserrat", Arial;
    line-height: 20px;
    text-align: justify;
}
.inst-home-desc p {
    margin: 25px 0;
}
.inst-home-desc.topicos, .inst-home-desc.topicos p{
    font-size: 14px;
    line-height: 28px;
    text-align: center!important;
    margin: 0 15px 0 30px;
    margin-bottom: 110px;
}
.btn-center {
    display:flex;
    justify-content: center;
}
.btn-padrao-todos img {
    margin-left: 10px;
    margin-bottom: 3px;
}
.inst-home-img {
    position: absolute;
    right: 0;
    top: 50%;
    transform: translateY(-50%);
    font-size: 0;
}
.inst-home-img img {
    max-width: 650px;
}

/*
.home-servico-destaque-img {
    text-align: center;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
}

.container-home-servico-conteudo {
    padding-top: 89px;
}
*/

.box-cliente {
    width: 100%;
    height: 10em;
    overflow: hidden;
    transition: all 0.5s ease-in-out;
}
.cliente-home-item, .item {
    height: 100%;
    width: 100%;
    background-size: contain;
    background-repeat: no-repeat;
    background-position: center
}


btn {
	cursor: pointer;
}

.container-home-tributo img {
    width: 100%;
}

.container-home-mapa iframe {
    height: 450px;
}

.container-home-info {
    padding: 80px 0;
}
.pst-top{
	position: relative;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
}

@media (min-width: 1451px) AND (max-width: 1680px) {
    .inst-home-img img {
        max-width: 700px;
    }
}
@media (min-width: 1251px) AND (max-width: 1450px) {
    .inst-home-img img {
        max-width: 650px;
    }
}
@media (min-width: 1200px) AND (max-width: 1250px) {
    .inst-home-img img {
        max-width: 550px;
    }
}
@media (max-width: 1199px) {
    .inst-home-img {
        max-width: 100%;
    }
    .inst-home-img img {
        max-width: 100%;
    }
    .inst-home-desc, .inst-home-desc p {
        font-size: 13px;
    }
}
@media (min-width: 576px) {
    .home-banner-container-txt,
    .home-banner-txt {
        max-width: 540px;
    }
}
@media (min-width: 768px) {
    .home-banner-container-txt,
    .home-banner-txt {
        max-width: 720px;
    }
}
@media (min-width: 992px) {
    .home-banner-container-txt,
    .home-banner-txt {
        max-width: 960px;
    }
}
@media (min-width: 1200px) {
    .home-banner-container-txt,
    .home-banner-txt {
        max-width: 1110px;
    }
}
@media (max-width: 991px) {
    .home-banner-mobile {
        display: block;
    }
    .container-home-mapa iframe {
        height: 400px;
    }

    .home-servico-destaque-branco {
        padding-top: 100px;
    }

    .linha-home-inst {
        padding-top: 40px;
        padding-bottom: 40px;
    }
    .inst-home-img-fundo-cima,
    .inst-home-img-fundo-baixo {
        margin: auto;
    }
    .inst-home-img {
        /* max-width: 47%; */
        position: relative;
        transform: none;
        top: 0;
        text-align: center;
        max-width: 100%;
        padding-top: 40px;
    }
    .container-home-servico {
        padding-top: 40px;
        padding-bottom: 40px;
    }
    .container-home-servico-conteudo {
        padding-top: 20px;
    }
    .home-banner-container-txt {
        position: absolute;
        top: 50%;
        left: 50%;
        transform: translate(-50%, -50%);
        padding-right: 15px;
        padding-left: 15px;
        width: 100%;
    }
    /*
    .home-banner-titulo {
        max-width: 100%;
        font-size: 24px;
    }
    */
}
@media (max-width: 768px) {
    .footer-center {
        text-align: center;
    }
    .redes-header {
        font-size: 50px;
    }
    .redes-header-2 {
        font-size: 60px;
    }
}
@media (max-width: 575px) {
    .home-prod-linha li button {
        font-size: 26px;
    }
    .home-prod-linha {
        height: 480px;
    }
    .container-home-mapa iframe {
        height: 300px;
    }
    .redes-header {
        font-size: 40px;
    }
    .redes-header-2 {
        font-size: 50px;
    }
    .insta-widget iframe {
        min-width: 285px !important;
    }
    .slide-parceiro img {
        max-width: 146px;
        margin: auto;
    }
    .box-cliente {
        width: 10em;
    }
    #interna-destaque .box-cliente {
        width: auto;
    }
}


/* CLIENTE */
#clientes .col-md-3 {
    padding-left: 10px;
    padding-right: 10px;
}

.box-cliente {
    border-radius: 10px;
    overflow: hidden;
    text-align: center;
    transition: transform 0.2s ease-in-out, box-shadow 0.2s ease-in-out;
    padding: 10px; /* espaçamento interno do card */
}

.box-cliente:hover {
    transform: scale(1.02);
}

.cliente-home-item {
    background-position: center;
    background-repeat: no-repeat;
    width: 100%;
    border-radius: 8px;
    margin-bottom: 10px; /* espaço entre imagem e conteúdo */
}


/* ---------------------- BLOG - ESTILO CARD ---------------------- */
.categoria-menu {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 20px;
    padding: 15px 0;
    border-bottom: 1px solid #ddd;
}
.categoria-link {
    text-decoration: none;
    color: #000;
    font-weight: 500;
    background: transparent;
    border: none;
    cursor: pointer;
}
.categoria-link:focus {
    outline: none;
}
.categoria-link:hover {
    color: #d10000;
}
.categoria-ativa {
    background-color: #d10000;
    color: #fff !important;
    padding: 5px 12px;
    border-radius: 20px;
    font-weight: 600;
}

.card-noticia {
    background: #fff;
    border-radius: 20px;
    overflow: hidden;
    box-shadow: 0px 4px 12px rgba(0,0,0,0.08);
    display: flex;
    flex-direction: column;
    height: 100%;
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.card-noticia:hover {
    box-shadow: 0px 8px 20px rgba(0,0,0,0.15);
}

.card-imagem img {
    width: 100%;
    height: 200px;
    object-fit: cover;
    display: block;
}

.card-conteudo {
    padding: 20px;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    height: 100%;
}

.card-conteudo .tag {
    top: 15px;
    left: 35px;
    display: inline-block;
    background: #a0100f;
    color: #fff;
    font-size: 12px;
    font-weight: 600;
    padding: 4px 10px;
    border-radius: 8px;
    margin-bottom: 10px;
    transition: all ease 0.5s;
}

.card-conteudo .titulo {
    font-size: 18px;
    font-weight: 700;
    margin-bottom: 8px;
    color: #000;
}

.card-conteudo .descricao {
    font-size: 14px;
    color: #555;
    margin-bottom: 15px;
}

.meta {
    font-size: 12px;
    color: #777;
    display: flex;
    gap: 15px;
    align-items: center;
    margin-bottom: 15px;
}

.card-conteudo .meta i {
    margin-right: 5px;
}

.card-conteudo .btn-ler {
    background: #f5f5f5;
    border-radius: 8px;
    text-align: center;
    padding: 10px;
    font-weight: 600;
    text-decoration: none;
    color: #000;
    transition: background 0.3s ease;
}

.card-conteudo .btn-ler:hover {
    color: #fff;
    background: #a0100f;
}

/* AUTOR */
/* Card principal */
.profile-card {
  border: 1px solid #e5e5e5;
  border-radius: 8px;
  padding: 50px 20px;
  background-color: #fff;
  margin: 60px 0 0;
}

/* Ícone circular */
.icon-circle {
  width: 40px;
  height: 40px;
  background-color: #f1f1f1;
  border-radius: 50%;
  font-size: 20px;
  color: #222;
  margin-right: 12px;
}

/* Nome */
.profile-name {
  font-weight: 600;
  margin-bottom: 4px;
}

/* Descrição */
.profile-desc {
  color: #6c757d;
  margin: 0;
  font-size: 0.9rem;
}

/* Para responsividade */
.profile-text {
  flex: 1;
}

/* Responsividade */
@media (max-width: 768px) {
    .card-imagem img {
        height: 160px;
    }
}

@media (max-width: 425px) {
    .profile-card {
        margin: 20px 0 0;
    }
}

/*------------------------------- PRODUTO -----------------------------------*/
.product-card {
    height: 450px;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    border: 1px solid #ddd;
    border-radius: 12px;
    box-shadow: 0 2px 6px rgba(0, 0, 0, 0.05);
    transition: transform 0.2s ease-in-out;
    overflow: hidden;
    background: #fff;
    margin-bottom: 30px;
}

.product-card:hover {
    transform: translateY(-3px);
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
}

.product-img {
    width: 100%;
    height: 160px;
    object-fit: contain;
    background: #fff;
    padding: 10px;
}

.tag {
    position: absolute;
    top: 10px;
    left: 10px;
    padding: 2px 8px;
    border-radius: 6px;
    font-size: 0.75rem;
    font-weight: bold;
    color: white;
}

.tag.destaque { background-color: #d32f2f; }
.tag.novo { background-color: #4CAF50;}

#catalogo-interna .tag, #blog-interna .tag {
    position: unset;
    padding: 5px 10px;
}

.card-content {
    flex-grow: 1;
}

.product-card .conteudo {
   padding: 1rem;
}

.product-card .card-content .text-danger {
   font-size: 14px;
}

.product-card .card-content h6 {
   font-weight: 900;
}

.product-card .card-content .marca {
   margin: 5px 0 15px 0;
   color: #757575;
   font-size: 13px;
   text-transform: uppercase;
}

.btn-detalhes {
    background: #d32f2f;
    color: white;
    border-radius: 8px;
    padding: 8px 12px;
    font-weight: 600;
    margin-top: auto;
    margin: 1rem;
    transition: all ease 0.5s;
}

.btn-detalhes:hover {
    background: #0C0C0C;
    color: #fff;
}

.cta-conteudo {
    width: 100%;
    height: 220px;
    display: block;
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    background-color: #fff;
}



#catalogo .card .header-destaque {
    color: #fff;
}
#catalogo .card .header-destaque span {
    font-size: 32px;
}
#catalogo .card {
    flex: 1;
    padding: 20px;
    display: flex;
    flex-direction: row;
    justify-content: center;
    align-items: center;
    text-align: center;
    color: white;
    border-radius: 0;
    transition: flex 0.5s ease, opacity 0.3s ease;
    position: relative;
    min-height: 400px; /* Define uma altura mínima para evitar o "samba" */
    max-height: 400px; /* Mantém a altura estável */
    overflow: hidden; /* Evita que o conteúdo quebre os limites */
}

@media (max-width: 425px) {
    .product-card {
        margin-bottom: 30px;
    }
}


/* Estilo do primeiro card "TORNEIO" sempre aberto */
#catalogo .catalogo {
    background-color: #C30D18;#catalogo .card .header-destaque {
    color: #fff;
}

#catalogo .card .header-destaque span {
    font-size: 35px;
}

#catalogo .card {
    flex: 1;
    padding: 20px;
    display: flex;
    flex-direction: column; /* Mantém a coluna para a disposição dos textos */
    justify-content: center;
    align-items: center;
    text-align: center;
    color: white;
    border-radius: 0;
    transition: flex 0.5s ease, opacity 0.3s ease;
    position: relative;
    min-height: 400px; /* Define uma altura mínima para evitar o "samba" */
    max-height: 400px; /* Mantém a altura estável */
    overflow: hidden; /* Evita que o conteúdo quebre os limites */
}

/* Estilo do primeiro card "TORNEIO" sempre aberto */
#catalogo .catalogo {
    background-color: #C30D18;
    flex: 3; /* Mantém o primeiro card aberto inicialmente */
    transition: opacity 0.3s ease;
}

/* Cards subsequentes */
#catalogo .kit-atleta {
    background-color: #662366;
}

#catalogo .pesquisa {
    background-color: #bb83c7;
    border-radius: 0 30px 30px 0;
}

#catalogo .card p {
    font-size: 1rem;
    margin-bottom: 30px;
    transition: opacity 0.3s ease; /* Suave transição na opacidade */
}

/* Botão */
#catalogo .padrao-btn button {
    border: 2px solid white;
    color: white;
    transition: opacity 0.3s ease; /* Suave transição na opacidade */
}

/* Cards subsequentes têm texto escondido inicialmente */
#catalogo .header-destaque {
    display: flex;
    align-items: center;
    justify-content: center;
    writing-mode: vertical-rl;
    text-orientation: mixed;
    font-size: 2rem;
    transform: rotate(180deg);
}

/* Quando o hover é feito em qualquer card */
#catalogo .card:hover {
    flex: 3; /* Expande o card em hover */
}

/* Mostra o conteúdo do card em hover */
#catalogo .card:hover p,
#catalogo .card:hover button {
    display: block;
    pointer-events: auto;
}

/* Esconde o texto do card catalogo ao passar o hover nos outros cards */
#catalogo .kit-atleta:hover ~ .catalogo p,
#catalogo .pesquisa:hover ~ .catalogo p {
    display: none; /* Esconde o conteúdo do card catalogo */
    pointer-events: none; /* Desabilita eventos de ponteiro */
}

/* Esconde todo o card "catalogo" ao passar o mouse sobre outros cards */
#catalogo .kit-atleta:hover .catalogo,
#catalogo .pesquisa:hover .catalogo {
    display: none; /* Esconde o card catalogo completamente */
}

/* Esconde o texto e botão nos outros cards inicialmente */
#catalogo .kit-atleta p,
#catalogo .kit-atleta button,
#catalogo .pesquisa p,
#catalogo .pesquisa button {
    display: none;
    pointer-events: none;
}

/* Estilo de transição ao passar o mouse */
#catalogo .row:hover .catalogo {
    flex: 0.5; /* Fecha o primeiro card quando hover em outro card */
}

    flex: 3; /* Mantï¿½m o primeiro card aberto inicialmente */
    transition: opacity 0.3s ease;
}


#catalogo .row:hover .catalogo p, #catalogo .row:hover .catalogo button {
    display: none;
}

#catalogo .row .catalogo:hover p, #catalogo .row .catalogo:hover button {
    display: block;
}

/* Cards subsequentes */
#catalogo .kit-atleta {
    background-color: #662366;
}

#catalogo .pesquisa {
    background-color: #bb83c7;
    border-radius: 0 30px 30px 0;
}

#catalogo .card h2 {
    font-size: 1.8rem;
}

#catalogo .card p {
    font-size: 1rem;
    margin-bottom: 30px;
    transition: opacity 0.3s ease; /* Suave transição na opacidade */
}

#catalogo .padrao-btn button {
    border: 2px solid white;
    color: white;
    transition: opacity 0.3s ease; /* Suave transição na opacidade */
}

/* Cards subsequentes tï¿½m texto escondido inicialmente */
#catalogo .catalogo .header-destaque, #catalogo .kit-atleta .header-destaque, .pesquisa .header-destaque {
    display: flex;
    align-items: center;
    justify-content: center;
    writing-mode: vertical-rl;
    text-orientation: mixed;
    font-size: 2rem;
    transform: rotate(180deg);
}

/* Quando o hover ï¿½ feito no container */
#catalogo .row:hover .catalogo {
    flex: 0.5; /* Fecha o primeiro card quando hover em outro card */
}

#catalogo .row .catalogo:hover {
    flex: 3; /* Fecha o primeiro card quando hover em outro card */
}

/* Quando o hover ï¿½ feito em qualquer card */
#catalogo .card.catalogo:hover, #catalogo .card.kit-atleta:hover, #catalogo .card.pesquisa:hover {
    flex: 3; /* Expande o card em hover */
}

/* Mostra o conteï¿½do do card em hover */
#catalogo .card:hover p,
#catalogo .card:hover button {
    display: block;
    pointer-events: auto;
}

#catalogo .card p {
    padding: 0 50px;
}

/* Quando outro card estï¿½ em hover, esconde o texto do primeiro card */
#catalogo .kit-atleta:hover #catalogo .catalogo p,
#catalogo .kit-atleta:hover #catalogo .catalogo button,
#catalogo .pesquisa:hover #catalogo .catalogo p,
#catalogo .pesquisa:hover #catalogo .catalogo button {
    display: none;
    pointer-events: none;
}

/* Esconde o texto e botï¿½o nos outros cards inicialmente */
#catalogo .kit-atleta p, #catalogo .kit-atleta button,
#catalogo .pesquisa p, #catalogo .pesquisa button {
    display: none;
    pointer-events: none;
}

.desktop {
    display: grid;
}
#parceiros .desktop {
    display: block;
}
.mobile {
    display: none;
}

@media (max-width: 1024px) {
    #catalogo .card p {
        font-size: 15px;
        padding: 0 50px;
    }

    #catalogo .card h2 {
        margin-bottom: 20px;
    }
}
@media (max-width: 768px) {
    .desktop, #parceiros .desktop {
        display: none;
    }
    .mobile {
        display: grid;
    }
    #parceiros .mobile {
        display: block;
    }
    #catalogo .header-destaque, #parceiros .header-titulo {
        font-size: 34px;
        text-align: center;
        margin-bottom: 20px;
    }
    #catalogo .card {
        margin-bottom: 30px;
        border-radius: 20px;
    }
    #catalogo .catalogo p, #catalogo .catalogo button,
    #catalogo .kit-atleta p, #catalogo .kit-atleta button,
    #catalogo .pesquisa p, #catalogo .pesquisa button,
    #catalogo .kit-atleta:hover #catalogo .catalogo p,
    #catalogo .kit-atleta:hover #catalogo .catalogo button,
    #catalogo .pesquisa:hover #catalogo .catalogo p,
    #catalogo .pesquisa:hover #catalogo .catalogo button {
        display: block;
        pointer-events: pointer;
    }

    #catalogo .card .header-destaque span {
        font-size: 30px;
    }
    #catalogo .card p {
        font-size: 16px;
        padding-left: 80px;
    }
}
@media (max-width: 425px) {
    #catalogo .card {
        padding-right: 60px;
    }
    #catalogo .card p {
        font-size: 16px;
        padding-right: 0;
        padding-left: 40px;
        margin-bottom: 10px;
        text-align: start;
    }
    #catalogo .card .padrao-btn {
        position: absolute;
        bottom: 0;
        padding: 25px 0px;
    }
    #catalogo .card .display-align {
        align-items: end;
    }
}
@media (max-width: 375px) {
    #catalogo .card p {
        font-size: 15px;
    }
}
@media (max-width: 325px) {
    #catalogo .card {
        padding-right: 20px;
    }
    #catalogo .card p {
        font-size: 14px;
        padding-left: 15px;
    }
}


/* ----------------------------- INSTITUCIONAL ----------------------------- */
hr.nav-linha-cor{
    width: 94.8%;
    margin-bottom: 0.5rem;
    background-color: #C30D18;
    position: relative;
}
hr.nav-linha-responsivel{
    display: none;
}
.inst-linha-cor-branco {
    background-color: #FFFFFF;
}
.inst-desc {
    font-family: 'Montserrat', Arial;
    /* font-size: 32px; */
    font-size: 20px;
    color: #BBBBBB;
    /* line-height: 39px; */
    position: relative;
    padding-right: 32px;
}
.marg-b-5 {
    margin-bottom: 5px;
}
.marg-b-29 {
    margin-bottom: 29px;
}
.aspas-invert {
    transform: scaleX(-1);
    position: absolute;
    right: 0;
    bottom: 15px;
}
.home-inst-img {
    border-radius: 15px;
    overflow: hidden;
}
.inst-linha-mvv {
    padding-top: 75px;
    padding-bottom: 75px;
}
#principal .header-padrao {
    font-size: 40px;
    line-height: 67px;
    color: #C30D18;
    font-weight: 500;
    position: relative;
}
#principal .header-titulo, #principal .header-titulo a {
    color: #7C7C7C;
    font-size: 30px;
    font-weight: 300;
    margin-bottom: 0;
}
#videos .header-titulo, #areaRestrita .header-titulo {
    font-weight: 500;
}
.inst-linha-mvv .header-padrao.topicos {
    font-size: 35px;
    font-weight: 800;
    text-align: center;
    margin-top: 40%;
}
.inst-linha-mvv .header-padrao img {
    position: absolute;
    top: -69px;
    left: -52px;
}
.inst-mvv-desc {
    font-family: 'Montserrat', Arial;
    font-size: 24px;
    font-weight: 400;
    color: #FFFFFF;
    line-height: 29px;
}
.inst-txt-info {
    margin-top: 90px;
}
.inst-txt-info .header-titulo,
.inst-txt-info .inst-home-desc {
    color: #FFFFFF;
}

.box-institucional {
    width: 100%;
    height: 20em;
    overflow: hidden;
    border-radius: 0 30px 0 30px;
}

.box-experiencia {
    width: 100%;
    height: 20em;
    overflow: hidden;
    border-radius: 30px;
    margin-bottom: 30px;
    position: relative;
}

.institucional-item, .item {
    height: 100%;
    width: 100%;
    background-size: cover;
    background-repeat: no-repeat;
    background-position: center;
    transition: all 0.5s ease-in-out;
}

.box-experiencia .institucional-item {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background-size: cover;
    background-position: center;
    height: 100%;
}

.box-experiencia:hover .institucional-item {
    transform: scale(1.1);
}

#experiencia .box-experiencia:hover .texto {
    background: rgba(0, 0, 0, 0.5); 
}


#institucional .header-destaque, #institucional .header-destaque h2 {
    font-size: 34px;
}

#institucional .header-destaque.subtitulo, #institucional .header-destaque.subtitulo h2 {
    font-size: 23px;
    font-weight: 500;
    line-height: 1;
}

#institucional .direita .header-destaque, #institucional .direita .header-destaque h2, #institucional .direita .inst-home-desc, #institucional .direita .inst-home-desc p {
    text-align: end;
}

#institucional .esquerda .header-destaque, #institucional .esquerda .header-destaque h2, #institucional .esquerda .inst-home-desc, #institucional .esquerda .inst-home-desc p {
    text-align: start;
}

#institucional .direita .inst-home-desc p, #institucional .esquerda .inst-home-desc p {
    margin-top: 10px;
}

.barrinha {
    display: flex;
    align-items: center;
    justify-content: space-around;
}

.barrinha .bar {
    width: 8px;
    height: 150px;
    background-color: #5C1764;
}

.card-inscricao, .card-contato, .card-newsletter {
    background-color: #5C1764;
    height: 15em;
    border-radius: 30px;
    padding: 0 5em;
}

.card-contato, .card-newsletter {
    height: 8em;
    border-radius: 0px;
}

.card-inscricao .display-align, .card-contato .display-align, .card-newsletter .container.display-align {
    justify-content: space-between;
}

.card-inscricao .header-titulo, .card-contato .header-titulo, .card-newsletter .header-titulo, #pesquisa .header-titulo {
    color: #fff;
    font-size: 50px;
    line-height: 45px;
}

.card-newsletter .header-titulo {
    line-height: 27px;
}

.card-contato .header-titulo, .card-newsletter .header-titulo {
    font-size: 30px;
}

.card-inscricao .inscricao, .card-contato .inscricao, .card-newsletter .newsletter {
    text-align: center;
}

.card-inscricao .inscricao .header-titulo {
    font-size: 30px;
}

.card-contato .inscricao .header-titulo, .card-newsletter .newsletter .header-titulo {
    font-size: 15px;
    line-height: normal;
    margin-bottom: 0;
}

.card-inscricao .inscricao .header-titulo strong, .card-contato .inscricao .header-titulo strong, .card-newsletter .inscricao .header-titulo strong {
    font-weight: 900;
}

.card-inscricao .padrao-btn button, .card-contato .padrao-btn button, .card-newsletter .padrao-btn button {
    color: #fff;
    border: 2px solid #fff;
}

.card-newsletter .text-news {
    color: #fff;
}

#localizacao .header-destaque, #localizacao .header-destaque h2 {
    text-align: start;
}

#localizacao .box-institucional {
    height: 31em;
}

#experiencia .texto {
    width: 100%;
    height: 100%;
    color: #fff; 
    padding: 80px 30px;
    position: relative;
    transition: all ease 0.5s;
}

#experiencia .header-titulo, #experiencia .titulo .header-destaque, #experiencia .inst-home-desc, #experiencia .inst-home-desc p {
    color: #fff;
    text-align: center;
}

#experiencia .header-titulo {
    font-size: 20px;
}

#experiencia .titulo .header-destaque {
    font-size: 25px;
    line-height: 15px;
}


#experiencia .inst-home-desc, #experiencia .inst-home-desc p {
    font-size: 12px;
}


.box-contato .contato-home-item {
    background: #C30D18;
    height: 92%;
    background-size: 8em;
    background-repeat: no-repeat;
    background-position: right bottom;
    background-origin: content-box;
    padding: 40px;
    border-radius: 50px;
}

.box-contato .contato-home-item .info-contato {
    margin-bottom: 50px;
}

.box-contato .contato-home-item .header-destaque {
    text-align: start;
    font-size: 28px;
    line-height: 25px;
    color: #fff;
    font-weight: 600;
    letter-spacing: -2px;
    margin-bottom: 20px;
}

.box-contato .contato-home-item a img {
    width: 10%;
}

.box-contato .contato-home-item p {
    color: #fff;
}

.box-contato .form-group label {
    font-family: "Montserrat", "Outfit", "Archivo Black", "Anton", sans-serif;
    margin-bottom: 5px;
    font-weight: 600;
}

.box-contato .contato-home-item.left {
    border-radius: 50px 0 0 50px;
}

.box-galeria {
    width: 100%;
    height: 21em;
    overflow: hidden;
    border-radius: 50px;
    transition: all 0.5s ease-in-out;
}

.box-galeria .galeria-home-item {
    height: 100%;
    background-size: cover;
    background-repeat: no-repeat;
    background-position: center;
}


@media (max-width: 1199px) {
    .inst-titulo {
        font-size: 54px;
    }
    .inst-subtitulo {
        font-size: 68px;
    }
    .inst-desc {
        margin-top: 20px;
        /* height: 63px; */
    }
    .inst-vid-titulo {
        font-size: 50px;
    }
    #experiencia .inst-home-desc, #experiencia .inst-home-desc p {
        font-size: 11px;
    }
}
@media (min-width: 992px) {
    .pad-l-lg-11 {
        padding-bottom: 11px;
    }
    .pad-r-lg-11 {
        padding-right: 11px;
    }
}
@media (max-width: 991px) {
    .cont-inst-txt {
        position: relative;
        transform: none;
        left: inherit;
        top: inherit;
        margin-top: 30px;
        margin-bottom: 30px;
    }
    .inst-desc {
        height: auto;
        margin-bottom: 30px;
    }

    .inst-linha-top {
        padding-bottom: 30px;
    }

    .inst-linha-mvv {
        padding-top: 10px;
        padding-bottom: 40px;
    }
    .inst-linha-mvv .header-padrao img {
        left: -15px;
    }    

    .inst-txt-info .header-titulo {
        margin-top: 30px;
    }
    .inst-txt-info .header-padrao {
        margin-top: 20px;
    }
    
}
@media (max-width: 768px) {
    .header hr.nav-linha-cor{
        display: none;
    }
    hr.nav-linha-responsivel{
        display: flex;
        width: 80%;
        position: relative;
        top: -35px;
        background-color: #fff;
    }
    .inst-titulo {
        font-size: 50px;
    }
    .inst-subtitulo {
        font-size: 60px;
    }
	.servico-titulo {
		top: 100px;
		width: 100%;
		margin-left: -15px;
	}
    .inst-home-desc.topicos {
        margin: 0;
    }
    .barra-lateral {
        display: none;
    }
	
    .cont-inst .header-padrao {
        font-size: 24px;
    }
    .inst-desc {
        font-size: 16px;
    }

    .inst-linha-mvv .header-padrao img {
        max-width: 50px;
        top: -20px;
    }
    .inst-mvv-desc {
        font-size: 16px;
    }
    .card-newsletter {
        height: 12em;
    }
    .card-inscricao .display-align, .card-contato .display-align, .card-newsletter .container.display-align {
        flex-direction: column;
        justify-content: space-around;
    }
    .card-newsletter .text-news {
        margin: 10px 0;
    }
}
@media (max-width: 575px) {
    .inst-titulo {
        font-size: 40px;
    }
    .inst-subtitulo {
        font-size: 44px;
    }
    .card-inscricao, .card-contato {
        height: 20em;
        padding: 0;
    }
    .card-inscricao .inscricao, .card-contato .inscricao, .card-contato .newsletter {
        margin: 15px 0;
    }
    .card-inscricao .header-titulo, .card-contato .header-titulo, .card-newsletter .header-titulo {
        font-size: 35px;
        line-height: 35px;
        text-align: center;
    }
    .card-inscricao .inscricao .header-titulo {
        font-size: 20px;
        margin-bottom: 15px;
    }
    .card-contato {
        height: 10em;
    }
    .card-newsletter {
        height: 25em;
        padding: 0 2em;
    }
    #experiencia .texto {
        padding: 45px;
        justify-content: center;
    }
    #experiencia .header-titulo {
        font-size: 25px;
    }
    #experiencia .titulo .header-destaque {
        font-size: 30px;
    }
    #experiencia .inst-home-desc, #experiencia .inst-home-desc p {
        font-size: 15px;
    }
}
@media (max-width: 375px) {
    .card-inscricao .header-titulo, .card-contato .header-titulo, .card-newsletter .header-titulo {
        font-size: 30px;
        line-height: 30px;
    }
    .card-contato {
        height: 15em;
    }
}
@media (max-width: 325px) {
    #experiencia .header-titulo {
        font-size: 20px;
    }
    #experiencia .titulo .header-destaque {
        font-size: 25px;
    }
    #experiencia .inst-home-desc, #experiencia .inst-home-desc p {
        font-size: 12px;
    }
    #experiencia .texto {
        padding: 30px;
    }
}

/* ====== CONTATO SECTION ====== */
#formContato {
    background: #000;
}

.swal2-content .select2-container.select2-container--default {
    display: none;
}

#formContato .btn-red { 
    width: 100%;
}

#formContato #interna-destaque {
    background-size: cover;
    background: linear-gradient(to right, rgba(0, 0, 0, 0.9) 0%, rgb(16 16 16 / 60%) 50%, rgb(53 31 31 / 90%) 100%);
}

.contato-section {
  color: #fff;
  font-family: 'Arial', sans-serif;
}

.container {
  max-width: 1200px;
  margin: 0 auto;
}

.contato-grid {
  display: grid;
  grid-template-columns: 1fr 2fr;
  gap: 30px;
  align-items: stretch; /* faz as colunas ficarem com a mesma altura */
}

/* Garante que a coluna esquerda ocupe 100% da altura da grid */
.contato-info {
  display: flex;
  flex-direction: column;
  gap: 15px; /* substitui o margin-bottom de .info-box */
  height: 100%;
}

/* Remove o margin-bottom das info-box, porque o gap da flex já faz espaçamento */
.contato-info .info-box {
  margin-bottom: 0;
  flex: 1; /* Faz cada info-box crescer proporcionalmente */
  display: flex;
  flex-direction: column;
  justify-content: center;
}


/* Coluna esquerda */
.info-box {
  position: relative;       /* necessário para o pseudo-elemento */
  background: #1a1a1a;
  border-radius: 10px;      /* seu border-radius */
  padding: 20px;
  overflow: hidden;         /* garante que o pseudo-elemento siga o border-radius */
}

.info-box::before {
  content: "";
  position: absolute;
  top: 0px;
  left: 0px;
  right: 0px;
  bottom: 0px;
  padding: 1px; /* espessura da "borda" */
  background: linear-gradient(120deg, #a0100f, #1a1a1a);
  border-radius: inherit;
  -webkit-mask: 
    linear-gradient(#fff 0 0) content-box, 
    linear-gradient(#fff 0 0);
  -webkit-mask-composite: xor;
  mask-composite: exclude; /* máscara para só mostrar o gradiente na borda */
  pointer-events: none; /* não interfere na interação */
}


.contato-info .info-box h3 {
  color: #A0100F;
  margin-bottom: 10px;
  font-size: 1.2rem;
  font-weight: 700;
}

.contato-info .info-box p,
.contato-info .info-box a {
  color: #A6A6A6;
  font-size: 0.95rem;
  line-height: 1.4rem;
}

.info-box span {
    color: #fff;
    font-weight: 700;
}

/* Coluna direita */
.contato-form h2 {
  font-size: 1.8rem;
  margin-bottom: 10px;
}

.contato-form p {
  color: #bbb;
  margin-bottom: 20px;
}

.form-grid {
  display: grid;
  gap: 15px;
}

.form-grid label {
  margin-bottom: 10px;
}

.form-control {
  background: #262626;
  border: 1px solid #444;
  border-radius: 8px;
  padding: 12px;
  color: #fff;
  font-size: 0.95rem;
}

.form-control:focus {
    background-color: #111;
    outline: none;
    border-color: #A0100F;
    box-shadow: none;
}

/* Botões */
.form-buttons {
  margin-top: 20px;
  display: flex;
  gap: 10px;
}

.btn {
  padding: 12px 20px;
  font-weight: bold;
  border-radius: 8px;
  cursor: pointer;
  text-align: center;
  text-decoration: none;
  font-size: 1rem;
}

.btn-red {
  background: #ff1e1e;
  color: white;
}

.btn-red:hover {
  background: #e01414;
}

.btn-green {
  background: #25D366;
  color: white;
}

.btn-green:hover {
  background: #1ea855;
  color: #fff;
}

/* Responsivo */
@media (max-width: 900px) {
    .contato-grid {
        grid-template-columns: 1fr;
    }

    .contato-info {
        height: auto; /* altura volta ao normal */
    }

    .contato-info .info-box {
        flex: initial; /* não força altura igual */
    }
}

@media (max-width: 425px) {
    .form-buttons {
        margin-top: 10px;
        flex-direction: column;
    }
}


/* ---------------------------------- MAPA ---------------------------------- */
.container-mapa iframe {
    height: 400px;
}
.container-mapa .container {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
}

@media (max-width: 1199px) {
    .container-mapa iframe {
        height: 500px;
    }
}
@media (max-width: 991px) {
    .container-mapa iframe {
        height: 400px;
    }
    .container-mapa .container {
        position: relative;
        left: inherit;
        top: inherit;
        transform: none;
    }
}
@media (max-width: 575px) {
    .container-mapa iframe {
        height: 300px;
    }
}

.dadosContato{
	position: relative;
    top: 45%;
    transform: translateY(-50%);
}

.dados{
	color: #2C394A !important;
}
/* --------------------------------- FOOTER --------------------------------- */
.container-rodape {
    background: #000;
    width: 100%;
    padding: 70px 0 10px 0;
    background-size: contain;
    background-position: right bottom;
    background-repeat: no-repeat;
}
.container-rodape hr {
    width: 100%;
    border-top: 2px solid rgb(255 255 255 / 25%);
}
.rodape-menu {
    margin: 0;
}
.rodape-menu .menu-titulo, .rodape-rede .menu-titulo {
    color: #fff;
    font-size: 20px;
    font-weight: 900;
    margin-bottom: 15px;
}
.logo-footer {
    width: 60%;
    display: flex;
    justify-content: center;
    flex-direction: column;
    align-items: center;
}
.logo-footer span {
    color: #a0a0a0;
}
.rodape-conteudo .row {
    display: flex;
    justify-content: center;
} 
#projetos .logo-cliente {
    width: 15%;
}
.logo-cliente img {
    margin-top: 6px;
    padding-bottom: 30px;
}
#projetos .logo-cliente img {
    margin-top: 0px;
    padding-bottom: 0px;
}
.rodape-txt, .rodape-txt a {
    font-family: 'Asap Condensed' ,Arial;
    text-align: center;
    color: #fff;
    text-transform: uppercase;
    font-size: 14px;
    font-weight: 400;
    line-height: 20px;
    letter-spacing: 0.2px;
}
.rodape-rede {   
    padding-top: 0;
    padding-bottom: 3em;
}
.rodape-rede .social a, .rodape-rede .social .dados-rodape {   
    gap: 10px;
    justify-content: flex-start;
}
.rodape-rede .social .dados-rodape span {
    color: #a0a0a0;
}
.rodape-rede.mobile {   
    display: none;
}
.rodape-header {
    font-family: "Manrope", sans-serif;
    font-size: 16px;
    line-height: 24px;
    letter-spacing: 0.1px;
    font-weight: 700;
    color: #fff;
    margin-bottom: 15px;
    margin-top: 15px;
}

.rodape-menu-item,
.rodape-menu-item a {
    font-family: "Manrope", sans-serif;
    font-size: 15px;
    line-height: 20px;
    color: #fff;
    transition: all 0.8s;
}
.rodape-menu-item button {
    border: none;
    outline: none;
    background: transparent;
    color: #fff;
    padding: 0;
    cursor: pointer;
}
.rodape-menu-item button.categoria-ativa {
    padding: 0;
    color: #d10000;
}
.rodape-menu-item .selected-menu a {
    color: #fff;
    font-size: 14px;
    font-weight: bold;
}
.rodape-menu-item a:hover {
    color: #fff;
}
.rodape-menu-item:last-child {
    padding-bottom: 0;
}

.beneficios {
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-wrap: wrap;
    color: white;
    padding: 40px 0px;
    gap: 20px;
    text-align: center;
}

.beneficio-item {
    display: flex;
    flex-direction: column;
    align-items: center;
    max-width: 200px;
}

.beneficio-icon {
    background-color: #a0100f;
    color: white;
    font-size: 1.5rem;
    border-radius: 50%;
    width: 50px;
    height: 50px;
    display: flex;
    justify-content: center;
    align-items: center;
    margin-bottom: 10px;
    transition: transform 0.3s ease;
}

.beneficio-icon:hover {
    transform: scale(1.1);
}

.beneficio-title {
    font-weight: bold;
    margin-bottom: 5px;
}

.beneficio-subtitle {
    font-size: 0.9rem;
    color: #bbb;
}

@media (max-width: 1024px) {
    .container-rodape {
        padding: 70px 30px 10px 30px;
    }
}
@media(max-width: 768px) {
    .logo-footer {
        width: 100%;
    }
    .rodape-rede .social a {
        justify-content: center;
    }
    .destaque-menu-item.destaque {
        display: none;
    }
    .rodape-rede.mobile {   
        display: block;
    }
    #projetos .logo-cliente img {
        width: 180%;
    }
    .rodape-rede .social a, .rodape-rede .social .dados-rodape {   
        justify-content: center;
    }
    .beneficios {
        justify-content: center;
    }
}
@media (max-width: 520px) {
    .rodape-menu,
    .rodape-servico {
        display: grid;
        text-align: center;
    }
    .rodape-menu-item {
        padding-bottom: 5px;
        justify-content: center;
    }
    #projetos .logo-cliente {
        width: 30%;
    }
    #projetos .logo-cliente img {
        width: 100%;
    }
    .container-rodape {
        height: auto;
        padding: 50px;
    }
}

.destaque-menu-item .rodape-menu .rodape-menu-item li{
    padding: 10px 20px;
}
.rodape-menu .rodape-menu-item li{
    padding: 10px 1px;
}

.rodape-servico .rodape-menu-item {
    padding-bottom: 16px;
}

.rodape-tel-txt {
    font-size: 18px;
    color: #fff;
}
.rodape-tel-numero a {
    font-family: "LondrinaSolid-Regular";
    font-size: 34.3px;
    color: #3B3B3B;
    transition: all 0.5s;
}
.rodape-tel-numero a:hover {
    color: #3B3B3B;
}

.copy {
    font-size: 11px;
    color: #8e8a93;
    padding-top: 1em;
    padding-bottom: 1em;
    position: relative;
}

@media (min-width: 992px) AND (max-width: 1199px) {
    footer .menu-item-link {
        font-size: 12px;
    }
}
@media (max-width: 1024px) {
    .logo-cliente img {
        max-width: 255px;
    }
}
@media (max-width: 991px) {
    .rodape-conteudo .container {
        text-align: center;
    }
    .news-img img {
        height: 140px;
        left: 50%;
        transform: translateX(-50%);
    }
    .rodape-txt {
        text-align: center;
    }
    .rodape-rede {
        padding-top: 20px;
        padding-bottom: 20px;
        text-align: center;
    }
    .rodape-header {
        padding-top: 30px;
    }
    
    footer .menu-item {
        display: block;
        text-align: center;
        padding: 10px 0;
    }
    .rodape-rede-tel {
        margin-top: 30px;
    }
    .redes-icone,
    .rodape-tel {
        width: 100%;
        padding-right: 0;
        text-align: center;
    }
    .rodape-tel {
        margin-top: 20px;
    }
    .copy {
        padding-bottom: 3em;
    }
}
.hidden-desk{
	display: none !important;
}
.hidden-mob{
	display: block !important;
}
@media (max-width: 768px) {
    .nav-menu .menu-item-link{
        text-transform: uppercase;
        font-size: 25px;
	}
    #tela-espera .nav-menu .menu-item-link{
        font-size: 25px;
	}
    .nav-menu .menu-item-link.img-header{
        width: 10%;
	}
    .menu-item-li {
        margin-right: 0px;
        margin-bottom: 30px;
    }	
	.btn-padrao-todos {
		width: 100%;
	}
	.div-img-produto {
		height: 100%;
	}
	
    .rodape-header {
        margin-top: 20px;
    }
    .copy {
        padding-bottom: 1em;
    }
	.hidden-desk{
		display: block !important;
	}
	.hidden-mob{
		display: none !important;
	}
}
@media (max-width: 575px) {
    .rodape-conteudo .container {
        padding-top: 30px;
    }
    .nav-menu .menu-item-link.img-header{
        width: 15%;
	}
    .logo-cliente img {
        margin-top: 40px;
    }
    .rodape-orcamento, .rodape-especialista {
        width: 100%;
    }
    .rodape-col-botao {
        padding-top: 40px;
    }
    .rodape-orcamento {
        padding-right: 0;
        padding-bottom: 20px;
    }
    .news-titulo {
        display: block;
    }
    .conteudo-news form {
        display: block;
        width: 100%;
    }
}


/*GALLERY*/

.gallery {
    display: grid;
    grid-template-columns: repeat(12, 1fr);
    grid-template-rows: repeat(4, 5vw);
    grid-gap: 15px;
}
.gallery__img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}


/*CAROUSEL*/
.owl-carousel .owl-item img{
    display: block;
    width: 100%;
    max-height: 360px;
}

.owl-dots {
    display: none!important;
}
.owl-theme .owl-dots .owl-dot.active span, .owl-theme .owl-dots .owl-dot:hover span {
    display: none!important;   
}
.owl-nav{
    z-index: 5;
    display: flex;
    justify-content: space-between;
}
.owl-nav .owl-prev, .owl-nav .owl-next{
    z-index: 5;
}
.owl-theme .owl-nav [class*=owl-] {
    background: transparent;
    padding: 0px 0px;
}
.owl-theme .owl-nav [class*=owl-] img{
    transition: all ease 0.5s;
    border-radius: 50%;
}
.owl-theme .owl-nav [class*=owl-] img:hover {    
    transform: scaleX(1.05);
    transform: scaleY(1.05);
}
.owl-theme .owl-nav [class*=owl-]:hover {
    background: transparent;
}
.owl-theme .owl-nav {
    position: absolute;
    position: absolute;
    top: 50%;
    transform: translateY(-90%);
    width: 100%;
    z-index: 7;
}
.navbar-nav .owl-theme .owl-nav {
    z-index: 0;
    width: 105%;
    margin: -3.8em 0 0 -50px!important;
}
.owl-carousel .owl-stage-outer {
    z-index: 6;
}

@media (max-width: 1024px) {
    .owl-carousel .owl-item img{
        max-height: 304px;
    }
}
@media (max-width: 768px) {
    .owl-carousel .owl-item img{
        max-height: 460px;
    }
    .navbar-nav .owl-carousel .owl-item {
        width: 20em!important;
        float: inherit!important;
    }
    .navbar-nav .owl-theme .owl-nav {
        display: none;
    }
    .inst-home-desc.topicos, .inst-home-desc.topicos p {
        margin-bottom: 25px;
    }
    .inst-linha-mvv .header-padrao.topicos {
        margin-top: 10%;
    }
}
@media (max-width: 520px) {
    .owl-theme .owl-nav [class*=owl-] {
        margin: 0;
    }
    .owl-theme .owl-nav {
        position: relative;
        bottom: 0;
        right: 0;
        padding-bottom: 60px;
        margin: 30px 0 -4.3em 0!important;
        transform: translateX(0%);
    }
    .owl-carousel .owl-item img{
        max-height: 267px;
    }
}
@media (max-width: 420px) {
    .owl-carousel .owl-item img{
        max-height: 204px;
    }
}
@media (max-width: 375px) {
    .owl-carousel .owl-item img{
        max-height: 196px;
    }
}


/* PAGINACAO */
.paginacao {
    font-family: "Manrope", sans-serif;
}
.paginacao ul {
    margin: 0;
}
.paginacao li {
    display: inline-block;
    vertical-align: middle;
    position: relative;
}
.paginacao .paginacao-busca {
    font-size: 17px;
    /*width: 30px;
    height: 40px;*/
    display: flex;
    align-items: center;
    justify-content: center;
    background-color: transparent;
    margin: 10px;
    color: #C30D18;
    transition: all 0.5s;
}

.paginacao .paginacao-busca:hover, .paginacao .borda-selecionada {
    color: #C30D18;
    transform: scale(1.20);
}
.paginacao .paginacao-busca input, .paginacao .borda-selecionada input{
    width: 2.5em;
    text-align: center; 
    padding: 0px;
    border: 1px solid #C30D18;
    border-radius: 4px;
    background: #e9ebedbd;
    color: #C30D18;
}

input[type=number]::-webkit-inner-spin-button, input[type=number]::-webkit-outer-spin-button {
    -webkit-appearance: none;
    margin: 0;
}

.ulcardapio {
    display: flex;
    justify-content: center;
}
.paginacao-icon svg{
    margin-top: 3px;
    width: 15px;
    height: 15px;
}

.paginacao-left .paginacao-icon svg{
    transform: rotateY(180deg);
}

.paginacao-icon svg:hover{
    fill: #fff;
}

#interna-segmento.container .row{
    justify-content: flex-end;
}

@media (max-width: 768px) {
    .paginacao .paginacao-busca {
        width: 40px;
        height: 40px;
    }
    .col-lg-12.no-padding {
        padding-left: 0px;
        padding-right: 0px;
    }    
}
@media (max-width: 520px) {
    .paginacao .paginacao-busca {
        width: 30px;
        height: 35px;
    }
}
@media (max-width: 420px) {
    .paginacao .paginacao-busca {
        width: 25px;
        font-size: 15px;
    }
}
@media (max-width: 375px) {
    .paginacao .paginacao-busca {
        width: 18px;
        font-size: 13px;
    }
}

[data-toggle="collapse"] i:before {  
    content: "\f068";
}
  
[data-toggle="collapse"].collapsed i:before {
    content: "\f067";
}

.card-header{
    margin-bottom: 8px;
}
.accordion-title{
    position: relative;
    display: block;
    padding:8px 0 8px 50px;
    background: #C30D18;
    border-radius: 8px;
    overflow: hidden;
    text-decoration: none;
    color: #fff;
    font-size: 16px;
    font-weight: 700;
    width: 100%;
    text-align: left;
    transition: all .4s ease-in-out; 
}
.accordion-title i{
    position: absolute;
    width: 40px;
    height: 100%;
    left: 0;
    top: 0;
    color: #fff;
    background: radial-gradient(rgba(#213744, .8), #213744);
    text-align: center;
    border-right: 1px solid transparent;
}
.accordion-title:hover{
    padding-left: 60px;
    background: #C30D18;
    color: #fff;
    text-decoration: none;
}
.accordion-title:hover i{
    border-right: 1px solid #fff;
}

.accordion-body{
    padding: 40px 55px;
}
.accordion-body ul{
    list-style: none;
    margin-left: 0;
    padding-left: 0;
}
.accordion-body li{
    padding-left: 1.2rem;
    text-indent: -1.2rem;
}
.accordion-body:before{
    content: \f10a;
    padding-right: 5px;
    font-family: "Flaticon";
    font-size: 16px;
    font-style: normal;
    color: #C30D18;
}

@media (max-width: 768px) {
    #accordion {
        display: block;
    }

    #accordion .rf-pg-link-util {
        padding: 5px 20px;
    }
}

/*ACCORDION (perguntas frequentes)*/
.card-body {
    padding: 10px 60px;
}

.listaUser button {
    width: 95%; 
    text-decoration: none!important;
}

@media (max-width: 1024px) {
    .listaUser button {
        width: 80%; 
    }
}
@media (max-width: 520px) {
    .card-body {
        padding: 10px 15px;
    }
}


/*INSTITUCIONAL*/
.produtos {
    box-shadow: 0px 4px 10px 0px #b3939359;
    padding: 40px;
    height: 90%;
    max-height: 90%;
    transition: all ease 0.5s;
}
.produtos:hover {
    transform: scale(1.03);
    box-shadow: 0px 4px 10px 0px #74666688;
    cursor: pointer;
}
.produtos .img-fluid {
    max-width: 40%;
}
.inst-home-produtos {
    font-size: 18px;
    color: #8B8B8B;
    font-weight: 600;
    position: relative;
    text-align: center;
    font-family: "Asap Condensed", Arial;
    line-height: 20px;
    margin-bottom: 25px;
    text-align: center;
}
.bk-home {
    width: 100%;
    height: 100%;
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
}

#capa-institucional {
    display: block;
    height: 30em;
}

#capa-institucional .bk-institucional, #capa-institucional .bk-catalogo {
    width: 100%;
    height: 100%;
    background-size: cover;
    background-position: center;
    background-position-x: right;
    background-repeat: no-repeat;
}

#capa-institucional .bk-catalogo {
    background-position-x: center;
}

@media (max-width: 768px) {
    .produtos {
        padding: 25px;
    }
    #capa-institucional .bk-institucional {
        background-position-x: left;
        border-radius: 20px;
    }
}

@media (max-width: 520px) {
    .produtos {
        padding: 80px;
    }
    #capa-institucional .bk-catalogo {
        background-position-x: left;
    }
}

@media (max-width: 375px) {
    .produtos {
        padding: 50px;
    }
    #capa-institucional .bk-catalogo {
        background-position-x: center;
    }
}

/*CHECKBOX*/
.switch .inst-home-produtos {
    padding-left: 0.5rem;
}

.switch .switch-wrapper {
    display: inline-block;
    width: 60px;
    height: 34px;
    position: relative;
}
.switch .switch-wrapper .switch-button {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    display: flex;
    justify-content: space-between;
    align-items: center;
    border-radius: 40px;
    background-color: #BFBFBF;
}

.switch .switch-wrapper .switch-button::before {
    content: "";
    width: 26px;
    height: 26px;
    position: absolute;
    left: 4px;
    bottom: 4px;
    border-radius: 50%;
    transition: all ease 0.4s;
    background-color: #C30D18;
    cursor: pointer;
}

.switch .switch-wrapper input:checked + .switch-button {
    background-color: #C30D18;
}
.switch .switch-wrapper input:checked + .switch-button::before {
    transform: translateX(20px);
    background-color: #fff;
}

/*CAROUSEL*/
.login-txt {
    font-family: 'Asap Condensed' ,Arial;
    color: #fff;
    display: flex;
    align-items: center;
    text-transform: uppercase;
    font-size: 15px;
    padding: 0 10px;
    font-weight: 400;
    letter-spacing: 0.2px;
}


/*PROJETOS*/
.box-conteudo {
    width: 100%;
    height: 26em;
    overflow: hidden;
    margin-bottom: 2em;
    border-radius: 20px;
    transition: all 0.5s ease-in-out;
}
.galeria-projeto .box-conteudo {
    height: 15em;
    transition: all linear 10s;
}
.projetos-item {
    height: 100%;
    border-radius: 20px;
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    transition: all 0.5s ease-in-out;
}
.galeria-projeto .projetos-item {
    background-position: top;
    transition: all linear 10s;
}
.box-cliente.projetos-item {
    background-size: contain;
}
.box-conteudo:hover {
    -webkit-box-shadow: 0 0 30px 2px #8c8c8c;
    -moz-box-shadow: 0 0 30px 2px #8c8c8c;
    box-shadow: 0 0 30px 2px #8c8c8c;
}
.box-conteudo:hover .projetos-item {
    transform: scale(1.1);
}
.galeria-projeto .box-conteudo:hover .projetos-item {
    background-position: bottom;
}

@media (max-width: 1440px) {
    .box-conteudo {
        height: 20em;
    }
}
@media (max-width: 1024px) {
    .box-conteudo {
        height: 21em;
    }
}
@media (max-width: 768px) {
    .box-conteudo {
        height: 25em;
    }
}
@media (max-width: 375px) {
    .box-conteudo {
        height: 21em;
    }
}


/*TABELA DE PREï¿½OS*/
@import url(https://fonts.googleapis.com/css?family=Lato:400,100,100italic,300,300italic,400italic,700italic,700,900italic,900);
@import url(https://fonts.googleapis.com/css?family=Raleway:400,100,200,300,500,600,700,800,900);
@import url(https://fonts.googleapis.com/css?family=Raleway:400,100,200,300,500,600,700,800,900);

#generic_price_table{
  background-color: #f0eded;
}

/*PRICE COLOR CODE START*/
#generic_price_table .generic_content{
  background-color: #fff;
}

#generic_price_table .generic_content .generic_head_price{
  background-color: #f6f6f6;
}

#generic_price_table .generic_content .generic_head_price .generic_head_content .head_bg{
  border-color: #e4e4e4 rgba(0, 0, 0, 0) rgba(0, 0, 0, 0) #e4e4e4;
}

#generic_price_table .generic_content .generic_head_price .generic_head_content .head span{
  color: #525252;
}

#generic_price_table .generic_content .generic_head_price .generic_price_tag .price .sign{
    color: #414141;
}

#generic_price_table .generic_content .generic_head_price .generic_price_tag .price .currency{
    color: #414141;
}

#generic_price_table .generic_content .generic_head_price .generic_price_tag .price .cent{
    color: #414141;
}

#generic_price_table .generic_content .generic_head_price .generic_price_tag .month{
    color: #414141;
}

#generic_price_table .generic_content .generic_feature_list ul li{  
  color: #a7a7a7;
}

#generic_price_table .generic_content .generic_feature_list ul li span{
  color: #414141;
}
#generic_price_table .generic_content .generic_feature_list ul li:hover{
  background-color: #E4E4E4;
  border-left: 5px solid #500580;
}

#generic_price_table .generic_content .generic_price_btn a{
  border: 1px solid #500580; 
    color: #500580;
} 

#generic_price_table .generic_content.active .generic_head_price .generic_head_content .head_bg,
#generic_price_table .generic_content:hover .generic_head_price .generic_head_content .head_bg{
  border-color: #500580 rgba(0, 0, 0, 0) rgba(0, 0, 0, 0) #500580;
  color: #fff;
}

#generic_price_table .generic_content:hover .generic_head_price .generic_head_content .head span,
#generic_price_table .generic_content.active .generic_head_price .generic_head_content .head span{
  color: #fff;
}

#generic_price_table .generic_content:hover .generic_price_btn a,
#generic_price_table .generic_content.active .generic_price_btn a{
  background-color: #500580;
  color: #fff;
} 
#generic_price_table{
    font-family: 'Raleway', Arial;
}
.row .table{
    padding: 28px 0;
}

/*PRICE BODY CODE START*/

#generic_price_table .generic_content{
  overflow: hidden;
  position: relative;
  text-align: center;
}

#generic_price_table .generic_content .generic_head_price {
  margin: 0 0 20px 0;
}

#generic_price_table .generic_content .generic_head_price .generic_head_content{
  margin: 0 0 50px 0;
}

#generic_price_table .generic_content .generic_head_price .generic_head_content .head_bg{
    border-style: solid;
    border-width: 90px 1411px 23px 399px;
  position: absolute;
}

#generic_price_table .generic_content .generic_head_price .generic_head_content .head{
  padding-top: 40px;
  position: relative;
  z-index: 1;
}

#generic_price_table .generic_content .generic_head_price .generic_head_content .head span{
    font-family: "Raleway",Arial;
    font-size: 28px;
    font-weight: 400;
    letter-spacing: 2px;
    margin: 0;
    padding: 0;
    text-transform: uppercase;
}

#generic_price_table .generic_content .generic_head_price .generic_price_tag{
  padding: 0 0 20px;
}

#generic_price_table .generic_content .generic_head_price .generic_price_tag .price{
  display: block;
}

#generic_price_table .generic_content .generic_head_price .generic_price_tag .price .sign{
    display: inline-block;
    font-family: "Lato",Arial;
    font-size: 28px;
    font-weight: 400;
    vertical-align: middle;
}

#generic_price_table .generic_content .generic_head_price .generic_price_tag .price .currency{
    font-family: "Lato",Arial;
    font-size: 60px;
    font-weight: 300;
    letter-spacing: -2px;
    line-height: 60px;
    padding: 0;
    vertical-align: middle;
}

#generic_price_table .generic_content .generic_head_price .generic_price_tag .price .cent{
    display: inline-block;
    font-family: "Lato",Arial;
    font-size: 24px;
    font-weight: 400;
    vertical-align: bottom;
}

#generic_price_table .generic_content .generic_head_price .generic_price_tag .month{
    font-family: "Lato",Arial;
    font-size: 18px;
    font-weight: 400;
    letter-spacing: 3px;
    vertical-align: bottom;
}

#generic_price_table .generic_content .generic_feature_list ul{
  list-style: none;
  padding: 0;
  margin: 0;
}

#generic_price_table .generic_content .generic_feature_list ul li{
  font-family: "Lato",Arial;
  font-size: 18px;
  padding: 15px 0;
  transition: all 0.3s ease-in-out 0s;
}
#generic_price_table .generic_content .generic_feature_list ul li:hover{
  transition: all 0.3s ease-in-out 0s;
  -moz-transition: all 0.3s ease-in-out 0s;
  -ms-transition: all 0.3s ease-in-out 0s;
  -o-transition: all 0.3s ease-in-out 0s;
  -webkit-transition: all 0.3s ease-in-out 0s;

}
#generic_price_table .generic_content .generic_feature_list ul li .fa{
  padding: 0 10px;
}
#generic_price_table .generic_content .generic_price_btn{
  margin: 20px 0 32px;
}

#generic_price_table .generic_content .generic_price_btn a{
    border-radius: 50px;
  -moz-border-radius: 50px;
  -ms-border-radius: 50px;
  -o-border-radius: 50px;
  -webkit-border-radius: 50px;
    display: inline-block;
    font-family: "Lato",Arial;
    font-size: 18px;
    outline: medium none;
    padding: 12px 30px;
    text-decoration: none;
    text-transform: uppercase;
}

#generic_price_table .generic_content,
#generic_price_table .generic_content:hover,
#generic_price_table .generic_content .generic_head_price .generic_head_content .head_bg,
#generic_price_table .generic_content:hover .generic_head_price .generic_head_content .head_bg,
#generic_price_table .generic_content .generic_head_price .generic_head_content .head h2,
#generic_price_table .generic_content:hover .generic_head_price .generic_head_content .head h2,
#generic_price_table .generic_content .price,
#generic_price_table .generic_content:hover .price,
#generic_price_table .generic_content .generic_price_btn a,
#generic_price_table .generic_content:hover .generic_price_btn a{
  transition: all 0.3s ease-in-out 0s;
  -moz-transition: all 0.3s ease-in-out 0s;
  -ms-transition: all 0.3s ease-in-out 0s;
  -o-transition: all 0.3s ease-in-out 0s;
  -webkit-transition: all 0.3s ease-in-out 0s;
} 
@media (max-width: 375px) { 
}

@media (max-width: 767px) {
  #generic_price_table .generic_content{
    margin-bottom:75px;
  }
}
@media (min-width: 768px) and (max-width: 991px) {
  #generic_price_table .col-md-3{
    float:left;
    width:50%;
  }
  
  #generic_price_table .col-md-4{
    float:left;
    width:50%;
  }
  
  #generic_price_table .generic_content{
    margin-bottom:75px;
  }
}
@media (min-width: 992px) and (max-width: 1199px) {
}
@media (min-width: 1200px) {
}
#generic_price_table_home{
   font-family: 'Raleway', Arial;
}
.demo-pic{
  margin: 0 auto;
}
.demo-pic:hover{
  opacity: 0.7;
}

#generic_price_table_home ul{
  margin: 0 auto;
  padding: 0;
  list-style: none;
  display: table;
}
#generic_price_table_home li{
  float: left;
}
#generic_price_table_home li + li{
  margin-left: 10px;
  padding-bottom: 10px;
}
#generic_price_table_home li a{
  display: block;
  width: 50px;
  height: 50px;
  font-size: 0px;
}
#generic_price_table_home .blue{
  background: #3498DB;
  transition: all 0.3s ease-in-out 0s;
}
#generic_price_table_home .emerald{
  background: #500580;
  transition: all 0.3s ease-in-out 0s;
}
#generic_price_table_home .grey{
  background: #7F8C8D;
  transition: all 0.3s ease-in-out 0s;
}
#generic_price_table_home .midnight{
  background: #34495E;
  transition: all 0.3s ease-in-out 0s;
}
#generic_price_table_home .orange{
  background: #E67E22;
  transition: all 0.3s ease-in-out 0s;
}
#generic_price_table_home .purple{
  background: #9B59B6;
  transition: all 0.3s ease-in-out 0s;
}
#generic_price_table_home .red{
  background: #E74C3C;
  transition:all 0.3s ease-in-out 0s;
}
#generic_price_table_home .turquoise{
  background: #1ABC9C;
  transition: all 0.3s ease-in-out 0s;
}

#generic_price_table_home .blue:hover,
#generic_price_table_home .emerald:hover,
#generic_price_table_home .grey:hover,
#generic_price_table_home .midnight:hover,
#generic_price_table_home .orange:hover,
#generic_price_table_home .purple:hover,
#generic_price_table_home .red:hover,
#generic_price_table_home .turquoise:hover{
  border-bottom-left-radius: 50px;
    border-bottom-right-radius: 50px;
    border-top-left-radius: 50px;
    border-top-right-radius: 50px;
  transition: all 0.3s ease-in-out 0s;
}
#generic_price_table_home .divider{
  border-bottom: 1px solid #ddd;
  margin-bottom: 20px;
  padding: 20px;
}
#generic_price_table_home .divider span{
  width: 100%;
  display: table;
  height: 2px;
  background: #ddd;
  margin: 50px auto;
  line-height: 2px;
}
#generic_price_table_home .itemname{
  text-align: center;
  font-size: 50px ;
  padding: 50px 0 20px ;
  border-bottom: 1px solid #ddd;
  margin-bottom: 40px;
  text-decoration: none;
    font-weight: 300;
}
#generic_price_table_home .itemnametext{
    text-align: center;
    font-size: 20px;
    padding-top: 5px;
    text-transform: uppercase;
    display: inline-block;
}

.price-heading{
    text-align: center;
}
.price-heading h1{
  color: #666;
  margin: 0;
  padding: 0 0 50px 0;
}
.demo-button {
    background-color: #333333;
    color: #ffffff;
    display: table;
    font-size: 20px;
    margin-left: auto;
    margin-right: auto;
    margin-top: 20px;
    margin-bottom: 50px;
    outline-color: -moz-use-text-color;
    outline-style: none;
    outline-width: medium ;
    padding: 10px;
    text-align: center;
    text-transform: uppercase;
}
.bottom_btn{
  background-color: #333333;
    color: #ffffff;
    display: table;
    font-size: 28px;
    margin: 60px auto 20px;
    padding: 10px 25px;
    text-align: center;
    text-transform: uppercase;
}
.demo-button:hover{
  background-color: #666;
  color: #FFF;
  text-decoration:none;
  
}
.bottom_btn:hover{
  background-color: #666;
  color: #FFF;
  text-decoration:none;
}


/*ACCORDION*/
a:hover,a:focus{
    text-decoration: none;
    outline: none;
}
#accordion .panel{
    border: none;
    border-radius: 5px;
    box-shadow: none;
    margin-bottom: 10px;
    background: linear-gradient(to right, #500580,#C30D18);
}
#accordion .panel-heading{
    padding: 0;
    border: none;
    border-radius: 5px;
    background: transparent;
    position: relative;
}
#accordion .panel-title a{
    display: block;
    padding: 20px 30px;
    margin: 0;
    background: rgba(0,0,0,0.4);
    font-size: 17px;
    font-weight: bold;
    color: #fff;
    text-transform: uppercase;
    letter-spacing: 1px;
    border: none;
    border-radius: 5px;
    position: relative;
}
#accordion .panel-title a.collapsed{ border: none; }
#accordion .panel-title a:before,
#accordion .panel-title a.collapsed:before{
    content: "\f107";
    font-family: "Font Awesome 5 Free";
    width: 30px;
    height: 30px;
    line-height: 27px;
    text-align: center;
    font-size: 25px;
    font-weight: 900;
    color: #fff;
    position: absolute;
    top: 15px;
    right: 30px;
    transform: rotate(180deg);
    transition: all .4s cubic-bezier(0.080, 1.090, 0.320, 1.275);
}
#accordion .panel-title a.collapsed:before{
    color: rgba(255,255,255,0.5);
    transform: rotate(0deg);
}
#accordion .panel-body{
    padding: 20px 30px;
    background: rgba(0,0,0,0.1);
    font-size: 15px;
    color: #fff;
    line-height: 28px;
    letter-spacing: 1px;
    border-top: none;
    border-radius: 5px;
}

/*CTA*/
#cta .cta-conteudo {
    width: 100%;
    height: 100%;
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
}


/*COOKIES*/
.wrapper {
    position: fixed;
    bottom: 16px;
    left: -444px;
    max-width: 345px;
    width: 100%;
    background: #fff;
    border-radius: 8px;
    padding: 15px 25px 22px;
    transition: left ease 0.5s;
}

.wrapper.show {
    left: 16px;
    z-index: 5;
}
.wrapper header {
    display: flex;
    align-items: center;
    column-gap: 15px;
}

.wrapper header img {
    width: 10%;
}

.wrapper header h2 {
    font-size: 30px;
    color: #500580;
    font-weight: 500;
}

.wrapper .data {
    margin-top: 16px;
}

.wrapper .data p {
    color: #696969;
    font-size: 16px;
}

.wrapper .data p a {
    color: #500580;
    text-decoration: underline!important;
}
.wrapper .data p a:hover {
    text-decoration: none;
}

.wrapper .buttons {
    margin-top: 16px;
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: space-between;
}
.wrapper .buttons form {
    width: 100%;
}

.wrapper .buttons .button {
    border: none;
    color: #fff;
    padding: 8px 0;
    border-radius: 4px;
    background: #500580;
    cursor: pointer;
    width: 100%;
    /*width: calc(100% / 2 - 10px);*/
    transition: all ease 0.2s;
}
.wrapper .buttons .button:hover {
    background-color: #C30D18;
}

@media (max-width: 520px) {
    .wrapper.show {
        left: 65px;
    }
}
@media (max-width: 420px) {
    .wrapper.show {
        left: 35px;
    }
}
@media (max-width: 375px) {
    .wrapper.show {
        left: 5px;
    }
}

.fancybox-slide>* {
    width: 50em;
}

@media (max-width: 520px) {
    .fancybox-slide>* {
        width: 30em;
        bottom: 53em;
    }

    html:not(.no-js) [data-aos^=fade][data-aos^=fade], html:not(.no-js) [data-aos^=fade][data-aos^=fade].aos-animate {
        opacity: 1!important;
    }

    html:not(.no-js) [data-aos=fade-up] {
        transform: matrix(1, 0, 0, 1, 0, 0)!important;
    }
}

.erromsg{
    color: #f30;
}


/*------------------------------- PREMIAÇÃO -----------------------------------*/
#pesquisa .box-pesquisa {
    margin: 10px 0;
    padding: 35px 60px;
    border-radius: 0 30px 30px 0;
}
#pesquisa .box-pesquisa.vermelho-escuro {
    background: #630606;
}
#pesquisa .box-pesquisa.vermelho {
    background: #A0100F;
}
#pesquisa .box-pesquisa.preto {
    background: #000;
}
#pesquisa .header-titulo {
    font-size: 35px;
}
#pesquisa .destaque.inst-home-desc, #pesquisa .destaque.inst-home-desc p {
    text-align: center;
    margin-top: 0;
}
#pesquisa .box-pesquisa .inst-home-desc, #pesquisa .box-pesquisa .inst-home-desc p {
    color: #fff;
}

@media (max-width: 768px) {
    #pesquisa .box-pesquisa {
        padding: 60px;
    }
}


/* NEWSLETTER */
.newsletter {
  background-color: #a0100f;
  color: white;
  padding: 30px 0;
}

.newsletter .conteudo {
  margin: 0 auto; /* centraliza horizontalmente */
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  gap: 20px;
}

.newsletter-text h3 {
    margin: 0;
    font-size: 1.4rem;
    font-weight: bold;
}

.newsletter-text p {
    margin: 5px 0 0 0;
    font-size: 0.9rem;
    opacity: 0.9;
}

.newsletter-form {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
}

.newsletter-form input {
    border: none;
    border-radius: 6px;
    padding: 10px 12px;
    font-size: 0.9rem;
    outline: none;
    min-width: 300px;
    width: auto;
    background-color: #fff;
}

.newsletter-form button {
    background-color: #000;
    color: white;
    border: none;
    border-radius: 6px;
    padding: 10px 16px;
    cursor: pointer;
    font-weight: bold;
    transition: background 0.3s ease;
}

.newsletter-form button:hover {
    background-color: #333;
}

@media (max-width: 1024px) {
    .newsletter .conteudo {
        justify-content: center;
    }

    .newsletter .conteudo .newsletter-text {
        text-align: center;
    }

    .newsletter-form {
        justify-content: center;
    }
}

@media (max-width: 768px) {
    .newsletter-form input {
        min-width: 250px;
    }
}

@media (max-width: 425px) {
    .newsletter-form input {
        min-width: 100%;
    }
}

/* CHAMADA HOME */
.bold {
    font-weight: 900;
}

/* Overlay com imagem + blur + granulado */
.txt-destaque {
    font-weight: 900;
}

.overlay-destaque {
    position: relative;
    background-size: cover!important;
    min-height: 100vh;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    text-align: center;
    padding: 4rem 1rem;
    overflow: hidden;
    color: #fff;
}

.overlay-destaque > .container {
    position: relative;
    z-index: 2; /* Faz o conteúdo ficar acima do ::before e ::after */
    max-width: 900px;
}

/* Camada de blur por cima do background */
.overlay-destaque::before {
    content: "";
    position: absolute;
    inset: 0;
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    z-index: 0;
}

/* Granulado via base64 */
.overlay-destaque::after {
    content: "";
    position: absolute;
    inset: 0;
    background-image: url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAEAAAAAQCAYAAAB49O97AAAACXBIWXMAAAsTAAALEwEAmpwYAAAARklEQVR4nO3SsQkAIAxE0dX/f+qFWlHgNi9kTsyRljxvgI0rEQAQIECAAAECBAgQIECAAAECBAjwjTMEjKJpdznzhnwAglFL9Ssy5bUAAAAASUVORK5CYII=");
    opacity: 0.15;
    mix-blend-mode: overlay;
    z-index: 1;
}

.overlay-destaque h1 {
    font-size: clamp(2rem, 4vw, 3rem);
    margin-bottom: 1.5rem;
    line-height: 1.2;
}

.overlay-destaque h4 {
    font-size: clamp(1.5rem, 2vw, 1rem);
    margin-bottom: 1.5rem;
    line-height: 1.2;
    font-weight: 900;
}

.overlay-destaque p {
    font-size: 1.1rem;
    line-height: 1.6;
    margin-bottom: 1rem;
}

.highlight {
    color: #BA1C1C;
}

.info-card {
    height: 100%;
    display: flex;
    flex-direction: column;
    justify-content: center;
    background: rgba(255, 255, 255, 0.05);
    color: #fff;
    backdrop-filter: blur(6px);
    border-radius: 1rem;
    padding: 1.5rem;
    text-align: center;
    border: 1px solid #ffffff1f;
    transition: all 0.3s ease-in-out;
}

.info-card:hover {
    background: rgba(255, 255, 255, 0.15);
    transform: translateY(-5px);
}

.info-icon {
    width: 50px;
    height: 50px;
    background: #BA1C1C;
    padding: 15px;
    border-radius: 50%;
    margin: 0 auto;
}

.cta-box {
    background: rgba(255, 255, 255, 0.05);
    color: #fff;
    backdrop-filter: blur(6px);
    border-radius: 1rem;
    padding: 2rem;
    margin-top: 3rem;
    border: 1px solid #ffffff1f;
}

.btn-danger {
    background-color: #BA1C1C;
    border: none;
    border-radius: 50px;
    padding: 0.7rem 1.5rem;
    font-weight: bold;
}

.btn-outline-light {
    border-radius: 50px;
    padding: 0.7rem 1.5rem;
    font-weight: bold;
}

.contact-info {
    margin-top: 1rem;
    font-size: 0.9rem;
    color: #ccc;
    gap: 50px;
}

.contact-info .bi {
    color: #BA1C1C;
}

@media (max-width: 425px) {
    .info-card {
        height: auto;
        margin-bottom: 30px;
    }

    .contact-info {
        gap: 10px;
    }
}


/* DESTAQUE */
#destaque .box-conteudo {
    height: 430px;
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    border-radius: 30px;
    margin: 1em 0;
}

@media (max-width: 1024px) {
    #destaque .box-conteudo {
        height: 300px;
    }
}

@media (max-width: 768px) {
    #destaque .box-conteudo {
        height: 230px;
    }
}

@media (max-width: 425px) {
    #destaque .box-conteudo {
        height: 300px;
    }
}

/* RODAPÉ STEAC */
.logo-steac {
    text-align: center;
}

.logo-steac span, .logo-steac a {
    color: #fff;
}

.logo-steac img {
    margin: 10px;
    width: 3em;
    transition: all ease 0.5s;
    opacity: 0.5;
}

.logo-steac span {
    opacity: 0.5;
    transition: all ease 0.5s;
}

/* --- Efeitos de Hover --- */

/* 1. Hover no container geral ? destaque no texto */
.logo-steac:hover span {
    opacity: 1;
}

/* 2. Hover no link de TEXTO "Steactech" ? destaque na IMAGEM */
.logo-steac a[href="https://steactech.com.br"]:hover + br + a img {
    opacity: 1;
}

/* 3. Hover na IMAGEM ? destaque nela mesma */
.logo-steac a:hover img {
    opacity: 1;
}