*{
  font-family: "DM Sans", sans-serif;
  font-optical-sizing: auto;
  color: #3f3f3f;
}
p{
    margin-bottom: 0;
    font-size: 16px;
}
a{
    text-decoration: none;
    color: inherit;
}
a:hover{
    text-decoration: none!important;
    color: inherit;
}
a:active{
    color: inherit;
}
h1, h2, h3, h4, h5, h6{
    letter-spacing: 0;
}
h1{
    margin-bottom: 0;
}
h3{
    text-transform: none;
    margin-bottom: 0;
}
button {
    background-color:#fff;
	border: none;
	outline: none;
	padding: 8px 20px 8px 20px;
	margin: 0px 5px !important;
    font-weight: 500;
    font-size: 16px;
    border-radius: 8px;
    transition: ease-in-out .3s;
}
button:hover{
    background-color:#e4e4e4;
}
button.border:hover{
    background-color: #e4e4e4;
    border:1px solid #3f3f3f !important;
}
button.border{
    background-color: #fff;
    border:1px solid #3f3f3f !important;
    transition: ease-in-out .3s;
}
button.border:hover{
    background-color: #e4e4e4;
    border:1px solid #3f3f3f !important;
}
button.square{
    border-radius: 8px;
    border: 1px solid #3f3f3f;
}
button.red{
    background-color: #C20A12;
    color: #fff;
    border-radius: 8px;
    transition: ease-in-out .3s;
}
button.red:hover{
    background-color: #ff1521;

}
.button-icon{
    margin: -3px 10px 0 0;
}

button a:hover{

    background-color: #dedede;
}
.contact-whats{
    position: fixed;
    bottom: 25px;
    right: 25px;
    width: 60px;
    height: 60px;
    z-index: 1000;
}
.whats-button{
    background-color: #189d0e;
    width: 60px;
    height: 60px;
    padding: 9px;
    border-radius: 50%;
    transition: ease-in-out .3s;
}
.whats-button:hover{
    background-color: #1cb811;
}

/* Lightbox */
.lightbox {
  display: none;
  position: fixed;
  z-index: 9999;
  top: 0; left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0,0,0,0.9);
  justify-content: center;
  align-items: center;
}

.lightbox.show {
  display: flex;
}

.lightbox img.lightbox-image {
  max-width: 90%;
  max-height: 80%;
  border-radius: 10px;
}

/* Botão fechar */
.lightbox-close {
  position: absolute;
  top: 20px;
  right: 30px;
  color: white;
  font-size: 40px;
  cursor: pointer;
  user-select: none;
}

/* Setas */
.lightbox-arrow {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  background: rgba(255,255,255,0.2);
  border: none;
  color: white;
  font-size: 40px;
  cursor: pointer;
  border-radius: 50%;
  padding: 10px 13px;
  transition: background 0.3s;
}

.lightbox-arrow.left { left: 30px; }
.lightbox-arrow.right { right: 30px; }

.lightbox-arrow:hover { background: rgba(255,255,255,0.5); }


/* Header */
.header-wrapper{
	position: fixed;
    top: 0;
	width: 100%;
	z-index: 99;
    display: flex;
    flex-direction: column;
    justify-content:center;
    align-items: center;
    background-color: rgb(255, 255, 255);
    box-shadow: 0 3px 5px rgba(0, 0, 0, 0.1);
    transition: all ease-in-out 0.4s;
}
.info{
    background-color: #3f3f3f;
    width: 100%;
    height: 45px;
    color: #999999;
    display: flex;
    justify-content: flex-start;
    align-items: center;
}
.info a p{
    color: #999999;
}
.info a p:hover{
    color: #fff;
    transition: .3s ease-in-out;
}
a:hover .icon-mail {
  filter: brightness(0) invert(0.8);
}
.info a:hover img {
  filter: brightness(0) invert(0.8);
  transition: .3s ease-in-out;
}
.info-wrapper{
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 0 10px;
}
.info-left{
    display: flex;
    justify-content: flex-start;
    align-items: center;
}
.icon-mail {
    margin-top: 3px;
    height: 18px !important;
    width: auto !important;
}
.resize{
    background-color:plum;
    padding: 7px 0;
}
.wrapper{
    width: 100%;
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 5px 0;
}
.logo{
    width: 100px;
    transition: all ease-in-out 0.4s;
}
.resize_logo{
    width: 90px;
}
.nav{
    width: auto;
}
.nav-link{
    color:#1e1e1e;
    text-transform: uppercase;
    border-bottom: 3px solid;
    border-color: rgba(0,113,188, 0);
    transition: all ease-in-out 0.4s;
}
.nav-link:hover{
    color: #c20A12;
    border-bottom: 3px solid ;
    border-color: #c20A12;
    text-decoration: none!important;
}
.active{
    color: #92070e;
}
.navbar-collapse {
    position: relative;
    left: 0;
    width:100%;
    overflow-y: none;
    visibility: auto;
    background-color: rgba(0, 0, 0, 0);
    transition: visibility .3s ease-in-out, -webkit-transform .3s ease-in-out;
}
.navbar-collapse{
    visibility: visible;
    transform: translateX(0%);
}
.topmenu, .close{
    display: none;
}
.navbar-expand-lg .navbar-nav .nav-link {
    padding: 4px 0;
}
.navbar-nav li{
    margin: 0px 10px;
}

