@import url('https://fonts.googleapis.com/css2?family=Ubuntu:wght@300;400;700&display=swap');
* {font-family: 'Ubuntu', sans-serif; font-weight: 400;}
html {overflow-x: hidden;}
body {background: #fff;  font-size: 18px; color: #1F2227; overflow-x: hidden;}
a,button, input, textarea {-webkit-transition: .3s;-o-transition: .3s;transition: .3s; outline: 0;}
button {cursor: pointer;}
a, a:hover {text-decoration: none;}
a:focus, button:focus, input:focus, textarea:focus {outline: 0; text-decoration: none;}
ul {-webkit-padding-start:0; -moz-padding-start:0; margin: 0;}
li {list-style-type: none;}
img {max-width: 100%;}
*{margin: 0; padding: 0; box-sizing:border-box;}
p {line-height: 32px;}
section{padding: 75px 0;}
html{scroll-behavior: smooth;}
sup {vertical-align: unset; font-size: inherit;}
q:before,q:after {content: '';}
strong {font-weight: 700;}
cite {margin-bottom: 15px; font-size: 18px; color: #1E1E1E; position: relative; display: flex; align-items: center; gap: 15px; font-style: normal; justify-content: center;}
cite:before {content: ''; display: inline-flex; width: 36px; height: 1px; background: rgba(16,173,233,1);}
h2 {margin-bottom: 60px; background: -webkit-linear-gradient(rgba(28,211,191), rgba(16,173,233)); -webkit-background-clip: text; -webkit-text-fill-color: transparent; font-size: 48px; font-weight: 600; text-align: center;}
.grid {max-width: 1360px; width: 100%; margin: 0 auto; padding: 0 30px; display: grid; grid-gap: 0;}
h3 {font-weight: 600; font-size: 36px; margin-bottom: 30px;}


body.bg {
    position: relative;
}
body.bg:before {
    content: '';
    position: absolute;
    background-image: url(../img/banner.png);
    background-size: 1550px;
    background-position: 100% -10em;
    background-repeat: no-repeat;
    width: 100%;
    height: 904px;   
    z-index: -1; 
}
header {
    position: absolute;
    width: 100%;
    top: 60px;    
}
header:before {
    content: '';
    position: absolute;
    background-image: url(../img/banner.png);
    background-size: 1550px;
    background-position: 100% 60px;
    background-repeat: no-repeat;    
}
header nav {
    padding: 35px;
    display: grid;
    grid-template-columns: max-content 1fr max-content;
    align-items: center;
    border-radius: 25px;
    background: rgb(255 255 255 / 60%);
    box-shadow: 0 50px 35px 0px rgb(0 189 255 / 10%);
}
header nav ul {
    display: flex;
    gap: 40px;
    justify-content: center;
}
header nav ul li:last-child {
    display: none;
}
header nav ul li a {
    color: #7A268A;
}
header nav ul li a:hover, header nav ul li.ativo a {
    color: #7A268A;   
}
header nav > a:last-child {
    background: linear-gradient(90deg, rgba(16,173,233,1) 0%, rgba(28,211,191,1) 100%);
    color: #fff;
    padding: 20px 50px;
    border-radius: 10px;
    font-weight: 600;
    text-align: center;
}
header .menu {
    display: none;
}




section.banner {
    padding-top: 275px;
    background-image: url('../img/banner.png');
    background-size: 1550px;
    background-position: 100% 60px;
    background-repeat: no-repeat;
}
section.banner .grid {
    grid-template-columns: .5fr;
}
section.banner h1 {
    font-size: 40px;
    font-weight: 600;
    margin-bottom: 15px;
}
section.banner h1 span {
    display: block;
    font-size: 24px;
    margin-bottom: 18px;
    background: linear-gradient(90deg, rgba(16,173,233,1) 0%, rgba(28,211,191,1) 100%);
    color: #fff;
    font-weight: 900;
    width: fit-content;
    padding: 12px 16px;
    border-radius: 10px;
}
section.banner p {
    color: #717171;
    margin-bottom: 30px;    
}
section.banner ul {
    display: flex;
    flex-direction: column;
    gap: 15px;
    margin-left: 20px;
}
section.banner ul {
    display: flex;
    flex-direction: column;
    gap: 15px;
    margin-left: 20px;
    margin-bottom: 40px;    
}
section.banner ul li {
    color: #717171;
    list-style-type: disc;  
}
section.banner a {
    background: linear-gradient(90deg, rgba(16,173,233,1) 0%, rgba(28,211,191,1) 100%);
    color: #fff;
    padding: 20px 50px;
    border-radius: 10px;
    font-weight: 600;
    width: fit-content;    
}





section.ferramenta {
    background-image: url('../img/linha.png');
    background-size: 1930px;
    background-repeat: no-repeat;
    background-position: 0; 
}
section.ferramenta article figure  {
    box-shadow: 0 0 35px 0px rgb(0 189 255 / 18%);
    background: #fff;
    border-radius: 100%;
    height: 120px;
    width: 120px;
    display: flex;
    align-items: center;
    justify-content: center; 
    margin-bottom: 30px; 
}
section.ferramenta article h4 {
    font-size: 20px;
    font-weight: 600;  
    margin-bottom: 20px;  
}
section.ferramenta article p {
    color: #717171;    
}
section.ferramenta .grid:nth-child(2) {
    grid-template-columns: repeat(4, 1fr);
    gap: 30px;    
}
section.ferramenta article:nth-child(1) {
    margin-top: 175px;
}
section.ferramenta article:nth-child(3) {
    margin-top: 225px;
}
section.ferramenta article:nth-child(4) {
    margin-top: 65px;
}



section.sobre .grid {
    grid-template-columns: max-content 1fr;
    gap: 100px;
    align-items: center;
}
section.sobre cite {
    justify-content: left;
}
section.sobre p {
    color: #717171;
    margin-bottom: 20px;
}
section.sobre a {
    background: linear-gradient(90deg, rgba(16,173,233,1) 0%, rgba(28,211,191,1) 100%);
    color: #fff;
    padding: 20px 50px;
    border-radius: 10px;
    font-weight: 600;
    width: fit-content;    
    display: flex;
    margin-top: 40px;
}



section.eleve {
    position: relative;
}
section.eleve:before {
    content: '';
    position: absolute;
    background-image: url('../img/eleve.png');
    background-repeat: no-repeat;
    background-size: cover;
    width: 1600px;
    height: 1000px;
    right: -200px;
    top: -200px; 
	z-index: -1;
}
section.eleve .grid {
    grid-template-columns: .5fr;
}
section.eleve cite {
    justify-content: left;
}
section.eleve a {
    background: linear-gradient(90deg, rgba(16,173,233,1) 0%, rgba(28,211,191,1) 100%);
    color: #fff;
    padding: 20px 50px;
    border-radius: 10px;
    font-weight: 600;
    width: fit-content;    
    display: flex;
    margin-top: 40px;
}



section.oportunidade .grid:not(:first-child) {
    align-items: center;
    gap: 100px;
}
section.oportunidade .grid:not(:first-child) cite {
    justify-content: left;
}
section.oportunidade .grid:nth-child(2),
section.oportunidade .grid:nth-child(4) {
    grid-template-columns: 1fr max-content;
}
section.oportunidade .grid:nth-child(3) {
    grid-template-columns: max-content 1fr;
}



section.blog {

}
section.blog .grid:nth-child(2) {
    grid-template-columns: .75fr 1fr;
    gap: 100px;
}
section.blog h2, section.blog cite {
    justify-self: left;
    text-align: left;
}
section.blog article {
    position: relative;
    transition: .3s;    
    cursor: pointer;
}
section.blog article figure {
    width: 500px;
    height: 310px;
    position: relative;
    background-size: cover;
    border-radius: 25px;
    margin-bottom: 50px; 
}
section.blog article:hover figure:before {
    transform: scale(1.05);
}
section.blog .grid:nth-child(2) div:nth-child(2) article:hover figure:before {
    transform: scale(1.1);
}
section.blog article figure:before {
    content: '';
    position: absolute;
    background-image: url('../img/bg.png');
    width: 522px;
    height: 350px;
    background-size: contain;
    background-repeat: no-repeat;
    z-index: -1;
    bottom: -30px;
    right: -65px;
    transition: .3s;
}
section.blog article time {
    font-size: 16px;
    margin-bottom: 20px;
    display: flex;
} 
section.blog article h4 {
    font-size: 20px;
    font-weight: 600;   
    margin-bottom: 10px; 
} 
section.blog .grid:nth-child(2) div:nth-child(2) figure {
    width: 250px;
    height: 175px;
    float: left;
    margin-right: 50px;
    clear: both;    
}
section.blog .grid:nth-child(2) div:nth-child(2) figure:before {
    width: 250px;
    height: 175px;    
    bottom: -20px;
    right: -23px;    
}
section.blog .grid:nth-child(2) div:nth-child(2) article:first-child {
    margin-bottom: 60px;
}
section.blog article a {
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
}



section.clientes h2 {
    margin-bottom: 40px;
}
section.clientes .grid {
    grid-template-columns: minmax(0, 1fr);
}
section.clientes .slick-prev,
section.clientes .slick-next {
    font-size: 0;
    border: 0;
    background: 0;
}
section.clientes .slick-prev:before,
section.clientes .slick-next:before {
    display: flex;
    font-size: 28px;
    position: absolute;
    top: 80px;
    color: #1cd3bf;
}
section.clientes .slick-prev:before {
    content: '⟵';
    left: -50px;
}
section.clientes .slick-next:before {
    content: '⟶';
    right: -50px;
}
section.clientes figure {
    background-size: contain;
    background-position: center;
    background-color: #fff;
    background-repeat: no-repeat;
    width: 100%;
    height: 150px;
    border: 1px solid #eee;
    border-radius: 20px;    
    position: relative;
}
/* section.clientes figure:before {
    content: '';
    position: absolute;
    background-image: url(../img/bg.png);
    width: 100%;
    height: 150px;
    background-size: contain;
    background-repeat: no-repeat;
    background-position: center;
    z-index: -1;
    bottom: -20px;
    right: 0;
    left: 0;
    margin: 0 auto;
    transition: .3s;
} */
section.clientes figure:hover:before {
    transform: scale(1.1);
}
section.clientes .slick-track {
    padding-bottom: 30px;
}

section.clientes .slick-slide {
    margin: 0 20px;
}
section.clientes .slick-list {
    margin: 0 -20px;
}
section.clientes figure a {
    position: absolute;
    left: 0;
    top: 0;
    right: 0;
    bottom: 0;
}



footer {
    background: linear-gradient(90deg, rgba(16,173,233,1) 0%, rgba(28,211,191,1) 100%);
    padding: 75px 0 45px;
    color: #fff;
}
footer p strong {
    display: block;
    margin-bottom: 5px;
    background: #fff;
    width: fit-content;
    color: #10ade8;
    padding: 2px 14px 3px;
    border-radius: 8px;
}
footer .grid:first-child {
    grid-template-columns: 1.5fr .5fr 1fr;
    gap: 80px;
}
footer .grid div:nth-child(1) img {
    filter: brightness(0) invert(1);
    margin-bottom: 30px;
}
footer h6 {
    color: #fff;
    font-size: 20px;
    font-weight: 600;
    margin-bottom: 20px;
}
footer ul li {
    margin-bottom: 10px;
}
footer ul li a {
	color: #fff
}
footer > .grid:first-child div:nth-child(3) ul li:first-child {

}
footer .creditos {
    border-top: 1px solid #fff;
    margin-top: 40px;
    padding-top: 40px;
    display: grid;
    grid-template-columns: 1fr 1fr;
}
footer .grid .creditos a img {
    filter: unset;
    margin: 0;
}
footer .creditos a {
    display: flex;
    align-items: center;
    width: fit-content;
    justify-self: right;
    color: #fff;
    gap: 10px;
}



section.pagina {
    padding-top: 275px;
}


section.blog.pagina h2, section.blog.pagina cite {
    justify-self: center;
    text-align: center;
}
section.blog.pagina .grid:nth-child(2) {
    grid-template-columns: 1fr 1fr 1fr;
}
section.blog.pagina article figure, section.blog.pagina article figure:before {
    width: 100%;
    height: 250px;
}


.screen-reader-text {
    display: none;
}
.nav-links {
    display: flex;
    gap: 10px;
    justify-content: center;
    margin-top: 60px;
}
.nav-links * {
    background: linear-gradient(90deg, rgba(16,173,233,1) 0%, rgba(28,211,191,1) 100%);
    color: #fff;
    padding: 8px 20px 10px;
    border-radius: 10px;
    font-weight: 600;
    display: flex;  
}


section.blog-single article figure {
    width: 800px;
    height: 400px;
    position: relative;
    background-size: cover;
    border-radius: 25px;
    margin: 0 auto 50px;
}
section.blog-single article figure:before {
    content: '';
    position: absolute;
    background-image: url(../img/bg.png);
    width: 600px;
    height: 400px;
    background-size: contain;
    background-repeat: no-repeat;
    background-position: 100% 0;
    z-index: -1;
    bottom: -30px;
    right: 0;
    left: 0;
    margin: 0 auto;
}
section.blog-single article time {
    font-size: 16px;
    margin-bottom: 20px;
    display: flex;
    justify-content: center;
}
section.blog-single article h4 {
    font-size: 36px;
    font-weight: 600;
    margin-bottom: 40px;
    text-align: center;
}
section.blog-single article p {
    margin-bottom: 20px;
    text-align: center;
}
section.blog-single article ul li {
    list-style-type: disc;
    margin-left: 20px;
}
section.blog-single article ol li {
    list-style-type: number;
    margin-left: 20px;
}


section.cliente .grid:nth-child(2) {
    grid-template-columns: 1fr 1fr 1fr;
    gap: 40px;    
}
section.cliente article {
    position: relative;
}
section.cliente article a {
    position: absolute;
    left: 0;
    right: 0;
    top: 0;
    bottom: 0;
}
section.cliente article figure {
    width: 100%;
    height: 250px;
    position: relative;
    background-size: contain;
    background-repeat: no-repeat;
    background-position: center;
    background-color: #fff;
    border-radius: 25px;
    border: 1px solid #eee;    
}
/* section.cliente article figure:before {
    content: '';
    position: absolute;
    background-image: url('../img/bg.png');
    width: 100%;
    height: 250px;
    background-size: contain;
    background-repeat: no-repeat;
    z-index: -1;
    bottom: -30px;
    right: -65px;
    transition: .3s;
} */
section.cliente article:hover figure:before {
    transform: scale(1.05);
}
section.cliente article h4 {
    font-size: 20px;
    font-weight: 600;
    margin-bottom: 10px;
}
section.cliente article p {

}



section.cliente-single article figure {
    width: 800px;
    height: 400px;
    position: relative;
    background-size: contain;
    background-repeat: no-repeat;
    background-position: center;
    background-color: #fff;
    border-radius: 25px;
    margin: 0 auto 50px;
    border: 1px solid #eee;
}
section.cliente-single article figure:before {
    content: '';
    position: absolute;
    background-image: url(../img/bg.png);
    width: 600px;
    height: 400px;
    background-size: contain;
    background-repeat: no-repeat;
    background-position: 100% 0;
    z-index: -1;
    bottom: -30px;
    right: 0;
    left: 0;
    margin: 0 auto;
}
section.cliente-single article time {
    font-size: 16px;
    margin-bottom: 20px;
    display: flex;
    justify-content: center;
}
section.cliente-single article h4 {
    font-size: 36px;
    font-weight: 600;
    margin-bottom: 40px;
    text-align: center;
}
section.cliente-single article p {
    margin-bottom: 20px;
    text-align: center;
}
section.cliente-single article ul li {
    list-style-type: disc;
    margin-left: 20px;
}
section.cliente-single article ol li {
    list-style-type: number;
    margin-left: 20px;
}


section.contato .grid:nth-child(2) {
    gap: 100px;
    grid-template-columns: max-content 1fr;
    align-items: center;
}
section.contato .grid:nth-child(2) cite {
    justify-content: left;
}
section.contato h3 {
    margin-bottom: 50px;
}
section.contato form > div {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 20px;
    margin-bottom: 30px;
}
section.contato form div div {
    position: relative;
    display: flex;
    flex-direction: column;
}
section.contato form label {
    position: absolute;
    top: 15px;
    left: 13px;    
    transition: .3s;
}
section.contato form label.ativo {
    top: -24px;
    font-size: 14px;
}
section.contato form input, section.contato form textarea {
    border: 0;
    border: 1px solid;
    font-size: 18px;
    padding: 15px 10px;
    border-radius: 15px;
}
section.contato form textarea {
    height: 120px;
}
section.contato form div:last-child {
    grid-template-columns: 1fr;
    gap: 0;
    position: relative;
}
section.contato form button {
    background: linear-gradient(90deg, rgba(16,173,233,1) 0%, rgba(28,211,191,1) 100%);
    color: #fff;
    padding: 20px 50px;
    border-radius: 10px;
    font-weight: 600;
    font-size: 18px;
    border: 0;
    margin: 30px 0 20px;    
}


section.sobre.pagina .grid:first-child {
	grid-template-columns: 1fr;
    gap: 0;
    justify-items: center;	
}
section.sobre.pagina .mais {
	margin-top: 70px;
    grid-template-columns: 1fr;
    gap: 0;	
}
section.sobre.pagina .mais ul {
	display: grid;
    gap: 50px;
    grid-template-columns: 1fr 1fr 1fr;
	margin-top: 25px;
}
section.sobre.pagina .mais ul li {
    display: flex;
    align-items: center;
    gap: 15px;
    box-shadow: 0 0 35px 0px rgb(0 189 255 / 18%);
    background: #fff;
    padding: 30px;
    border-radius: 20px;
}
section.sobre.pagina .mais ul li p {
	display: flex;
	flex-direction: column;
	margin-bottom: 0;
	line-height: 25px;
}
section.sobre.pagina .mais figure {
    display: grid;
    grid-template-columns: 1fr 1fr 1fr;
    gap: 50px;
    margin-top: 50px;	
}


a.zap {
    position: fixed;
    bottom: 30px;
    right: 30px;
    background: #34c159;
    border-radius: 50px;
    padding: 13px;
    animation: zap 2s infinite;
    height: 60px;
    width: 60px;    
}
a.zap img {
    width: 40px;
}
@keyframes zap {
    0% {box-shadow: 0px 0px 0px 0px rgb(91 204 120 / 25%);}
    50% {box-shadow: 0px 0px 0px 15px rgb(91 204 120 / 25%);}
    
}
.enviado {
	position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    padding: 10px;
    text-align: center;
    background: linear-gradient(90deg, rgba(16,173,233,1) 0%, rgba(28,211,191,1) 100%);
    color: #fff;
    z-index: 1;	
}