:root {
  --primary-blue: #003B8E; 
  --light-blue: #049AD7;
  --secondary-blue: #0056B3;
  --blue: #025CA7;
  --blue-strong: #1C2B4D;
  --blue-light: #049AD7;
  --blue-clean: #189BD8;
  --light-gray: #E3E5E7;
  --gray: #90999F;
  --purple: #9F3ECD;
}

/* Fontes do Google Fonts */
body { font-family: 'Roboto', sans-serif; /* Texto corrido */ }
a{ text-decoration: none; }
a:hover{ text-decoration: none; color: var(--blue-strong) ; }

/* Títulos e chamadas */
h1, h2, h3 { font-family: 'Poppins', sans-serif; font-weight: 600; }

h4{ font-family: 'Oxanium', sans-serif; font-weight: 600; font-size: 14px; font-size: 400; color: var(--blue-light); }

h2{ color: var(--blue-strong); font-size: 32px; font-weight: 500; margin-bottom: 30px; }
.content{ margin: 40px auto 50px auto;}
.content p{ color:#90999F; font-size: 18px; font-weight: 300; }

.txt-blue{ color: var(--blue) !important;}
.txt-blue-strong{ color: var(--blue-strong) !important;}
.txt-blue-light{ color: var(--blue-light) !important;}
.bg-gray-strong{ background-color: var(--gray) !important;; }


@media (max-width: 900px) { 
  h2{ font-size: 22px; margin-bottom: 15px; }
  .content{ margin: 0px auto 20px auto; }
}

/* Formulario */
.form-section { background-color: var(--light-gray); padding: 80px 0; } 
.form-section .text { padding-right: 50px; } 
.form-section .text h2 { color: var(--blue); font-weight: 300; } 
.form-section .text img { max-width: 450px; } 
.form-section .form { padding-top: 50px; } 
.form-section .form-control { border-radius: 50rem; padding: 0.75rem 1rem 0.75rem 2.5rem; } 
.form-section .form-floating > label { margin-left: 2rem; } 
.form-section .input-icon { position: absolute; left: 1rem; top: 50%; transform: translateY(-50%); color: #6c757d; } 
.form-section .col-md-6 .input-icon { left: 1.8rem; }
.form-section .col-md-6 label { left: 0.8rem; }
.form-section textarea.form-control { border-radius: 2rem; }
.form-section .form-floating { position: relative; }
.form-floating > .form-control { padding-top: 1.625rem; padding-bottom: 0.625rem; }
.form-section .form-section .form-floating > label { position: absolute; top: 0; left: 0; height: 100%; padding: 1rem 0.75rem; pointer-events: none; border: 1px solid transparent; transform-origin: 0 0; transition: opacity .1s ease-in-out, transform .1s ease-in-out; }
.form-section .form-floating > .form-control:focus ~ label, .form-floating > .form-control:not(:placeholder-shown) ~ label { opacity: .45; transform: scale(.85) translateY(-0.5rem) translateX(-0.15rem); }
.form-section .form-floating > .form-control:-webkit-autofill ~ label { opacity: .45; transform: scale(.85) translateY(-0.5rem) translateX(0.5rem); }
.form-section .form-control:focus { border-color: #d5d9dc; box-shadow: 0 0 0 0.2rem rgba(213, 217, 220, 0.50); }

.is-invalid { border-color: #dc3545; }
.is-invalid:focus { border-color: #dc3545; box-shadow: 0 0 0 0.2rem rgba(220, 53, 69, 0.25); }
.alert-success { background-color: #d4edda; border-color: #c3e6cb; color: #155724; padding: 1rem; border-radius: 0.25rem; margin-top: 1rem; }
.alert-danger { background-color: #f8d7da; border-color: #f5c6cb; color: #721c24; padding: 1rem; border-radius: 0.25rem; margin-top: 1rem; }

#alertContainer { text-align: center; }

.btn-submit { color: var(--light-blue); border: 2px solid var(--light-blue); border-radius: 50rem; padding: 1rem 4rem; font-weight: 500; font-weight: bold; background-color: transparent } 
.btn-submit:hover { background-color: var(--light-blue); color: white; } 

@media (max-width: 768px) { 
  .form-section { padding: 40px 0; } 
  #contactForm div { margin-bottom: 2px !important; display: block; }  
  .form-section .animation-container { display: none; } 
  .form-section .form { padding-top: 10px; } 
  .form-section .bt { padding-top: 15px; text-align: center; } 
  .form-section .btn-submit { width: 100%; } 
}




/* Numeros */
.stats-section { text-align: center; padding: 80px 0; }
.stats-section h2{ color: var(--blue-strong);     }
.stats-section .stats-number span { font-size: 24px; color: var(--blue); font-weight: 400; font-family: 'Poppins', sans-serif; }
.stats-section .stats-number { color: var(--light-blue); font-size: 48px; font-weight: bold; line-height: 1.2; margin-bottom: 10px; font-family: 'Poppins', sans-serif; }
.stats-section .stats-text { color: #90999F; font-size: 16px; line-height: 1.4; }

@media (max-width: 768px) {
  .stats-section .row .col-md-3 {
      flex: 0 0 50%;
      max-width: 50%;
  }
  .stats-section { padding: 40px 0 0px 0; }
  .stats-section h2{ margin-bottom: 30px; }
  .stats-section .stats-number span { font-size: 18px;  }
  .stats-section .stats-number { font-size: 36px; margin-bottom: 5px;  }
}




/* banner */
.banner-hero { background-color: #1C2B4D; color: white; position: relative; }
.banner-hero .row { padding: 0; }
.banner-hero .bg { background-image: url('../images/vetor-interno.png'); background-size: auto 100%; background-position: left; background-repeat: no-repeat; padding: 5em 20px; }
.banner-hero h1 { font-size: 3rem; color: var(--light-blue); font-weight: 400;}
.banner-hero h1 span { color: #fff;  }
.banner-hero .hero-image { position: relative; bottom: -5rem; }
.banner-hero .hero-image img { width: 100%; max-width: 400px; height: auto; }

@media (max-width: 992px) { 
  .banner-hero .bg { padding: 2em 15px; }
  .banner-hero h1 { font-size: 1.5rem; }
  .banner-hero .hero-image { bottom: 0rem; margin-top: 0; display: none; }
  .banner-hero .hero-image img { width: 100%; max-width: 300px; height: auto; }
}

/* Breadcrumb */
.breadcrumb { padding: 2rem 0; margin-bottom: 0; font-family: 'Roboto', sans-serif; font-weight: 100; font-size: 14px; }
.breadcrumb-item a { color: var(--light-blue); text-decoration: none; }
.breadcrumb-item.active { color: #666; }

/* Contact */
.contact-section { padding: 60px 0; } 
/* .contact-section h2 { font-size: 32px; color: var(--blue-strong); font-weight: 600; margin-bottom: 40px; }  */
.contact-section .contact-info { margin-bottom: 40px; } 
.contact-section .contact-item { display: flex; align-items: center; margin-bottom: 20px; color: #666; text-decoration: none; transition: color 0.3s; } 
.contact-section .contact-icon { width: 50px; height: 50px; background-color: var(--light-blue); border-radius: 50%; display: flex; align-items: center; justify-content: center; margin-right: 15px; color: white; } 
.contact-section .contact-text { font-size: 1.1rem; color: var(--blue-strong); } 
.contact-section .map-container { border-radius: 40px; overflow: hidden; }

@media (max-width: 992px) { 
  .contact-section { padding: 10px 0; } 
}

/* Top Bar Styles */
.top-bar { background-color: var(--blue); color: white; font-size: 11px; padding: 8px 0; }
.top-bar a { color: #fff; font-size: 12px; }
.top-bar select { border: none; background-color: transparent; color: #fff; font-size: 13px; }
.top-bar .gtranslate_wrapper { display: inline-block; padding: 0 30px; }
.top-bar .gtranslate_wrapper select {   }
.top-bar .btn { border-radius: 20px; padding: 5px 20px; background-color: #fff; color: #1C2B4D; font-size: 12px; }
.top-bar .btn:hover { background-color: #1C2B4D; color: #fff; text-decoration: none; }


/* Navbar Styles */
.navbar { background-color: #F1F1F1; padding: 20px 0; transition: all 0.3s ease; }
.navbar a { color: #90999F !important; font-weight: 500; font-size: 0.9rem; padding: 0 15px !important; transition: all 0.3s ease; }
.navbar a:hover { text-decoration: none; color: var(--blue-strong) !important; }
.navbar .btn-specialist { background-color: var(--purple); color: white !important; border-radius: 25px; padding: 12px 25px !important; font-size: 0.9rem; font-weight: 600; display: inline-flex; align-items: center; gap: 8px; transition: all 0.3s ease; }
.navbar .btn-specialist:hover { background-color: #B24ED1; color: white !important; }
.navbar.fixed-nav { position: fixed; top: 0; left: 0; right: 0; z-index: 1000; padding: 10px 0; box-shadow: 0 2px 10px rgba(0,0,0,0.1); }
.navbar.fixed-nav .navbar-brand img { height: 35px; transition: height 0.3s ease; }
.navbar.fixed-nav a { font-size: 0.85rem; }
.navbar.fixed-nav .btn-specialist { padding: 10px 20px !important; }

/* Desktop Dropdown Styles */
@media (min-width: 992px) {
  .nav-item.dropdown { position: relative; }
  .nav-item.dropdown a { padding: 8px 15px !important; }
  .nav-item.dropdown > a::after { content: ''; display: inline-block; width: 6px; height: 6px; border: none; border-right: 2px solid #90999F; border-bottom: 2px solid #90999F; margin-left: 8px; transform: rotate(45deg); position: relative; top: -2px; transition: transform 0.3s ease; }
  .nav-item.dropdown.show > a::after { transform: rotate(-135deg); top: 2px; }
  .dropdown-menu { margin-top: 0; border: none; border-radius: 0; box-shadow: 0 4px 20px rgba(0,0,0,0.1); padding: 12px 0; min-width: 220px; opacity: 0; visibility: hidden; transform: translateY(10px); transition: all 0.2s ease; display: block; background-color: #F1F1F1; }
  .dropdown-menu.show { opacity: 1; visibility: visible; transform: translateY(0); }
  .dropdown-menu::before { content: ''; position: absolute; top: -10px; left: 0; right: 0; height: 10px; background: transparent; }
  .dropdown-item { color: #90999F !important; font-size: 0.85rem; padding: 10px 24px !important; transition: all 0.2s ease; position: relative; }
  .dropdown-item:hover { color: var(--blue) !important; padding-left: 28px !important; background: #F1F1F1; }
  .dropdown-item::before { content: ''; position: absolute; left: 0; top: 0; bottom: 0; width: 3px; background-color: var(--blue); opacity: 0; transition: opacity 0.2s ease; }
  .dropdown-item:hover::before { opacity: 1; }
}
/* Mobile Menu Styles Melhorados */
@media (max-width: 991.98px) {
  .navbar-collapse { position: fixed; top: 0; right: -320px; bottom: 0; width: 88%; max-width: 480px; padding: 2rem 1.5rem 2rem 1.5rem; background-color: #F1F1F1; transition: right 0.3s ease; overflow-y: auto; z-index: 1050; }
  .navbar-collapse.show { right: 0; }
  .navbar-toggler { position: relative; z-index: 1049; }
  .navbar-nav { margin-top: 30px; }
  .nav-item { margin: 3px 0; border-bottom: 1px solid rgba(0,0,0,0.08); padding-bottom: 3px; }
  .nav-item:last-child { border-bottom: none; }
  .nav-item a { font-size: 1rem !important; padding: 8px 0 !important; display: block; }
  .dropdown-menu { display: none; border: none; padding: 10px 0 5px 20px; margin-top: 10px; background: transparent; box-shadow: none; }
  .dropdown-menu.show { display: block; opacity: 1; visibility: visible; transform: none; }
  .dropdown-item { padding: 8px 0 !important; font-size: 0.95rem !important; color: #90999F !important; }
  .dropdown-item:hover { background: transparent; padding-left: 5px !important; color: var(--blue) !important; }
  .dropdown-item::before { display: none; }
  .navbar-collapse .d-flex { margin-top: 20px; flex-direction: column; align-items: flex-start !important; }
  .navbar-collapse .btn-specialist { margin-top: 20px; width: 100%; justify-content: center; }
  .navbar-collapse a { color: #90999F !important; font-size: 0.9rem; transition: color 0.3s ease; }
  .navbar-collapse a:hover { color: var(--blue-strong) !important; }
  .nav-item.dropdown > a::after { float: right; margin-top: 10px; }
  .mobile-menu-close { position: absolute; top: 20px; right: 20px; background: none; border: none; font-size: 24px; color: #90999F; cursor: pointer; width: 40px; height: 40px; display: flex; align-items: center; justify-content: center; border-radius: 50%; transition: all 0.3s ease; }
  .mobile-menu-close:hover { background-color: rgba(0,0,0,0.05); }
  .mobile-menu-overlay { display: none; position: fixed; top: 0; left: 0; right: 0; bottom: 0; background-color: rgba(0,0,0,0.5); z-index: 1040; }
  .mobile-menu-overlay.show { display: block; }
  .top-bar { display: none; }
  .navbar .contatos { padding: 18px 0; }
  .navbar .contatos a { padding: 0 !important; }
}

.navbar-spacer { display: none; height: 86px; }
.navbar-spacer.show { display: block; }


/* banner home */
.hero-section { padding: 0; position: relative; }
.hero-section .bg { background-image: url('../images/vetor-home.png'); background-size: auto 100%; background-position: left; background-repeat: no-repeat; padding: 5em 20px; margin: 0; }
.hero-section .hero-title { color: var(--primary-blue); font-size: 56px; font-weight: 600; line-height: 1.2; margin-bottom: 30px; }
.hero-section .hero-title span { color: var(--light-blue); }
.hero-section .hero-text { color: #90999F; font-size: 18px; margin-bottom: 60px; line-height: 22px; }
.hero-image img { opacity: 0; transition: opacity 1s ease-out; }
.hero-image.aparecendo img { opacity: 1; }
.hero-image img:hover { transform: scale(1.1); transition: transform 0.3s ease-in-out; }

@media (max-width: 992px) { 
  .hero-section .bg { padding: 3em 20px; margin: 0; }
  .hero-section .hero-title { font-size: 36px; line-height: 1.2; margin-bottom: 15px; }
  .hero-section .hero-text { font-size: 18px; margin-bottom: 30px; line-height: 22px; }
  .hero-section .imagem { text-align: center; }
  .hero-section img { max-width: 400px; }
}




/* Valores */
.valores { padding: 60px 0; text-align: center; }
.valores .row.g-4 { display: flex; gap: 24px; justify-content: center; margin-top: 30px; }
.valores .card { border: 1px solid var(--blue); color: var(--blue); border-radius: 16px; display: flex; flex-direction: column; align-items: center; justify-content: space-between; padding: 40px 30px; max-width: 380px; width: 100%; height: 100%; transition: transform 0.3s ease; }
.valores .card:hover { transform: translateY(-10px); box-shadow: 0 10px 20px rgba(0, 0, 0, 0.1); }
.valores .card img { max-width: 150px; margin-bottom: 20px; }
.valores .card h3 { font-size:20px; font-weight: bold; margin-bottom: 15px; }
.valores .card p { font-size: 16px; line-height: 1.6; margin-bottom: 0; flex: 1; }
@media (max-width: 768px) { 
  .valores { padding: 30px 0; }
  .valores .row.g-4 { flex-direction: column; gap: 16px; margin-top: 0px; --bs-gutter-y: 0rem;}
  .valores .card { display: block; padding: 20px 20px; max-width: 100%; width: 100%; height: 100%; }
  .valores .card:hover { transform: translateY(-10px); box-shadow: 0 10px 20px rgba(0, 0, 0, 0.1); }
  .valores .card img { max-width: 100px; margin-bottom: 10px; }
  .valores .card h3 { margin-bottom: 10px; }
}

/* Video */
.video-box { position: relative; height: 600px; background: url('../images/bg-video.png') no-repeat center center; background-size: cover; display: flex; justify-content: center; align-items: center; overflow: hidden; }
.video-overlay { position: absolute; top: 0; left: 0; width: 100%; height: 100%; background-color: rgba(0, 0, 0, 0.5); display: flex; justify-content: center; align-items: center; }
.play-icon { width: 100px; height: auto; cursor: pointer; transition: transform 0.3s ease; }
.play-icon:hover { transform: scale(1.2);  }

@media (max-width: 992px) { 
  .video-box { height: 400px;}
}

@media (max-width: 768px) { 
  .video-box { height: 200px;}
  .play-icon { width: 70px; }
}


/* Accordion */
#accordion { background-color: var(--blue); padding: 40px 0; color: #fff !important; font-weight: 200; }
#accordion h2 { color: #fff !important; }
#accordion h4 { color: #fff !important; }
#accordion .accordion { margin-top: 40px; }
#accordion .accordion-item { background-color: transparent; border: none; margin-bottom: 0; }
#accordion .accordion-item + .accordion-item { border-top: 1px solid #189BD8; }
#accordion .accordion-button { background-color: transparent; color: white; font-size: 18px; padding: 1.5rem 0; border: none; font-weight: 200; }
#accordion .accordion-button:not(.collapsed) { background-color: transparent; color: white; box-shadow: none; }
#accordion .accordion-button::after { background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='%23fff'%3e%3cpath fill-rule='evenodd' d='M1.646 4.646a.5.5 0 0 1 .708 0L8 10.293l5.646-5.647a.5.5 0 0 1 .708.708l-6 6a.5.5 0 0 1-.708 0l-6-6a.5.5 0 0 1 0-.708z'/%3e%3c/svg%3e"); }
#accordion .accordion-button:not(.collapsed)::after { background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='%23fff'%3e%3cpath fill-rule='evenodd' d='M1.646 4.646a.5.5 0 0 1 .708 0L8 10.293l5.646-5.647a.5.5 0 0 1 .708.708l-6 6a.5.5 0 0 1-.708 0l-6-6a.5.5 0 0 1 0-.708z'/%3e%3c/svg%3e"); }
#accordion .accordion-body { color: white; padding: 1rem 1rem 2rem 1rem; }
#accordion .accordion-body p { font-size: 16px; }
.accordion-button::after { background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='%23fff'%3e%3cpath fill-rule='evenodd' d='M1.646 4.646a.5.5 0 0 1 .708 0L8 10.293l5.646-5.647a.5.5 0 0 1 .708.708l-6 6a.5.5 0 0 1-.708 0l-6-6a.5.5 0 0 1 0-.708z'/%3e%3c/svg%3e"); }
.accordion-button:not(.collapsed)::after { background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='%23fff'%3e%3cpath fill-rule='evenodd' d='M1.646 4.646a.5.5 0 0 1 .708 0L8 10.293l5.646-5.647a.5.5 0 0 1 .708.708l-6 6a.5.5 0 0 1-.708 0l-6-6a.5.5 0 0 1 0-.708z'/%3e%3c/svg%3e"); }

#accordion.bg-gray { background-color: var(--gray);}
#accordion.bg-gray .accordion-item + .accordion-item { border-top: 1px solid #fff; }

@media (max-width: 768px) { 
  #accordion { padding: 10px 0;}
}

/* Clientes */
.clients { padding: 30px 0; }
.clients .client-box { background: transparent; border: 1px solid var(--blue); border-radius: 25px; padding: 1.5rem; transition: transform 0.3s ease, box-shadow 0.3s ease; justify-content: center; }
.clients .client-box:hover { transform: scale(1.0); box-shadow: 0 10px 20px rgba(0, 0, 0, 0.1); }
.clients .client-box img { width: 100%; max-width: 200px; }
@media (max-width: 768px) { 
  .clients { padding: 10px 0; }
  .clients .client-box { height: 100px; margin-bottom: 15px; padding: 1rem; } 
  .clients .section-title { font-size: 1.5rem; margin-bottom: 2rem; } 
}


.depoimentos { padding: 80px 0; position: relative; overflow: hidden; }
.depoimentos .label-depoimentos { color: var(--light-blue); font-size: 0.875rem; text-transform: uppercase; margin-bottom: 1.5rem; display: block; }
.depoimentos h2 { width: 80%; margin-top: 20px; }
.depoimentos .testimonial-text { color: var(--gray); font-size: 1.25rem; line-height: 1.6; margin-bottom: 2rem; font-weight: 200; }
.depoimentos .testimonial-author { color: var(--primary-blue); font-weight: 600; font-size: 1.125rem; margin-bottom: 0.25rem; }
.depoimentos .testimonial-company { color: var(--light-blue); font-size: 1rem; margin-bottom: 1.5rem; }
.depoimentos .testimonials-slider { position: relative; margin-top: 30px; }
.depoimentos .testimonial-item { display: none; width: 90%; }
.depoimentos .testimonial-item.active { display: block; }
.depoimentos .slider-navigation { display: flex; gap: 1rem; margin-top: 1rem; justify-content: flex-start; }
.depoimentos .slider-button { width: 48px; height: 48px; border: 1px solid #e0e0e0; border-radius: 50%; background: white; display: flex; align-items: center; justify-content: center; cursor: pointer; transition: all 0.3s ease; }
.depoimentos .slider-button:hover { border-color: var(--light-blue); color: var(--light-blue); }
@media (max-width: 768px) { 
  .depoimentos { padding: 40px 0; }
  .depoimentos .testimonial-text { font-size: 1.125rem; }
}

.depoimentos #testimonialSlider { background: url('../images/bg-corner.png') no-repeat bottom right; background-size: auto; }

.bg-block { background-color: var(--blue-clean); height: 40%; width: 100%; bottom: 0; z-index: 0; position: absolute; }

.services-box { padding: 60px 0; }
.services-box .text { color: var(--gray); text-align: center; max-width: 80%; margin: 0 auto; padding: 20px 0; }

.services-slider { position: relative; overflow: hidden; margin: 20px 0; }
.content .services-slider { margin: 60px 0; }
.services-slider .service-card { aspect-ratio: 1 / 0.8; border-radius: 30px; display: flex; align-items: center; justify-content: center; text-align: center; padding: 10px; border: 1px solid var(--blue); transition: all 0.3s ease; margin-bottom: 20px; }
.services-slider .service-card:hover { background-color: var(--blue-clean); text-decoration: none; box-shadow: 0 10px 20px rgba(0, 0, 0, 0.1); border: 1px solid var(--blue-clean); color: #fff; }
.services-slider .service-card .service-content { display: flex; flex-direction: column; align-items: center; justify-content: center; height: 100%; }
.services-slider .service-card .service-icon { font-size: 50px; margin-bottom: 10px; }
.services-slider .service-card h3 { font-size: 1.20rem; line-height: 1.3; margin: 0; font-weight: 600; color: var(--blue); min-height: 65px; }
.services-slider .service-card:hover h3 { color: #fff; }

.services-slider .service-card .service-icon .service-svg { width: 60px;  height: auto; }

.services-slider .service-card:hover .service-icon .service-svg { filter: brightness(0) invert(1); }

@media (max-width: 768px) { 
  .services-box { padding: 30px 0 0px 0; }
  .services-slider .service-card {  aspect-ratio: auto; height: 180px; } 
  .services-slider .service-card h3 { font-size: 1rem; }
}
@media (max-width: 500px) { 
  .services-slider .service-card { aspect-ratio: 1 / 0.7.4; height: 170px; } 
}
@media (max-width: 350px) { 
  .services-slider .service-card { aspect-ratio: auto; height: 150px; } 
  .services-slider .service-card h3 { font-size: 1rem; }mas c
}







.clientes-slide { width: 90%; }
.clientes-slide .clients-section { display: flex; align-items: center; background-color: #f4f4f4; padding: 20px 20px 0 20px; }
.clientes-slide .clients-title h4 { color: var(--blue-strong); font-weight: 200; margin-right: 20px; position: relative; }
.clientes-slide .logo-carousel img { max-width: 200px; margin: 0 5px; }
.clientes-slide .owl-carousel { width: 96%; }
@media (max-width: 768px) { 
  .clientes-slide { width: 95%; }
  .clientes-slide .clients-section { padding: 0; }
}


/* Estilos existentes mantidos */
.cases { position: relative; padding: 40px 0 10px 0; }
.cases .case { position: relative; z-index: 1; padding: 40px; }
.cases .card { padding: 50px 50px 50px 0; background-color: var(--blue-strong); border-radius: 0 0 50px 0; border: none; }
.cases .card-body { padding: 20px 0; }
.cases .imagem { overflow: hidden; position: absolute; left: -50%; top: 50%; transform: translateY(-50%); width: calc(100% + 120px); max-width: none; }
.cases .img-fluid { width: 100%; height: auto; max-width: 500px; }
.cases .text h2 { color: #fff; }
.cases .text { color: #fff; padding-right: 30px; }


@media (max-width: 992px) { 
  .cases { padding: 20px 0 20px 0; text-align: center; }
  .cases .case { padding: 30px 15px; }
  .cases .card { padding: 40px; display: flex; flex-direction: column-reverse; }
  .cases .card-body { padding: 0; }
  .cases .col-10 { width: 100%; }
  .cases .imagem { overflow: hidden; position: relative; left: 0%; top: 0; transform: translateY(0); width: 100%; max-width: none; }
  .cases .img-fluid {  max-width: 300px; padding-bottom: 20px; }
  .cases .text { padding-right: 0px; padding: 0px; }
}



/* Novos estilos para o carrossel */
.slider-navigation {
  display: flex;
  justify-content: flex-end;
  gap: 10px;
  margin-top: 20px;
  padding-right: 20px;
}

.carousel-inner{ position: relative;}

.nav-button { width: 40px; height: 40px; padding: 0; display: inline-flex; align-items: center; justify-content: center; cursor: pointer; transition: all 0.3s ease; background: transparent; }
.nav-prev { border: 2px solid var(--blue-clean); border-radius: 50%; color: var(--blue-clean); }
.nav-next { border: 2px solid var(--blue-clean); border-radius: 50%; color: var(--blue-clean); }
.nav-prev:hover, .nav-next:hover { background-color: var(--blue-clean); color: #fff; }


.bg-gray .bg-block { background-color: var(--light-gray);}



/* Vantagens */
.vantagens{ position: relative; padding: 40px 0; background-color: var(--light-gray);  }
.vantagens .bg-block { height: 50%; top: 0; }
.vantagens h4 { color:#fff; }
.vantagens .card { background-color: var(--blue); border-radius: 0 0 0 80px; color:#fff; }
.vantagens .card .itens{ padding: 10px 0;}
.vantagens .card .itens .item{ padding: 30px 10px;}
.vantagens .card .itens .item p{ width: 90%;}
.vantagens .card .itens .item h3{ font-weight: 400; }
.vantagens img{ max-width: 140px; }



@media (max-width: 992px) { 
  .vantagens .d-flex { flex-direction: column; gap: 0rem !important; }
  .vantagens{ padding: 20px 0;  }
  .vantagens .card .itens{ padding: 5px 0;}
  .vantagens .card .itens .item{ padding: 15px 5px; text-align: center;}
  .vantagens .card .itens .item p{ width: 100%;}
  .vantagens img{ max-width: 80px; } 
}

.bg-white{ background-color: #fff !important; }

/* servicos / soluções */
/* .services { background-color: var(--blue-clean); padding: 0px 0; color:#fff; }
.services .service-block { display: flex; align-items: center; padding: 80px 0; flex-wrap: wrap; }
.services .service-block:not(.no-img) + .service-block { border-top: 1px solid #fff; }
.services .service-block.no-img { display: flex; align-items: center; flex-direction: row; }
.services .service-block:last-child { margin-bottom: 0; }
.services .service-block.reverse { flex-direction: row-reverse; } */


.services { background-color: var(--blue-clean); padding: 40px 0; color: #fff; }
.services .blocks { display: flex; flex-wrap: wrap; gap: 20px; }
.services .service-block { display: flex; align-items: center; padding: 80px 0; flex-wrap: wrap; width: 100%; }
.services .service-block:first-child { padding-top: 40px; }
.services .service-block:not(.no-img) + .service-block { border-top: 1px solid #fff; }
.services .service-block.no-img { display: flex; justify-content: flex-start; align-items: flex-start; flex-direction: row; width: calc(50% - 10px); padding: 40px 0; }
.services .no-img .text { flex: 0 0 100%; padding: 0 40px; }
.services .service-block.reverse { flex-direction: row-reverse; }
.services .text { flex: 0 0 50%; padding: 0 40px; }
.services .image-wrapper { flex: 0 0 50%; position: relative; padding: 20px; }
.services .image-container { text-align: center; }
.services .image-container img { max-width: 500px; }
.services h2 { color: #fff; }
.services p { color: #fff; }
@media (max-width: 900px) { 
  .services { padding: 20px 0; }
  .services .service-block { 
      padding: 30px 0; 
      flex-direction: column !important; /* Força todos os blocos a ficarem empilhados */
  }

  .services .service-block.reverse { 
      flex-direction: column !important; /* Remove a inversão no mobile */
  }

  /* Garante que a imagem sempre fique na linha de cima */
  .services .service-block .image-wrapper { 
      order: -1; /* Move a imagem para o topo */
      flex: 0 0 auto;
      width: 100%;
      display: flex;
      justify-content: center;
      padding-bottom: 10px; /* Adiciona espaçamento entre a imagem e o texto */
  }

  .services .image-container { 
      width: 100%;
      display: flex;
      justify-content: center; /* Centraliza a imagem */
  }

  .services .image-container img { 
      max-width: 100%; 
      height: auto; 
  }

  .services .text { 
      flex: 0 0 auto; 
      width: 100%;
      padding: 0 20px !important;
      text-align: left; 
  }

  .services .service-block.no-img { 
      width: 100%; 
      padding: 10px 0; 
      flex-direction: column; 
  }
}






@media (max-width: 991px) {
  .contact-hero h1 {
      font-size: 2.5rem;
  }
  .contact-heading {
      font-size: 2rem;
  }
  .hero-image {
      margin-top: 30px;
  }
}



.author-info {
  margin-top: 3rem;
  padding-top: 2rem;
  border-top: 1px solid #eee;
}

.downloads{ padding: 20px 0;}
.downloads a{    font-family: 'Oxanium', sans-serif; font-weight: 600; font-size: 14px; font-size: 400; color: var(--blue-light);}
.downloads a:hover{ text-decoration: none; color: var(--blue-strong) !important; }



footer{ background-color: #E3E5E7; border-top: 1px solid #fff; padding: 60px 0 0 0;}
footer h5{ color: var(--primary-blue); font-weight: bold; font-size: 18px; margin-bottom: 20px;}
footer p, a{ color: var(--blue); font-size: 15px;}
footer b{ font-size: 20px;}
footer i{ color: #90999F; font-size: 30px;}
footer .copy{  text-align: center; padding: 30px 0 15px 0; font-size: 14px; color: #90999F; }
footer .copy img{ max-width:80px; margin-top: 10px;}


@media (max-width: 1000px) {
  footer .cols { width: 100% !important; text-align: center; display: block;}
  footer .subnav{ display: none;}
}

/* ANIMAÇÃO IMAGEM */
.animation-container { position: relative; width: 100%; max-width: 450px; height: 450px; overflow: hidden; display: flex; align-items: center; justify-content: center; transition: transform 0.5s ease-in-out; opacity: 0; transform: translateY(50px); }
.animation-container .main-image { position: absolute; width: 80%; opacity: 0; transition: opacity 1s ease-in-out; }
.animation-container .icon { position: absolute; opacity: 0; transition: opacity 1s ease-in-out, transform 1.5s ease-in-out; }
.animation-container .icon-top-right { width: 90px; top: 16%; right: 10%; transform: translateX(100px); }
.animation-container .icon-bottom-center { width: 110px; bottom: 2%; left: 50%; transform: translateX(-50%) translateY(100px); }
.animation-container .icon-bottom-left { width: 85px; bottom: 25%; left: 5%; transform: translateY(100px); }
.animation-visible .animation-container { opacity: 1; transform: translateY(0); }
.animation-visible .main-image { opacity: 1; }
.animation-visible .icon { opacity: 1; transform: translateX(0) translateY(0); }
.animation-container:hover { transform: scale(1.05); }
.animation-container:hover .main-image { transform: scale(1.1); }
.animation-container:hover .icon { transform: scale(1.2) rotate(10deg); }

.animate-scroll {
  opacity: 0;
  transform: translateY(50px);
  transition: transform 0.8s ease-out, opacity 0.8s ease-out;
}


.animate-scroll.ativo {
  opacity: 1;
  transform: translateY(0);
}