/* Webdoor */
#carouselwebdoor {
    width: 100%;
    height: 675px;
    position: relative;
    padding-top: 120px;
}

.carousel-inner,
.carousel-item {
    height: 100%;
}

/* Container dos indicators */
#carouselwebdoor .carousel-indicators {
    position: relative;
    padding-left: 15px; /* dentro da largura do container */
    width: 100%;
    margin: -55px 0 0 0 ;
    display: flex;
    justify-content: flex-start; /* alinha à esquerda */
    z-index: 5;
}

/* Cada indicador */
#carouselwebdoor .carousel-indicators button {
    width: 12px;
    height: 12px;
    border-radius: 50%; /* deixa redondo */
    background-color: rgba(255,255,255,0.5); /* cor padrão */
    border: none;
    margin-right: 8px; /* espaçamento entre eles */
    transition: background-color 0.3s;
}

/* Indicador ativo */
#carouselwebdoor .carousel-indicators .active {
    background-color: #ffb6b8; /* cor do ativo */
}

.carousel-bg {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center center;
}

/* Overlay */
.blend-overlay {
    position: absolute;
    top: 0;
    left: 0;
    width: 50%;
    height: 100%;
    background: #C61A21;
    mix-blend-mode: multiply;
    clip-path: polygon(0 0, 100% 0%, 75% 100%, 0% 100%);
    z-index: 2;
}

/* Conteúdo verticalmente centralizado, mas alinhado à esquerda dentro da container */
.carousel-caption {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 5;
    display: flex;
    align-items: center; /* centraliza verticalmente */
    text-align: left;
}

.carousel-caption .container {
    max-width: 1140px; /* largura do Bootstrap container */
}
.caption-wrapper{
    width: 420px;
    height: 410px;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    align-items: flex-start;
}

.carousel-caption h2 {
    font-size: 56px;
    font-weight: 700;
    line-height: 1.05;
    color: #fff;
    margin-bottom: 10px;
}
.carousel-caption p{
    color: #fff;
}
.carousel-caption .btn {
    padding: 12px 30px;
    font-size: 18px;
    background: #fff;
    color: #C61A21;
    border: none;
    border-radius: 4px;
    text-decoration: none;
}

.carousel-caption .btn:hover {
    background: #C61A21;
    color: #fff;
}


/* Liderança */
.lideranca{
    position: relative;
    background-color: #ededed;
    width: 100%;
    height: 620px;
    padding: 80px 0;
    color: #3f3f3f;
    display: flex;
    justify-content: center;
    align-items: center;
}
.liderança-wrapper{
    position: absolute;
    z-index: 10;

}
.lideranca h2{
    font-size: 24px;
    font-weight: 700;
    color: #3f3f3f;
}

.lideranca h1{
    font-size: 45px;
    font-weight: 700;
    color: #3f3f3f;
    line-height: 47px;
}

/* Services */
.services{
    width: 100%;
    padding: 60px 0;
    color: #3f3f3f;
    display: flex;
    justify-content: center;
    align-items: center;
    flex-direction: column;
}

.services h2{
    font-size: 36px;
    font-weight: 700;
    color: #3f3f3f;
    margin-bottom: 50px;
}

