* {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

/* Colors */
:root {
  --color-primary: #0f98d9;
  --color-primary-dark: #087aae;
  --color-secondary: #8d8bac;
  --color-dark: #292839;
  --color-light: #ece9fb;
  --color-white: #fff;
  --color-black: #000;

  /* rgb */
  --bs-primary-rgb:15, 152, 217;
  --bs-dark-rgb: 41, 40, 57;
}

body {
    font-size: 16px;
    line-height: 1.4;
    -moz-osx-font-smoothing: grayscale;
    -webkit-font-smoothing: antialiased;
    overscroll-behavior: none;
    letter-spacing: 0.3px;
}

img {
    height: auto;
    max-width: 100%;
}

a {
    text-decoration: none;
    color: var(--color-primary);
    transition: 0.3s ease-in-out;
}
a:hover {
   color: var(--color-dark);
}

.btn-primary {
    --bs-btn-color: #fff;
    --bs-btn-bg: var(--color-primary);
    --bs-btn-border-color: var(--color-primary);
    --bs-btn-hover-color: #fff;
    --bs-btn-hover-bg: var(--color-primary-dark);
    --bs-btn-hover-border-color: var(--color-primary-dark);
    --bs-btn-focus-shadow-rgb: 49, 132, 253;
    --bs-btn-active-color: #fff;
    --bs-btn-active-bg: var(--color-primary-dark);
    --bs-btn-active-border-color: var(--color-primary-dark);
    --bs-btn-active-shadow: inset 0 3px 5px rgba(0, 0, 0, 0.125);
    --bs-btn-disabled-color: #fff;
    --bs-btn-disabled-bg: var(--color-primary);
    --bs-btn-disabled-border-color: var(--color-primary);
}

/* header */
.header { padding: 10px 0; position: fixed; z-index: 7; left: 0; top: 0; width: 100%; border-bottom: 1px solid rgba(255,255,255,0.1); transition: 0.3s ease-in-out ; }
.header .header-logo { width: 50px; }
.header ul { list-style: none; padding-left: 80px; }
.header ul li+li { margin-left: 50px; }
.header ul li a { font-size: 18px; color: var(--color-white)}
.header ul li.active a,
.header ul li a:hover { color: var(--color-primary); }
.header .header-contact img { width: 38px; margin-right: 5px; }
.header .header-contact a { color: var(--color-white); font-size: 18px; font-weight: 700; }
.header .header-contact a:hover { color: var(--color-primary); }
.header .header-backdrop { display: none; position: fixed; left: 0; top: 0; width: 100%; height: 100%; background-color: rgba(0,0,0,0.6); z-index: 8; opacity: 0; visibility: hidden; transition: 0.3s ease-in-out; }
.header .header-toggle { display: none; width: 25px; height: 20px; position: relative; }
.header .header-toggle span { font-size: 0; color: transparent; height: 2px; position: absolute; top: 50%; left: 0; width: 100%; transform: translateY(-50%); background: #fff; }
.header .header-toggle span::before,
.header .header-toggle span::after { content: ''; display: block; width: 100%; height: 2px; position: absolute; left: 0; transition: 0.3s ease-in-out; background: #fff; }
.header .header-toggle span::before { top: -7px; }
.header .header-toggle span::after { bottom: -7px; }
.header .header-toggle.active span { background: transparent; }
.header .header-toggle.active span::before { top: 0; transform: rotate(45deg) }
.header .header-toggle.active span::after { bottom: 0; transform: rotate(-45deg) }
.header.active { border-bottom: 0; box-shadow: 0 5px 10px rgba(0,0,0,0.1); background-color: var(--color-dark); }

/* banner */
.banner { padding: 120px 0 50px; min-height: 500px; background-repeat: no-repeat; background-size: cover; background-position: center; background-attachment: fixed; }
.banner::before { width: 100%; background-color: var(--color-black); opacity: 0.7; mix-blend-mode: multiply; content: ''; position: absolute; left: 0; height: 100%; top: 0; }
.banner > div { z-index: 1; }
.banner p { font-size: 20px; opacity: 0.8; }
.banner article { max-width: 600px; margin: 0 auto; }

/* drives */
.drives picture { height: 170px; background-color: rgba(255,255,255,0.1); }
.drives img { width: 100px; margin: 0 auto; display: block; }
.drives article { background-color: rgba(255,255,255,0.1); border-radius: 10px; overflow: hidden; }
.drives p { letter-spacing: 0.5px; opacity: 0.7; font-weight: 300; }

/* workflow */
.workflow .workflow-card { padding: 30px 0 30px 100px; }
.workflow .workflow-card:first-child::before { top: 50%; }
.workflow .workflow-card:last-child::before { height: 50%; }
.workflow .workflow-card strong { position: absolute; left: 0; top: 50%; transform: translate(-50%, -50%); font-size: 20px; line-height: 1; width: 50px; height: 50px; border: 1px solid #eeeded; }
.workflow .workflow-card::before { content: ''; position: absolute; left: 0; top: 0; width: 1px; height: 100%; background-color: #afabab; }
.workflow .workflow-card picture { width: 80px; height: 80px; }
.workflow .workflow-card img { width: 60px; }
.workflow .workflow-card aside { width: calc(100% - 80px); padding-left: 30px; }

/* choose us */
.choose-us .choose-us-card { border-radius: 10px; border: 2px dashed rgba(255,255,255,0.2); transition: 0.3s ease-in-out; }
.choose-us .choose-us-card picture { width: 100px; height: 100px; background-color: rgba(255,255,255,0.1); }
.choose-us .choose-us-card img { width: 70px; }
.choose-us .choose-us-card:hover { background-color: rgba(255,255,255,0.2); }

/* clients */
.clients .slick-track { display: flex; }
.clients .slick-track::before, 
.clients .slick-track::after{ display: none; }
.clients .slick-slide { padding: 0 10px; height: auto; }
.clients picture { max-height: 120px; height: 100%; display: flex; width: 100%; padding: 15px; border: 1px solid rgba(0,0,0,0.1); border-radius: 5px; }
.clients img { max-height: 80%; }

/* contact-us */
.contact-us picture { width: 100px; height: 100px; }
.contact-us img { max-width: 70%; max-height: 60%; width: 100%; }
.contact-us a { color: currentColor; }
.contact-us a:hover { color: var(--color-primary); }

/* service */
.service .service-card { box-shadow: 0 0 10px rgba(0,0,0,0.1); transition: 0.3s ease-in-out; border-radius: 10px; overflow: hidden; }
.service .service-card p { color: rgba(0,0,0,0.6) }
.service .service-card img { width: 100%; aspect-ratio: 16/9; object-fit: cover; transition: 2s ease-in-out; }
.service .service-card:hover { box-shadow: 0 0 30px rgba(0,0,0,0.1); }
.service .service-card:hover img  { transform: scale(1.2); }

/* contactForm */
.contactForm iframe { height: 100%; width: 100%; min-height: 400px; border-radius: 10px; }

/* whatsapp */
.whatsapp { position: fixed; left: 0; bottom: 20px; left: 20px; z-index: 2; width: 50px;  height: 50px; border-radius: 50%; background-color: #48c357; padding: 12px; box-shadow: 0 0 10px rgba(0,0,0,0.2); }

/* footer */
.footer { color: rgba(255,255,255,0.8); }
.footer h4 { font-weight: 700; }
.footer a { opacity: 0.8; color: var(--color-white); }
.footer a:hover { opacity: 1; color: var(--color-primary); }
.footer ul { list-style: none; }
.footer ul li { margin-bottom: 7px; }
.footer ul a { color: var(--color-white); }
.footer ul a.active,
.footer ul a:hover { color: var(--color-primary); }
.footer .footer-social { gap: 10px; }
.footer .footer-social a { width: 40px; height: 40px; opacity: 1; border-radius: 50%; background-color: var(--color-primary); }
.footer .footer-social img { max-height: 50%; }
.footer .footer-social a:hover { background-color: var(--color-primary-dark); }
.footer .footer-copyright { border-top: 1px solid rgba(255,255,255,0.3); opacity: 0.7; }

@media only screen and (max-width: 991px){
    .banner { min-height: 350px; }
}
@media only screen and (max-width: 767px){
    .header .header-logo { width: 40px; }
    .header nav { transform: translateX(-105%); transition: 0.3s ease-in-out; position: fixed; left: 0; top: 0; height: 100%; width: 280px; background-color: var(--color-dark); z-index: 9; }
    .header nav.active { transform: translateX(0); }
    .header nav ul { padding: 0; }
    .header nav ul li { margin: 0 !important; border-bottom: 1px solid rgba(255,255,255,0.05); }
    .header nav ul li a { padding: 10px 15px; display: block; font-size: 14px; }
    .header .header-contact { width: 35px; height: 35px; margin-left: auto; margin-right: 20px; border-radius: 50%;  display: flex; align-items: center; justify-content: center; }
    .header .header-contact img { width: 25px; margin: 0; }
    .header .header-contact a { font-size: 0; }
    .header .header-backdrop { display: block; }
    .header .header-backdrop.active { opacity: 1; visibility: visible; }
    .header .header-toggle { display: block; }

    .banner { min-height: 300px; padding-top: 100px; }

    .drives section span {
        width: 100%;
    }
    .drives section { overflow: hidden; }
    .drives section img { position: absolute; right: -50px;  bottom: -50px; width: 200px; max-width: 200px; opacity: 0.3; z-index: -1; }
    .drives section .col-md-6:has(img) { padding: 0 !important; }
    
    .workflow .workflow-card {  padding: 20px 0 20px 30px; }
    .workflow .workflow-card aside { width: 100%; }
    .workflow .workflow-card picture { margin-left: 30px; margin-bottom: 20px; } 
    
    .footer { text-align: center; }
}

@media only screen and (max-width: 575px){
    .clients picture { max-height: 90px; }
}