@import url("https://fonts.googleapis.com/css2?family=Inter:ital,opsz,wght@0,14..32,100..900;1,14..32,100..900&display=swap");
@font-face {
  font-family: Sentient;
  src: url(./Sentient-Variable.ttf); }
* {
  -webkit-transition: all ease .2s;
  transition: all ease .2s; }

div#wpadminbar {
  display: none; }

html {
  margin: 0 !important;
  overflow-x: hidden !important; }

body {
  margin: 0 !important;
  font-family: "Inter", sans-serif !important;
  background-color: #222222;
  color: #fff;
  position: relative;
  overflow-x: hidden !important; }

::-moz-selection {
  color: #222222;
  background: #fff; }

::selection {
  color: #222222;
  background: #fff; }

.cookiealert {
  position: fixed;
  bottom: 20px;
  right: 20px;
  width: 275px;
  margin: 0 auto !important;
  z-index: 999;
  opacity: 0;
  visibility: hidden;
  border-radius: 15px;
  transform: translate(0, 100%);
  transition: all 500ms ease-out;
  background: #D9D9D9; }
  .cookiealert p {
    font-size: 0.75rem;
    line-height: 1.3;
    font-weight: 300;
    margin-bottom: 15px;
    color: #222222; }
  .cookiealert a {
    color: #000; }
  .cookiealert button.acceptcookies {
    padding: 10px 18px;
    font-size: 0.875rem;
    text-transform: uppercase;
    margin-top: 0; }

.cookiealert.show {
  opacity: 1;
  visibility: visible;
  transform: translate(0, 0%);
  transition-delay: 1000ms; }

@media screen and (max-width: 900px) {
  .cookiealert {
    width: calc(100% - 20px);
    left: 10px;
    bottom: 10px;
    text-align: center; } }
.grid {
  display: -ms-grid;
  display: grid;
  grid-auto-columns: 1fr;
  grid-column-gap: 30px;
  grid-row-gap: 0px;
  -ms-grid-columns: 1fr 1fr 1fr;
  grid-template-columns: 1fr 1fr 1fr;
  -ms-grid-rows: auto;
  grid-template-rows: auto; }

button:focus {
  outline: none !important;
  box-shadow: none; }

a {
  color: #fff;
  text-decoration: none !important; }
  a:hover {
    color: #D9D9D9; }

.center {
  display: -webkit-box !important;
  display: -ms-flexbox !important;
  display: flex !important;
  -webkit-box-align: center !important;
  -ms-flex-align: center !important;
  align-items: center !important;
  -webkit-box-pack: center !important;
  -ms-flex-pack: center !important;
  justify-content: center !important;
  -webkit-box-orient: vertical !important;
  -webkit-box-direction: normal !important;
  -ms-flex-direction: column !important;
  flex-direction: column !important; }

.centerleft {
  -webkit-box-align: start !important;
  -ms-flex-align: start !important;
  align-items: start !important; }

.centerright {
  -webkit-box-align: end !important;
  -ms-flex-align: end !important;
  align-items: end !important; }

.ulflex {
  padding-left: 0;
  list-style-type: none;
  display: flex;
  margin: 0; }

.show-for-small {
  display: none !important; }

@media screen and (max-width: 1140px) {
  .grid {
    grid-column-gap: 0px !important;
    grid-row-gap: 30px !important;
    -ms-grid-columns: 1fr !important;
    grid-template-columns: 1fr !important; }

  img {
    max-width: 100%; }

  br {
    display: none; }

  .show-for-small {
    display: block !important; }

  .show-for-large {
    display: none !important; }

  .order-mobile-2 {
    -webkit-box-ordinal-group: 3;
    -ms-flex-order: 2;
    order: 2; } }
h1, h2 {
  font-family: Sentient;
  font-weight: 400;
  font-size: 45px;
  line-height: 50px;
  margin-bottom: 25px; }

p {
  font-size: 22px;
  line-height: 1.2; }

section {
  position: relative;
  padding: 90px 0; }

.social-flex {
  display: flex;
  gap: 8px;
  justify-content: center; }
  .social-flex a {
    background-color: #D9D9D9;
    width: 38px;
    height: 38px;
    display: flex !important;
    border-radius: 50%;
    padding: 0;
    justify-content: center;
    align-items: center; }
    .social-flex a:hover {
      background-color: #fff; }

.swiper-button-next, .swiper-button-prev {
  background-image: none !important;
  background-position: center;
  background-size: 24px;
  background-repeat: no-repeat;
  width: 64px;
  height: 64px;
  display: flex;
  align-items: center;
  justify-content: center;
  background-color: #222222;
  border-radius: 100px;
  top: 6px; }
  .swiper-button-next:after, .swiper-button-next:before, .swiper-button-prev:after, .swiper-button-prev:before {
    display: none; }

.swiper-button-prev {
  background-image: url("../img/icons/arrow-prev.svg") !important;
  right: 90px;
  left: auto; }

.swiper-button-next {
  background-image: url("../img/icons/arrow-next.svg") !important;
  right: 15px; }

.video-container {
  position: relative;
  max-width: 1240px;
  margin: 30px auto 0; }
  .video-container .bg-video {
    position: relative;
    width: 100%;
    height: 100%;
    overflow: hidden; }
  .video-container .bg-video-thumb {
    background: #D9D9D9;
    position: absolute;
    z-index: 4;
    top: 0;
    left: 0;
    background-position: center;
    background-size: cover;
    width: 100%;
    height: 100%;
    -webkit-transition: all ease .5s;
    transition: all ease .5s; }
  .video-container button.play {
    background-position: center;
    background-size: cover;
    background-repeat: no-repeat;
    width: 76px;
    height: 76px;
    border: none;
    background-color: transparent;
    cursor: pointer;
    -webkit-transition: all ease .5s;
    transition: all ease .5s; }
    .video-container button.play:hover {
      transform: scale(1.1); }
  .video-container .embed-container {
    position: relative;
    padding-bottom: 56.25%;
    height: 0;
    overflow: hidden;
    max-width: 100%;
    width: 100%; }
  .video-container .embed-container iframe,
  .video-container .embed-container object,
  .video-container .embed-container embed {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%; }

.formulario span.wpcf7-list-item {
  margin: 0; }
.formulario .wpcf7-not-valid-tip {
  color: red;
  font-size: 0.875rem;
  margin: -10px 10px 15px;
  font-weight: 300; }
.formulario .wpcf7 form .wpcf7-response-output {
  font-size: 1.125rem;
  line-height: 1.3;
  margin: 0 0;
  padding: 20px;
  border-radius: 12px;
  text-align: center; }
.formulario .wpcf7 form.invalid .wpcf7-response-output {
  color: #222222;
  background-color: #ffb900; }
.formulario .wpcf7 form.sent .wpcf7-response-output {
  background-color: #46b450;
  color: #fff; }

.flex-end {
  display: flex;
  flex-direction: column;
  justify-content: end; }

.bg {
  background-position: center;
  background-size: cover;
  background-repeat: no-repeat; }

.btn.btn-primary {
  display: flex;
  align-items: center;
  width: fit-content;
  gap: 15px;
  color: #222222;
  font-size: 20px;
  border: none;
  border-radius: 0px;
  padding: 18px 22px;
  line-height: 1;
  background-color: #D9D9D9 !important;
  margin-top: 30px; }
  .btn.btn-primary:hover {
    background-color: #fff !important; }
    .btn.btn-primary:hover svg {
      transform: translateX(2px); }

.btn.btn-primary._2 {
  background-color: #222222 !important;
  color: #fff; }
  .btn.btn-primary._2:hover {
    background-color: #000 !important; }

a.link-absolute {
  position: absolute;
  inset: 0%;
  width: 100%;
  height: 100%;
  display: block;
  z-index: 2; }

@media screen and (max-width: 1580px) {
  section {
    padding: 80px 0; }

  .mt-5, .my-5 {
    margin-top: 2rem !important; }

  .pl-5, .px-5 {
    padding-left: 15px !important; }

  h1, h2 {
    font-size: 40px;
    line-height: 45px;
    margin-bottom: 20px; }

  p {
    font-size: 20px; }

  .btn.btn-primary {
    gap: 12px;
    font-size: 18px; }
    .btn.btn-primary svg {
      margin-top: 2px; } }
.background-video {
  position: absolute;
  inset: 0%;
  z-index: -1;
  pointer-events: none; }
  .background-video video {
    width: 100%;
    height: 100%;
    object-fit: cover; }

@media screen and (max-width: 1380px) {
  section {
    padding: 70px 0; }

  h1, h2 {
    font-size: 38px;
    line-height: 42px;
    margin-bottom: 15px; }

  p {
    font-size: 18px; } }
@media screen and (max-width: 1140px) {
  section {
    padding: 60px 0; }

  h1, h2 {
    font-size: 32px;
    line-height: 36px; }

  p {
    font-size: 16px; }

  img {
    max-width: 100%; }

  br {
    display: none; }

  .btn.btn-primary {
    width: 100%;
    gap: 10px;
    font-size: 16px;
    padding: 16px 18px;
    justify-content: center; }

  .mt-5, .my-5 {
    margin-top: 1rem !important; }

  .mt-4, .my-4 {
    margin-top: 0.5rem !important; } }
header {
  position: relative;
  width: 100%;
  background-color: #222;
  padding-top: 110px;
  z-index: 5; }
  header.Home {
    position: absolute;
    background-color: transparent; }
  header .nav-container {
    display: flex;
    align-items: start;
    justify-content: space-between; }
  header a {
    background-color: transparent; }
  header a.brand {
    padding: 0;
    position: relative; }
    header a.brand img {
      max-width: 317px; }
  header nav.nav-menu ul {
    margin: 0;
    padding: 0;
    list-style-type: none;
    display: flex;
    gap: 32px; }
    header nav.nav-menu ul li {
      position: relative;
      display: flex;
      gap: 16px; }
      header nav.nav-menu ul li a {
        position: relative;
        display: block;
        width: 100%;
        padding: 10px 5px;
        text-align: center; }
        header nav.nav-menu ul li a:hover {
          transform: translateY(-2px); }
      header nav.nav-menu ul li:not(:last-child)::after {
        content: '';
        position: absolute;
        top: -130px;
        right: -16px;
        display: block;
        width: 1px;
        height: 170px;
        background-color: rgba(255, 255, 255, 0.2); }
  header .hamburger {
    position: relative;
    z-index: 10;
    cursor: pointer; }
  header .hamburger-btn .hamburger-lines .close-line {
    position: relative;
    z-index: 1;
    height: 2px;
    width: 28px;
    border-radius: 0px;
    background-color: #fff;
    margin: 8px 0;
    -webkit-transform: none;
    -ms-transform: none;
    transform: none;
    -webkit-transition: all ease .2s;
    transition: all ease .2s; }
  header .hamburger-btn .hamburger-lines.open .close-top {
    transform: translate3d(0px, 10px, 0px) scale3d(1, 1, 1) rotateX(0deg) rotateY(0deg) rotateZ(45deg) skew(0deg, 0deg);
    transform-style: preserve-3d; }
  header .hamburger-btn .hamburger-lines.open .close-middle {
    opacity: 0; }
  header .hamburger-btn .hamburger-lines.open .close-bottom {
    transform: translate3d(0px, -10px, 0px) scale3d(1, 1, 1) rotateX(0deg) rotateY(0deg) rotateZ(-45deg) skew(0deg, 0deg);
    transform-style: preserve-3d; }
  header .menu-overlay {
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
    width: 100%;
    height: 0;
    overflow: hidden;
    -webkit-transition: all ease .8s;
    transition: all ease .8s; }
    header .menu-overlay .nav-menu {
      display: block;
      position: absolute;
      width: 100%;
      top: 100%;
      left: 0;
      right: 0;
      top: 0;
      background-color: #222222;
      padding: 10px 15px;
      z-index: 200;
      transform: translateY(-80vh) translateX(0px);
      -webkit-transition: all ease .8s;
      transition: all ease .8s; }
      header .menu-overlay .nav-menu ul {
        flex-direction: column;
        gap: 0px; }
        header .menu-overlay .nav-menu ul li a {
          font-size: 1.25rem;
          text-align: left;
          padding: 15px 0px; }
        header .menu-overlay .nav-menu ul li a.active {
          border-bottom: solid 1px #fff; }
        header .menu-overlay .nav-menu ul li:not(:last-child)::after {
          top: auto;
          right: 0px;
          bottom: 0px;
          width: 100%;
          height: 1px; }
  header .menu-overlay.open {
    display: block;
    height: 600px; }
    header .menu-overlay.open .nav-menu {
      transform: translateY(0vh) translateX(0px); }
  @media screen and (max-width: 1580px) {
    header {
      padding-top: 80px; } }
  @media screen and (max-width: 1380px) {
    header {
      padding-top: 70px; } }
  @media screen and (max-width: 1140px) {
    header {
      padding-top: 40px; }
      header a.brand img {
        max-width: 205px; } }

.main-section {
  height: 823px; }
  .main-section .container {
    margin-bottom: -115px;
    z-index: 2; }
  .main-section p {
    font-size: 24px;
    line-height: 30px; }
  @media screen and (max-width: 1580px) {
    .main-section {
      height: 665px; }
      .main-section p {
        font-size: 22px;
        line-height: 26px; } }
  @media screen and (max-width: 1380px) {
    .main-section {
      height: 565px; }
      .main-section .container {
        margin-bottom: -95px; }
      .main-section p {
        font-size: 20px;
        line-height: 22px; } }
  @media screen and (max-width: 1380px) {
    .main-section {
      height: auto;
      padding: 200px 0 70px; }
      .main-section .container {
        margin-bottom: -95px; }
      .main-section p {
        font-size: 18px; } }

.solutions-section {
  padding: 150px 0;
  z-index: 1; }
  .solutions-section:after {
    content: '';
    background-image: url("../img/home/shape-1.svg");
    position: absolute;
    right: 0;
    bottom: -190px;
    width: 930px;
    height: 478px;
    pointer-events: none;
    z-index: -1; }
  .solutions-section h2 {
    margin-bottom: 50px; }
  .solutions-section img {
    border-radius: 30px;
    max-width: 460px;
    margin-left: auto; }
  .solutions-section h3 {
    font-size: 22px;
    font-weight: 700; }
  .solutions-section br {
    display: none; }
  .solutions-section p {
    font-size: 18px;
    margin-bottom: 0; }
  .solutions-section ul {
    padding-left: 0;
    list-style-type: none;
    margin-bottom: 50px; }
    .solutions-section ul li {
      max-width: 682px; }
  .solutions-section li:not(:last-child) {
    padding-bottom: 32px;
    border-bottom: 1px solid #FFF; }
  .solutions-section li:not(:first-child) {
    padding-top: 32px; }
  @media screen and (max-width: 1580px) {
    .solutions-section:after {
      transform: scale(0.8);
      transform-origin: right; }
    .solutions-section h3 {
      font-size: 20px; }
    .solutions-section p {
      font-size: 16px; } }
  @media screen and (max-width: 1380px) {
    .solutions-section {
      padding: 120px 0; } }
  @media screen and (max-width: 1140px) {
    .solutions-section {
      padding: 80px 0; }
      .solutions-section h2 {
        margin-bottom: 40px; }
      .solutions-section ul li {
        max-width: 100%; }
      .solutions-section h3 {
        font-size: 18px; }
      .solutions-section p {
        font-size: 14px; }
      .solutions-section img {
        max-width: 100%;
        margin-top: 30px; } }

.numbers-section {
  background-color: #555555; }
  .numbers-section .numbers-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 0 116px; }
    .numbers-section .numbers-grid .number-wrapper {
      display: flex;
      gap: 32px;
      align-items: center; }
      .numbers-section .numbers-grid .number-wrapper .circle {
        width: 78px;
        height: 78px;
        min-width: 78px;
        border-radius: 50%;
        border: 1px solid white; }
      .numbers-section .numbers-grid .number-wrapper p {
        font-size: 22px;
        margin-bottom: 0; }
      .numbers-section .numbers-grid .number-wrapper:first-child, .numbers-section .numbers-grid .number-wrapper:nth-child(2) {
        padding-bottom: 35px;
        border-bottom: 1px solid white; }
      .numbers-section .numbers-grid .number-wrapper:nth-child(3), .numbers-section .numbers-grid .number-wrapper:nth-child(4) {
        padding-top: 35px; }
  @media screen and (max-width: 1580px) {
    .numbers-section .numbers-grid .number-wrapper {
      gap: 26px; }
      .numbers-section .numbers-grid .number-wrapper p {
        font-size: 20px; }
      .numbers-section .numbers-grid .number-wrapper .circle {
        transform: scale(0.9);
        transform-origin: left; } }
  @media screen and (max-width: 1140px) {
    .numbers-section .numbers-grid {
      grid-template-columns: 1fr; }
      .numbers-section .numbers-grid .number-wrapper {
        gap: 5px;
        border: none !important;
        padding: 5px 0 !important; }
        .numbers-section .numbers-grid .number-wrapper p {
          font-size: 18px; }
        .numbers-section .numbers-grid .number-wrapper .circle {
          transform: scale(0.8); } }

.numbers-section._2 {
  background-color: #fff; }
  .numbers-section._2 * {
    color: #222222; }
  .numbers-section._2 .numbers-grid .number-wrapper .circle {
    border: 1px solid #222222; }
  .numbers-section._2 .numbers-grid .number-wrapper:first-child, .numbers-section._2 .numbers-grid .number-wrapper:nth-child(2) {
    border-bottom: 1px solid #222222; }

.big-numbers .flex {
  display: flex;
  justify-content: space-between;
  gap: 60px;
  flex-wrap: wrap; }
  .big-numbers .flex .item:last-child:after {
    display: none; }
.big-numbers .item {
  position: relative;
  width: calc(25% - 45px); }
  .big-numbers .item:after {
    content: '';
    position: absolute;
    right: -30px;
    top: -20px;
    border-right: solid 1px #fff;
    height: 130%;
    width: 1px; }
  .big-numbers .item span.counter {
    font-family: Sentient;
    font-size: 50px;
    font-weight: 400; }
  .big-numbers .item span.count {
    font-size: 70px; }
  .big-numbers .item p {
    font-weight: 300;
    margin-bottom: 0; }
@media screen and (max-width: 1580px) {
  .big-numbers .item span.counter {
    font-size: 40px; }
  .big-numbers .item span.count {
    font-size: 60px; } }
@media screen and (max-width: 1140px) {
  .big-numbers .flex {
    flex-direction: column; }
    .big-numbers .flex .item {
      width: 100%;
      gap: 30px; }
      .big-numbers .flex .item:after {
        right: auto;
        top: auto;
        border-bottom: solid 1px #fff;
        height: 1px;
        width: 100%;
        bottom: -15px;
        left: 0; } }

.partner-sect {
  height: 1060px;
  padding: 0 0 120px; }
  @media screen and (max-width: 1580px) {
    .partner-sect {
      height: 860px;
      padding: 0 0 100px; } }
  @media screen and (max-width: 1380px) {
    .partner-sect {
      height: 760px;
      padding: 0 0 80px; } }
  @media screen and (max-width: 1140px) {
    .partner-sect {
      height: 650px;
      padding: 0 0 50px; } }

.contact-section {
  background-color: #D9D9D9; }
  .contact-section * {
    color: #222222; }
  .contact-section img.absolute {
    position: absolute;
    left: 0;
    top: 0;
    width: auto;
    height: 100%;
    max-width: 38vw;
    object-fit: cover; }
  .contact-section .contact-wrapper h2 {
    margin-bottom: 20px; }
  .contact-section .contact-wrapper form {
    margin-top: 32px; }
    .contact-section .contact-wrapper form input, .contact-section .contact-wrapper form textarea, .contact-section .contact-wrapper form .curriculo-wrapper, .contact-section .contact-wrapper form .area-label, .contact-section .contact-wrapper form select {
      width: 100%;
      line-height: 1;
      margin-bottom: 12px;
      background-color: transparent;
      border: 1px solid #222;
      border-radius: 30px;
      padding: 11px 20px;
      font-size: 16px; }
      .contact-section .contact-wrapper form input::placeholder, .contact-section .contact-wrapper form textarea::placeholder, .contact-section .contact-wrapper form .curriculo-wrapper::placeholder, .contact-section .contact-wrapper form .area-label::placeholder, .contact-section .contact-wrapper form select::placeholder {
        color: #222; }
      .contact-section .contact-wrapper form input:focus, .contact-section .contact-wrapper form textarea:focus, .contact-section .contact-wrapper form .curriculo-wrapper:focus, .contact-section .contact-wrapper form .area-label:focus, .contact-section .contact-wrapper form select:focus {
        outline: none; }
    .contact-section .contact-wrapper form textarea {
      border-radius: 20px;
      padding: 17px 20px;
      max-height: 130px; }
    .contact-section .contact-wrapper form .input-box {
      display: flex;
      gap: 8px; }
    .contact-section .contact-wrapper form .select-wrapper {
      width: 100%;
      position: relative; }
    .contact-section .contact-wrapper form .select-wrapper .left-icon {
      position: absolute;
      left: 22px;
      top: 6px; }
    .contact-section .contact-wrapper form select {
      padding-left: 42px;
      width: 100%;
      -webkit-appearance: none;
      -moz-appearance: none;
      appearance: none; }
      .contact-section .contact-wrapper form select::before {
        content: url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" width="9" height="5" viewBox="0 0 9 5" fill="none"><path d="M5.02532 4.79225L8.78112 1.21133C9.07166 0.934041 9.07166 0.485043 8.78112 0.207754C8.49059 -0.0692513 8.01936 -0.0692513 7.72853 0.207754L4.49902 3.28717L1.26922 0.207754C0.978683 -0.0692516 0.507458 -0.0692517 0.216627 0.207753C0.0713596 0.346256 -0.00127413 0.527899 -0.00127414 0.709542C-0.00127415 0.891184 0.0713596 1.07283 0.216627 1.21133L3.97243 4.79225C4.26296 5.06925 4.73419 5.06925 5.02502 4.79225L5.02532 4.79225Z" fill="%23222222"/></svg>');
        display: block;
        width: 5px;
        height: 9px; }
    .contact-section .contact-wrapper form .area-label {
      display: flex;
      align-items: center;
      max-width: fit-content; }
    .contact-section .contact-wrapper form input[type="file"] {
      display: none; }
    .contact-section .contact-wrapper form .curriculo-wrapper {
      position: relative;
      padding-left: 54px; }
      .contact-section .contact-wrapper form .curriculo-wrapper .circle {
        position: absolute;
        border-radius: 50%;
        width: 22px;
        display: flex;
        justify-content: center;
        align-items: center;
        left: 20px;
        top: 8px;
        height: 22px;
        border: 1px solid #222; }
      .contact-section .contact-wrapper form .curriculo-wrapper p {
        color: #222;
        margin-bottom: 0;
        font-size: 16px;
        line-height: 1; }
        .contact-section .contact-wrapper form .curriculo-wrapper p span {
          font-size: 10px; }
    .contact-section .contact-wrapper form .checkbox-container {
      display: flex;
      gap: 12px;
      margin-bottom: 22px;
      align-items: center; }
      .contact-section .contact-wrapper form .checkbox-container input[type="checkbox"] {
        margin-bottom: 0;
        position: absolute;
        opacity: 0;
        width: 0;
        height: 0; }
      .contact-section .contact-wrapper form .checkbox-container label {
        margin: 0; }
      .contact-section .contact-wrapper form .checkbox-container span.wpcf7-form-control-wrap {
        width: 100%; }
      .contact-section .contact-wrapper form .checkbox-container span.wpcf7-list-item-label {
        cursor: pointer;
        padding-left: 35px; }
      .contact-section .contact-wrapper form .checkbox-container .checkmark {
        cursor: pointer;
        width: 24px;
        min-width: 24px;
        height: 24px;
        border: 1px solid #222;
        border-radius: 50%;
        position: absolute;
        z-index: -1; }
      .contact-section .contact-wrapper form .checkbox-container .checkmark.active {
        background-color: #222;
        background-image: url("data:image/svg+xml,%3Csvg fill='none' stroke='white' stroke-width='2' viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M5 13l4 4L19 7'/%3E%3C/svg%3E");
        background-repeat: no-repeat;
        background-position: center; }
    .contact-section .contact-wrapper form .btn.btn-primary._2 {
      margin-left: auto;
      padding: 14px 30px;
      font-size: 18px;
      max-width: max-content;
      border-radius: 0px; }
  @media screen and (max-width: 1140px) {
    .contact-section img.absolute {
      display: none; }
    .contact-section .contact-wrapper form input, .contact-section .contact-wrapper form textarea, .contact-section .contact-wrapper form .curriculo-wrapper, .contact-section .contact-wrapper form .area-label, .contact-section .contact-wrapper form select {
      padding: 12px 16px;
      font-size: 14px; }
    .contact-section .contact-wrapper form select {
      padding-left: 40px; }
    .contact-section .contact-wrapper form .curriculo-wrapper p {
      font-size: 12px;
      padding-left: 40px; }
    .contact-section .contact-wrapper form .circle svg {
      margin-top: -1px; }
    .contact-section .contact-wrapper form .checkbox-container {
      font-size: 12px;
      line-height: 1.2; } }

.contact-section._2 {
  background-color: #222222; }
  .contact-section._2 * {
    color: #fff; }
  .contact-section._2 form input, .contact-section._2 form textarea {
    border: 1px solid #fff; }
    .contact-section._2 form input::placeholder, .contact-section._2 form textarea::placeholder {
      color: #fff; }
  .contact-section._2 form .btn.btn-primary._2 {
    background-color: #fff !important;
    color: #222222; }
  .contact-section._2 form span.wpcf7-form-control-wrap {
    width: 100%; }

.top-sect {
  background-color: #fff;
  padding: 43px 0; }
  .top-sect h1 {
    color: #222222;
    margin-bottom: 0; }
  @media screen and (max-width: 1140px) {
    .top-sect {
      padding: 28px 0; } }

.breadcrumb-custom {
  display: flex;
  margin-bottom: 20px;
  gap: 14px;
  align-items: center; }
  .breadcrumb-custom a, .breadcrumb-custom p {
    font-size: 16px;
    font-weight: 300;
    line-height: 1;
    color: #555555;
    margin-bottom: 0; }
  @media screen and (max-width: 1140px) {
    .breadcrumb-custom {
      margin-bottom: 10px;
      gap: 10px; }
      .breadcrumb-custom a, .breadcrumb-custom p {
        font-size: 14px; } }

.sobre-hero {
  min-height: 848px; }
  @media screen and (max-width: 1580px) {
    .sobre-hero {
      min-height: 678px; } }
  @media screen and (max-width: 1380px) {
    .sobre-hero {
      min-height: 578px; } }
  @media screen and (max-width: 1140px) {
    .sobre-hero {
      min-height: 450px; } }

.features-section {
  background-color: #222;
  padding: 90px 0 200px; }
  .features-section p {
    font-weight: 300; }
    .features-section p:not(:first-child) {
      margin-top: 38px; }
  .features-section h2 {
    margin: 80px 0; }
  .features-section .features-wrapper {
    display: flex;
    flex-wrap: wrap;
    gap: 16px;
    row-gap: 125px; }
    .features-section .features-wrapper .feature-card {
      border-radius: 30px;
      border: 1px solid #fff;
      padding: 42px 37px 120px 40px;
      position: relative;
      max-width: 290px;
      width: 100%; }
      .features-section .features-wrapper .feature-card h3 {
        font-size: 22px;
        font-weight: 700;
        margin-bottom: 0; }
      .features-section .features-wrapper .feature-card img {
        position: absolute;
        width: calc(100% + 2px);
        border-radius: 30px;
        left: -1px;
        bottom: -100px; }
  @media screen and (max-width: 1380px) {
    .features-section {
      padding: 60px 0 160px; } }
  @media screen and (max-width: 1140px) {
    .features-section {
      padding: 60px 0 80px; }
      .features-section h2 {
        margin: 60px 0; }
      .features-section p:not(:first-child) {
        margin-top: 20px; }
      .features-section .features-wrapper {
        flex-direction: column;
        gap: 40px; }
        .features-section .features-wrapper .feature-card {
          max-width: 100%;
          padding: 30px 20px 0 20px; }
          .features-section .features-wrapper .feature-card img {
            position: relative;
            max-width: none;
            width: calc(100% + 50px);
            left: -25px;
            margin-bottom: -10px;
            bottom: auto;
            margin-top: 10px; } }

.team-banner {
  padding: 60px 0;
  height: 530px; }
  @media screen and (max-width: 1380px) {
    .team-banner {
      padding: 50px 0;
      height: 440px; } }
  @media screen and (max-width: 1140px) {
    .team-banner {
      height: 350px; } }

.cta-section {
  padding: 120px 0;
  background-color: #555555; }
  .cta-section:after {
    content: '';
    background-image: url("../img/sobre/shape-cta.svg");
    position: absolute;
    right: 0;
    top: -140px;
    width: 818px;
    height: 478px;
    pointer-events: none; }
  @media screen and (max-width: 1380px) {
    .cta-section {
      padding: 100px 0; } }
  @media screen and (max-width: 1140px) {
    .cta-section {
      padding: 80px 0; } }

.hero-team {
  padding: 50px 0;
  height: 535px; }
  @media screen and (max-width: 1580px) {
    .hero-team {
      height: 435px; } }
  @media screen and (max-width: 1140px) {
    .hero-team {
      height: auto; } }

.team-members {
  padding: 0; }
  .team-members:after {
    content: '';
    background-image: url("../img/equipe/shape-team.svg");
    position: absolute;
    left: 0;
    top: -80px;
    width: 435px;
    height: 478px;
    pointer-events: none; }
  .team-members .member {
    padding: 80px 0; }
    .team-members .member .top {
      display: flex;
      justify-content: space-between; }
    .team-members .member .teammate-img {
      max-width: 378px;
      max-height: 378px; }
      .team-members .member .teammate-img img {
        max-height: 100%;
        height: 100%;
        border-radius: 30px;
        object-fit: cover; }
    .team-members .member .container {
      display: flex;
      gap: 65px; }
    .team-members .member .info {
      display: flex;
      flex-direction: column;
      justify-content: space-between;
      gap: 20px; }
      .team-members .member .info h2 {
        font-size: 32px;
        line-height: 42px;
        margin-bottom: 0; }
      .team-members .member .info h3 {
        font-size: 24px;
        font-weight: 400; }
      .team-members .member .info p {
        font-size: 18px; }
      .team-members .member .info p:last-child {
        margin: 0; }
  .team-members .member:nth-child(odd) {
    background-color: #222222; }
  .team-members .member:nth-child(even) {
    background-color: #555555; }
  @media screen and (max-width: 1580px) {
    .team-members .member .info h2 {
      font-size: 30px;
      line-height: 38px; }
    .team-members .member .info h3 {
      font-size: 22px; }
    .team-members .member .info p {
      font-size: 16px; } }
  @media screen and (max-width: 1380px) {
    .team-members .member {
      padding: 70px 0; } }
  @media screen and (max-width: 1140px) {
    .team-members .member {
      padding: 50px 0; }
      .team-members .member .container {
        gap: 20px;
        flex-direction: column; }
      .team-members .member .teammate-img {
        max-width: 100%;
        max-height: none;
        width: 100%; }
        .team-members .member .teammate-img img {
          width: 100%; }
      .team-members .member .top {
        flex-direction: column;
        align-items: start; }
      .team-members .member .info h2 {
        font-size: 28px;
        line-height: 30px;
        margin-bottom: 10px; }
      .team-members .member .info h3 {
        font-size: 20px;
        margin-bottom: 15px; }
      .team-members .member .info p {
        font-size: 14px; } }

.hero-banner {
  height: 650px; }
  @media screen and (max-width: 1580px) {
    .hero-banner {
      height: 535px; } }
  @media screen and (max-width: 1380px) {
    .hero-banner {
      height: 435px; } }
  @media screen and (max-width: 1140px) {
    .hero-banner {
      height: 390px;
      padding-bottom: 40px; } }

.services-list {
  z-index: 1; }
  .services-list:after {
    content: '';
    background-image: url("../img/servicos/shape-servicos.svg");
    position: absolute;
    right: 0;
    bottom: -230px;
    width: 658px;
    height: 478px;
    pointer-events: none; }
  .services-list .services-grid {
    display: flex;
    flex-direction: column;
    gap: 30px; }
  .services-list .service-container {
    width: 100%;
    height: 297px;
    border: 1px solid #FFF;
    border-radius: 30px;
    display: flex;
    justify-content: space-between; }
    .services-list .service-container h2 {
      font-size: 35px;
      line-height: 40px; }
    .services-list .service-container img {
      border-radius: 30px;
      height: calc(100% + 2px);
      margin-top: -1px;
      margin-right: -1px; }
    .services-list .service-container > div {
      padding: 48px 0 48px 54px;
      height: 100%;
      display: flex;
      flex-direction: column;
      justify-content: space-between; }
      .services-list .service-container > div p {
        margin-bottom: 0; }
  @media screen and (max-width: 1580px) {
    .services-list h2 {
      font-size: 32px;
      line-height: 36px; } }
  @media screen and (max-width: 1380px) {
    .services-list:after {
      transform: scale(0.8);
      transform-origin: right; } }
  @media screen and (max-width: 1140px) {
    .services-list .service-container {
      flex-direction: column;
      height: auto; }
      .services-list .service-container > div {
        padding: 30px 20px; }
      .services-list .service-container h2 {
        font-size: 30px;
        line-height: 30px; }
      .services-list .service-container img {
        height: auto;
        margin-top: 0;
        margin-right: 0;
        max-width: none;
        width: calc(100% + 2px);
        margin-left: -1px;
        margin-bottom: -8px; } }

.cta-services {
  height: 500px; }
  @media screen and (max-width: 1380px) {
    .cta-services {
      height: 420px; } }
  @media screen and (max-width: 1140px) {
    .cta-services {
      height: auto; } }

.blog-articles {
  background-color: #777777; }
  .blog-articles .blog-wrapper {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 80px 30px; }
  .blog-articles .blog-post {
    width: 100%;
    display: flex;
    flex-direction: column;
    gap: 30px;
    cursor: pointer; }
    .blog-articles .blog-post .blog-image {
      width: 100%;
      height: 240px;
      border-radius: 30px;
      overflow: hidden; }
      .blog-articles .blog-post .blog-image img {
        width: 100%;
        height: 100%;
        object-fit: cover;
        transition: all ease 300ms; }
    .blog-articles .blog-post .bottom {
      width: 100%;
      display: flex;
      justify-content: space-between;
      gap: 20px; }
      .blog-articles .blog-post .bottom .button {
        border: 1px solid #FFF;
        height: 40px;
        width: 40px;
        min-width: 40px;
        display: flex;
        justify-content: center;
        align-items: center;
        transition: all ease 200ms; }
    .blog-articles .blog-post h3 {
      font-weight: 400;
      font-size: 22px;
      margin-bottom: 0; }
    .blog-articles .blog-post:hover .blog-image img {
      transform: scale(1.05); }
    .blog-articles .blog-post:hover .bottom .button {
      transform: translateX(4px); }
  .blog-articles a.more {
    background-color: white;
    margin-left: auto;
    padding: 14px;
    font-size: 18px;
    margin-top: 0px; }
  @media screen and (max-width: 1140px) {
    .blog-articles .blog-wrapper {
      grid-template-columns: 1fr;
      margin-bottom: 30px; }
    .blog-articles .blog-post {
      gap: 20px; }
      .blog-articles .blog-post .blog-image {
        height: 200px; }
      .blog-articles .blog-post h3 {
        font-size: 20px; }
      .blog-articles .blog-post .bottom {
        align-items: center; }
        .blog-articles .blog-post .bottom .button {
          transform: scale(0.9);
          transform-origin: right; } }

.blog-articles._2 {
  background-color: #111; }
  .blog-articles._2 #load-more {
    background-color: white; }

.blog-articles._2._relacionados {
  background-color: #EFEFEF; }
  .blog-articles._2._relacionados * {
    color: #222222 !important; }
  .blog-articles._2._relacionados .blog-post .bottom .button {
    border: 1px solid #222222; }
    .blog-articles._2._relacionados .blog-post .bottom .button svg path {
      fill: #222222; }

.hero-blog {
  height: 550px;
  padding: 50px 0; }
  .hero-blog .container {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    height: 100%; }
  .hero-blog .breadcrumb-custom a, .hero-blog .breadcrumb-custom p {
    color: #fff; }
  .hero-blog .content {
    max-width: 60%; }
  .hero-blog h4 {
    font-size: 16px;
    line-height: 22px;
    font-weight: 300; }
  .hero-blog .blog-info {
    gap: 10px;
    display: flex;
    align-items: center;
    margin-bottom: 30px; }
    .hero-blog .blog-info span {
      font-weight: 300;
      font-size: 16px; }
    .hero-blog .blog-info .circle {
      width: 6px;
      height: 6px;
      border-radius: 50%;
      background-color: white;
      display: block; }
  @media screen and (max-width: 1380px) {
    .hero-blog {
      height: 470px;
      padding: 40px 0; } }
  @media screen and (max-width: 1140px) {
    .hero-blog .blog-info {
      margin-bottom: 20px; }
      .hero-blog .blog-info span {
        font-size: 14px; } }

.post-content {
  padding: 60px 0;
  background-color: #EFEFEF; }
  .post-content * {
    color: #222222; }
  .post-content .share {
    display: flex;
    flex-direction: column;
    gap: 14px; }
    .post-content .share a {
      padding: 0;
      background-color: #222;
      border-radius: 50%;
      width: 58px;
      height: 58px;
      display: flex;
      justify-content: center;
      align-items: center; }
  .post-content article h2, .post-content article h3 {
    margin: 40px 0 10px; }
  .post-content article h3 {
    font-size: 2.125rem; }
  @media screen and (max-width: 1140px) {
    .post-content {
      padding: 40px 0; }
      .post-content .share {
        flex-direction: row;
        margin-top: 20px;
        transform: scale(0.8);
        transform-origin: left; }
      .post-content article h2, .post-content article h3 {
        margin: 30px 0 10px; }
      .post-content article h3 {
        font-size: 1.75rem; } }

.carreiras-hero {
  padding: 120px 0; }
  @media screen and (max-width: 1380px) {
    .carreiras-hero {
      padding: 100px 0; } }

.about-carreira {
  background-color: #111;
  padding: 150px 0; }
  .about-carreira img.absolute {
    position: absolute;
    top: 0;
    right: 0;
    width: 50vw;
    height: 100%;
    object-fit: cover;
    pointer-events: none; }
  .about-carreira ul {
    font-size: 22px;
    font-weight: 300; }
  @media screen and (max-width: 1580px) {
    .about-carreira {
      padding: 100px 0; }
      .about-carreira ul {
        font-size: 20px; } }
  @media screen and (max-width: 1380px) {
    .about-carreira {
      padding: 80px 0; }
      .about-carreira ul {
        font-size: 18px; } }
  @media screen and (max-width: 1140px) {
    .about-carreira {
      padding: 60px 0 0; }
      .about-carreira ul {
        font-size: 16px;
        padding-left: 25px; }
      .about-carreira img.absolute {
        position: relative;
        width: 100%;
        margin-top: 20px; } }

section.map .map-wrapper {
  position: relative;
  width: 100%;
  height: 450px;
  margin-top: 50px; }
  section.map .map-wrapper iframe {
    width: 100%;
    height: 100%; }

footer {
  background-color: #222;
  padding: 94px 0; }
  footer .newsletter {
    border: 1px solid #FFF;
    border-radius: 30px;
    padding: 70px 88px;
    display: flex;
    gap: 40px;
    margin-bottom: 70px; }
    footer .newsletter .text {
      min-width: fit-content; }
    footer .newsletter h2 {
      font-size: 30px;
      line-height: 34px;
      margin-bottom: 8px; }
    footer .newsletter form {
      display: flex;
      flex-direction: column;
      gap: 12px;
      width: 100%; }
      footer .newsletter form input {
        width: 100%;
        border: 1px solid #fff;
        padding: 12px 30px;
        border-radius: 30px;
        color: white;
        background-color: transparent;
        line-height: 1; }
        footer .newsletter form input::placeholder {
          color: white; }
      footer .newsletter form .btn.btn-primary {
        gap: 10px;
        font-size: 18px;
        padding: 14px 21px;
        margin-left: auto; }
    footer .newsletter .formulario .wpcf7-not-valid-tip {
      margin: 0px 10px -5px; }
  footer p {
    margin: 0; }
  footer img.brand {
    max-width: 279px; }
  footer .row h3 {
    margin-bottom: 13px;
    font-size: 20px;
    font-weight: 600; }
  footer .row .links-footer ul {
    list-style-type: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-wrap: wrap;
    gap: 10px 25px; }
    footer .row .links-footer ul li {
      width: calc(25% - 20px); }
      footer .row .links-footer ul li a {
        color: #D9D9D9;
        font-weight: 300; }
        footer .row .links-footer ul li a:hover {
          color: #fff; }
  footer .copy {
    margin-top: 70px;
    display: flex;
    justify-content: space-between;
    align-items: center; }
    footer .copy a {
      margin-left: auto;
      margin-bottom: 0; }
    footer .copy p {
      font-size: 16px;
      font-weight: 400;
      margin-left: auto; }
  @media screen and (max-width: 1580px) {
    footer .newsletter h2 {
      font-size: 28px; } }
  @media screen and (max-width: 1380px) {
    footer .newsletter {
      padding: 60px 78px; } }
  @media screen and (max-width: 1140px) {
    footer {
      padding: 50px 0; }
      footer .newsletter {
        padding: 30px 30px;
        flex-direction: column;
        gap: 20px; }
        footer .newsletter h2 {
          font-size: 26px;
          line-height: 30px; }
        footer .newsletter form input {
          padding: 12px 20px; }
        footer .newsletter .btn.btn-primary {
          border-radius: 100px; }
      footer .social-flex {
        justify-content: left;
        margin: 30px 0; }
      footer .row .links-footer ul li {
        width: calc(50% - 20px); }
      footer .copy {
        justify-content: center;
        align-items: center;
        flex-direction: column-reverse;
        gap: 20px;
        text-align: center;
        margin-top: 40px; }
        footer .copy a {
          margin-left: unset; }
        footer .copy p {
          font-size: 14px; } }

/*# sourceMappingURL=styles.css.map */