.services-box{
    width: 100%;
    min-height: auto;
    border: 1px solid #3f3f3f;
    border-radius: 16px;
    display: flex;
    justify-content: start;
    align-items: center;
    flex-direction: column;
}
.box-photo {
  width: 100%;          
  height: 260px;       
  overflow: hidden;    
  border-top-left-radius: 16px;
  border-top-right-radius: 16px;
  position: relative;  
}
.box-photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;   
  object-position: center;
  display: block;     
}
.box-title{
    padding: 25px;
}
.box-title h3{
    font-size: 20px;
    font-weight: 700;
    color: #3f3f3f;
    text-align: center;
}
.services-buttons{
    padding-top: 50px;
    display: flex;
    justify-content: center;
    align-items: center;
}

/* Indicadores do Owl Carousel */
.services-carousel .owl-dots {
  text-align: center;
  margin-top: 10px;
}

.services-carousel .owl-dot{
  width: 12px;
  height: 12px;
  margin: 0 6px;
  background-color: #ccc !important;
  opacity: 1 !important;
  border-radius: 50%;
}

.services-carousel .owl-dot span{
  opacity: 0;
}

.services-carousel .owl-dot.active {
  background: #C61A21 !important;
}
.services-carousel .owl-dot.active span {
   opacity: 0;
}


/* Segments */
.segments{
    padding: 60px 0;
    background-color: #ebebeb;
}
.segments h2{
    font-size: 36px;
    font-weight: 700;
    color: #3f3f3f;
    text-align: center;
    margin-bottom: 50px;
}
.segments-box{
    background-color: #fff;
    display: flex;
    justify-content: center;
    align-items: center;
    flex-direction: column;
    padding: 30px 0;
    border-radius: 16px;
    margin: 12px 0;
    text-align: center;
    max-height: 140px;
}
.segments-box img{
    width: 40px;
}
.segments-box:hover{
    box-shadow: 0 6px 15px rgba(0, 0, 0, 0.2);
}
.segments-box img {
  transition: filter 0.3s ease-in-out;
  filter: brightness(0) saturate(100%) invert(60%) sepia(0%) saturate(0%) brightness(90%) contrast(85%);
}

.segments-box:hover img {
  filter: brightness(0) saturate(100%) invert(18%) sepia(86%) saturate(6010%) brightness(90%) contrast(98%);
}
.segments.red,
.segments.red * {
    background-color: #C20A12;
    color: #fff;
}
.segments-box h3, .escolha-box h3, .certificacao-box h3{
    font-size: 18px;
    font-weight: 700;
    color: #3f3f3f;
    margin-top: 15px;
}
.segments-dots, .escolha-dots, .certificacao-dots{
  text-align: center;
  margin-top: 15px;
}

.segments-dots .owl-dot, .escolha-dots .owl-dot, .certificacao-dots .owl-dot {
    display: inline-block;
    width: 12px;         /* largura fixa */
    height: 12px;        /* altura fixa igual à largura */
    margin: 0 5px;
    background-color: #ccc;
    border-radius: 50%;  /* garante círculo perfeito */
    cursor: pointer;
    transition: background-color 0.3s;
    padding: 0 !important; /* remove qualquer padding interno do Owl */
}

.segments-dots .owl-dot.active, .escolha-dots .owl-dot.active, .certificacao-dots .owl-dot.active {
    background-color: #C61A21; /* mesma cor do carousel de services */
}

.segments .owl-carousel .owl-item img, .escolha .owl-carousel .owl-item img, .certificacao .owl-carousel .owl-item img {
    display: block;
    width: auto;
}


/* Contact */
.contact{
    background: #F5151E;
    background: radial-gradient(circle,rgba(245, 21, 30, 1) 0%, rgba(152, 15, 21, 1) 50%);
    height: 300px;
}
.contact h3{
    font-size: 36px;
    font-weight: 700;
    color: #fff;
}
.contact p{
    color: #fff;
}

.contact img{
    margin-top: -42px;
}

