.open-sans {
  font-family: "Open Sans", serif;
  font-optical-sizing: auto;
  font-style: normal;
  font-variation-settings:
    "width" 100;
}

.libre-baskerville-regular {
  font-family: "Libre Baskerville", serif;
  font-weight: 400;
  font-style: normal;
}

.libre-baskerville-bold {
  font-family: "Libre Baskerville", serif;
  font-weight: 700;
  font-style: normal;
}

.libre-baskerville-regular-italic {
  font-family: "Libre Baskerville", serif;
  font-weight: 400;
  font-style: italic;
}


.dm-sans {
  font-family: "DM Sans", serif;
  font-optical-sizing: auto;
  font-weight: 400;
  font-style: normal;
}


body {
    font-family: "DM Sans", serif;
    background: #fff;
    margin: 0;
    padding: 0;
}
a,
a:hover,
a:active,
a:visited,
a:focus {
    text-decoration: none !important;
    transition: 0.3s all;
}

.main-width{
    max-width: 1200px;
    margin: auto;
}

header{
    background: linear-gradient(135deg, #46BFE0, #34bee3, #119abf);
    color: #e0e0e0;
    padding: 20px;
}
nav ul li{
    display: inline-block;
    list-style-type: none;
    padding: 0px 15px;
}
nav ul{
    text-align: right;
    margin-top: 7px;
    margin-bottom: 0px;
}
nav ul li a{
    color: #fff;
    text-transform: uppercase;
    font-size: 14px;
}
nav ul li a:hover{
    color: #00546b;
}
.banners{
    height: 495px;
    width: 100%;
}
.banner{
    background: #000;
    text-align: center;
    padding-top: 100px;
}
.banner-1{
    text-align: left;
    background: transparent url(assets/img/banner-1.png) top center ;
}
.banner-servicos{
    text-align: left;
    background: transparent url(assets/img/banner-servicos.png) top center ;
}
.banner-2{
    text-align: left;
    background: transparent url(assets/img/banner-2.png) top center ;
}
.banner-3{
    text-align: right;
    background: transparent url(assets/img/banner-3.png) top center ;
}
.banner-3 .btn-cta{
  float:right;
}
.banners .banner{
    background-size: cover;
    height: 495px;
    display: inline-block;
    width: 100vw;
}
.banners h2{
    font-style: 30px;
    color: #fff;
    margin-bottom: 30px;
}
.banners h2 strong{
    display: block;
    font-size: 88px;
}
.btn-cta{
    display: table;
    padding: 10px 30px;
    background: #46bfe0;
    color: #fff;
    text-transform: uppercase;
    font-weight: 600;
    border-radius: 25px;
}
.btn-cta:hover{
    color: #fff;
    background: #00546b;
}

.home-section{
    padding: 50px 0px;
}

.servicos-home{
    background: #f4f4f4;
    
}

.home-section h3{
    font-size: 19px;
    text-transform: uppercase;
    text-align: center;
    display: block;
}

.home-section h2{
    padding: 10px 0px 50px;
    font-size: 33px;
    color: #333;
    text-align: center;
}
.item-servicos-home{
    background: #fff;
    text-align: center;
    padding: 25px 0px;
}
.item-servicos-home img{
    max-width: 100%;
    width: auto;
    margin: auto;
}
.servicos-text{
    margin-top: 10px;
    border-left: 5px solid #46bfe0;
    text-align: left;
    padding-left: 25px;
}
.historia-home{
    background: #000 url(assets/img/back-nossa-historia.png) top center;
    background-size: cover;
}
.historia-home h3{
    color: rgba(255,255,255,0.5);
}
.historia-home h2{
    color: #fefefe;
}
.historia-home p{
    font-size: 20px;
    color: rgba(255,255,255,0.75);
}
.equipe-home{
    text-align: center;
}

footer{
    background: #46bfe0;
}
.icon-servicos-home{
    width: 90%;
    margin: auto;
    text-align: center;
    background: #46bfe0;
    height: 230px;
    transition: 0.3s all;
    padding-top: 35px;
    margin-bottom: 25px;
}
.icon-servicos-home img{
    width: 50%;
    margin: auto;
}
.icon-servicos-home h3{
    color: #fff;
}
.icon-servicos-home:hover, .item-equipe-home img:hover{
    transform: scale(1.10);
}
.item-equipe-home img{
    transition: 0.3s all;
    width: 90%;
    margin: auto;
}
.item-equipe-home{
    text-align: center;
    color: #333;
}
.item-equipe-home h3{
    font-size: 24px;
    font-weight: 800;
    padding: 10px;
}
.txt-footer{
    color: #fff;
    font-size: 18px;
    padding: 25px 0px;
}

.txt-footer a{
    color: #fff;
    font-weight: bold;
    text-decoration: underline;
}
.copy{
    text-transform: uppercase;
    font-weight: bold;
    font-size: 10px;
    color: #fff;
    text-align: center;
    display: block;
    width: 100%;
    background: rgba(0,0,0,0.15);
    padding: 15px;
}

.banners {
    position: relative;
    width: 100%;
    height: 495px;
    overflow: hidden;
}

.banner {
    position: absolute;
    width: 100%;
    height: 100%;
    opacity: 0;
    transition: opacity 1s ease-in-out;
}

.banner.active {
    opacity: 1;
}

.titulo-com-linhas {
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 10px 0;
  gap: 20px;
}


.titulo-com-linhas .linha {
  flex: 1;
  height: 4px;
  background-color: #ddd; /* cor cinza claro */
  max-width: 100px;
}

.equipe-home .titulo-com-linhas .linha {
  background-color: rgba(255,255,255,0.5);
}

.titulo-com-linhas h3 {
  margin: 0;
  font-weight: normal;
  color: #666;
  text-transform: uppercase;
  font-size: 16px;
  letter-spacing: 1px;
}   
.menu-mobile i{
    font-size: 22px;
    margin-top: 5px;
}
.menu-mobile a{
    color: #fff;
}

.txt-servicos-interna{
    border-top: 4px solid #46bfe0;
    padding-bottom: 25px;
}

.txt-servicos-interna h3{
    border-left: 4px solid #46bfe0;
    text-align: left;
    text-transform: uppercase;
    font-weight: bold;
    margin: 15px 0px;
    padding-left: 5px;
    margin-top: 25px;
    color: #333;
    font-size: 22px;
}
.row-servicos-interna{
    margin-bottom: 15px;
}


.banners-interna{
    height: 250px;
}
.banners-interna .banner{
    background-size: contain ;
    background-position: center center;
}
.img-equipe{
    width: 100%;
    height: 500px;
    overflow: hidden;
}

.nav-menu-mobile{
    background: #46bfe0 ;
    position: absolute;
    z-index: 10000;
    width: 100%;
}

.nav-menu-mobile ul{
    margin: 0px;
    padding: 0px;
}

.nav-menu-mobile ul li{
    display: block ;
    width: 100%;
    text-align: center;
    border-bottom: 1px solid rgba(255,255,255,0.4);
    padding: 10px;
}
.nav-menu-mobile ul li a{
    color: #fff;
    font-weight: bold;
}