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

a {
  all: unset; /* Remove TODAS as personalizações do navegador */
  cursor: pointer; /* Mantém o cursor de link */
  margin: 0;
}

body {
    font-family: 'Open Sans', sans-serif;
    background-color: #F8F9FA;
    color: #4A4A4A;
    line-height: 1.6;
}

/* 1) Nunca deixe a página rolar na horizontal */
html, body { overflow-x: hidden; }

/* ==========================================
   SCROLLBAR – identidade visual do site
   (global; aplique a um container se preferir)
   ========================================== */
:root{
  --scroll-track: #EAF8FB;   /* fundo clarinho (tema) */
  --scroll-thumb: #2E3F5B;   /* polegar (azul-escuro) */
  --scroll-thumb-hover: #1E2A3A;
  --scroll-accent: #25BACF;  /* ciano do tema (borda/realce) */
}

/* Firefox */
html{
  scrollbar-color: var(--scroll-thumb) var(--scroll-track);
  scrollbar-width: auto; /* auto | thin | none */
}

/* WebKit (Chrome, Edge, Safari) */
*::-webkit-scrollbar{
  width: 12px;               /* verticais */
  height: 12px;              /* horizontais */
}
*::-webkit-scrollbar-track{
  background: var(--scroll-track);
  border-radius: 999px;
  box-shadow: inset 0 0 0 1px rgba(37,186,207,.25); /* fio ciano discreto */
}
*::-webkit-scrollbar-thumb{
  background: linear-gradient(180deg, var(--scroll-thumb), #2a3b54);
  border-radius: 999px;
  border: 2px solid var(--scroll-track); /* cria “trilho” vazado */
  box-shadow: 0 1px 4px rgba(0,0,0,.18);
}
*::-webkit-scrollbar-thumb:hover{
  background: linear-gradient(180deg, var(--scroll-thumb-hover), #223146);
}
*::-webkit-scrollbar-corner{ background: transparent; }

/* Tweak nos principais containers horizontais da página de Acessos */
.kits-track::-webkit-scrollbar{ height: 10px; }
.compare-wrapper::-webkit-scrollbar{ height: 10px; }

/* Estado focado (acessibilidade): realça o thumb quando o container recebe focus */
.kits-track:focus::-webkit-scrollbar-thumb,
.compare-wrapper:focus::-webkit-scrollbar-thumb{
  box-shadow: 0 0 0 2px var(--scroll-accent), 0 1px 4px rgba(0,0,0,.18);
}

.highlight-azul-escuro {
    color: #2E3F5B;
}

/* Layout principal com Grid */
.page-container {
    display: grid;
    grid-template-rows: auto 1fr;
    min-height: 100vh;
}



/* Header */
.header{
  position: sticky;
  top: 0;
  z-index: 1000;
  background: rgba(248,249,250);
  backdrop-filter: saturate(180%) blur(6px);
  padding: 20px 100px;
}

.header-content {
    margin: 0 auto;
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.logo {
    display: flex;
    align-items: center;
    gap: 15px;
    width: 200px;
    height: auto;
}

@media (width: 1920px) {
    .logo {
        width: 260px;
        height: auto;
    }
}

.logo-only-image {
    width: 100%;
    height: 100%;
}

.navbar {
    display: flex;
    align-items: center;
    gap: 40px;
}


/* Acessibilidade: foco visível */
.nav-links a:focus-visible,
.menu-toggle:focus-visible,
.dropdown-toggle:focus-visible,
.cta-comprar:focus-visible{
  outline: 2px solid #25BACF;
  outline-offset: 2px;
}

/* ========================================= */
/* DROPDOWN MENU SEGMENTOS - VERSÃO CRIATIVA */
/* ========================================= */

.dropdown {
    position: relative;
}

.dropdown-toggle {
    cursor: pointer;
    position: relative;
    padding: 8px 0;
    transition: color 0.3s ease;
    border: none;
    background: none;
    text-decoration: none;
    color: #4A4A4A;
    font-weight: 500;
    font-size: 14px;
}

.dropdown-toggle:hover::after {
    transform: scaleX(1);
}

.dropdown-toggle:hover {
    color: #2E3F5B;
}

/* Menu dropdown com design moderno */
.dropdown-menu {
    position: absolute;
    top: calc(100% + 20px);
    left: 50%;
    transform: translateX(-50%);
    background: linear-gradient(135deg, #f8f9fa 0%, #F8F9FA 100%);
    border-radius: 16px;
    box-shadow: 
        0 10px 40px rgba(0, 0, 0, 0.1),
        0 4px 16px rgba(0, 0, 0, 0.06),
        inset 0 1px 0 rgba(255, 255, 255, 0.8);
    padding: 15px;
    min-width: 220px;
    opacity: 0;
    visibility: hidden;
    transition: all 0.4s cubic-bezier(0.175, 0.885, 0.32, 1.275);
    transform: translateX(-50%) translateY(-15px) scale(0.95);
    z-index: 1000;
    border: 1px solid rgba(37, 186, 207, 0.2);
    backdrop-filter: blur(10px);
}

/* Seta moderna com gradiente */
.dropdown-menu::before {
    content: '';
    position: absolute;
    top: -10px;
    left: 50%;
    transform: translateX(-50%);
    width: 0;
    height: 0;

    border-left: 8px solid transparent;
    border-right: 8px solid transparent;
    border-bottom: 8px solid #25BACF;
}

/* Mostrar menu no hover com animação suave */
.dropdown:hover .dropdown-menu {
    opacity: 1;
    visibility: visible;
    transform: translateX(-50%) translateY(0);
    border: 2px solid #25BACF;
}

/* Container dos itens */
.dropdown-menu li {
    list-style: none;
    margin: 0;
    overflow: hidden; /* IMPORTANTE: Contém as animações */
}

/* Itens do menu com design moderno */
.drop-down-menu-item {
    display: block;
    padding: 14px 20px;
    color: #4A4A4A;
    text-decoration: none;
    font-weight: 500;
    font-size: 14px;
    text-align: center; /* CENTRALIZADO */
    transition: all 0.3s cubic-bezier(0.25, 0.46, 0.45, 0.94);
    position: relative;
    margin-bottom: 4px;
    overflow: hidden; /* Contém o efeito de preenchimento */
}

/* Animação de entrada escalonada dos itens */
.dropdown-menu li {
    opacity: 0;
    transform: translateY(15px);
    transition: all 0.4s cubic-bezier(0.175, 0.885, 0.32, 1.275);
}

.dropdown:hover .dropdown-menu li {
    opacity: 1;
    transform: translateY(0);
}

.dropdown:hover .dropdown-menu li:nth-child(1) { 
    transition-delay: 0.1s; 
}
.dropdown:hover .dropdown-menu li:nth-child(2) { 
    transition-delay: 0.18s; 
}
.dropdown:hover .dropdown-menu li:nth-child(3) { 
    transition-delay: 0.26s; 
}

.dropdown:hover .dropdown-menu li:nth-child(4) { 
    transition-delay: 0.34s; 
}

.dropdown:hover .dropdown-menu li:nth-child(5) { 
    transition-delay: 0.42s; 
}

.dropdown:hover .dropdown-menu li:nth-child(6) { 
    transition-delay: 0.50s; 
}

/* Efeito de brilho sutil no hover do container */
.dropdown:hover .dropdown-menu {
    box-shadow: 
        0 15px 50px rgba(37, 186, 207, 0.15),
        0 6px 20px rgba(0, 0, 0, 0.1),
        inset 0 1px 0 rgba(255, 255, 255, 0.9);
}

 /* ========================================= */
/* ANIMAÇÕES E ESTILOS DO HEADER */
/* ========================================= */

.nav-links {
    display: flex;
    list-style: none;
    gap: 30px;
}

.nav-links a {
    text-decoration: none;
    color: #4A4A4A;
    font-weight: 500;
    font-size: 14px;
            
    /* Configurações para animação */
    position: relative;
    padding: 8px 0;
    transition: color 0.3s ease;
            
    /* Remove qualquer decoração padrão */
    border: none;
    background: none;
}

/* 1. ESTADO ATIVO (página atual) */
.nav-links a.active {
    color: #2E3F5B;
    font-weight: 700; /* Bold para link ativo */
}

/* Linha embaixo do link ativo (sempre visível) */
.nav-links a.active::after {
    content: '';
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    height: 2px;
    background: #25BACF;
    transform: scaleX(1); /* Sempre visível */
    transform-origin: center;
}

/* 2. ANIMAÇÃO HOVER (centro para bordas) */
.nav-links a:not(.active)::after {
    content: '';
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    height: 2px;
    background: #25BACF;
            
    /* Animação do centro para bordas */
    transform: scaleX(0);
    transform-origin: center;
    transition: transform 0.3s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

.nav-links a:not(.active):hover::after {
    transform: scaleX(1);
}

/* Mudança de cor no hover */
.nav-links a:hover {
    color: #2E3F5B;
}

.cta-comprar {
    width: auto;
    background: #2E3F5B;
    color: #F8F9FA;
    padding: 12px 30px;
    border: none;
    border-radius: 10px;
    font-family: 'Open Sans', sans-serif;
    font-weight: 600;
    font-size: 1rem;
    cursor: pointer;
    transition: all 0.3s ease;
    text-decoration: none;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    position: relative;
    overflow: hidden;
}

.cta-comprar span {
    position: relative;
    z-index: 10;
    transition: color 0.4s;
}

.cta-comprar:hover span {
    color: #f8f9fa;
}

.cta-comprar::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: #25BACF;
    transform: scaleX(0);
    transform-origin: left;
    transition: transform 0.4s cubic-bezier(0.3, 1, 0.8, 1);
    z-index: 5;
}

.cta-comprar:hover::before {
    transform: scaleX(1);
}

.cta-hero-descripition {
    width: auto;
    background: #2E3F5B;
    color: #F8F9FA;
    padding: 12px 30px;
    border: none;
    border-radius: 10px;
    font-family: 'Open Sans', sans-serif;
    font-weight: 600;
    font-size: 1rem;
    cursor: pointer;
    transition: all 0.3s ease;
    text-decoration: none;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    position: relative;
    overflow: hidden;
}

.cta-hero-descripition span{
    color: #f8f9fa;
}

.cta-hero-descripition:hover {
    transform: translateY(-2px);
}

.cta-verifique-sections {
    width: auto;
    background: #2E3F5B;
    color: #F8F9FA;
    padding: 12px 30px;
    border: none;
    border-radius: 10px;
    font-family: 'Open Sans', sans-serif;
    font-weight: 600;
    font-size: 1rem;
    cursor: pointer;
    transition: all 0.3s ease;
    text-decoration: none;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    position: relative;
    overflow: hidden;
    margin: 0 auto;
}

.cta-verifique-sections span {
    position: relative;
    z-index: 10;
    transition: color 0.4s;
}

.cta-verifique-sections:hover span {
    color: #f8f9fa;
}

.cta-verifique-sections::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: #25BACF;
    transform: scaleX(0);
    transform-origin: left;
    transition: transform 0.4s cubic-bezier(0.3, 1, 0.8, 1);
    z-index: 5;
}

.cta-verifique-sections:hover::before {
    transform: scaleX(1);
}

.cta-container {
    display: flex;
    justify-content: center;
    align-items: center;
}

.cta-comprar-integracao {
    width: auto;
    background: #25BACF;
    color: #F8F9FA;
    padding: 12px 30px;
    border: none;
    border-radius: 10px;
    font-family: 'Open Sans', sans-serif;
    font-weight: 600;
    font-size: 1.1rem;
    cursor: pointer;
    margin: auto 0;
    transition: all 0.3s ease;
    text-decoration: none;
    margin-top: 40px;

    position: relative;
    overflow: hidden;
}

.cta-comprar-integracao:hover {
    background: #25BACF;
    transform: translateY(-3px);
    box-shadow: 0 8px 25px rgba(46, 63, 91, 0.3);
}

/* Hero Section - REFORMULADA */
.hero {
    position: relative;
    overflow: hidden;
    display: flex;
    align-items: center;
}

.hero-background {
    aspect-ratio: 16/6;
    top: 0;
    right: 0;
    width: 80%;
    height: 100%;
    overflow: hidden;
    z-index: 1;
}

.hero-image {
    aspect-ratio: 16/6;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    opacity: 0;
    visibility: hidden;
    transition: opacity 1s ease-in-out, visibility 1s ease-in-out;
    z-index: 1;
}

.hero-image.active {
    opacity: 1;
    visibility: visible;
}

/*
.hero-overlay {
    aspect-ratio: 16/6;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: #25BACF;
    z-index: 2;
}
*/

.hero-content {
    width: 100%;
    align-items: center;
    justify-content: flex-start;
    padding-left: 100px;
    position: relative;
    z-index: 10;
    display: flex;
    align-items: center;
    min-height: 400px;
    max-height: 55vh;
}

.hero-text {
    flex: 0 0 auto;
    max-width: 500px;
    width: 100%;
    margin-left: 0 auto;
}

.hero-title {
    font-family: 'Poppins', sans-serif;
    font-weight: 900; 
    font-size: 3.1rem;
    line-height: 1.1;
    margin-bottom: 30px;
    color: #FEFEFE;
}

.hero-description {
    font-size: 1rem;
    color: #FEFEFE;
    margin-bottom: 40px;
    line-height: 1.5;
}

.hero-cta {
    background: #2E3F5B;
    color: white;
    padding: 16px 28px;
    border: none;
    border-radius: 8px;
    font-size: 1rem;
    font-weight: 600;
    cursor: pointer;
    transition: all 0.3s ease;
    text-decoration: none;
    display: inline-block;
}

.hero-cta:hover {
    transform: translateY(-3px);
    box-shadow: 0 8px 25px rgba(46, 63, 91, 0.3);
}

/* Animação das imagens */
@keyframes slideInFromRight {
    0% {
        transform: translateX(30px);
        opacity: 0;
    }
    100% {
        transform: translateX(0);
        opacity: 1;
    }
}

.hero-image.slide-in {
    animation: slideInFromRight 1s ease-out forwards;
}

/* Stats Section */
.stats {
    background: #F8F9FA;
    padding: 40px 60px;
    overflow: hidden;
}

.stats-container {
    margin: 0 auto;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 60px;
}

.stats-grid {
    display: grid;
    grid-template-columns: 1fr auto 1fr auto 1fr auto 1fr;
    gap: 40px;
    align-items: center;
    width: 100%;
}

.stat-divider {
    width: 2px;
    height: 80px;
    background: #E0E0E0;
    border-radius: 1px;
}

.stat-item {
    text-align: center;
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.stat-number {
    font-family: 'Poppins', sans-serif;
    font-weight: 700;
    font-size: 2.1rem;
    color: #2E3F5B;
    line-height: 1;
    display: flex;
    align-items: baseline; /* Alinha o + na linha de base */
    justify-content: center;
    gap: 0.2rem;
}

.stat-number::before {
    content: '+';
    font-size: 1.8rem;
}

.stat-label {
    font-family: 'Open Sans', sans-serif;
    font-size: 20px;
    color: #4A4A4A;
    font-weight: 700;
    line-height: 1.4;
    max-width: 200px;
    margin: 0 auto;
}


/* Seção Nossas Soluções */
.nossas-solucoes {
    background: #F8F9FA;
    padding: 40px 100px;
    overflow: hidden;
}
        
.nossas-solucoes-container {
    margin: 0 auto;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 60px;
}
        
.nossas-solucoes-subtitle {
    font-family: 'Open Sans', sans-serif;
    font-size: 1.1rem;
    color: #4A4A4A;
    text-align: center;
    font-weight: 300;
}
        
.solucoes-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 40px;
    width: 100%;
}

.solucoes-grid-app {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 40px;
    width: 100%;
}
        
.solucao-card {
    background: #fff;
    border-radius: 20px;
    padding: 40px 30px;
    text-align: center;
    box-shadow: 0 5px 15px rgba(0, 0, 0, 0.08);
    transition: all 0.3s ease;
    border: 2px solid transparent;
    position: relative;
    overflow: hidden;
}

.solucao-imagem {
    width: 100%;
    height: 200px;
    border-radius: 12px;
    object-fit: cover;
    margin-bottom: 25px;
    transition: all 0.3s ease;
}

.solucao-imagem-app {
    width: 100%;
    height: 200px;
    border-radius: 12px;
    object-fit: cover;
    margin-bottom: 25px;
    transition: all 0.3s ease;
    border: 2px solid #25BACF;
}

.solucao-card:hover .solucao-imagem-app {
    transform: scale(1.05);
}

.solucao-card:hover .solucao-imagem {
    transform: scale(1.05);
}
        
.solucao-card:hover {
    transform: translateY(-10px);
    box-shadow: 0 20px 40px rgba(0, 0, 0, 0.15);
    border: 2px solid #25BACF;
}
        
.solucao-card::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 4px;
    background: linear-gradient(90deg, #25BACF, #2E3F5B);
    transform: scaleX(0);
    transition: transform 0.3s ease;
}
        
.solucao-card:hover::before {
    transform: scaleX(1);
}
        
.solucao-titulo {
    font-family: 'Poppins', sans-serif;
    font-weight: 600;
    font-size: 1.5rem;
    color: #2E3F5B;
    margin-bottom: 20px;
}
        
.solucao-descricao {
    font-family: 'Open Sans', sans-serif;
    font-size: 15px;
    color: #4A4A4A;
    line-height: 1.6;
    margin-bottom: 30px;
}
        
.solucao-cta {
    background: #2E3F5B;
    color: white;
    padding: 12px 24px;
    border: none;
    border-radius: 8px;
    font-size: 16px;
    font-weight: 600;
    cursor: pointer;
    transition: all 0.3s ease;
    text-decoration: none;
    display: inline-flex;
    align-items: center;
    gap: 8px;
}

.solucao-cta::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: #25BACF;
    transform: scaleX(0);
    transform-origin: left;
    transition: transform 0.4s cubic-bezier(0.3, 1, 0.8, 1);
    z-index: 5;
}

.solucao-cta:hover::before {
    transform: scaleX(1);
}

/* Seção Quem Confia */
.quem-confia {
    background: #F8F9FA;
    padding: 40px 100px;
    overflow: hidden;
}

.quem-confia-container {
    margin: 0 auto;
    text-align: center;
}

.quem-confia-subtitle {
    font-family: 'Open Sans', sans-serif;
    font-size: 1.1rem;
    color: #4A4A4A;
    margin-bottom: 15px;
    font-weight: 400;
}

.quem-confia-categories {
    font-family: 'Open Sans', sans-serif;
    font-size: 1rem;
    color: #6B7280;
    margin-bottom: 60px;
    line-height: 1.6;
    margin-left: auto;
    margin-right: auto;
    font-weight: 300;
}

.carousel-container {
    width: 100%;
    position: relative;
}

/* Track do carrossel */
.carousel-track {
    display: flex;
    width: fit-content;
    animation: scroll-infinite 30s linear infinite;
}

/* Itens do carrossel */
.carousel-item {
    flex: 0 0 auto;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.carousel-item:hover {
    transform: translateY(-5px);
}

/* Logos dos clientes */
.client-logo {
    max-width: 180px;
    height: auto;
    object-fit: contain;
    transition: all 0.3s ease;
}

.carousel-item:hover .client-logo {
    transform: scale(1.05);
}

/* Animação do carrossel infinito */
@keyframes scroll-infinite {
    0% {
        transform: translateX(0);
    }
    100% {
        transform: translateX(calc(-50% - 20px));
    }
}

/* Pausa a animação no hover */
.carousel-container:hover .carousel-track {
    animation-play-state: paused;
}

/* Seção Segmentos */
.segmentos {
    background: #F8F9FA;
    padding: 40px 100px 80px 100px;
    overflow: hidden;
}
        
.segmentos-container {
    margin: 0 auto;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 60px;
}
        
.segmentos-header {
    text-align: center;
}
        
.segmentos-subtitle {
    font-family: 'Open Sans', sans-serif;
    font-size: 1.1rem;
    color: #4A4A4A;
    font-weight: 300;
}
        
/* Carousel Container */
.segmentos-carousel {
    position: relative;
    width: 100%;
    margin: 0 auto;
}
        
/* Navigation Buttons */
.carousel-nav {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    background: rgba(46, 63, 91, 0.8);
    color: white;
    border: none;
    width: 40px;
    height: 40px;
    border-radius: 50%;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 20px;
    z-index: 10;
    transition: all 0.3s ease;
    backdrop-filter: blur(10px);
}
        
.carousel-nav:hover {
    background: rgba(46, 63, 91, 1);
    transform: translateY(-50%) scale(1.1);
}
        
.carousel-nav.prev {
    left: -70px;
}
        
.carousel-nav.next {
    right: -70px;
}
        
/* Carousel Content */
.carousel-content {
    position: relative;
    overflow: hidden;
    border-radius: 20px;
    box-shadow: 0 5px 15px rgba(0, 0, 0, 0.08);
    background: #FEFEFE;
}
        
/* Segmento Item - NOVA ABORDAGEM */
.segmento-item {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    display: flex;
    flex-direction: column;
    background: #FEFEFE;
    opacity: 0;
    visibility: hidden;
    transition: opacity 0.8s ease, visibility 0.8s ease;
}
        
/* Apenas o item ativo fica visível */
.segmento-item.active {
    opacity: 1;
    visibility: visible;
    position: relative;
}
        
.segmento-image {
    width: 100%;
    height: 250px;
    position: relative;
    overflow: hidden;
}
        
.segmento-image picture {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.6s ease;
}
        
/* Caixa de Conteúdo */
.segmento-content {
    padding: 40px;
    display: flex;
    flex-direction: column;
    justify-content: center;
    background: #FEFEFE;
    position: relative;
    text-align: center;
    flex: 1;
}
        
.segmento-content::before {
    content: '';
    position: absolute;
    left: 0;
    top: 0;
    width: 5px;
    height: 100%;
    background: linear-gradient(180deg, #25BACF, #2E3F5B);
}
        
.segmento-titulo {
    font-family: 'Poppins', sans-serif;
    font-weight: 600;
    font-size: 1.8rem;
    color: #2E3F5B;
    margin-bottom: 20px;
    line-height: 1.2;
}
        
.segmento-descricao {
    font-family: 'Open Sans', sans-serif;
    font-size: 16px;
    color: #4A4A4A;
    line-height: 1.7;
    margin-bottom: 30px;
}
        
.segmento-cta {
    background: #2E3F5B;
    color: white;
    padding: 14px 28px;
    border: none;
    border-radius: 8px;
    font-size: 16px;
    font-weight: 600;
    cursor: pointer;
    transition: all 0.3s ease;
    text-decoration: none;
    display: inline-flex;
    align-items: center;
    gap: 8px;
    margin: 0 auto;
}
        
.segmento-cta:hover {
    background: #1E2A3A;
    transform: translateY(-2px);
    box-shadow: 0 5px 15px rgba(0, 0, 0, 0.08);
}
        
.segmento-cta:hover::after {
    transform: translateX(3px);
}
        
/* Progress Indicators */
.carousel-indicators {
    display: flex;
    justify-content: center;
    gap: 12px;
    margin-top: 30px;
}
        
.indicator {
    width: 12px;
    height: 12px;
    border-radius: 50%;
    background: #D1D5DB;
    cursor: pointer;
    transition: all 0.3s ease;
    position: relative;
    overflow: hidden;
}
        
.indicator.active {
    background: #2E3F5B;
    transform: scale(1.2);
}
        
.indicator.active::after {
    content: '';
    position: absolute;
    top: 0;
    left: -100%;
    width: 100%;
    height: 100%;
    background: linear-gradient(90deg, transparent, rgba(255,255,255,0.4), transparent);
}

/* Rodapé da página */
.footer {
    background: #2E3F5B;
    padding: 60px 100px 40px 100px;
    position: relative;
}

.footer-container {
    position: relative;
    z-index: 2; /* Garante que o conteúdo fique acima do overlay */
    margin: 0 auto;
    display: grid;
    grid-template-columns: 1fr 1fr 1.2fr;
    gap: 80px;
    align-items: start;
}

.footer-container {
    margin: 0 auto;
    display: grid;
    grid-template-columns: 1fr 1fr 1.2fr;
    gap: 80px;
    align-items: start;
}

/* Coluna do Logo */
.footer-brand {
    display: flex;
    flex-direction: column;
    gap: 30px;
}

.footer-logo img {
    max-width: 300px;
    height: auto;
}

.footer-tagline {
    font-family: 'Open Sans', sans-serif;
    font-size: 16px;
    line-height: 1.6;
    color: #E5E5E5;
    margin: 0 auto;
    text-align: center;
}

/* Coluna de Navegação */
.footer-nav {
    display: flex;
    flex-direction: column;
    gap: 30px;
    margin: 0 auto;
}

.footer-title {
    font-family: 'Poppins', sans-serif;
    font-weight: 600;
    font-size: 20px;
    color: #E5E5E5;
    margin: 0;
    position: relative;
    padding-bottom: 15px;
}

/* ========================================= */
/* ATUALIZAÇÕES DO FOOTER */
/* ========================================= */

/* Container das redes sociais */
.social-media-container {
    display: flex;
    justify-content: center;
    gap: 20px;
}

/* Ícones das redes sociais */
.social-icon {
    width: 40px;
    height: 40px;
    border-radius: 12px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #FFFFFF;
    background-color: #25BACF;
    text-decoration: none;
    transition: all 0.3s ease;
    position: relative;
    overflow: hidden;
}

/* Efeitos de hover */
.social-icon:hover {
    transform: translateY(-3px) scale(1.05);
    box-shadow: 0 5px 15px rgba(0, 0, 0, 0.08);
}

/* Container do mapa */
.company-map {
    width: 100%;
    border-radius: 10px;
    overflow: hidden;
    transition: all 0.3s ease;
    position: relative;
}

.footer-title::after {
    content: '';
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100px;
    height: 2px;
    background: #25BACF;
}

.footer-links {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.footer-links a {
    font-family: 'Open Sans', sans-serif;
    font-size: 1rem;
    color: #F8F9FA;
    text-decoration: none;
    transition: color 0.3s ease;
}

.footer-links a:hover {
    color: #25BACF;
}

/* Coluna de Contatos */
.footer-contact {
    display: flex;
    flex-direction: column;
    gap: 30px;
}

.footer-marca {
  border-top: 1px solid rgba(255,255,255,0.1); /* linha superior */
  text-align: center;
  margin-top: 50px;
  padding-top: 15px;
}

.footer-marca p {
    font-family: 'Poppins', sans-serif;
    margin: 0;
    color: #F8F9FA;  /* cor do texto */
    font-size: 1rem; /* tamanho */
}

/* Caixa branca dos contatos */
.contact-box {
    background: #FFFFFF;
    border-radius: 15px;
    padding: 30px;
    box-shadow: 0 5px 15px rgba(0, 0, 0, 0.08);
}

.contact-info {
    display: flex;
    flex-direction: column;
    gap: 20px;
}

/* Item de contato com emoji */
.contact-item {
  display: flex;
  align-items: center;
  margin-bottom: 12px;
}

.contact-icon {
  margin-right: 10px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.contact-icon svg {
  width: 24px;
  height: 24px;
  fill: #2E3F5B;
  transition: 0.3s;
}

.contact-item a {
  color: #2E3F5B;
  text-decoration: none;
  transition: 0.3s;
}

.contact-address {
    font-family: 'Open Sans', sans-serif;
    font-size: 16px;
    line-height: 1.6;
    color: #4A4A4A;
    margin: 0;
}

.contact-phone {
    font-family: 'Open Sans', sans-serif;
    font-size: 18px;
    font-weight: 600;
    color: #2E3F5B;
    margin: 0;
}

/* Botão WhatsApp */
.whatsapp-button {
    background: #25C26E;
    color: #FFFFFF;
    padding: 15px 30px;
    border-radius: 25px;
    font-family: 'Poppins', sans-serif;
    font-weight: 600;
    font-size: 16px;
    text-decoration: none;
    display: block;
    text-align: center;
    transition: all 0.3s ease;
    margin: 10px auto 0 auto;
    max-width: fit-content;
}

.whatsapp-button:hover {
    background: #22B865;
    transform: translateY(-2px);
    box-shadow: 0 8px 20px rgba(37, 194, 110, 0.3);
}

/* =======================================================
   SOLUÇÕES — V4 (multi-grids)  — complementos
   ======================================================= */
:root{
  --solv4-ink: var(--ink, #2E3F5B);
  --solv4-cyan: var(--cyan, #25BACF);
  --solv4-bg: var(--bg, #F8F9FA);
  --solv4-radius: 18px;
  --solv4-shadow: 0 12px 26px rgba(0,0,0,.08);
  --solv4-pad-x: 100px;
  --solv4-pad-y: 40px;
}
@media (min-width:1920px){
  :root{ --solv4-pad-x: 300px; --solv4-pad-y: 60px; }
}

.sol-v4.section{
  background: var(--solv4-bg);
  padding: var(--solv4-pad-y) var(--solv4-pad-x);
  overflow: clip;
}
.sol-v4__container{ margin: 0 auto; display:flex; flex-direction:column; gap:20px; }
.sol-v4__header{ text-align:center; display:flex; flex-direction:column; gap:12px; }
.sol-v4__subtitle{ color:#4A4A4A; margin: 6px auto 0; }

/* KPIs */
.sol-v4__kpis{
  list-style:none; padding:0; margin: 8px auto 0;
  display:grid; grid-template-columns:repeat(3,1fr); gap:12px;
}
.sol-v4__kpis li{
  background:#fff; border:1px solid rgba(37,186,207,.18); border-radius:16px; padding:14px; text-align:center;
  box-shadow: var(--solv4-shadow);
}
.sol-v4__kpis strong{ display:block; color:var(--solv4-ink); font-size: clamp(18px, 2.2vw, 24px); }
.sol-v4__kpis span{ color:#4A4A4A; font-size: .95rem; }

/* Chips */
.sol-v4__highlights{
  list-style:none; padding:0; margin: 6px auto 6px;
  display:flex; gap:10px; flex-wrap:wrap; justify-content:center;
}
.sol-v4__highlights li{
  padding:8px 12px; border-radius:999px; background:#fff; color:var(--solv4-ink);
  border:1.5px solid rgba(37,186,207,.35); font-weight:600; white-space:nowrap;
}

/* Cards (grid 3x) */
.sol-v4__grid{ display:grid; grid-template-columns: repeat(3, minmax(0,1fr)); gap:16px; margin-top: 35px; }
.sol-v4__card{
  background:#fff; border:1px solid rgba(37,186,207,.18); border-radius:var(--solv4-radius); padding:18px;
  box-shadow: var(--solv4-shadow);
  transition:.25s ease; position:relative; display:flex; flex-direction:column; gap:10px;
}
.sol-v4__card::before{
  content:""; position:absolute; inset:0 0 auto 0; height:4px;
  background: linear-gradient(90deg, var(--solv4-cyan), var(--solv4-ink));
  transform: scaleX(0); transform-origin: left; transition: transform .28s ease;
}
.sol-v4__card:hover{ transform: translateY(-4px); box-shadow:0 18px 40px rgba(0,0,0,.12); border-color: var(--solv4-cyan); }
.sol-v4__card:hover::before{ transform: scaleX(1); }
.sol-v4__icon{ width:44px; height:44px; border-radius:12px; display:grid; place-items:center; background:#EAF8FB; border:1px solid rgba(37,186,207,.25); }
.sol-v4__icon img{ width:24px; height:24px; object-fit:contain; }
.sol-v4__card h3{ margin:2px 0 2px; color:var(--solv4-ink); font-size: clamp(18px,2vw,20px); }
.sol-v4__card p{ margin:0; color:#4A4A4A; font-size: .98rem; }
.sol-v4__list{ margin:2px 0 0; padding-left:18px; color:#2E3F5B; display:grid; gap:4px; }
.sol-v4__card .solucao-cta{ margin-top:auto; align-self:flex-start; }

/* Rail / Timeline 4x */
.sol-v4__rail{
  position:relative; display:grid; grid-template-columns:repeat(4,1fr); gap:16px;
  background:#fff; border:1px solid rgba(37,186,207,.18); border-radius:var(--solv4-radius); padding:18px;
  box-shadow: var(--solv4-shadow); overflow:hidden; margin-top: 35px;
}
.sol-v4__rail::before{
  content:""; position:absolute; top:34px; left:24px; right:24px; height:3px;
  background: linear-gradient(90deg, var(--solv4-cyan), var(--solv4-ink)); opacity:.35; border-radius:3px;
}
.sol-v4__step{ text-align:center; padding-top:24px; }
.sol-v4__dot{
  width:36px; height:36px; border-radius:999px; margin:-42px auto 8px;
  display:grid; place-items:center; background:var(--solv4-ink); color:#fff; font-weight:700;
  border:2px solid var(--solv4-cyan); box-shadow:0 8px 20px rgba(0,0,0,.12);
}
.sol-v4__step h4{ margin:0 0 4px; color:var(--solv4-ink); font-size: 1rem; }
.sol-v4__step p{ margin:0; color:#4A4A4A; font-size:.95rem; }

.mosaic__item{ position:relative; border-radius:16px; overflow:hidden; }
.mosaic__item img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; filter: saturate(105%); transition: transform .35s ease; }
.mosaic__overlay{
  position:absolute; inset:auto 0 0 0; padding:16px; background: linear-gradient(180deg, transparent 0%, rgba(0,0,0,.55) 90%);
  color:#fff; display:flex; flex-direction:column; gap:4px;
}
.mosaic__overlay h3{ font-size: 1.05rem; line-height:1.15; }
.mosaic__overlay p{ font-size:.95rem; opacity:.95; }

.mosaic__item:hover img{ transform: scale(1.04); }

/* Comparativo 3x */
.sol-v4__compare{
  margin-top: 35px;
  display:grid; grid-template-columns: repeat(3, minmax(0,1fr)); gap:12px;
}
.cmp-card{
  background:#fff; border:1px solid rgba(37,186,207,.18); border-radius:16px; padding:16px;
  box-shadow: var(--solv4-shadow);
}
.cmp-card h4{ color:var(--solv4-ink); margin: 0 0 6px; font-size: 1rem; }
.cmp-card ul{ margin:0; padding-left: 18px; display:grid; gap:4px; }

.porque-escolher-educacao {
    background: #f8f9fa;
    padding: 40px 100px;
    overflow: hidden;
}

.porque-escolher-container {
    margin: 0 auto;
    display: flex;
    flex-direction: column;
    gap: 50px;
}

.nova-sessao-header {
    text-align: center;
    margin-bottom: 30px;
}

.nova-sessao-subtitle {
    font-family: 'Open Sans', sans-serif;
    font-weight: 400;
    font-size: 1.1rem;
    color: #6C757D;
    margin: 0 auto;
    line-height: 1.6;
}

.porque-escolher-content {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 60px;
    align-items: center;
}

.float-wrapper{
  width: 280px;
  height: 580px;
  margin: 50px auto;
}

.phone {
  width: 100%;
  height: 100%;
  border-radius: 40px;
  border: 8px solid #2d2d2d;
  overflow: hidden;
}

.phone-img {
    width: 100%;
    height: auto;
}

.educacao-image {
    width: 100%;
    height: auto;
    border-radius: 20px;
    box-shadow: 0 20px 40px rgba(0, 0, 0, 0.15);
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.educacao-image:hover {
    transform: translateY(-5px);
    box-shadow: 0 25px 50px rgba(0, 0, 0, 0.2);
}

.porque-escolher-text {
    padding-left: 40px;
}

.diferenciais-list {
    display: flex;
    flex-direction: column;
    gap: 35px;
}

.diferencial-item {
    display: flex;
    align-items: flex-start;
    gap: 25px;
    background: #fff;
    padding: 25px;
    border-radius: 15px;
    box-shadow: 0 5px 15px rgba(0, 0, 0, 0.08);
    transition: all 0.3s ease;
     border-left: 4px solid transparent;
}

.diferencial-item:hover {
    transform: translateX(5px);
    background: rgba(255, 255, 255, 0.9);
    border-left-color: #25BACF;
    box-shadow: 0 8px 25px rgba(0, 0, 0, 0.12);
}

.diferencial-icon-space {
    width: 70px;
    height: 70px;
    display: flex;
    margin: auto 0;

}

.diferencial-icon-space img {
    width: 70px;
    height: auto;
}

.diferencial-content {
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.diferencial-title {
    font-family: 'Poppins', sans-serif;
    font-weight: 600;
    font-size: 1.1rem;
    color: #2E3F5B;
    margin-bottom: 5px;
}

.diferencial-text p {
    font-family: 'Open Sans', sans-serif;
    font-size: 15px;
    color: #5A6C7D;
    line-height: 1.6;
    margin: 0;
}

/* Seção Vídeo */
.video-section {
    padding: 40px 100px;
    position: relative;
    overflow: hidden;
}

.video-section::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    pointer-events: none;
}

.video-container {
    margin: 0 auto;
    position: relative;
    z-index: 1;
}

.video-header {
    text-align: center;
    margin-bottom: 50px;
}

.video-wrapper {
    max-width: 1100px;
    position: relative;
    margin: 0 auto 40px;
    background: #F8F9FA;
    border-radius: 20px;
    padding: 10px;
    box-shadow: 
        0 20px 40px rgba(0, 0, 0, 0.1),
        0 8px 24px rgba(0, 0, 0, 0.08);
    transform: translateY(0);
    transition: all 0.3s ease;
}

.video-wrapper:hover {
    transform: translateY(-10px);
    box-shadow: 
        0 30px 60px rgba(0, 0, 0, 0.15),
        0 12px 36px rgba(0, 0, 0, 0.12);
}

.video-wrapper::before {
    content: '';
    position: absolute;
    top: -2px;
    left: -2px;
    right: -2px;
    bottom: -2px;
    background: linear-gradient(45deg, #25BACF, #2E3F5B, #25BACF);
    border-radius: 22px;
    z-index: -1;
    opacity: 0;
    transition: opacity 0.3s ease;
}

.video-wrapper:hover::before {
    opacity: 1;
}

.video-frame {
    position: relative;
    width: 100%;
    padding-bottom: 56.25%; /* Proporção 16:9 */
    height: 0;
    border-radius: 16px;
    overflow: hidden;
    background: #000;
}

.video-frame iframe {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    border-radius: 16px;
}

.video-cta {
    text-align: center;
    margin-top: 40px;
}

.video-cta-text {
    font-size: 1.1rem;
    color: #4A4A4A;
    margin-bottom: 25px;
    line-height: 1.6;
}

.video-cta .cta-comprar {
    background: linear-gradient(135deg, #25BACF 0%, #2E3F5B 100%);
    color: white;
    border: none;
    border-radius: 50px;
    padding: 18px 40px;
    font-size: 1.1rem;
    font-weight: 600;
    cursor: pointer;
    transition: all 0.3s ease;
    box-shadow: 0 8px 25px rgba(52, 152, 219, 0.3);
    position: relative;
    overflow: hidden;
}

.video-cta .cta-comprar::before {
    content: '';
    position: absolute;
    top: 0;
    left: -100%;
    width: 100%;
    height: 100%;
    background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.3), transparent);
    transition: left 0.5s ease;
}

.video-cta .cta-comprar:hover::before {
    left: 100%;
}

.video-cta .cta-comprar:hover {
    transform: translateY(-3px);
    box-shadow: 0 12px 35px rgba(52, 152, 219, 0.4);
}

.video-cta .cta-comprar span a {
    color: white;
    text-decoration: none;
}

/* Seção Tecnologias */
.tecnologias {
    background: #F8F9FA;
    padding: 40px 100px 80px 100px;
    overflow: hidden;
}

.tecnologias-container {
    margin: 0 auto;
    display: flex;
    flex-direction: column;
    gap: 60px;
}

/* Título */
.tecnologias-header {
    text-align: center;
}

.tecnologias-title {
    font-family: 'Poppins', sans-serif;
    font-weight: 600;
    font-size: 2rem;
    color: #2E3F5B;
    margin: 0;
    line-height: 1.2;
}

/* Conteúdo principal */
.tecnologias-content {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 80px;
    align-items: center;
}

/* Lado esquerdo - Lista de tecnologias */
.tecnologias-list {
    display: flex;
    flex-direction: column;
    gap: 40px;
    padding-right: 20px;
}

.tecnologia-item {
    display: flex;
    align-items: flex-start;
    gap: 25px;
}

.tecnologia-icon {
    flex: 0 0 40px;
    width: 40px;
    height: 40px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.tecnologia-icon img {
    width: 40px;
    height: 40px;
    object-fit: contain;
}

.tecnologia-text {
    flex: 1;
    display: flex;
    align-items: center;
}

.tecnologia-text p {
    font-family: 'Open Sans', sans-serif;
    font-size: 16px;
    color: #4A4A4A;
    line-height: 1.6;
    margin: 0;
}

/* Lado direito - Imagens das tecnologias */
.tecnologias-images {
    display: flex;
    flex-direction: column;
    gap: 30px;
    align-items: center;
}

.tecnologia-image {
    width: 100%;
    max-width: 600px;
    height: 80px; /* Altura fixa pré-definida */
}

.tecnologia-img {
    width: 100%;
    height: 100%; /* Ocupa toda a altura do container */
    border-radius: 12px;
    box-shadow: 0 10px 25px rgba(0, 0, 0, 0.1);
    object-fit: cover; /* Mantém proporção e preenche o espaço */
}

.nova-sessao {
    background: #F8F9FA;
    padding: 40px 100px;
    overflow: hidden;
}

.nova-sessao-header {
    text-align: center;
    margin-bottom: 50px;
}

.nova-sessao-subtitle {
    font-family: 'Open Sans', sans-serif;
    font-size: 1.2rem;
    color: #4A4A4A;
    margin: 0 auto;
    line-height: 1.6;
}

.parceiros-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(400px, 1fr));
    gap: 40px;
    margin-top: 40px;
 }

.parceiro-card {
    background: white;
    border-radius: 16px;
    padding: 30px;
    box-shadow: 0 8px 30px rgba(0, 0, 0, 0.08);
    transition: all 0.3s ease;
    border: 1px solid rgba(46, 63, 91, 0.1);
}

.parceiro-card:hover {
    transform: translateY(-8px);
    box-shadow: 0 20px 50px rgba(0, 0, 0, 0.15);
    border-color: rgba(46, 63, 91, 0.2);
}

.parceiro-header {
    display: flex;
    align-items: center;
    margin-bottom: 25px;
    padding-bottom: 20px;
    border-bottom: 2px solid #E9ECEF;
}

.parceiro-logo {
    width: 110px;
    height: 110px;
    display: flex;
    align-items: center;
    justify-content: center;
    margin-right: 20px;
}

.parceiro-logo img {
    width: 110px;
    height: auto;
    object-fit: contain;
}

.parceiro-info h3 {
    font-family: 'Poppins', sans-serif;
    font-weight: 600;
    font-size: 1.4rem;
    color: #2E3F5B;
    margin: 0 0 5px 0;
}

.parceiro-info .categoria {
    font-family: 'Open Sans', sans-serif;
    font-size: 0.9rem;
    color: #6C757D;
    background: #E7F3FF;
    padding: 4px 12px;
    border-radius: 20px;
    display: inline-block;
}

.info-section {
    margin-bottom: 25px;
}

.info-section:last-child {
    margin-bottom: 0;
}

.info-title {
    font-family: 'Poppins', sans-serif;
    font-weight: 600;
    font-size: 1rem;
    color: #2E3F5B;
    margin-bottom: 8px;
    display: flex;
    align-items: center;
}

.info-title::before {
    content: "";
    width: 4px;
    height: 16px;
    background: linear-gradient(135deg, #007BFF, #0056B3);
    border-radius: 2px;
    margin-right: 10px;
}

.info-content {
    font-family: 'Open Sans', sans-serif;
    font-size: 0.95rem;
    color: #495057;
    line-height: 1.6;
    margin-left: 14px;
}

.tecnologias-tags {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-left: 14px;
}

.tech-tag {
    background: #25BACF;
    color: #F8F9FA;
    padding: 6px 12px;
    border-radius: 20px;
    font-family: 'Open Sans', sans-serif;
    font-size: 0.85rem;
    font-weight: 700;
}

.resultados-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 15px;
    margin-left: 14px;
}

.resultado-item {
    background: #F8F9FA;
    padding: 15px;
    border-radius: 10px;
    border-left: 4px solid #28A745;
}

.resultado-numero {
    font-family: 'Poppins', sans-serif;
    font-weight: 700;
    font-size: 1.5rem;
    color: #28A745;
    margin-bottom: 5px;
}

.resultado-descricao {
    font-family: 'Open Sans', sans-serif;
    font-size: 0.85rem;
    color: #495057;
    line-height: 1.4;
}


/* Banner Educação */
/* OPÇÃO 4: Minimalista com texto escuro */
.banner-educacao {
    position: relative;
    height: 45vh;
    display: flex;
    align-items: center;
    overflow: hidden;
}

.banner-image {
    aspect-ratio: 16/6;
    top: 0;
    left: 0;
    width: 100%;
    height: auto;
    object-fit: contain;
    filter: brightness(1.2) contrast(0.5) saturate(0.4);
    z-index: 1;
}

.banner-image picture img{
    width: 100%;
    height: 100%;
}

.banner-educacao .banner-overlay {
    aspect-ratio: 16/6;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(255,255,255,0.7);
    z-index: 2;
}

.banner-educacao .banner-content {
    position: relative;
    z-index: 3;
    margin: 0 auto;
    padding-left: 100px;
    padding-right: 100px;
}

.banner-educacao .banner-title {
    font-family: 'Poppins', sans-serif;
    font-size: 3rem;
    font-weight: 600;
    color: #2c3e50;
    line-height: 1.2;
    margin: 0;
    text-align: left;
    position: relative;
    padding-left: 20px;
}

.banner-educacao .banner-title::before {
    content: '';
    position: absolute;
    left: 0;
    top: 0;
    bottom: 0;
    width: 6px;
    background: linear-gradient(180deg, #3498db, #2980b9);
    border-radius: 3px;
}

/* Seção Integração Completa */
.integracao-section {
    background: #F8F9FA;
    padding: 40px 100px;
    display: flex;
    align-items: center;
}

.integracao-container {
    margin: 0 auto;
    width: 100%;
}

.integracao-header {
    text-align: center;
    margin-bottom: 0px;
    position: relative;
}

.header-badge {
    background: #25BACF;
    color: #F8F9FA;
    padding: 12px 40px;
    border-radius: 50px;
    font-family: 'Poppins', sans-serif;
    font-weight: 600;
    font-size: 2rem;
    display: inline-block;
    margin-bottom: 0px;
    box-shadow: 0 8px 25px rgba(23, 162, 184, 0.3);
    position: relative;
    overflow: hidden;
}

/* Diagrama */
.integracao-diagram {
    position: relative;
    display: flex;
    flex-direction: column;
    align-items: center;
}

/* Linha vertical principal conectando diretamente ao badge */
.main-connector {
    width: 4px;
    height: 60px;
    background: #25BACF;
    border-radius: 2px;
    margin: 0 auto;
    position: relative;
    animation: pulse 2s infinite;
}

/* Nova linha horizontal conectando todos os cards */
.horizontal-connector {
    width: 77%;
    height: 4px;
    background: #25BACF;
    border-radius: 2px;
    margin-bottom: 20px;
    position: relative;
    animation: pulse 2s infinite;
}

@keyframes pulse {
    0%, 100% { opacity: 0.8; }
    50% { opacity: 1; }
}

/* Grid dos apps */
.apps-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 30px;
    width: 100%;
    position: relative;
}

/* Conectores individuais para cada card */
.card-connector {
    position: absolute;
    top: -26px;
    left: 50%;
    transform: translateX(-50%);
    width: 4px;
    height: 26px;
    background: #25BACF;
    border-radius: 2px;
    animation: pulse 2s infinite;
}

/* Cards dos apps */
.app-card {
    background: #f8f9fa;
    border-radius: 16px;
    padding: 25px 20px;
    text-align: center;
    box-shadow: 0 8px 30px rgba(0, 0, 0, 0.1);
    transition: all 0.3s ease;
    border: 2px solid rgba(23, 162, 184, 0.1);
    position: relative;
}

.app-card:hover {
    box-shadow: 0 20px 40px rgba(0, 0, 0, 0.15);
    border: 2px solid #25BACF;
}

.app-icon {
    max-width: 80px;
    height: auto;
    margin: 0 auto 20px;
    display: flex;
    align-items: center;
    justify-content: center;
    position: relative;
    overflow: hidden;
}

.app-icon img{
    width: 80px;
    height: auto;
}

.app-title {
    font-family: 'Poppins', sans-serif;
    font-weight: 600;
    font-size: 1.1rem;
    color: #2E3F5B;
    margin-bottom: 15px;
}

.app-description {
    font-family: 'Open Sans', sans-serif;
    font-size: 0.9rem;
    color: #6C757D;
    line-height: 1.6;
    text-align: center;
    margin: 0;
}

/* ============================= */
/* Sessão Introdução Educação    */
/* ============================= */
.introducao-educacao {
  background: #F8F9FA;
  padding: 40px 100px;
  text-align: center;
}

.introducao-header {
  margin: 0 auto 60px;
}

.introducao-titulo {
  font-family: 'Poppins', sans-serif;
  font-size: 2.2rem;
  font-weight: 700;
  color: #2E3F5B;
  margin-bottom: 20px;
}

.introducao-subtitle {
  font-family: 'Open Sans', sans-serif;
  font-size: 1.1rem;
  color: #4A4A4A;
  line-height: 1.6;
}

/* Grid de Cards */
.introducao-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:24px;
  align-items:stretch;           /* todos os cards com mesma altura */
  justify-items:stretch;
}

/* Card com centro perfeito e mesma estética dos Acessos */
.introducao-card{
  position:relative;
  background:#F8F9FA;
  border-radius:20px;
  padding:26px 22px;
  box-shadow:0 10px 30px rgba(0,0,0,.08);
  border: solid transparent;
  transition:transform .25s ease, box-shadow .25s ease, border-color .25s ease;

  display:flex;
  flex-direction:column;
  align-items:center;            /* tudo centralizado */
  text-align:center;
  gap:14px;

  min-height:360px;              /* altura coerente entre cards */
  height:100%;
}

.introducao-card {
    opacity: 1;
    transform: translateY(0);
}

.introducao-card:hover {
    transform: translateY(-10px);
    box-shadow: 0 20px 40px rgba(0, 0, 0, 0.15);
    border: 2px solid #25BACF;
}

.introducao-card::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 4px;
    background: linear-gradient(90deg, #25BACF, #2E3F5B);
    transform: scaleX(0);
    transition: transform 0.3s ease;
}

.introducao-card:hover::before {
    transform: scaleX(1);
}

.introducao-card .card-icon{
  width:72px; height:72px;
  border-radius:14px;
  background:#F0FBFD;
  display:grid; place-items:center;
  border:1px solid rgba(37,186,207,.2);
}
.introducao-card .card-icon img{
  width:44px; height:44px; object-fit:contain;
}

/* Tipografia consistente */
.introducao-card .card-title{
  font-family:'Poppins',sans-serif;
  font-weight:600;
  font-size:1.1rem;
  color:#2E3F5B;
  line-height:1.25;
  min-height:2.6em;              /* estabiliza altura do título */
}
.introducao-card .card-text{
  font-family:'Open Sans',sans-serif;
  font-size:15px;
  color:#4A4A4A;
  line-height:1.6;
  min-height:4.5em;              /* estabiliza o parágrafo */
}

/* Se o card tiver CTA, ele fica sempre alinhado no rodapé */
.introducao-card .cta-container{ margin-top:auto; }
.introducao-card .cta-comprar-integracao{
  display:inline-flex; align-items:center; justify-content:center;
}

/* =======================================================
   SESSÃO ACESSOS – alinhado ao centro e no padrão do site
   ======================================================= */
.acessos{
  background:#F8F9FA;
  padding:40px 100px;           /* mesmo respiro das outras sessões */
  overflow:hidden;
}

.acessos-container{
  margin:0 auto;
  display:flex;
  flex-direction:column;
  gap:40px;
}

.acessos-header{ text-align:center; }

/* GRID principal – pensado para 1300px (4 colunas) */
.acessos-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:24px;
  align-items:stretch;          /* todos os cards com mesma altura */
  justify-items:stretch;
}

/* CARD */
.acesso-card{
  position:relative;
  background:#FEFEFE;
  border-radius:20px;
  padding:26px 22px;
  box-shadow:0 10px 30px rgba(0,0,0,0.08); /* mesma “vibe” dos outros */
  border:2px solid transparent;
  transition:transform .25s ease, box-shadow .25s ease, border-color .25s ease;

  /* centro absoluto do conteúdo */
  display:flex;
  flex-direction:column;
  align-items:center;           /* tudo centralizado */
  text-align:center;
  gap:14px;

  min-height:380px;
  height:100%;
}

/* 1) Garante clipping nos cantos (como .solucao-card / .vantagem-card) */
.acesso-card{
  position: relative;
  overflow: hidden;                /* evita “vazar” no raio do card */
  border: 2px solid transparent;   /* mesmo padrão visual */
  transition: transform .3s ease, box-shadow .3s ease, border-color .3s ease;
}

/* 2) Barrinha superior no mesmo estilo das suas sessões anteriores */
.acesso-card::before{
  content: '';
  position: absolute;
  top: 0;            /* sem inset — igual ao padrão existente */
  left: 0;
  width: 100%;
  height: 4px;
  background: linear-gradient(90deg, #25BACF, #2E3F5B); /* mesmo gradiente */
  transform: scaleX(0);           /* começa “fechada” */
  transform-origin: center;
  transition: transform 0.3s ease;/* mesmo tempo/curva dos seus cards */
  /* IMPORTANTE: removemos qualquer background-size/animation para igualar */
}

/* 3) Hover idêntico ao padrão (só abre a barra) */
.acesso-card:hover::before {
  transform: scaleX(1);
}

/* 4) Hover visual do card (igual ao que você já usa) */
.acesso-card:hover{
  transform: translateY(-6px);
  box-shadow: 0 20px 40px rgba(0,0,0,.12);
  border-color: #25BACF;
}

/* --- Fix: barra do topo não sai do card no hover --- */
.acesso-card,
.introducao-card{
  position: relative;   /* garante contexto para o ::before */
  overflow: hidden;     /* CLIPA a barra dentro do raio do card */
}

/* Se suas bordas têm 2px, inset 2px.
   Se mudar a espessura, ajuste o valor abaixo. */
.acesso-card::before,
.introducao-card::before{
  border-radius: 999px; /* termina redondinho e não espeta no canto */
  background-size: 200% 100%;
  will-change: transform, background-position;
}

@keyframes acessoShimmer{
  0%{background-position:0% 0;}
  100%{background-position:100% 0;}
}

/* Ícone dentro de “pill” – centralizado */
.acesso-icon{
  width:72px; height:72px;
  border-radius:14px;
  background:#F0FBFD;
  display:grid; place-items:center;
  border:1px solid rgba(37,186,207,.2);
}
.acesso-icon img{
  width:44px; height:44px; object-fit:contain;
}

/* Tipografia no mesmo tom das demais seções */
.acesso-title{
  font-family:'Poppins',sans-serif;
  font-weight:600;
  font-size:1.1rem;
  color:#2E3F5B;
  line-height:1.25;
  min-height:2.6em;             /* garante altura parecida entre cards */
}
.acesso-text{
  font-family:'Open Sans',sans-serif;
  font-size:15px;
  color:#4A4A4A;
  line-height:1.6;
  min-height:4.5em;
}

/* Lista centralizada e consistente com o resto do site */
.acesso-list{
  list-style:none;
  margin:0;
  padding:0;
  display:grid;
  gap:8px;
  width:100%;
}
.acesso-list li{
  display:flex;
  align-items:flex-start;
  justify-content:center;       /* centraliza o conjunto */
  gap:8px;
  color:#2E3F5B;
  font-size:14px;
}
.acesso-list li::before{
  content:"";
  width:6px; height:6px;
  margin-top:.45em;
  border-radius:50%;
  background:#25BACF;
  flex:0 0 6px;
}

/* CTA igual às demais sessões (central) */
.acesso-cta{
  margin-top:auto;              /* empurra o CTA pro rodapé do card */
  background:#2E3F5B;
  color:#FFFFFF;
  padding:10px 18px;
  border-radius:10px;
  font-weight:600;
  font-size:1rem;
  text-decoration:none;
  display:inline-flex; align-items:center; justify-content:center; gap:8px;
  transition:transform .2s ease, box-shadow .2s ease;
  margin: 0 auto;
}
.acesso-cta:hover{
  background:#1E2A3A;
  transform:translateY(-2px);
  box-shadow:0 10px 24px rgba(46,63,91,.25);
}

/* Seção Parceria Exclusiva */
.parceria-exclusiva {
    background: linear-gradient(135deg, #fdf3f3, #ffffff);
    padding: 40px 100px;
    border-radius: 20px;
}

.parceria-header {
    text-align: center;
    margin-bottom: 50px;
}

.parceria-header h2 {
    font-family: 'Poppins', sans-serif;
    font-weight: 600;
    font-size: 2rem;
    color: #e53e3e;
    margin-bottom: 20px;
    text-align: center;
}

.parceria-subtitle {
    font-size: 1.2rem;
    color: #444;
    margin-top: 8px;
}

.parceria-grid {
    display: grid;
    grid-template-columns: 1.2fr 0.8fr;
    gap: 60px;
    align-items: stretch;
}

.parceria-texto p {
    font-size: 1.1rem;
    line-height: 1.6;
    color: #333;
    margin-bottom: 20px;
}

.beneficios-title {
    font-size: 1.3rem;
    font-weight: 600;
    color: #2E3F5B;
    margin: 20px 0;
}

.beneficios-lista {
    list-style: none;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 15px;
}

.beneficios-lista li {
    display: flex;
    align-items: center;
    font-size: 1rem;
    color: #444;
    gap: 10px;
}

.lucide-circle-check-big {
    color: #e53e3e;
}

/* Define o tamanho do card */
.parceria-card {
    width: 100%;
    height: auto;
    display: flex;
    justify-content: center;
    align-items: center;
    border-radius: 15px;
    overflow: visible; /* Mudança aqui para permitir que os quadrados saiam do container */
    position: relative; /* Necessário para posicionamento absoluto dos quadrados */
}

/* Ajusta a imagem dentro do bloco */
.parceria-img {
    width: 100%;
    height: 100%;
    object-fit: contain;
    border-radius: 15px;
    position: relative;
    z-index: 2;
}

/* Estilos dos quadrados flutuantes */
.floating-square {
    position: absolute;
    border-radius: 12px;
    z-index: 1; /* Fica atrás da imagem */
}

.square-1 {
    width: 80px;
    height: 80px;
    background: linear-gradient(135deg, #e53e3e, #ff6b6b);
    top: -20px;
    right: -30px;
    animation: float1 6s ease-in-out infinite;
    opacity: 0.8;
}

.square-2 {
    width: 60px;
    height: 60px;
    background: linear-gradient(135deg, #ff6b6b, #e53e3e);
    bottom: -15px;
    left: -25px;
    animation: float2 8s ease-in-out infinite reverse;
    opacity: 0.7;
}

/* Animações de flutuação */
@keyframes float1 {
    0%, 100% {
        transform: translateY(0px) rotate(0deg);
    }
    50% {
        transform: translateY(-20px) rotate(5deg);
    }
}

@keyframes float2 {
    0%, 100% {
        transform: translateY(0px) rotate(0deg);
    }
    50% {
        transform: translateY(-15px) rotate(-3deg);
    }
}

/* Adicione este CSS ao seu arquivo de estilos */
.parceria-cta {
    margin-top: 30px;
    display: flex;
    justify-content: flex-start;
}

.btn-parceria {
    background: #e53e3e;
    color: #F8F9FA;
    border: none;
    padding: 15px 30px;
    font-size: 1rem;
    font-weight: 600;
    border-radius: 8px;
    cursor: pointer;
    display: flex;
    align-items: center;
    gap: 8px;
    transition: all 0.3s ease;
    box-shadow: 0 4px 15px rgba(229, 62, 62, 0.2);
}

.btn-parceria:hover {
    background: #c53030;
    transform: translateY(-2px);
    box-shadow: 0 8px 25px rgba(229, 62, 62, 0.3);
}

.btn-parceria:hover .btn-arrow {
    transform: translateX(4px);
}

.btn-arrow {
    transition: transform 0.3s ease;
}

/* Seção Tecnologias */
.tecnologias-section {
    background: #F8F9FA;
    padding: 40px 100px 60px 100px;
    overflow: hidden;
}

.tecnologias-section-container {
    margin: 0 auto;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 60px;
}

/* Cabeçalho */
.tecnologias-section-header {
    text-align: center;
}

/* Grid dos boxes principais */
.tecnologias-boxes-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 40px;
    width: 100%;
}

/* Box individual */
.tecnologia-box {
    background: #F8F9FA;
    border-radius: 20px;
    padding: 30px;
    position: relative;
    overflow: hidden;
    box-shadow: 0 10px 30px rgba(0, 0, 0, 0.2);
}

/* Cabeçalho do box */
.tecnologia-box-header {
    background: #25BACF;
    margin: -30px -30px 25px -30px;
    padding: 20px 30px;
    display: flex;
    align-items: center;
    gap: 15px;
    border-radius: 20px 20px 0 0;
}

.tecnologia-box-icon {
    width: 50px;
    height: 50px;
    border-radius: 8px;
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;

    background: rgba(255, 255, 255, 0.4);
    backdrop-filter: blur(50px);
    -webkit-backdrop-filter: blur(50px);
    border: 1px solid rgba(255, 255, 255, 0.3);
    box-shadow: 
        0 8px 32px rgba(0, 0, 0, 0.1),
        inset 0 1px 0 rgba(255, 255, 255, 0.5),
        inset 0 -1px 0 rgba(255, 255, 255, 0.1),
        inset 0 0 0px 0px rgba(255, 255, 255, 0);
    position: relative;
}

.tecnologia-box::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 1px;
    background: linear-gradient(
        90deg,
        transparent,
        rgba(255, 255, 255, 0.8),
        transparent
    );
}

.tecnologia-box::after {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 1px;
    height: 100%;
    background: linear-gradient(
        180deg,
        rgba(255, 255, 255, 0.8),
        transparent,
        rgba(255, 255, 255, 0.3)
    );
}

.tecnologia-box-icon img {
    width: 80%;
    height: 80%;
    object-fit: contain;
}

.tecnologia-box-title {
    font-family: 'Poppins', sans-serif;
    font-weight: 600;
    font-size: 1.4rem;
    color: #FEFEFE;
    margin: 0;
}

/* Imagem do box */
.tecnologia-box-image {
    margin-bottom: 25px;
}

.placeholder-image {
    width: 100%;
    height: 200px;
    background: #9E9E9E;
    border-radius: 12px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #6B7280;
    font-family: 'Poppins', sans-serif;
    font-weight: 600;
    font-size: 1.2rem;
}

/* Conteúdo do box */
.tecnologia-box-content {
    display: flex;
    flex-direction: column;
    gap: 25px;
}

/* Seção de características */
.caracteristicas-section {
    display: flex;
    flex-direction: column;
    gap: 20px;
}

.caracteristicas-title {
    font-family: 'Poppins', sans-serif;
    font-weight: 600;
    font-size: 1.1rem;
    color: #2E3F5B;
    margin: 0;
}

/* Grid das características */
.caracteristicas-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 20px;
}

.caracteristica-item {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    gap: 8px;
    padding: 5px;
}

.caracteristica-icon {
    width: 80px;
    height: 80px;
    border-radius: 8px;
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
}

.caracteristica-icon img {
    width: 80%;
    height: 80%;
    object-fit: contain;
}

.caracteristica-text {
    font-family: 'Open Sans', sans-serif;
    font-size: 14px;
    color: #4A4A4A;
    line-height: 1.4;
    margin: 0;
}

/* Botão CTA */
.tecnologia-cta {
    background: #9E9E9E;
    color: #FEFEFE;
    padding: 15px 30px;
    border: none;
    border-radius: 25px;
    font-family: 'Poppins', sans-serif;
    font-weight: 600;
    font-size: 14px;
    text-decoration: none;
    display: block;
    text-align: center;
    margin-top: 10px;
}

.tecnologia-cta:hover {
    background: #2E3F5B;
}

/* ========================================= */
/* SEÇÃO SERVIÇOS */
/* ========================================= */

.servicos {
    background: #F8F9FA;
    padding: 80px 100px 40px 100px;
    overflow: hidden;
}

.servicos-container {
    margin: 0 auto;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 60px;
}

.servicos-header {
    text-align: center;
}

.servicos-title {
    font-family: 'Poppins', sans-serif;
    font-weight: 600;
    font-size: 2rem;
    color: #2E3F5B;
    margin-bottom: 20px;
    text-align: center;
}

.servicos-subtitle {
    font-family: 'Open Sans', sans-serif;
    font-size: 1.1rem;
    color: #4A4A4A;
    max-width: 800px;
    line-height: 1.6;
    font-weight: 300;
    text-align: center;
    margin: 0 auto;
}

.servicos-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 30px;
    width: 100%;
    
}

.servico-card {
    background: #fff;
    border-radius: 20px;
    padding: 40px 30px;
    text-align: center;
    box-shadow: 0 5px 15px rgba(0, 0, 0, 0.08);
    transition: all 0.4s cubic-bezier(0.25, 0.46, 0.45, 0.94);
    border: 2px solid transparent;
    position: relative;
    overflow: hidden;
    opacity: 0;
    transform: translateY(30px);
}

.servico-card.aos-animate {
    opacity: 1;
    transform: translateY(0);
}

.servico-card:hover {
    transform: translateY(-10px);
    box-shadow: 0 20px 40px rgba(0, 0, 0, 0.15);
    border: 2px solid #25BACF;
}

.servico-card::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 4px;
    background: linear-gradient(90deg, #25BACF, #2E3F5B);
    transform: scaleX(0);
    transition: transform 0.3s ease;
}

.servico-card:hover::before {
    transform: scaleX(1);
}

.servico-icon {
    width: 80px;
    height: 80px;
    margin: 0 auto 25px;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.3s ease;
    position: relative;

    border-radius:14px; background:#F0FBFD;
    place-items:center; border:1px solid rgba(37,186,207,.2);
}

.servico-card:hover .servico-icon {
    transform: scale(1.1) rotate(5deg);
}

.servico-icon-change{
    width: 80%;
    height: auto;
}

.servico-titulo {
    font-family: 'Poppins', sans-serif;
    font-weight: 600;
    font-size: 1.4rem;
    color: #2E3F5B;
    margin-bottom: 15px;
}

.servico-descricao {
    font-family: 'Open Sans', sans-serif;
    font-size: 14px;
    color: #4A4A4A;
    line-height: 1.6;
    margin-bottom: 30px;
    min-height: 60px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.servico-cta {
    background: #2E3F5B;
    color: white;
    padding: 12px 30px;
    border: none;
    border-radius: 25px;
    font-family: 'Open Sans', sans-serif;
    font-weight: 600;
    font-size: 14px;
    cursor: pointer;
    transition: all 0.3s ease;
    text-decoration: none;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    position: relative;
    overflow: hidden;
}

.servico-cta span {
    position: relative;
    z-index: 10;
    transition: color 0.4s;
}

.servico-cta:hover {
    background: #2E3F5B;
    transform: translateY(-2px);
    box-shadow: 0 8px 20px rgba(46, 63, 91, 0.3);
}

.servico-cta:hover span {
    color: #FFFFFF;
}

.servico-cta::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: #25BACF;
    transform: scaleX(0);
    transform-origin: left;
    transition: transform 0.4s cubic-bezier(0.3, 1, 0.8, 1);
    z-index: 5;
}

.servico-cta:hover::before {
    transform: scaleX(1);
}

.servico-cta-servicos {
    background: #2E3F5B;
    color: white;
    padding: 12px 30px;
    border: none;
    border-radius: 25px;
    font-family: 'Open Sans', sans-serif;
    font-weight: 600;
    font-size: 14px;
    cursor: pointer;
    transition: all 0.3s ease;
    text-decoration: none;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    position: relative;
    overflow: hidden;
}

.servico-cta-servicos span {
    position: relative;
    z-index: 10;
    transition: color 0.4s;
}

.servico-cta-servicos:hover {
    background: #2E3F5B;
    transform: translateY(-2px);
    box-shadow: 0 8px 20px rgba(46, 63, 91, 0.3);
}

.servico-cta-servicos:hover span {
    color: #FFFFFF;
}

.servico-cta-servicos::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: #25BACF;
    transform: scaleX(0);
    transform-origin: left;
    transition: transform 0.4s cubic-bezier(0.3, 1, 0.8, 1);
    z-index: 5;
}

.servico-cta-servicos:hover::before {
    transform: scaleX(1);
}
/* ========================================= */
/* SISTEMA DE POP-UP */
/* ========================================= */

.popup-overlay {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.7);
    backdrop-filter: blur(8px);
    display: flex;
    justify-content: center;
    align-items: center;
    z-index: 1000;
    opacity: 0;
    visibility: hidden;
    transition: all 0.4s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

.popup-overlay.active {
    opacity: 1;
    visibility: visible;
}

.popup-container {
    background: #FEFEFE;
    border-radius: 25px;
    width: 90%;
    max-height: 85vh;
    overflow-y: auto;
    position: relative;
    transform: scale(0.8) translateY(50px);
    transition: all 0.4s cubic-bezier(0.25, 0.46, 0.45, 0.94);
    box-shadow: 0 25px 50px rgba(0, 0, 0, 0.2);
}

.popup-overlay.active .popup-container {
    transform: scale(1) translateY(0);
}

.popup-header {
    background: linear-gradient(135deg, #2E3F5B, #25BACF);
    color: white;
    padding: 30px 40px;
    border-radius: 25px 25px 0 0;
    position: relative;
    overflow: hidden;
}

.popup-header::before {
    content: '';
    position: absolute;
    top: -50%;
    right: -20%;
    width: 100px;
    height: 100px;
    background: rgba(255, 255, 255, 0.1);
    border-radius: 50%;
    animation: float 6s ease-in-out infinite;
}

@keyframes float {
    0%, 100% { transform: translateY(0px) rotate(0deg); }
    50% { transform: translateY(-20px) rotate(180deg); }
}

.popup-close {
    position: absolute;
    top: 20px;
    right: 20px;
    background: rgba(255, 255, 255, 0.2);
    border: none;
    color: white;
    width: 40px;
    height: 40px;
    border-radius: 50%;
    cursor: pointer;
    font-size: 18px;
    transition: all 0.3s ease;
    z-index: 10;
}

.popup-close:hover {
    background: rgba(255, 255, 255, 0.3);
    transform: rotate(90deg);
}

.popup-title {
    font-family: 'Poppins', sans-serif;
    font-size: 2rem;
    font-weight: 700;
    margin-bottom: 10px;
    position: relative;
    z-index: 5;
}

.popup-subtitle {
    font-size: 1rem;
    opacity: 0.9;
    position: relative;
    z-index: 5;
}

.popup-content {
    padding: 40px;
}

.popup-description {
    font-size: 16px;
    color: #4A4A4A;
    line-height: 1.8;
    margin-bottom: 30px;
    text-align: justify;
}

.popup-features {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: 25px;
    margin-bottom: 30px;
}

.feature-item {
    background: #F8F9FA;
    padding: 25px;
    border-radius: 15px;
    border-left: 4px solid #25BACF;
    transition: all 0.3s ease;
}

.feature-item:hover {
    transform: translateX(5px);
    box-shadow: 0 5px 15px rgba(37, 186, 207, 0.2);
}

.feature-icon {
    color: #25BACF;
    font-size: 24px;
    margin-bottom: 15px;
}

.feature-title {
    font-family: 'Poppins', sans-serif;
    font-weight: 600;
    color: #2E3F5B;
    margin-bottom: 10px;
    font-size: 1.1rem;
}

.feature-description {
    font-size: 14px;
    color: #666;
    line-height: 1.6;
}

.popup-gallery {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: 15px;
    margin-top: 20px;
}

.gallery-item {
    position: relative;
    border-radius: 12px;
    overflow: hidden;
    height: 150px;
    background: linear-gradient(45deg, #25BACF, #2E3F5B);
    display: flex;
    align-items: center;
    justify-content: center;
    color: white;
    font-size: 14px;
    text-align: center;
    transition: all 0.3s ease;
    cursor: pointer;
}

.gallery-item:hover {
    transform: scale(1.05);
    box-shadow: 0 10px 25px rgba(0, 0, 0, 0.2);
}

.popup-footer {
    background: #F8F9FA;
    padding: 25px 40px;
    border-radius: 0 0 25px 25px;
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 20px;
    flex-wrap: wrap;
}

.popup-contact {
    display: flex;
    align-items: center;
    gap: 15px;
    color: #2E3F5B;
    font-size: 14px;
}

.popup-contact i {
    color: #25BACF;
    font-size: 16px;
}

.popup-action {
    background: linear-gradient(135deg, #25BACF, #2E3F5B);
    color: white;
    padding: 12px 30px;
    border: none;
    border-radius: 25px;
    font-weight: 600;
    cursor: pointer;
    transition: all 0.3s ease;
    text-decoration: none;
    display: inline-flex;
    align-items: center;
    gap: 8px;
}

.popup-action:hover {
    transform: translateY(-2px);
    box-shadow: 0 8px 20px rgba(37, 186, 207, 0.4);
}


/* Conteúdo expandido - inicialmente oculto */
.servico-expandido {
    max-height: 0;
    overflow: hidden;
    opacity: 0;
    transition: all 0.5s cubic-bezier(0.25, 0.46, 0.45, 0.94);
    margin-top: 0;
}

/* Estado expandido */
.servico-card.expandido .servico-expandido {
    max-height: 400px;
    opacity: 1;
    margin-top: 20px;
}

/* Container da imagem */
.servico-imagem-container {
    width: 100%;
    height: 160px;
    border-radius: 12px;
    overflow: hidden;
    margin-bottom: 20px;
}

.servico-imagem {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

/* Lista de características */
.servico-lista {
    list-style: none;
    
}

.servico-lista li {
    font-family: 'Open Sans', sans-serif;
    font-size: 13px;
    color: #4A4A4A;
    padding: 8px 0;
    border-bottom: 1px solid #E8E8E8;
    position: relative;
    padding-left: 20px;
}

.servico-lista li:last-child {
    border-bottom: none;
}

/* Ícone de check para os itens da lista */
.servico-lista li::before {
    content: "✓";
    position: absolute;
    left: 0;
    color: #25BACF;
    font-weight: 600;
    font-size: 14px;
}

/* Ajuste no grid para manter altura uniforme */
.servicos-grid {
    align-items: flex-start;
}

/* Modificação no botão para alternar texto */
.servico-cta[data-action="collapse"] span::after {
    content: " menos";
}

.servico-cta[data-action="expand"] span::after {
    content: "";
}

/* ========================================= */
/* MODAL DE SERVIÇOS */
/* ========================================= */

.servicos-modal {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 1000;
    opacity: 0;
    visibility: hidden;
    transition: all 0.3s ease;
}

.servicos-modal.active {
    opacity: 1;
    visibility: visible;
}

.modal-overlay {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.7);
    backdrop-filter: blur(5px);
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 20px;
}

.modal-content {
    background: #FEFEFE;
    border-radius: 20px;
    width: 100%;
    max-height: 90vh;
    overflow-y: auto;
    position: relative;
    transform: translateY(50px);
    transition: transform 0.3s ease;
}

.servicos-modal.active .modal-content {
    transform: translateY(0);
}

.modal-close {
    position: absolute;
    top: 20px;
    right: 25px;
    background: none;
    border: none;
    font-size: 30px;
    color: #9E9E9E;
    cursor: pointer;
    z-index: 10;
    transition: color 0.3s ease;
}

.modal-close:hover {
    color: #2E3F5B;
}

.modal-header {
    text-align: center;
    padding: 40px 40px 20px 40px;
    border-bottom: 1px solid #E0E0E0;
}

.modal-icon {
    width: 100px;
    height: 100px;
    margin: 0 auto 20px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    color: white;
    background: linear-gradient(135deg, #25BACF, #2E3F5B);
}

.modal-title {
    font-family: 'Poppins', sans-serif;
    font-weight: 600;
    font-size: 1.8rem;
    color: #2E3F5B;
    margin: 0;
}

.modal-body {
    padding: 30px 40px;
}

.modal-description {
    font-family: 'Open Sans', sans-serif;
    font-size: 16px;
    color: #4A4A4A;
    line-height: 1.6;
    margin-bottom: 30px;
    text-align: center;
}

.modal-features,
.modal-benefits {
    margin-bottom: 25px;
}

.modal-features h4,
.modal-benefits h4 {
    font-family: 'Poppins', sans-serif;
    font-weight: 600;
    font-size: 1.1rem;
    color: #2E3F5B;
    margin-bottom: 15px;
}

.modal-features ul,
.modal-benefits ul {
    list-style: none;
    padding: 0;
    margin: 0;
}

.modal-features li,
.modal-benefits li {
    font-family: 'Open Sans', sans-serif;
    font-size: 14px;
    color: #4A4A4A;
    margin-bottom: 10px;
    display: flex;
    align-items: center;
    gap: 10px;
}

.modal-features li::before,
.modal-benefits li::before {
    content: '✓';
    color: #25BACF;
    font-weight: bold;
    font-size: 16px;
    flex-shrink: 0;
}

.modal-footer {
    padding: 20px 40px 40px 40px;
    display: flex;
    gap: 15px;
    justify-content: center;
}

.modal-cta-primary,
.modal-cta-secondary {
    padding: 12px 30px;
    border: none;
    border-radius: 25px;
    font-family: 'Open Sans', sans-serif;
    font-weight: 600;
    font-size: 14px;
    cursor: pointer;
    transition: all 0.3s ease;
    text-decoration: none;
}

.modal-cta-primary {
    background: #2E3F5B;
    color: white;
}

.modal-cta-primary:hover {
    background: #1E2A3A;
    transform: translateY(-2px);
    box-shadow: 0 8px 20px rgba(46, 63, 91, 0.3);
}

.modal-cta-secondary {
    background: transparent;
    color: #25BACF;
    border: 2px solid #25BACF;
}

.modal-cta-secondary:hover {
    background: #25BACF;
    color: white;
}

/* =========================
   CLIENTES (cl-*)
   ========================= */
:root{
  --cl-cyan:#25BACF;
  --cl-ink:#2E3F5B;
  --cl-bg:#F8F9FA;
}

.cl-section{ background:var(--cl-bg); padding:40px 100px; overflow:clip; }
.cl-container{ margin:0 auto; display:flex; flex-direction:column; gap:18px; }
.cl-header{ text-align:center; }
.cl-subtitle{ color:#4A4A4A; margin:0 auto; }

/* ===== Logo Wall ===== */
.cl-logo-grid{
  margin:18px 0 8px; padding:0; list-style:none;
  display:grid; gap:35px;
  grid-template-columns: repeat(6, minmax(120px,1fr));
}
.cl-logo-grid li{
  display:grid; place-items:center;
}
.cl-logo-grid img{
  width:100%; height:auto; object-fit:contain;
}

/* Marquee opcional */
.cl-marquee{ overflow:hidden; border-radius:12px; margin-top:6px; }
.cl-marquee-track{
  display:flex; gap:40px; align-items:center; padding:12px 0;
  animation: cl-marquee 28s linear infinite;
}
.cl-marquee img{ height:42px; width:auto; object-fit:contain; filter:grayscale(100%) opacity(.7); }
.cl-marquee:hover .cl-marquee-track{ animation-play-state:paused; }
@keyframes cl-marquee{
  from{ transform: translateX(0); }
  to  { transform: translateX(-50%); }
}

/* ===== Depoimentos ===== */
.cl-t-grid{
  display:grid; gap:18px;
  grid-template-columns: repeat(3, minmax(0,1fr));
}

.cl-t-head{ display:flex; align-items:center; gap:12px; }
.cl-t-logo{ width:46px; height:46px; object-fit:contain; border-radius:10px; background:#EAF8FB; border:1px solid rgba(37,186,207,.2); padding:6px; }
.cl-t-name{ color:var(--cl-ink); font-weight:700; }
.cl-t-role{ display:block; color:#667; font-size:.9rem; }
.cl-t-quote p{ margin:0; color:#4A4A4A; }
.cl-stars{ width:100px; height:20px; color:#F5B700; }

/* ===== Mini–cases / KPIs ===== */
.cl-cases-track{
  display:grid; grid-template-columns: repeat(3, minmax(0,1fr)); gap:18px;
  scroll-snap-type:x mandatory; overflow-x:auto; padding-bottom:6px;
}
.cl-case{
  background:#fff; border:1px solid rgba(37,186,207,.18); border-radius:18px;
  box-shadow:0 12px 26px rgba(0,0,0,.07); padding:22px;
  scroll-snap-align:start; min-width:280px;
}
.cl-kpis{ display:flex; align-items:baseline; gap:8px; margin-bottom:6px; color:var(--cl-ink); }
.cl-kpi{ font:700 1.8rem/1 Poppins,system-ui; }
.cl-case-title{ margin:.2rem 0 .3rem; color:var(--cl-ink); font:700 1.05rem/1.2 Poppins,system-ui; }
.cl-case-text{ margin:0; color:#4A4A4A; }

:root{
  --t-ink:#2E3F5B; --t-cyan:#25BACF; --t-bg:#F8F9FA;
  --t-br:18px; --t-bd:1px solid rgba(37,186,207,.18);
  --t-shadow:0 14px 32px rgba(0,0,0,.08);
}

.cl-testimonials.cl-v2{ background:var(--t-bg); padding:40px 100px; overflow:clip; }
.cl-testimonials.cl-v2 .cl-container{ margin:0 auto; display:flex; flex-direction:column; gap:18px; }

.cl-t-card{
  background:#fff; border:var(--t-bd); border-radius:var(--t-br);
  box-shadow:var(--t-shadow); padding:22px;
  position:relative; display:flex; flex-direction:column; gap:14px;
  transition: box-shadow .25s ease, border-color .25s ease, transform .25s ease;
  overflow: hidden;
}

/* 2) Barrinha superior no mesmo estilo das suas sessões anteriores */
.cl-t-card::before{
  content: '';
  position: absolute;
  top: 0;            /* sem inset — igual ao padrão existente */
  left: 0;
  width: 100%;
  height: 4px;
  background: linear-gradient(90deg, #25BACF, #2E3F5B); /* mesmo gradiente */
  transform: scaleX(0);           /* começa “fechada” */
  transform-origin: center;
  transition: transform 0.3s ease;/* mesmo tempo/curva dos seus cards */
  /* IMPORTANTE: removemos qualquer background-size/animation para igualar */
}

/* 3) Hover idêntico ao padrão (só abre a barra) */
.cl-t-card:hover::before {
  transform: scaleX(1);
}

/* 4) Hover visual do card (igual ao que você já usa) */
.cl-t-card:hover{
  transform: translateY(-6px);
  box-shadow: 0 20px 40px rgba(0,0,0,.12);
  border: 2px solid #25BACF;
}

/* hero mais amplo */
.cl-t-hero{ padding:26px 26px 24px; }
.cl-t-hero .cl-t-quote p{ font-size:1.05rem; line-height:1.55; }

/* header do card */
.cl-t-head{ display:grid; grid-template-columns:auto 1fr auto; gap:12px; align-items:center; }
.cl-t-avatar{ width:100px; height:auto; }
.cl-t-brand{ width:54px; height:54px; object-fit:contain; background:#EAF8FB; border:1px solid rgba(37,186,207,.2); border-radius:12px; padding:6px; }
.cl-t-name{ color:var(--t-ink); font-weight:700; }
.cl-t-role{ display:block; color:#667; font-size:.92rem; }

/* citação */
.cl-t-quote{ position:relative; }
.cl-t-quote::before{
  content:"“"; position:absolute; left:-6px; top:-8px; font:700 42px/1 serif; color:rgba(46,63,91,.4);
}
.cl-t-quote p{ padding-top: 25px; color:#4A4A4A; }

/* footer */
.cl-t-foot{ display:flex; align-items:center; justify-content:space-between; gap:12px; }
.cl-t-stars{ color:#F5B700; letter-spacing:.1em; font-weight:900; }
.cl-badge{
  display:inline-flex; align-items:center; gap:6px;
  padding:6px 10px; border-radius:999px; background:#F7FAFB; color:var(--t-ink);
  border:1px solid rgba(46,63,91,.15); font-size:.85rem;
}
.cl-t-badges{ display:flex; gap:10px;  margin: 0 auto; }

/* track: grid no desktop, carrossel no mobile */
.cl-t-track{
  display:grid; grid-template-columns:repeat(3, minmax(0,1fr)); gap:18px;
  scroll-snap-type:x mandatory; padding-bottom:6px;
}
.cl-t-track > .cl-t-card{ scroll-snap-align:start; min-width:280px; }

/* ========================================= */
/* SEÇÃO FALE CONOSCO */
/* ========================================= */

.fale-conosco {
    background: #F8F9FA;
    padding: 80px 100px 40px 100px;
    overflow: hidden;
}

.fale-conosco-container {
    margin: 0 auto;
    display: flex;
    flex-direction: column;
    gap: 60px;
}

/* Cabeçalho */
.fale-conosco-header {
    text-align: center;
}

.fale-conosco-title {
    font-family: 'Poppins', sans-serif;
    font-weight: 600;
    font-size: 2rem;
    color: #2E3F5B;
    margin-bottom: 20px;
}

.fale-conosco-subtitle {
    font-family: 'Open Sans', sans-serif;
    font-size: 1.1rem;
    color: #4A4A4A;
    line-height: 1.6;
    margin: 0;
}

/* Conteúdo Principal */
.fale-conosco-content {
    display: grid;
    grid-template-columns: 1.5fr 1fr;
    gap: 30px;
    align-items: start;
}

/* Formulário */
.fale-conosco-form {
    background: #25BACF;
    border-radius: 20px;
    padding: 20px;
    position: relative;
    overflow: hidden;
}

.contact-form {
    display: flex;
    flex-direction: column;
    gap: 25px;
}

/* Grupos de formulário */
.form-group {
    display: flex;
    flex-direction: column;
}

.form-row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 20px;
}

/* Inputs do formulário */
.form-input {
    width: 100%;
    padding: 16px 20px;
    border: 2px solid transparent;
    border-radius: 12px;
    font-family: 'Open Sans', sans-serif;
    font-size: 16px;
    color: #4A4A4A;
    background: #f8f9fa;
    transition: all 0.3s ease;
    box-sizing: border-box;
}

.form-input:focus {
    outline: none;
    border-color: #2E3F5B;
    box-shadow: 0 0 0 3px rgba(46, 63, 91, 0.1);
}

/* Placeholder customizado */
.form-input::placeholder {
    color: #9E9E9E;
    font-weight: 400;
}

/* Select customizado */
.form-select {
    width: 100%;
    padding: 16px 20px;
    border: 2px solid transparent;
    border-radius: 12px;
    font-family: 'Open Sans', sans-serif;
    font-size: 16px;
    color: #4A4A4A;
    background: #f8f9fa;
    transition: all 0.3s ease;
    box-sizing: border-box;
    appearance: none;
    background-image: url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%239E9E9E' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3e%3cpolyline points='6,9 12,15 18,9'%3e%3c/polyline%3e%3c/svg%3e");
    background-repeat: no-repeat;
    background-position: right 16px center;
    background-size: 20px;
    cursor: pointer;
}

.form-select:focus {
    outline: none;
    border-color: #2E3F5B;
    box-shadow: 0 0 0 3px rgba(46, 63, 91, 0.1);
    background-image: url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%232E3F5B' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3e%3cpolyline points='6,9 12,15 18,9'%3e%3c/polyline%3e%3c/svg%3e");
}

/* Opção disabled no select */
.form-select option:disabled {
    color: #9E9E9E;
}

/* Textarea */
.form-textarea {
    width: 100%;
    padding: 16px 20px;
    border: 2px solid transparent;
    border-radius: 12px;
    font-family: 'Open Sans', sans-serif;
    font-size: 16px;
    color: #4A4A4A;
    background: #f8f9fa;
    transition: all 0.3s ease;
    box-sizing: border-box;
    resize: vertical;
    min-height: 120px;
    line-height: 1.6;
}

.form-textarea:focus {
    outline: none;
    border-color: #2E3F5B;
    box-shadow: 0 0 0 3px rgba(46, 63, 91, 0.1);
}

.form-textarea::placeholder {
    color: #9E9E9E;
    font-weight: 400;
}

/* Botão de enviar */
.form-submit {
    display: flex;
    justify-content: center;
    margin-top: 10px;
}

.form-button {
    background: #2E3F5B;
    color: #f8f9fa;
    padding: 16px 40px;
    border: none;
    border-radius: 25px;
    font-family: 'Poppins', sans-serif;
    font-weight: 600;
    font-size: 16px;
    cursor: pointer;
    transition: all 0.3s ease;
    min-width: 200px;
}

.form-button:hover {
    background: #1E2A3A;
    transform: translateY(-2px);
    box-shadow: 0 8px 20px rgba(46, 63, 91, 0.3);
}

/* Informações de contato */
.fale-conosco-info {
    display: flex;
    flex-direction: column;
    gap: 30px;
}

/* Card de informações */
.contact-info-card {
    background: #f8f9fa;
    border-radius: 20px;
    padding: 30px;
    box-shadow: 0 10px 30px rgba(0, 0, 0, 0.08);
    display: flex;
    flex-direction: column;
    gap: 25px;
}

.contact-info-item {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.contact-info-label {
    font-family: 'Open Sans', sans-serif;
    font-size: 14px;
    color: #6B7280;
    font-weight: 500;
}

.contact-info-value {
    font-family: 'Poppins', sans-serif;
    font-size: 16px;
    color: #2E3F5B;
    font-weight: 600;
    margin: 0;
    line-height: 1.4;
}

.contact-info-value-footer {
    font-family: 'Open Sans', sans-serif;
    font-size: 1rem;
    color: #2E3F5B;
    margin: auto 0;
    line-height: 1.4;
}

/* Botões de contato */
.contact-buttons {
    display: flex;
    flex-direction: column;
    gap: 20px;
}

.contact-button {
    padding: 20px;
    border-radius: 15px;
    font-family: 'Poppins', sans-serif;
    font-weight: 600;
    font-size: 14px;
    text-decoration: none;
    text-align: center;
    transition: all 0.3s ease;
    line-height: 1.3;
}

.contact-button span {
    font-weight: 400;
    font-size: 12px;
}

.whatsapp-btn {
    background: #25C26E;
    color: #FFFFFF;
}

.whatsapp-btn:hover {
    background: #22B865;
    transform: translateY(-2px);
    box-shadow: 0 8px 20px rgba(37, 194, 110, 0.3);
}

.email-btn {
    background: #2E3F5B;
    color: #FFFFFF;
}

.email-btn:hover {
    background: #1E2A3A;
    transform: translateY(-2px);
    box-shadow: 0 8px 20px rgba(46, 63, 91, 0.3);
}

/* =========================================================
   ACESSOS — PADRONIZAÇÃO DE SESSÕES (comparativo, kits, operação)
   Segue o padrão global do site (cores, raios, sombras, paddings)
   ========================================================= */

/* -------- Base + paddings alinhados -------- */
:root{
  /* padrão das páginas (sides 100px / vertical 40px) */
  --svc-pad-x: 100px;
  --svc-pad-y: 40px;
  --svc-card-br: 18px;
  --svc-card-bd: 1px solid rgba(37,186,207,.18);
  --svc-card-shadow: 0 12px 26px rgba(0,0,0,.07);
  --svc-blue: #25BACF;
  --svc-ink: #2E3F5B;
  --svc-bg: #F8F9FA;
}

#acessos-comparativo,
#acessos-kits,
#acessos-operacao{
  background: var(--svc-bg);
  padding-left:  var(--svc-pad-x);
  padding-right: var(--svc-pad-x);
  padding-top:   var(--svc-pad-y);
  padding-bottom:var(--svc-pad-y);
}

.svc-header{ text-align:center; }
.svc-subtitle{ color:#4A4A4A; }

/* ---------- paddings padrão da página ---------- */
:root{
  --svc-pad-x: 100px;
  --svc-pad-y: 40px;
  --svc-ink: #2E3F5B;
  --svc-blue: #25BACF;
  --svc-card-br: 18px;
}

/* aplica apenas nas 3 sections */
#acessos-comparativo,
#acessos-kits,
#acessos-operacao{
  padding-inline: var(--svc-pad-x);
  padding-block: var(--svc-pad-y);
  background: #F8F9FA;
  position: relative;
  overflow: clip;            /* recorta sombras/linhas decorativas */
}

.svc-section .svc-container{
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  gap: 32px;
}

/* =========================================================
   1) COMPARATIVO — scroll local (nunca no body)
   ========================================================= */
.svc-compare .compare-wrapper{
  max-width: 100%;
  overflow-x: auto;                /* rolagem só aqui */
  -webkit-overflow-scrolling: touch;
  overscroll-behavior-x: contain;
  border-radius: var(--svc-card-br);
  border: 1px solid rgba(37,186,207,.18);
  background:#fff;
  box-shadow: 0 12px 26px rgba(0,0,0,.07);
}
.svc-compare .compare-table{
  width: 100%;
  min-width: 720px;               /* força scroll local se faltar espaço */
  border-collapse: separate;
  border-spacing: 0;
}
.svc-compare thead th{
  background:#F7FAFB; color:var(--svc-ink);
  font-weight:700; padding:14px; text-align:left;
  border-bottom:1px solid rgba(46,63,91,.12);
}
.svc-compare tbody td{
  padding:14px; color:var(--svc-ink);
  border-bottom:1px solid rgba(46,63,91,.08);
}
.svc-compare tbody tr:last-child td{ border-bottom:none; }
.svc-compare .state{ position:relative; }
.svc-compare .state[data-state="yes"]::before{ content:"✓"; color:#1f9d6a; font-weight:800; }
.svc-compare .state[data-state="partial"]::before{ content:"~"; color:#e2a32b; font-weight:800; }
.svc-compare .state[data-state="no"]::before{ content:"—"; color:#9aa3af; font-weight:800; }

/* cards “quando usar” */
.svc-compare .use-cases{
  display:grid; grid-template-columns:repeat(3,1fr);
  gap:16px;
}

.svc-compare .uc-card{
  background:#fff; border:1px solid rgba(37,186,207,.18);
  border-radius:16px; padding:16px; box-shadow:0 8px 20px rgba(0,0,0,.06);
}
.svc-compare .uc-card h3{ margin:0 0 6px; color:var(--svc-ink); font-size:1.05rem; }
.svc-compare .uc-card ul{ margin:0; padding-left:18px; color:#4A4A4A; }

/* ================================
   ACESSOS — Cards (v3)
   ================================ */
:root{
  --ax-pad-x: var(--svc-pad-x, 100px);
  --ax-pad-y: var(--svc-pad-y, 40px);
  --ax-ink:  #2E3F5B;
  --ax-blue: #25BACF;
  --ax-bg:   #F8F9FA;
}

#acessos-cards-v3{
  padding-inline: var(--ax-pad-x);
  padding-block:  var(--ax-pad-y);
  background: var(--ax-bg);
  position: relative;
  overflow: clip; /* evita qualquer “vazamento” */
}

#acessos-cards-v3 .svc-container{
  margin: 0 auto;
  display: flex; flex-direction: column; gap: 18px;
}

/* Grid responsivo */
.ax-grid{
  display: grid;
  grid-template-columns: repeat(4, minmax(0,1fr));
  gap: 16px;
}

/* Card */
.ax-card{
  position: relative;
  display: flex; flex-direction: column; align-items: center; text-align:center;
  gap: 12px;
  background: #fff;
  border: 1px solid rgba(37,186,207,.18);
  border-radius: 18px;
  padding: 22px;
  box-shadow: 0 12px 26px rgba(0,0,0,.07);
  min-height: 340px;
  transition: box-shadow .25s ease, border-color .25s ease;
}
.ax-card::before{
  content:""; position:absolute; inset:0 0 auto 0; height:4px;
  background: linear-gradient(90deg, var(--ax-blue), var(--ax-ink));
  transform: scaleX(0); transform-origin: left;
  transition: transform .28s ease;
}
.ax-card:hover{ border-color: var(--ax-blue); box-shadow: 0 18px 40px rgba(0,0,0,.12); }
.ax-card:hover::before{ transform: scaleX(1); }

.ax-icon{
  width: 70px; height: 70px; border-radius: 14px;
  display: grid; place-items: center;
  background: #EAF8FB; border: 1px solid rgba(37,186,207,.25);
  box-shadow: 0 8px 20px rgba(0,0,0,.06);
}
.ax-icon svg{ width: 42px; height: 42px; stroke: var(--ax-ink); stroke-width: 2; }

.ax-title{ color: var(--ax-ink); font-weight: 700; font-size: 1.05rem; }
.ax-text{ color:#4A4A4A; }
.ax-list{
  list-style:none; padding:0; margin:0; display:grid; gap:6px;
}
.ax-list li{
  display:flex; gap:8px; justify-content:center; color:var(--ax-ink);
}
.ax-list li::before{
  content:""; width:6px; height:6px; border-radius:999px; margin-top:.55em;
  background: var(--ax-blue);
}

/* Botões */
.ax-btn, .ax-cta{
  background: var(--ax-ink); color:#fff; text-decoration:none;
  padding:10px 18px; border-radius:10px; font-weight:600;
  display:inline-flex; align-items:center; justify-content:center; gap:8px;
  transition: transform .2s ease, box-shadow .2s ease, background .2s ease;
}
.ax-btn:hover, .ax-cta:hover{ background:#1E2A3A; transform: translateY(-2px); box-shadow:0 10px 24px rgba(46,63,91,.25); }
.ax-cta-row{ display:flex; justify-content:center; margin-top:6px; }

/* =========================================================
   3) OPERAÇÃO — timeline com linha segura (clipada)
   ========================================================= */
.svc-ops {padding: 40px 100px;}
.svc-ops .ops-header{ text-align:center; margin-bottom: 14px; }
.svc-ops .ops-subtitle{ color: #5b6b73; margin-top: 4px; }

/* Grid 2×2 de etapas */
.svc-ops .ops-rail{
  display: grid;
  grid-template-columns: repeat(2, minmax(0,1fr));
  gap: 20px;
  padding: 18px;
  background: #25BACF;
  border: 1px solid rgba(37,186,207,.18);
  border-radius: var(--svc-card-br, 16px);
  box-shadow: 0 12px 26px rgba(0,0,0,.07);
  position: relative;
  overflow: hidden;
}
.svc-ops .ops-rail::before{ content: none !important; } /* remove linha do layout antigo, se houver */

/* Card da etapa */
.svc-ops .ops-step{
  position: relative;
  background: #fff;
  border: 1px solid rgba(37,186,207,.18);
  border-radius: 16px;
  padding: 20px 18px 18px 18px;
  box-shadow: 0 8px 20px rgba(0,0,0,.06);
  transition: box-shadow .25s ease, border-color .25s ease, transform .25s ease;
}
.svc-ops .ops-step:hover{
  border-color: var(--svc-blue, #25BACE);
  box-shadow: 0 18px 40px rgba(0,0,0,.12);
  transform: translateY(-2px);
}

/* Badge numérico (1–4) */
.svc-ops .ops-step .ops-dot{
  position: absolute;
  top: 12px; left: 12px;
  width: 34px; height: 34px;
  border-radius: 999px;
  display: grid; place-items: center;
  background: var(--svc-ink, #0a2a2e);
  color: #fff; font-weight: 700;
  border: 2px solid var(--svc-blue, #25BACE);
  box-shadow: 0 8px 20px rgba(0,0,0,.12);
}

/* Área de imagem da etapa */
.svc-ops .ops-media{
  margin: 6px 0 12px 54px;       /* alinha com o recuo do badge */
  display: flex; align-items: center; gap: 12px;
}
.svc-ops .ops-media img{
  width: 100%; height: auto;
  object-fit: contain;
  border-radius: 14px;
}

/* Títulos e listas */
.svc-ops .ops-step .svc-title{
  margin: 0 0 8px 0;
  padding-left: 54px;             /* respiro para o badge */
  color: var(--svc-ink, #0a2a2e);
}
.svc-ops .ops-step .svc-list{
  list-style: none;
  padding: 0 0 0 54px;
  margin: 0;
  display: grid;
  gap: 8px;
}
.svc-ops .ops-step .svc-list li{
  position: relative;
  color: #4A4A4A;
  line-height: 1.55;
  padding-left: 14px;             /* bullet custom */
}
.svc-ops .ops-step .svc-list li::before{
  content:"";
  position: absolute;
  left: 0; top: .65em;
  width: 6px; height: 6px;
  border-radius: 999px;
  background: var(--svc-blue, #25BACE);
}

/* KPIs abaixo (mantidos, só garantimos grid e respiro) */
.svc-ops .ops-kpis{
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
  margin-top: 16px;
}
.svc-ops .kpi-card{
  background: #fff;
  border: 1px solid rgba(37,186,207,.18);
  border-radius: 16px;
  padding: 18px;
  text-align: center;
  box-shadow: 0 8px 18px rgba(0,0,0,.06);
}
.svc-ops .kpi-value{ font-size: 1.6rem; font-weight: 800; color: var(--svc-ink, #0a2a2e); }
.svc-ops .kpi-label{ color: #5b6b73; }

/* =======================================================
   SERVIÇOS • PONTO — estilos gerais (.ponto-)
   ======================================================= */
.ponto-section{ background:#F8F9FA; padding:40px 100px 60px 100px; }
.ponto-section-numebers{ background:#F8F9FA; padding:0px 100px 80px 100px; }
.ponto-container{ margin:0 auto; display:flex; flex-direction:column; gap:28px; margin-top: 10px;}
.ponto-header{ text-align:center; margin-bottom:8px; }
.ponto-subtitle{ font-size:1.05rem; color:#4A4A4A; text-align: center;}
.ponto-numeros {padding: 0px 100px 40px 100px;}
.recursos-avancados {padding: 40px 100px;}

/* utilitários */
.ponto-grid{ display:grid; gap:24px; }
.ponto-grid-3{ grid-template-columns:repeat(3,1fr); }
.ponto-grid-4{ grid-template-columns:repeat(4,1fr); }

.foto-ponto{
  width:80%; border-radius:16px; overflow:hidden; margin: 0 auto 15px;
  background:#F0FBFD; border:1px solid rgba(37,186,207,.18); box-shadow:0 6px 18px rgba(0,0,0,.06);
}
.foto-ponto img{ width:100%; height:100%; object-fit:cover; display:block; }

.ponto-card{
  background:#fff; border-radius:20px; border:2px solid transparent;
  box-shadow:0 10px 30px rgba(0,0,0,.08);
  padding:26px 22px; position:relative; overflow:hidden;
  transition:transform .25s ease, box-shadow .25s ease, border-color .25s ease;
  display:flex; flex-direction:column; gap:12px;
}
.ponto-card::before{
  content:''; position:absolute; top:0; left:0; width:100%; height:4px;
  background:linear-gradient(90deg,#25BACF,#2E3F5B);
  transform:scaleX(0); transform-origin:center; transition:transform .3s ease;
}
.ponto-card:hover{ transform:translateY(-6px); box-shadow:0 18px 40px rgba(0,0,0,.12); border-color:#25BACF; }
.ponto-card:hover::before{ transform:scaleX(1); }
.ponto-card-center{ align-items:center; text-align:center; }

.ponto-icon{
  width:72px; height:72px; border-radius:14px; background:#f8f9fa;
  display:grid; place-items:center; border:1px solid rgba(37,186,207,.2);
}

.ponto-icon img {
    width: 80%; height: auto;
}

.ponto-title{ font-family:'Poppins',sans-serif; font-weight:600; font-size:1.1rem; color:#2E3F5B; line-height:1.25; }
.ponto-text{ font-size:15px; color:#4A4A4A; line-height:1.6; }
.ponto-text-lg{ font-size:1rem; color:#4A4A4A; line-height:1.75; }

/* lista bullet no padrão */
.ponto-list{ list-style:none; margin:10px 0 0; padding:0; display:grid; gap:8px; }
.ponto-list li{ display:flex; align-items:flex-start; justify-content:center; gap:8px; color:#2E3F5B; font-size:14px; }
.ponto-list li::before{ content:''; width:6px; height:6px; border-radius:50%; background:#25BACF; margin-top:.5em; flex:0 0 6px; }

/* CTA padrão */
.ponto-cta{
  margin-top:12px; background:#2E3F5B; color:#fff; padding:10px 18px; border-radius:10px;
  font-weight:600; font-size:14px; text-decoration:none; display:inline-flex; align-items:center; justify-content:center; gap:8px;
  transition:transform .2s ease, box-shadow .2s ease, background .2s ease;
}
.ponto-cta:hover{ background:#1E2A3A; transform:translateY(-2px); box-shadow:0 10px 24px rgba(46,63,91,.25); }

/* números / prova social */
.ponto-metrics{ display:grid; grid-template-columns:repeat(3,1fr); gap:16px; align-items:stretch; }
.ponto-metric{ background:#fff; border-radius:16px; padding:20px; box-shadow:0 8px 22px rgba(0,0,0,.08); text-align:center; border:1px solid rgba(46,63,91,.08); }
.ponto-metric-number{ display:block; font-family:'Poppins',sans-serif; font-weight:700; font-size:1.5rem; color:#2E3F5B; }
.ponto-metric-label{ color:#4A4A4A; font-size:.95rem; }

/* consultoria: painel + steps (em coluna) */
.ponto-retrofit-layout{ display:grid; grid-template-columns:1.2fr .8fr; gap:24px; align-items:start; }
.ponto-panel{ min-height:280px; align-items:center; text-align:center; }
.ponto-panel::before{ transform:scaleX(1); } /* barra sempre visível */
.ponto-steps{ display:grid; grid-template-columns:1fr; gap:20px; }
.ponto-step-card{ position:relative; padding:22px; border-radius:18px; border:2px solid transparent; background:#FEFEFE; box-shadow:0 10px 30px rgba(0,0,0,.08); overflow:hidden; transition:transform .25s ease, box-shadow .25s ease, border-color .25s ease; text-align:center; display:flex; flex-direction:column; align-items:center; gap:10px; min-height:150px; }
.ponto-step-card::before{ content:""; position:absolute; top:0; left:0; width:100%; height:4px; background:linear-gradient(90deg,#25BACF,#2E3F5B); transform:scaleX(0); transform-origin:left; transition:transform .3s ease; }
.ponto-step-card:hover{ transform:translateY(-6px); border-color:#25BACF; box-shadow:0 18px 40px rgba(0,0,0,.12); }
.ponto-step-card:hover::before{ transform:scaleX(1); }
.ponto-step-icon{ width:64px; height:64px; border-radius:14px; background:#F0FBFD; border:1px solid rgba(37,186,207,.25); display:grid; place-items:center; }
.ponto-step-badge{ position:absolute; top:10px; right:10px; width:28px; height:28px; border-radius:999px; display:grid; place-items:center; color:#2E3F5B; font-weight:700; font-size:13px; background:#F0FBFD; border:1px solid rgba(37,186,207,.35); }

/* experimente (band) */
.ponto-experimente .ponto-band{ background:#FFFFFF; border-radius:20px; padding:24px; box-shadow:0 12px 32px rgba(0,0,0,.10); display:grid; grid-template-columns:repeat(4,1fr); gap:16px; align-items:center; }
.ponto-experimente .ponto-band-item{ text-align:center; }
.ponto-experimente .ponto-band-item strong{ display:block; font-family:'Poppins',sans-serif; font-size:1.4rem; color:#2E3F5B; }
.ponto-experimente .ponto-band-item span{ color:#4A4A4A; }

/* =========================================================
   PONTO • V2 (somente recursos & avançados)
   Cores seguem o tema: #25BACF (azul), #2E3F5B (azul escuro)
   ========================================================= */

/* ---------- Recursos v2 ---------- */
.ponto-recursos-sistema {padding: 40px 100px;}
.ponto-recursos-avancados {padding: 40px 100px;}
.ponto-consultoria {padding: 40px 100px;}

.recursos-v2 .recursos-rail{
  display:grid;
  grid-template-columns: 0.9fr 1.6fr;
  gap:32px;
  align-items:start;
}


/* Centralizar título, subtítulo e chips da coluna esquerda */
.recursos-v2 .recursos-aside{
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;   /* centraliza tudo no eixo X */
}

/* Centralizar as linhas de chips (App, Web, ...) */
.recursos-v2 .recursos-chips{
  display: flex;         /* já existe, reforçado aqui */
  flex-wrap: wrap;
  justify-content: center;   /* <-- faz os itens irem para o meio */
  align-content: center;     /* centraliza quando quebrar de linha */
  width: 100%;
}

.recursos-v2 .recursos-chips{
  display:flex; flex-wrap:wrap; gap:10px; margin-top:12px;
}
.recursos-v2 .recursos-chips li{
  list-style:none;
  padding:6px 10px;
  border:1px solid rgba(37,186,207,.25);
  border-radius:999px;
  font-size:.9rem; color:#2E3F5B; background:#fff;
}

/* lista conectada */
.recursos-v2 .recursos-list{
  position:relative;
  display:flex; flex-direction:column; gap:18px;
  padding-left:18px;
}
.recursos-v2 .recursos-list::before{
  content:""; position:absolute; left:0; top:4px; bottom:4px;
  width:3px; border-radius:3px;
  background: linear-gradient(#25BACF,#2E3F5B);
  opacity:.45;
}

.recurso-row{
  display:grid; grid-template-columns: 56px 1fr; gap:16px;
  background:#fff; border-radius:16px; padding:18px;
  border:1px solid rgba(37,186,207,.18);
  box-shadow:0 10px 24px rgba(0,0,0,.06);
}
.recurso-icon{
  width:56px; height:56px; border-radius:14px;
  display:grid; place-items:center;
  background:#EAF8FB; border:1px solid rgba(37,186,207,.25);
}
.recurso-body h3{
  margin:0 0 6px; font:600 1.15rem/1.2 Poppins,system-ui;
  color:#2E3F5B;
}
.recurso-body p{ margin:0; color:#4A4A4A; }
.recurso-meta{ display:flex; gap:10px; margin-top:10px; align-items:center; flex-wrap:wrap;}
.badge{
  border:1px solid rgba(46,63,91,.18);
  background:#F7FAFB; color:#2E3F5B; border-radius:999px;
  padding:4px 10px; font-size:.8rem;
}
.recurso-link{
  border:none; background:#2E3F5B; color:#fff;
  padding:8px 12px; border-radius:10px; cursor:pointer;
  transition:transform .2s ease, box-shadow .2s ease;
}
.recurso-link:hover{ transform:translateY(-2px); box-shadow:0 8px 20px rgba(46,63,91,.25); }

/* ---------- Avançados v2 (accordion) ---------- */
.av-accordion{ display:flex; flex-direction:column; gap:14px; }
.av-item{
  border:1px solid rgba(37,186,207,.2);
  border-radius:16px; background:#fff;
  box-shadow:0 10px 24px rgba(0,0,0,.06);
  overflow:hidden;
}
.av-summary{
  list-style:none; display:flex; align-items:center; gap:12px;
  padding:16px 18px; cursor:pointer;
}
.av-summary::-webkit-details-marker{ display:none; }
.av-icon{
  width:52px; height:52px; border-radius:12px; flex:0 0 52px;
  display:grid; place-items:center; background:#EAF8FB;
  border:1px solid rgba(37,186,207,.25);
}
.av-summary h3{ margin:0; font:600 1.05rem/1.2 Poppins,system-ui; color:#2E3F5B; }
.chev{
  margin-left:auto; width:14px; height:14px; border-right:3px solid #2E3F5B; border-bottom:3px solid #2E3F5B; transform:rotate(-45deg);
  transition:transform .2s ease;
}
.av-item[open] .chev{ transform:rotate(45deg); }

.av-content{
  display:grid; grid-template-columns: 1.1fr 1.3fr; gap:18px;
  padding:0 18px 18px;
}
.av-media{
  border:1px solid rgba(37,186,207,.18);
  border-radius:14px; overflow:hidden; background:#F0FBFD;
  aspect-ratio: 16/9;
}
.av-media img{ width:100%; height:100%; object-fit:cover; display:block; }

/* Lista de características */
.recursos-avancados-list {
    list-style: none;
    margin: 0 auto;
    padding-top: 45px;
}

.recursos-avancados-list li {
    font-family: 'Open Sans', sans-serif;
    font-size: 15px;
    color: #4A4A4A;
    border-bottom: 1px solid #E8E8E8;
    position: relative;
    padding-left: 20px;
    padding-bottom: 8px;
    padding-top: 8px;
}

.recursos-avancados-list li:last-child {
    border-bottom: none;
}

/* Ícone de check para os itens da lista */
.recursos-avancados-list li::before {
    content: "✓";
    position: absolute;
    left: 0;
    color: #25BACF;
    font-weight: 600;
    font-size: 14px;
}

/* ================================
   SOLUÇÕES.HTML — ajustes v4
   ================================ */

/* containers já existem; aqui estão reforços de layout */
.sol-v4.section{ background:#F8F9FA; padding: var(--solv4-pad-y,40px) var(--solv4-pad-x,100px); }

.sol-v4__header{ text-align:center; }
.sol-v4__subtitle{ color:#4A4A4A; margin:8px auto 0; }

/* KPIs */
.sol-v4__kpis{ list-style:none; padding:0; margin:35px auto 0 auto; display:grid; grid-template-columns:repeat(3,1fr); gap:12px; }
.sol-v4__kpis li{ background:#fff; border:1px solid rgba(37,186,207,.18); border-radius:16px; padding:14px; text-align:center; box-shadow:0 12px 26px rgba(0,0,0,.08); }
.sol-v4__kpis strong{ display:block; color:#2E3F5B; font-weight:800; font-size: clamp(20px, 3.6vw, 28px); }
.sol-v4__kpis span{ color:#4A4A4A; font-weight:600; }

/* Chips */
.sol-v4__highlights{ list-style:none; padding:0; margin:6px auto 0; display:flex; gap:10px; flex-wrap:wrap; justify-content:center; }
.sol-v4__highlights li{ padding:8px 12px; border-radius:999px; background:#fff; color:#2E3F5B; border:1.5px solid rgba(37,186,207,.35); font-weight:600; }

/* Grid de cards */
.sol-v4__grid{ display:grid; grid-template-columns: repeat(3, minmax(0,1fr)); gap:16px; }
.sol-v4__card{ background:#fff; border:1px solid rgba(37,186,207,.18); border-radius:18px; padding:18px; box-shadow:0 12px 26px rgba(0,0,0,.08); transition:.25s ease; position:relative; display:flex; flex-direction:column; gap:8px; }
.sol-v4__card::before{ content:""; position:absolute; inset:0 0 auto 0; height:4px; background:linear-gradient(90deg,#25BACF,#2E3F5B); transform:scaleX(0); transform-origin:left; transition:transform .28s ease; }
.sol-v4__card:hover{ transform: translateY(-4px); box-shadow:0 18px 40px rgba(0,0,0,.12); border-color:#25BACF; }
.sol-v4__card:hover::before{ transform: scaleX(1); }
.sol-v4__icon{ width:44px; height:44px; border-radius:12px; display:grid; place-items:center; background:#EAF8FB; border:1px solid rgba(37,186,207,.25); }
.sol-v4__icon img{ width:24px; height:24px; object-fit:contain; }
.sol-v4__card h3{ margin:6px 0 4px; color:#2E3F5B; font-weight:700; }
.sol-v4__card p{ margin:0; color:#4A4A4A; }
.sol-v4__list{ margin:6px 0 0; padding-left:18px; color:#2E3F5B; }

/* Timeline */
.sol-v4__rail{ position:relative; display:grid; grid-template-columns:repeat(4,1fr); gap:16px; background:#fff; border:1px solid rgba(37,186,207,.18); border-radius:18px; padding:30px; box-shadow:0 12px 26px rgba(0,0,0,.08); overflow:hidden; }
.sol-v4__rail::before{ content:""; position:absolute; top:34px; left:24px; right:24px; height:3px; background:linear-gradient(90deg,#25BACF,#2E3F5B); opacity:.35; border-radius:3px; }
.sol-v4__step{ text-align:center; padding-top:24px; }
.sol-v4__dot{z-index: 3; width:36px; height:36px; border-radius:999px; margin:-42px auto 8px; display:grid; place-items:center; background:#2E3F5B; color:#fff; font-weight:800; border:2px solid #25BACF; box-shadow:0 8px 20px rgba(0,0,0,.12); }

.seg {padding: 40px 0px;}

/* ========================================= */
/* MEDIA QUERIES RESPONSIVAS */
/* ========================================= */

/* ===== Footer ===== */
.footer, footer{ padding-left:100px; padding-right:100px; } /* base, reduzimos abaixo */
.footer-container{
  display:grid; grid-template-columns: 1.2fr .8fr 1fr; gap:24px;
  
}

.footer-logo {margin: 0 auto;}

.footer-logo img{ width:100%; height:auto; }
.social-media-container{ display:flex; gap:10px; margin-top:12px; flex-wrap:wrap; }
.company-map{ width:100%; max-width:100%; overflow:hidden; margin-top:12px; }
.company-map iframe{ min-width:100% !important; border-radius:12px; }
.footer-links{ columns:2; gap:12px; }

@media (min-width:1920px){
  .footer {padding: 60px 300px;}
}

@media (max-width:1200px){
  .footer-links{ columns: 1; }
}
@media (max-width:768px){
  .footer, footer{ padding-left:20px; padding-right:20px; }
  .footer-container{ grid-template-columns: 1fr; }
  .footer-logo img{ width:100%;  }
}
@media (max-width:460px){
  .footer, footer{ padding-left:14px !important; padding-right:14px !important; }
}
@media (max-width:360px){
  .footer, footer{ padding-left:12px !important; padding-right:12px !important; }
}

/* ===========================
   FOOTER — MOBILE IMPROVEMENTS
   (sobrescreve regras do main.css)
   =========================== */

/* Até 768px: brand em cima; nav e contato lado a lado */
@media (max-width: 768px){
  .footer{ padding: 32px 20px; }

  .footer-container{
    display: grid;
    grid-template-columns: 1fr 1fr;
    grid-template-areas:
      "brand brand"
      "nav   contact";
    gap: 16px;
    align-items: start;
  }

  .footer-brand   { grid-area: brand; align-items: center; }
  .footer-nav     { grid-area: nav; }
  .footer-contact { grid-area: contact; }

  /* títulos e lista mais compactos */
  .footer-title{ text-align: left; margin-bottom: 6px; }
  .footer-title::after{ width: 80px; }

  /* menu em 2 colunas quando couber */
  .footer-links{
    columns: 2;             /* duas colunas fluidas */
    column-gap: 14px;
  }
  .footer-links li{ break-inside: avoid; }

  /* card de contato mais enxuto e CTA cheio */
  .contact-box{ padding: 18px; }
  .whatsapp-button{
    width: 100%;
    border-radius: 12px;
  }

  /* mapa ocupa toda a largura do bloco */
  .company-map iframe{
    width: 100% !important;
    height: 220px;          /* ajuste de altura para mobile */
    border-radius: 12px;
  }

  /* ícones sociais centralizados */
  .social-media-container{ justify-content: center; gap: 12px; }
}

/* Telas bem estreitas: volta para 1 coluna para não “apertar”*/
@media (max-width: 580px){
  .footer-container{
    grid-template-columns: 1fr;
    grid-template-areas:
      "brand"
      "nav"
      "contact";
  }
  .footer-links{ columns: 1; }    /* menu em 1 coluna */
}

/* Micro-ajustes extras para ultra-pequenas */
@media (max-width: 400px){
  .footer{ padding-left: 16px; padding-right: 16px; }
  .footer-title::after{ width: 64px; }
}

/* ===== Banner / Título ===== */
.banner-educacao{ aspect-ratio: 16/6; overflow: hidden; width:100%; }
.banner-educacao .banner-image{
  width:100%; height: clamp(260px, 36vw, 520px);
  object-fit: cover; object-position: center;
}

@media (max-width: 674px) {
    .banner-educacao{ position: relative; overflow: hidden; width:100%; height: 70vh; }
    .banner-educacao .banner-image{
        width:100%; height: 100%;
        object-fit: cover; object-position: center;
    }
}

.banner-educacao .banner-overlay{ position:absolute; inset:0; }
.banner-educacao .banner-content{ position:absolute; inset:0; display:flex; align-items:center; }
.banner-title{
  margin-left: 100px;
  font-size: clamp(1.6rem, 7.2vw, 3rem);
  line-height: 1.15; letter-spacing:-.02em;
  text-wrap: balance; max-inline-size: 22ch;
  word-break: normal !important; overflow-wrap: break-word;
}


@media (max-width: 1024px){
  .banner-educacao .banner-overlay{
    clip-path: none !important; transform:none !important; width:100% !important; left:0 !important; right:0 !important;
  }
  .banner-title{ margin: 0 24px; }
}
/* Título legível em telas pequenas */
@media (max-width: 650px){
  .banner-educacao .banner-content{ padding: 18px 16px 26px; }
  .banner-title{ max-inline-size: clamp(24ch, 86vw, 28ch); font-size: clamp(1.3rem, 6.2vw, 1.9rem); }
}
@media (max-width: 420px){
  .banner-title{ max-inline-size: clamp(26ch, 92vw, 30ch); font-size: clamp(1.2rem, 6.6vw, 1.6rem); }
}

.header { position: static;}

/* ===== HEADER/MENU ===== */
@media (max-width:1024px){
  /* Mostra o hamburguer */
  .header .menu-toggle{ display:flex !important; }

  /* Esconde a lista desktop e prepara off‑canvas */
  .header .navbar .nav-links{
    display:none !important;
    position: static !important;
    top:0; right:0; bottom:0; left:min(30%,120px);
    transform: translateX(100%);
    transition: transform .3s ease;
    background:#fff;
    padding: 18px 16px 28px;
    flex-direction: column !important;
    gap: 10px;
    overflow-y: auto;
    z-index: 2200;
    box-shadow: -12px 0 30px rgba(0,0,0,.14);
    border-radius: 12px 0 0 12px;
  }
  /* Largura total em telas muito pequenas */
  @media (max-width:400px){
    .header .navbar .nav-links{ left:0; border-radius:0; }
  }

  /* Estado aberto (classe aplicada via JS) */
  .header .navbar.active .nav-links{
    display:flex !important;
    transform: translateX(0);
  }

  /* Dropdowns sempre visíveis em mobile */
  .header .navbar .dropdown > .dropdown-menu{
    position: static !important;
    opacity:1 !important; visibility:visible !important; transform:none !important;
    border:0 !important; box-shadow:none !important;
    padding:0 !important; margin-left:10px;
    display:block !important;
  }
}



/* Ocultar barra no mobile */
@media (max-width: 500px){
  html, body{ overflow-y: auto; scrollbar-width: none; -ms-overflow-style: none; }
  html::-webkit-scrollbar, body::-webkit-scrollbar{ width: 0; height: 0; }
}

/* Ocultar barra no mobile */
@media (max-width: 768px){
  .footer-title {text-align: left;}
 
}

/* === Header padding fix (only) === */
.header{ padding-left: 100px; padding-right: 100px; } /* mantém desktop */

@media (min-width: 1920px) {
    .header{padding: 30px 300px;}
}

@media (max-width: 1024px){
  .header{ padding-left: 100px; padding-right: 100px; }
}

@media (max-width: 768px){
  .header{ padding-left: 20px; padding-right: 20px; }
}

@media (max-width: 500px){
  .header{ padding-left: 16px; padding-right: 16px; }
}

@media (max-width: 360px){
  .header{ padding-left: 12px; padding-right: 12px; }
}

@media (max-width: 1024px){
  .porque-escolher-text{ padding-left: 0 !important; }
}

@media (min-width: 1920px) {
    .banner-content {padding-left: 300px !important;  padding-right: 300px !important;}
}

/* ===== BANNER – PATCH DE RESPONSIVIDADE ===== */

/* Base: garante que a imagem sempre cubra toda a área do banner */
.banner-educacao{
  height: clamp(360px, 52vh, 720px); /* substitui o 45vh e adapta ao viewport */
  position: relative; /* redundante, mas garante o contexto */
  overflow: hidden;
}
.banner-educacao .banner-image{
  aspect-ratio: 16/6;
  inset: 0;
  width: 100%;
  height: 100% !important;         /* cobre todo o banner */
  object-fit: cover !important;    /* evita “faixas” e cortes estranhos */
  object-position: center;
}

/* Conteúdo sem paddings fixos nas faixas intermediárias */
.banner-educacao .banner-content{
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  padding: 0 !important;           /* zera os 100px antigos */
}

/* Título realmente responsivo (mais específico que .banner-title isolado) */
.banner-educacao .banner-title{
  font-size: clamp(1.6rem, 6.6vw, 3rem);
  line-height: 1.15;
  margin-left: 100px;
  padding-left: 16px;
}

/* Intermediárias (≤ 674px): reduz fonte e dá respiro lateral */
@media (max-width: 674px){
  .banner-educacao{ height: 40vh; }
  .banner-educacao .banner-title{
    font-size: clamp(1.25rem, 5.5vw, 1.9rem);
    margin: 0 16px;
    padding-left: 12px;
  }
}

/* Telas pequenas (≤ 466px): um pouco menor e mais compacto */
@media (max-width: 466px){
  .banner-educacao{ height: 30vh; }
  .banner-educacao .banner-title{
    font-size: clamp(2rem, 7vw, 2.5rem);
    margin: 0 14px;
    padding-left: 10px;
  }
}

/* Telas grandes (≥ 1920px): banner mais alto e grande respiro lateral */
@media (min-width: 1920px){
  .banner-educacao{ height: 60vh; }
  .banner-educacao .banner-content{ padding: 0 300px !important; }
  .banner-title {margin-left: 0 !important;}
}


/* ===== WhatsApp FAB (flutuante) ===== */
:root{
  --whatsapp: #25C26E;         /* verde do site */
  --whatsapp-dark: #22B865;    /* hover */
}

.whatsapp-fab{
  position: fixed;
  /* top | right | bottom | left (usa safe-area p/ iPhone) */
  inset: auto calc(16px + env(safe-area-inset-right))
         calc(16px + env(safe-area-inset-bottom)) auto;

  width: clamp(48px, 6vw, 64px);
  height: clamp(48px, 6vw, 64px);
  border-radius: 999px;
  background: var(--whatsapp);
  color: #fff;
  display: grid;
  place-items: center;
  box-shadow: 0 10px 25px rgba(0,0,0,.18);
  z-index: 12000; /* acima de header, overlays, etc. */
  transition: transform .2s ease, box-shadow .2s ease, background .2s ease;
}

.whatsapp-fab:hover{ 
  transform: translateY(-2px) scale(1.03);
  background: var(--whatsapp-dark);
  box-shadow: 0 14px 32px rgba(0,0,0,.22);
}

.whatsapp-fab:focus-visible{
  outline: 3px solid #25BACF; /* ciano da identidade */
  outline-offset: 3px;
}

.whatsapp-fab svg{
  width: 55%;
  height: 55%;
  display: block;
}

/* Ajustes para telas pequenas */
@media (max-width: 480px){
  .whatsapp-fab{
    width: 52px; height: 52px;
    inset: auto calc(12px + env(safe-area-inset-right))
           calc(12px + env(safe-area-inset-bottom)) auto;
  }
}

@media (max-width: 360px){
  .whatsapp-fab{
    width: 46px; height: 46px;
    inset: auto calc(10px + env(safe-area-inset-right))
           calc(10px + env(safe-area-inset-bottom)) auto;
  }
}

/* Oculta ao imprimir */
@media print { .whatsapp-fab{ display:none; } }

/* Acessibilidade: texto só p/ leitores de tela */
.sr-only{
  position:absolute; width:1px; height:1px; overflow:hidden;
  clip: rect(0 0 0 0); white-space:nowrap; border:0; padding:0; margin:-1px;
}

/* ===========================
   NAV MOBILE (OFF-CANVAS)
   =========================== */
@media (max-width: 1024px) {
  /* Gaveta lateral */
  .header .navbar {
    position: fixed;
    top: 0;
    right: 0;
    width: min(86vw, 360px);
    height: 100dvh;
    padding: 24px 16px 32px;
    background: #fff;
    box-shadow: -12px 0 28px rgba(0,0,0,.16);
    transform: translateX(100%);          /* escondido por padrão */
    transition: transform .35s cubic-bezier(.2,.7,.2,1), visibility 0s linear .35s;
    visibility: hidden;
    z-index: 1000;
    display: flex;
    flex-direction: column;
  }
  .header .navbar.active {
    transform: translateX(0);
    visibility: visible;
    transition-delay: 0s;
  }

  .header .nav-links {
    display: flex;
    flex-direction: column;
    gap: 22px;
    overflow: auto;
    padding-right: 6px;
    margin: 12px 0 16px;
  }

  /* Botão CTA vai para o rodapé da gaveta */
  .header .cta-comprar {
    margin-top: auto;
  }

  /* Botão hambúrguer */
  .menu-toggle {
    position: fixed;
    top: 14px;
    right: 14px;
    width: 44px;
    height: 44px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: #ffffff;
    border: 0;
    border-radius: 12px;
    box-shadow: 0 6px 18px rgba(0,0,0,.08);
    z-index: 1100; /* acima da gaveta e do backdrop */
    cursor: pointer;
  }
  .menu-toggle .bar {
    display: block;
    width: 22px;
    height: 2px;
    background: #2E3F5B;
    border-radius: 2px;
    transition: transform .3s ease, opacity .2s ease;
  }
  .menu-toggle .bar + .bar { margin-top: 5px; }

  /* Animação para "X" */
  .menu-toggle.is-open .bar:nth-child(1) {
    transform: translateY(7px) rotate(45deg);
  }
  .menu-toggle.is-open .bar:nth-child(2) {
    opacity: 0;
  }
  .menu-toggle.is-open .bar:nth-child(3) {
    transform: translateY(-7px) rotate(-45deg);
  }

  /* Bloqueia scroll do body quando menu aberto */
  body.no-scroll { overflow: hidden; }

  /* Backdrop (clicar fora) */
  .nav-backdrop {
    position: fixed;
    inset: 0;
    background: rgba(0,0,0,.45);
    opacity: 0;
    visibility: hidden;
    transition: opacity .35s ease;
    z-index: 950;
  }
  .nav-backdrop.show {
    opacity: 1;
    visibility: visible;
  }
}

/* Desktop mantém layout atual e esconde o hambúrguer */
@media (min-width: 1025px) {
  .menu-toggle { display: none; }
  .header .navbar {
    position: static;
    transform: none !important;
    visibility: visible !important;
    box-shadow: none;
    height: auto;
    width: auto;
  }
  .header .nav-links {
    flex-direction: row;
    overflow: visible;
    gap: 24px;
    margin: 0;
  }
}

/* Header como linha: logo à esquerda, botão à direita */
.header .header-content{
  display:flex;
  align-items:center;           /* centraliza verticalmente com o logo */
}

/* Botão quadrado “flutuante” mas alinhado visualmente ao header */
@media (max-width:1024px){
  .menu-toggle{
    position: relative;         /* (antes era fixed) fica dentro da linha do header */
    margin-left:auto;           /* vai para a direita */
    width:44px; height:44px;
    display:inline-flex; align-items:center; justify-content:center;
    background:#fff; border:0; border-radius:12px;
    box-shadow:0 6px 18px rgba(0,0,0,.08);
    z-index:1100;               /* acima da gaveta e do backdrop */
    cursor:pointer;
  }

  /* Ícones */
  .menu-toggle .icon{ width:22px; height:22px; color:#2E3F5B; display:block }
  .menu-toggle .icon-x{ display:none }
  .menu-toggle.is-open .icon-menu{ display:none }
  .menu-toggle.is-open .icon-x{ display:block }
}

/* Em desktop, esconder botão */
@media (min-width:1025px){
  .menu-toggle{ display:none }
}

/* Alinhamento do header no mobile */
@media (max-width:1024px){
  .header .header-content{
    position: relative;         /* referência para o botão */
    display: flex;
    align-items: center;        /* alinha a logo verticalmente */
    min-height: 64px;           /* altura confortável do header */
  }

  /* evita “sombra” de linha de base da imagem sem mudar seu tamanho */
  .header .logo img{
    display: block;             /* sem alterar width/height */
  }

  /* Botão: centralizado verticalmente na mesma linha da logo */
  .menu-toggle{
    position: absolute;
    right: 16px;                /* distância da borda direita */
    top: 50%;
    transform: translateY(-50%);/* centraliza verticalmente */
    margin: 0;                  /* zera qualquer margem antiga */
    z-index: 1100;
  }
}

/* ===== Desliga qualquer backdrop do menu mobile ===== */
.navbar::before { content: none !important; }
.navbar.active::before,
.navbar.is-open::before { opacity: 0 !important; pointer-events: none !important; }

/* Se existir o elemento injetado via JS, mantenha-o invisível */
.nav-backdrop { display: none !important; }

/* === MENU MOBILE FIX (off-canvas) =================================== */
@media (max-width: 1024px){
  .menu-toggle{ display:flex; z-index:1021; }
  .navbar{ position:relative; z-index:1020; }

  /* Overlay escuro do fundo */
  .navbar::before{
    content:"";
    position:fixed; inset:0;
    background: rgba(0,0,0,.40);
    opacity:0; pointer-events:none;
    transition: opacity .25s ease;
  }
  .navbar.active::before{ opacity:1; pointer-events:auto; }

  /* Gaveta lateral (painel) */
  .nav-links{
    position: fixed; top:0; right:0; bottom:0;
    width: min(88vw, 360px);
    transform: translateX(100%); transition: transform .28s ease;
    background:#fff; box-shadow: -12px 0 30px rgba(0,0,0,.15);
    padding: 20px 18px 90px;             /* espaço pro CTA no rodapé */
    display:flex; flex-direction:column; gap:14px; align-items:stretch;
    overflow-y: auto; z-index:1015;
  }
  .navbar.active .nav-links{ transform: translateX(0); }

  /* Trava o scroll do body quando o menu abre */
  body.no-scroll{ overflow:hidden; }

  /* Dropdowns: colapsados por padrão no mobile */
  .dropdown > .dropdown-menu{
    position: static; transform:none; opacity:1; visibility:visible;
    display:none; padding:8px 0 0; border:0; box-shadow:none; background:transparent;
  }
  .dropdown.mobile-open > .dropdown-menu{ display:block; }
  .dropdown-menu a{
    text-align:left; padding:10px 12px; border-radius:10px;
    background:#F5F7FA; margin-top:6px;
  }

  /* CTA: esconda o botão padrão e use um dentro do painel */
  .cta-comprar{ display:none; }
  .nav-links .mobile-cta{ margin-top:auto; }
  .nav-links .mobile-cta .cta-comprar{ display:block; width:100%; }
}

/* Desktop: restaura comportamento normal */
@media (min-width:1025px){
  .nav-links{ position:static; transform:none; display:flex; overflow:visible; }
  .navbar::before{ display:none; }
}

/* Hambúrguer vira "X" quando menu está aberto */
.menu-toggle .bar{ transition: transform .25s ease, opacity .2s ease; }
.navbar.active .menu-toggle .bar:nth-child(1){ transform: translateY(6px) rotate(45deg); }
.navbar.active .menu-toggle .bar:nth-child(2){ opacity:0; }
.navbar.active .menu-toggle .bar:nth-child(3){ transform: translateY(-6px) rotate(-45deg); }

/* Fallback: se você não mover o CTA pro <ul>, posicione o atual dentro da gaveta */
@media (max-width:1024px){
  .navbar.active > .cta-comprar{
    position: fixed; right: 18px;
    left: calc(100% - min(88vw, 360px) + 18px);
    bottom: 18px; z-index:1022; display:block !important;
    width: calc(min(88vw, 360px) - 36px);
  }
}

html, body{ width:100%; max-width:100%; overflow-x: clip; }
@supports not (overflow-x: clip){ html, body{ overflow-x: hidden; } }
*, *::before, *::after{ box-sizing: border-box; }
img, svg, video, canvas, iframe{ max-width:100%; height:auto; display:block; }
main, section, header, footer{ max-width: 100%; }

/* ============================
   MOBILE PATCH (≤768px): 2-up + compactação
   ============================ */
@media (max-width: 768px){

  /* 1) Paddings menores nas seções largas */
  .acessos, .servicos, .nossas-solucoes, .segmentos,
  .tecnologias, .tecnologias-section, .ponto-section,
  .ponto-section-numebers, .ponto-recursos-avancados, .ponto-consultoria,
  .cl-section, .cl-testimonials.cl-v2, .fale-conosco,
  .nova-sessao, .porque-escolher-educacao, .video-section,
  .integracao-section, .sol-v4.section,
  #acessos-comparativo, #acessos-kits, #acessos-operacao{
    padding: 28px 20px;
  }

  /* 2) 2 cards por linha nos grids principais */
  .solucoes-grid,
  .solucoes-grid-app,
  .servicos-grid,
  .sol-v4__grid,
  .sol-v4__kpis,
  .sol-v4__compare,
  .svc-compare .use-cases,
  .acessos-grid,
  .ax-grid,
  .ponto-grid-4,
  .ponto-grid-3,
  .ponto-metrics,
  .cl-logo-grid,
  .cl-t-track,
  .cl-cases-track,
  .resultados-grid,
  .tecnologias-boxes-grid{
    display: grid;
    grid-template-columns: repeat(2, minmax(0,1fr));
    gap: 12px;
  }

  /* 3) Listas do artigo em 2 colunas (quando couber) */
  .post-content .checklist{
    display: grid;
    grid-template-columns: repeat(2, minmax(0,1fr));
    gap: 8px 14px;
  }
  .post-content .checklist li{ margin: 6px 0; }

  /* 4) Blog (lista de cards) — cobre vários nomes possíveis */
  .blog-grid, .blog-list, .blog-cards{
    display: grid;
    grid-template-columns: repeat(2, minmax(0,1fr));
    gap: 12px;
  }

  /* 5) Post: topo mais compacto */
  .post-page{ padding: 28px 16px; }
  .post-hero{ padding: 18px; }
  .post-lead{ font-size: .98rem; }
  .post-footer{ gap: 10px; }
}

/* Telas muito estreitas (≤420px): volta pra 1 coluna */
@media (max-width: 420px){
  .solucoes-grid,
  .solucoes-grid-app,
  .servicos-grid,
  .sol-v4__grid,
  .sol-v4__kpis,
  .sol-v4__compare,
  .svc-compare .use-cases,
  .acessos-grid,
  .ax-grid,
  .ponto-grid-4,
  .ponto-grid-3,
  .ponto-metrics,
  .cl-logo-grid,
  .cl-t-track,
  .cl-cases-track,
  .resultados-grid,
  .tecnologias-boxes-grid,
  .blog-grid, .blog-list, .blog-cards{
    grid-template-columns: 1fr;
  }
  .post-content .checklist{ grid-template-columns: 1fr; }
}

/* Utilidade: aplique em QUALQUER container para forçar 2-up no mobile
   <div class="stack-sm-2"> ... </div> */
@media (max-width: 768px){
  .stack-sm-2{ display:grid; grid-template-columns:repeat(2, minmax(0,1fr)); gap:12px; }
}
@media (max-width:420px){
  .stack-sm-2{ grid-template-columns:1fr; }
}

.navbar.active {background-color: transparent; box-shadow: none;}
.cta-comprar {z-index: 5000;}

@media (max-width: 600px) {
  .servicos-container {
    gap: 20px;
}
}

/* =========================
   MENU MOBILE – REFINOS
   ========================= */
@media (max-width: 1024px) {

  /* Painel (off-canvas) e backdrop (mantém animação/blur) */
  .navbar {
    position: fixed;
    top: 0;
    right: 0;
    bottom: 0;
    width: min(88vw, 360px);
    transform: translateX(105%);
    transition: transform .3s ease;
    background: rgba(255,255,255,.98);
    border-radius: 12px 0 0 12px;
    box-shadow: -12px 0 30px rgba(16,24,40,.12);
    z-index: 1000;
  }
  .navbar.active { transform: translateX(0); }

  .nav-backdrop {
    position: fixed;
    inset: 0;
    background: rgba(16,24,40,.55);
    backdrop-filter: blur(2px);
    opacity: 0; visibility: hidden;
    transition: opacity .25s ease, visibility .25s ease;
    z-index: 999;
  }
  .nav-backdrop.show { opacity: 1; visibility: visible; }

  /* Botão hamburguer/fechar alinhado ao header (não sobrepõe o painel) */
  header .menu-toggle {
    position: absolute;
    top: 50%;
    right: 16px;
    transform: translateY(-50%);
    z-index: 1300;
  }
  /* Quando o menu abre, desloca o X para a esquerda do painel */
  .menu-toggle.is-open {
    right: calc(min(88vw, 360px) + 16px);
  }

  /* Conteúdo rolável do painel com respiro no topo */
  .nav-links {
    height: 100dvh;
    overflow: auto;
    padding: 88px 18px 20px; /* espaço p/ CTA no topo */
  }

 

  /* Dropdowns tocáveis no mobile (sem mexer no HTML) */
  .navbar .dropdown > .dropdown-menu {
    display: none !important;           /* fechado por padrão */
    position: static;
    opacity: 1; visibility: visible;    /* sem transições de hover */
    transform: none;
    border: 0; box-shadow: none;
    padding-left: 12px;
    margin-top: 8px;
  }
  .navbar .dropdown.mobile-open > .dropdown-menu {
    display: block !important;          /* abre quando ganha a classe */
  }
  .cta-comprar {width: 100%;}
}

/* === MOBILE MENU – FIX LIMPO (cola no fim do main.css) ================== */
@media (max-width:1024px){
  /* Gaveta off-canvas única (sobrepõe o bloco antigo) */
  .header .navbar .nav-links{
    position: fixed !important;
    inset: 0 0 0 auto;              /* top:0; right:0; bottom:0; left:auto */
    width: min(88vw, 360px);
    transform: translateX(100%);
    display: flex !important;
    flex-direction: column;
    gap: 14px;
    padding: 120px 18px 90px;       /* espaço pro X (topo) e CTA */
    background: #fff;
    box-shadow: -12px 0 30px rgba(0,0,0,.15);
    overflow-y: auto;
    z-index: 1015;
    border-radius: 0;               /* sem bordas arredondadas que criavam “vazios” */
  }
  .navbar.active .nav-links{ transform: translateX(0); }

  /* Backdrop */
  .navbar::before{
    content:""; position:fixed; inset:0;
    background: rgba(0,0,0,.40);
    opacity:0; pointer-events:none; transition:opacity .25s ease; z-index:1000;
  }
  .navbar.active::before{ opacity:1; pointer-events:auto; }

  

  /* Dropdowns como lista simples (some a “setinha” e a animação que cria espaço) */
  .navbar .dropdown > .dropdown-menu{
    position: static !important;
    opacity:1 !important; visibility:visible !important; transform:none !important;
    border:0 !important; box-shadow:none !important; padding:0 !important; margin:0 !important;
  }
  .navbar .dropdown-menu::before{ display:none !important; }
  .navbar .dropdown-menu li{ opacity:1 !important; transform:none !important; transition:none !important; }

  /* Links ocupam a linha toda—acabam os “buracos” de clique */
  .header .nav-links a{ display:block; padding:12px 4px; color:#2E3F5B; }

}

/* Botão "X" sempre DENTRO da gaveta – CSS only */
@media (max-width:1024px){
  :root{ --drawer-w: min(88vw, 360px); } /* mesma largura da sua gaveta */

  /* posição do botão (como já usa) */
  .menu-toggle{
    position: fixed;
    top: 14px;
    right: 14px;
    z-index: 3000;
  }

  /* quando o menu abrir, recorta a área visível do botão
     ao retângulo da gaveta, impedindo que ele “escape” para fora */
  .menu-toggle.is-open{
    clip-path: inset(0 calc(100vw - var(--drawer-w)) 0 0);
  }
  /* caso seu JS não use .is-open, use esta linha alternativa:
     .navbar.active ~ .menu-toggle{ clip-path: inset(0 calc(100vw - var(--drawer-w)) 0 0); }
  */
}