/* Clients */
.clients-title{
    text-align: center;
    display: flex;
    justify-content: center;
    flex-direction: column;
    align-items: center;
}
.clients-title h2{
    font-size: 36px;
    font-weight: 700;
    color: #3f3f3f;
    text-align: center;
    margin-bottom: 0px;
}
.clients-title p{
    width: 450px;
}
.clients-box{
    background-color: #fff;
    display: flex;
    justify-content: center;
    align-items: center;
    flex-direction: column;
    padding: 30px 0;
    border-radius: 16px;
    margin: 12px 0;
    height: 100px;
}
.clients-box img{
    max-width: 85%;
}
.clients-dots {
    text-align: center;
    margin-top: 15px;
}

.clients-dots .owl-dot {
    display: inline-block;
    width: 12px;         /* largura fixa */
    height: 12px;        /* altura fixa igual à largura */
    margin: 0 5px;
    background-color: #ccc;
    border-radius: 50%;  /* garante círculo perfeito */
    cursor: pointer;
    transition: background-color 0.3s;
    padding: 0 !important; /* remove qualquer padding interno do Owl */
}

.clients-dots .owl-dot.active {
    background: #C61A21; /* sua cor de destaque */
}


/* Footer */
footer{
    padding: 50px 0;
}
.footer-left{
    display: flex;
    justify-content: start;
    align-items: flex-start;
}
.footer-left h2, .footer-right h2{
    font-size: 16px;
    font-weight: 700;
    text-transform: uppercase;
    color: #C20A12;
    margin-bottom: 10px;
}
.footer-left ul{
    list-style-type: none;
    padding-left: 0;
}
.footer-left ul li{
    padding: 4px 0;
}
.footer-left ul li a {
    color: inherit;
    text-decoration: none;
    transition: color 0.3s ease;
    font-size: 16px;
}
.footer-left ul li a:hover {
    color: #c20A12;
}
.footer-right .brand{
    display: flex;
    justify-content: flex-start;
    align-items: start;
    margin-left: -10px;
}
.footer-right .social-media{
    display: flex;
    justify-content: flex-start;
    align-items: center;
}
.footer-right .social-media h2{
    margin: 5px 10px 0 0;
}
.footer-right .social-media img {
    height: 22px;
    margin-right: 10px;
    transition: filter 0.3s ease; 
}
.footer-right .social-media img:hover {
    filter: brightness(0.6); 
}

.selo-certificacao{
    width: 120px;
}
.copyright{
    width: 100%;
    height: 50px;
    background-color: #8f8f8f;
    display: flex;
    justify-content: flex-start;
    align-items: center;
}
.copyright small{
    color: #fff;
    font-size: 0.875em;
}
.copyright p{
    line-height: 18px;
    padding: 0 30px;
}

/* Empresa */
.topo {
  position: relative;
  width: 100%;
  height: 250px;
  overflow: hidden;
  margin-top: 122px;
}

.topo-picture,
.topo-img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover; /* cobre todo o topo sem distorcer */
  object-position: center center;
  z-index: 1;
}

.blend-overlay-topo {
  position: absolute;
  width: 50%;
  inset: 0;
  background: #C61A21;
  mix-blend-mode: multiply;
  clip-path: polygon(0 0, 100% 0%, 75% 100%, 0% 100%);
  z-index: 2;
}

.topo-title {
  position: relative;
  height: 250px;
  z-index: 3;
  color: #fff;
  text-transform: uppercase;
  font-size: 38px;
  font-weight: 700;
  display: flex;
  justify-content: flex-start;
  align-items: center;
}


/* Sobre */
.sobre{
    padding: 80px 0;
}
.sobre-title{
    text-align: center;
    display: flex;
    justify-content: center;
    align-items: center;
    margin-bottom: 50px;
}
.sobre-title h1{
    width: 63%;
    font-size: 38px;
    font-weight: 700;
}
.sobre-text h2{
    font-size: 24px;
    font-weight: 700;
    margin-bottom: 20px;
}

/* Carrosel Empresa */
.carousel-container {
	width: 100%;
	max-width: 1200px;
	height: 450px;
	position: relative;
	perspective: 1000px;
	margin-top: 80px;
}

.carousel-track {
	width: 100%;
	height: 100%;
	display: flex;
	justify-content: center;
	align-items: center;
	position: relative;
	transform-style: preserve-3d;
	transition: transform 0.8s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

.card-photo {
	position: absolute;
	width: 280px;
	height: 380px;
	background: white;
	border-radius: 20px;
	overflow: hidden;
	box-shadow: 0 20px 40px rgba(0, 0, 0, 0.15);
	transition: all 0.8s cubic-bezier(0.25, 0.46, 0.45, 0.94);
	cursor: pointer;
}

.card-photo img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: all 0.8s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

.card-photo.center {
	z-index: 10;
	transform: scale(1.1) translateZ(0);
}

.card-photo.center img {
	filter: none;
}

.card-photo.left-2 {
	z-index: 1;
	transform: translateX(-340px) scale(0.8) translateZ(-450px);
	opacity: 0.7;
}

.card-photo.left-2 img {
	filter: grayscale(100%);
}

.card-photo.left-1 {
	z-index: 5;
	transform: translateX(-170px) scale(0.9) translateZ(-100px);
	opacity: 0.9;
}

.card-photo.left-1 img {
	filter: grayscale(100%);
}

.card-photo.right-1 {
	z-index: 5;
	transform: translateX(170px) scale(0.9) translateZ(-100px);
	opacity: 0.9;
}

.card-photo.right-1 img {
	filter: grayscale(100%);
}

.card-photo.right-2 {
	z-index: 1;
	transform: translateX(340px) scale(0.8) translateZ(-450px);
	opacity: 0.7;
}

.card-photo.right-2 img {
	filter: grayscale(100%);
}

.card-photo.hidden {
	opacity: 0;
	pointer-events: none;
}

.dots {
	display: flex;
	justify-content: center;
	gap: 7px;
	margin-top: 60px;
}

.dot {
	min-width: 12px;
	height: 12px;
	border-radius: 50%;
	background: rgba(178, 56, 51, 0.2);
	cursor: pointer;
	transition: all 0.3s ease;
}

.dot.active {
	background:#c20A12;
	transform: scale(1.2);
}

.nav-arrow {
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	background: rgba(8, 42, 123, 0.6);
	color: white;
	width: 40px;
	height: 40px;
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	cursor: pointer;
	z-index: 20;
	transition: all 0.3s ease;
	font-size: 1.5rem;
	border: none;
	outline: none;
	padding-bottom: 4px;
}

.nav-arrow:hover {
	background: rgba(0, 0, 0, 0.8);
	transform: translateY(-50%) scale(1.1);
}

.nav-arrow.left {
	left: 20px;
	padding-right: 3px;
}

.nav-arrow.right {
	right: 20px;
	padding-left: 3px;
}

/* Escolha */
.escolha-text{
    text-align: center;
    display: flex;
    justify-content: center;
    align-items: center;
    margin-bottom: 30px;
}
.escolha-box{
    min-height: 300px;
    background-color: #fff;
    display: flex;
    justify-content: center;
    align-items: center;
    flex-direction: column;
    padding: 30px 26px;
    border-radius: 16px;
    margin: 12px 0;
    text-align: center;
    transition: .3s ease-in-out;
}
.escolha-box:hover{
    box-shadow: 0 6px 15px rgba(0, 0, 0, 0.2);
}

.escolha-box img {
  transition: filter 0.3s ease-in-out;
  filter: brightness(0) saturate(100%) invert(60%) sepia(0%) saturate(0%) brightness(90%) contrast(85%);
}

.escolha-box:hover img{
  filter: brightness(0) saturate(100%) invert(18%) sepia(86%) saturate(6010%) brightness(90%) contrast(98%);
}

.escolha-box p, .certificacao-box p{
    margin-top: 12px;
    line-height: 22px;
}

/* Servicos */
.todos-servicos-title{
    display: flex;
    justify-content: center;
    align-items: center;
}
.todos-servicos-title h1{
    width: 70%;
    font-size: 36px;
    font-weight: 700;
    color: #3f3f3f;
    text-align: center;
    margin-bottom: 50px;
}

/* Todos Serviços */
.response-title{
    font-size: 18px;
    margin-bottom: 20px;
}

/* Tipos de Serviços */
.tipos{
    padding: 80px 0; 
}

.tipos-title h2{
    font-size: 38px;
    font-weight: 700;
}
.tipos-box{
    border: 1px solid #3f3f3f;
    border-radius: 16px;
    padding: 40px;
}
.tipos-box-title{
    display: flex;
    justify-content: start;
    align-items: center;
    margin-bottom: 25px;
}
.tipos-box-title h3{
    font-size: 18px;
    margin-left: 10px;
}
.certificacao-box{
    min-height: 300px;
    background-color: #fff;
    display: flex;
    justify-content: start;
    align-items: center;
    flex-direction: column;
    padding: 30px 30px;
    border-radius: 16px;
    margin: 12px 0;
    text-align: center;
    transition: .3s ease-in-out;
}
.certificacao-box:hover{
    box-shadow: 0 6px 15px rgba(0, 0, 0, 0.2);
}

/* Contatos */
.contacts{
    width: 100%;
    height: 670px;
    background-image: url(../images/contact-photo.jpg);
    background-position: center center;
    background-repeat: no-repeat;
    background-size: cover;
    padding: 80px 0;
}
.contacts a{
    text-decoration: none!important;
    font-size: 16px;
}
.contacts h1{
    color: #fff!important;
    font-size: 32px;
    font-weight: 700;
    line-height: 34px;
}
.contacts p, .contacts a{
    color: #fff;
}
.address{
    width: 375px;
    display: flex;
    justify-content: flex-start;
    align-items: flex-start;
}
.contacts-box{
    background-color: #fff;
    padding: 20px;
    border-radius: 16px;
}
.gray-form{
    background-color: #f9f9f9;
}

/* Formulário */
form label.form-label {
    font-size: 0.9rem;
    color: #333;
    letter-spacing: 0.3px;
    margin-bottom: 3px;
    padding-left: 15px;
}
select.form-select {
    color: #788088; 
    font-size: 0.85rem;
}
select.form-select option {
    color: #000;
}
select.form-select option[disabled] {
    color: #6c757d;
}
.btn-enviar {
    background-color: #C61A21;
    border: none;
    color: #fff;
}
.btn-enviar:hover {
    background-color: #a4151b;
    color: #efd4d4;
}
#resultado-form, #resultado-vagas{
    text-align: center;
}
.box-sucesso {
    background: #017730;
    color: #fff;
    border: 1px solid #017730;
    padding: 12px 16px;
    border-radius: 6px;
    margin-top: 15px;
    font-weight: 900;
}
.box-erro {
    background: #ffcccc;
    color: #ff0000;
    border: 1px solid #ffcccc;
    padding: 12px 16px;
    border-radius: 6px;
    margin-top: 15px;
    font-weight: 700;
}
.grecaptcha-badge {
    visibility: hidden;
}

/* Normas */
.normas{
    padding-top: 180px;
    padding-bottom: 60px;
    border-bottom: 2px solid #d1d1d1 ;
}
.normas h1{
    font-size: 38px;
    font-weight: 700;
    margin-bottom: 15px;
}

.normas h2{
    font-size: 18px;
    font-weight: 700;
    margin: 30px 0 15px;
}
.normas p{
    color: #3f3f3f;
}
.normas ul li{
    font-size: 16px;
}
.accordion.accordion-modern-status > .card .card-header a {
    font-size: 18px;
    padding-right: 50px;
}

/*X-Large devices (large desktops, less than 1400px)*/
@media (max-width: 1399.98px) {
  
}
/*Large devices (desktops, less than 1200px)*/
@media (max-width: 1199.98px) {
    .services-box {
        min-height: 385px;
    }
    .contact {
        height: 250px;
    }
    .contact img {
        margin-top: -35px;
    }
    .contact h3 {
        font-size: 27px;
    }
    .carousel-container {
        margin-top: 0px;
    }
    .card-photo.left-2 {
        transform: translateX(-255px) scale(0.8) translateZ(-450px);
    }
    .card-photo.left-1 {
        transform: translateX(-150px) scale(0.9) translateZ(-100px);
    }
    .card-photo.right-1 {
        transform: translateX(150px) scale(0.9) translateZ(-100px);
    }
    .card-photo.right-2 {
        transform: translateX(255px) scale(0.8) translateZ(-450px);
    }
    .escolha-box {
        min-height: 360px;
    }
    .todos-servicos-title h1 {
        width: 100%;
    }
    .carousel-caption .container{
        padding: 50px 50px;
    }
    .lideranca {
        height: 760px;
    }
    
}
/*Medium devices (tablets, less than 992px)*/
@media (max-width: 991.98px) {
     h1{
        font-size: 25px!important;
        line-height: 27px!important;
    }
    h2{
        font-size: 20px!important;
        line-height: 22px!important;
    }
    .wrapper{
        width: 96vw;
        display: flex;
        justify-content: space-between;
        align-items: center;
    }
    .logo{
        width: 180px;
        padding-top: 4px;
    }
    .navbar-nav{
        margin-top: 15px;
    }
    .navbar-toggler {
        position: fixed;
        right: 15px;
        top: 10px;
        padding: 4px;
    }
    .navbar-collapse {
        position: fixed;
        top:0; 
        bottom: 0;
        left: -281px;
        width: 280px;
        overflow-y: auto;
        visibility: hidden;
        background-color: rgba(0, 0, 0, .7);
        transition: visibility .3s ease-in-out, -webkit-transform .3s ease-in-out;
    }
    .navbar-collapse.show {
        visibility: visible;
        transform: translateX(100%);
        z-index: 99;
    }
    .nav-link{
        width: auto;
        padding:15px 5px!important;
        margin-left: 20px;
        color: #fff !important;
        border-bottom: unset;
        border-color: unset;
        font-size: 16px;
        transition: all ease-in-out 0.4s;
    }
    .nav-link:hover{
        color: #fff !important;
        border-bottom: unset;
        border-color:unset;
    }
    .active{
        color: blue;
    }
    .topmenu{
        display: block;
    }
    .close{
        display: block;
        position: absolute;
        top: 20px;
        right: 20px;
        width: 30px;
        height: 30px;
        z-index: 100;
        padding: 0px 0 0 0;
        color: rgba(48, 48, 48, 0.6);
        border-radius: 50%;
    }  
    .logo {
        width: 90px;
        padding-top: 0px;
    }
    .navbar-toggler {
        top: 60px;
    }
    .services-box {
        min-height: 365px;
    }
    .box-title h3 {
        font-size: 19px;
    }
    #carouselwebdoor {
        height: 550px;
        padding-top: 116px;
    }
    .blend-overlay {
        top: auto;
        bottom: 0;
        width: 100%;
        height: 30%;
        clip-path: polygon(0 0, 100% 0%, 100% 100%, 0% 100%);
    }
    .carousel-caption h2{
        font-size: 40px!important;
        line-height: 41px!important;
        margin-bottom: 15px;
        margin-top: 290px;
    }
    #carouselwebdoor .carousel-indicators {
        margin: -45px 0 0 0;
    }
    .contact {
        height: 250px;
    }
    .contact img {
        margin-top: -15px;
    }
    .contact h3 {
        font-size: 27px;
    }
    .carousel-container {
        margin-top: 50px;
    }
    .card-photo.left-2 {
        transform: translateX(-320px) scale(0.8) translateZ(-450px);
    }
    .card-photo.left-1 {
        transform: translateX(-180px) scale(0.9) translateZ(-100px);
    }
    .card-photo.right-1 {
        transform: translateX(180px) scale(0.9) translateZ(-100px);
    }
    .card-photo.right-2 {
        transform: translateX(320px) scale(0.8) translateZ(-450px);
    }
    .escolha-box {
        min-height: 320px;
    }
    .certificacao-box {
        min-height: 220px;
    }
    .contacts {
        height: auto;
        padding: 60px 80px;
        background-color: rgba(0, 0, 0, 0.7);
        background-blend-mode: darken;
    }
    .topo {
        height: 88px;
        margin-top: 115px;
    }
    .topo-title {
        height: 88px;
    }
    .caption-wrapper{
        width: 90%;
        height: 435px;
    }
    .blend-overlay {
        height: 38%;
    }
    .carousel-caption h2{
        margin-bottom: 5px;
    }
    .lideranca {
        height: 720px;
    }
    .lideranca h1{
        min-height: 35px;
    }
    
}
/*Small devices (landscape phones, less than 768px)*/
@media (max-width: 767.98px) {
   
    .about-title {
		font-size: 4.5rem;
	}
	.card-photo {
		width: 200px;
		height: 280px;
	}
	.card-photo.left-2 {
		transform: translateX(-250px) scale(0.8) translateZ(-300px);
	}
	.card-photo.left-1 {
		transform: translateX(-120px) scale(0.9) translateZ(-100px);
	}
	.card-photo.right-1 {
		transform: translateX(120px) scale(0.9) translateZ(-100px);
	}
	.card-photo.right-2 {
		transform: translateX(250px) scale(0.8) translateZ(-300px);
	}
    .info{
        display: none;
    } 
     .navbar-toggler {
        top: 15px;
    }
    .contact{
        text-align: center;
        padding: 40px 30px 0px 30px;
        height: auto;
    }
     .contact img {
        margin-top: 15px;
    }
    .footer-menu{
        display: none;
    }
    .contacts {
        height: auto;
        padding: 40px 20px;
    }
    #carouselwebdoor {
        height: 505px;
        padding-top: 69px;
    }
    .carousel-caption .container {
        padding: 50px 30px;
    }
    .carousel-caption h2 {
        font-size: 27px !important;
        line-height: 29px !important;
        margin-top: 285px;
    }
    .topo {
        height: 88px;
        margin-top: 70px;
    }
    .blend-overlay-topo {
        width: 100%;
        clip-path: polygon(0 0, 100% 0%, 100% 100%, 0% 100%);
    }
    .caption-wrapper{
        width: 100%;
    }
    .lideranca {
        height: 920px;
    }
    .liderança-wrapper{
        padding: 40px;
    }
    .contact-whats{
        bottom: 15px;
        right: 15px;
        width: 40px;
        height: 40px;
    }
    .whats-button{
        width: 40px;
        height: 40px;
        padding: 6px;
    }
    
   
}
/* X-Small devices (portrait phones, less than 576px)*/
@media (max-width: 575.98px) { 
    .lideranca {
        padding: 60px 30px;
    }
   .services{
        padding: 40px 30px;
   }
   .services h2 {
        margin-bottom: 30px;
    }
    .services-buttons{
        display: flex;
        align-items: center;
        justify-content: center;
        flex-direction: column;
        padding-top: 25px;
    }
    .services button.square {
        padding: 8px 25px;
        margin-bottom: 15px !important;
    }
    .segments, .escolha {
        padding: 40px 20px;
    }
    .segments h2 {
        margin-bottom: 30px;
    }
    .segments-box, .certificacao-box{
        max-width: 95%;
        margin-left: 5px;
    }
  
    .certificacao-box {
        min-height: auto;
    }
    .escolha-box {
        max-width: 92%;
        margin-left: 5px;
    }
    .clients-title p{
        width: 300px;
    } 
    .clients-wrapper{
        margin-left: 0px;
    }  
    .clients-box {
        max-width: 100%;
        margin-left: -12px;
        margin-right: -20px;
    }
    .clients-box img {
        max-width: 90%;
        height: auto;
    } 
    .column-reverse-mobile {
        flex-direction: column-reverse !important;
        padding: 0 30px;
    }
    .selo-certificacao{
        width: 85px;
    }
    .footer-right .brand img{
        width: 125px;
    }
    .footer-space{
        margin: 20px 0;
        width: 100%;
        height: 1px;
        background-color: #3f3f3f;
    }
    .copyright{
        text-align: center;
        height: auto;
        padding: 12px 0;
    }
    .copyright p{
        line-height: 18px;
        padding: 0 30px;
    }
    .sobre {
        padding: 40px 20px;
    }
    .sobre-title h1 {
        width: 100%;
    }
     .carousel-container {
        margin-top: 50px;
        height: 270px;
    }
    .card-photo.left-2 {
		transform: translateX(-220px) scale(0.8) translateZ(-300px);
	}
	.card-photo.left-1 {
		transform: translateX(-150px) scale(0.9) translateZ(-100px);
	}
	.card-photo.right-1 {
		transform: translateX(150px) scale(0.9) translateZ(-100px);
	}
	.card-photo.right-2 {
		transform: translateX(220px) scale(0.8) translateZ(-300px);
	}
    .card-body {
        padding: 0rem;
    }
    .services-buttons .square{
        min-width: 192px;
    }
    .tipos {
        padding: 40px 30px;
    }
    .tipos-box {
        padding: 30px;
    }
    .contacts h1{
        margin-bottom: 20px;
    }
    .address {
        width: 280px;
    }
    .topo-title {
        font-size: 30px;
        margin-left: 30px;
    }
    .caption-wrapper{
        height: 485px;
    }
    .blend-overlay{
        height: 44%;
    }
 }
