/* ================== RESET E VARIAVEIS ================== */

* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
    font-family: 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
}

:root {
    --azul-escuro-profundo: #0A1C44;
    --azul-cinza-contraste: #1B2A47;
    --laranja: #F15730;
    --texto-branco: #ffffff;
}

/* ================== HERO SECTION CLEAN ================== */

.hero-clean {
    position: relative;
    display: flex;
    height: 100vh;
    min-height: 800px;
    background-color: var(--azul-escuro-profundo);
    overflow: hidden;
}

/* ----- LADO ESQUERDO (SÓLIDO COM CORTE) ----- */
.hero-esq-clean {
    width: 60%;
    background-color: var(--azul-escuro-profundo);
    z-index: 2;
    clip-path: polygon(0 0, 100% 0, 85% 100%, 0% 100%);
    display: flex;
    flex-direction: column;
    justify-content: center;
    position: relative;
}

.hero-conteudo-clean {
    width: 80%;
    margin: 0 auto;
    padding: 100px 5% 150px 8%;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
}

.logo-hero-clean {
    max-width: 280px;
    height: auto;
    margin-bottom: 50px;
    display: block;
    background: none;
}

.subtitulo-clean {
    font-size: 1.15rem;
    font-weight: 400;
    letter-spacing: 0.15em;
    color: var(--texto-branco);
    margin-bottom: 20px;
    text-transform: uppercase;
}

.hero-esq-clean h1 {
    font-size: 4rem;
    font-weight: 900;
    color: var(--texto-branco);
    line-height: 1.1;
    margin-bottom: 30px;
}

.hero-esq-clean h1 strong {
    color: var(--laranja);
}

.hero-lead-clean {
    font-size: 1.25rem;
    color: #e5e7eb;
    line-height: 1.7;
    max-width: 550px;
    margin-bottom: 55px;
    border-left: 5px solid var(--laranja);
    padding-left: 25px;
    font-weight: 400;
}

.btn-laranja-clean {
    background: linear-gradient(135deg, #ff7b3b, var(--laranja));
    color: #fff;
    font-weight: 800;
    font-size: 1.15rem;
    padding: 18px 36px;
    text-decoration: none;
    border-radius: 50px;
    text-transform: uppercase;
    border: none;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 12px;
    box-shadow: 0 12px 30px rgba(241, 87, 48, 0.45);
    transition: all 0.3s ease;
    width: fit-content;
}

.btn-laranja-clean:hover {
    transform: translateY(-4px);
    box-shadow: 0 16px 40px rgba(241, 87, 48, 0.65);
    filter: brightness(1.1);
}

/* ----- LADO DIREITO (COM A FOTO DO CLIENTE) ----- */
.hero-dir-clean {
    position: absolute;
    top: 0;
    right: 0;
    width: 45%;
    height: 100%;
    z-index: 1;
    background-image: url('../imagens/capa.jpeg');
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
}

.capa-overlay {
    position: absolute; 
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: linear-gradient(to right, rgba(10, 28, 68, 0.4) 0%, rgba(10, 28, 68, 0.1) 30%, rgba(255,255,255,0) 100%);
}

/* ================== RESPONSIVIDADE ================== */

@media (max-width: 1200px) {
    .hero-esq-clean h1 { 
        font-size: 3rem;
    }
}

/* Adaptável para dispositivos Mobile (celulares ou tablets em pé) (telas menores que 992px) */
@media (max-width: 992px) {
    .hero-clean { 
        /* column-reverse faz o filho nº 2 (foto) subir e o nº 1 (texto) descer */
        flex-direction: column-reverse; 
        height: auto; 
    }
    .hero-esq-clean { 
        width: 100%; 
        clip-path: none; 
        padding: 0; /* Tiramos o padding excessivo da div externa */
    }
    .hero-conteudo-clean {
        width: 100%; /* Força a ocupar todo o celular */
        margin: 0; /* Tira o alinhamento central automático do desktop */
        padding: 50px 20px 80px 20px; /* Alinha firmemente à esquerda com 20px de respiro lateral */
    }
    .hero-esq-clean h1 {
        font-size: 2.6rem; /* Deixa o título um pouco menor para caber melhor na tela do celular */
    }
    .hero-dir-clean { 
        position: relative; 
        width: 100%; 
        height: 400px; /* Reduzi um pouquinho para a pessoa já conseguir ver o começo do texto logo abaixo */
    }
}

/* ================== RESPONSIVIDADE ================== */

/* Adaptável para monitores médios/tablets (quando a tela for menor que 1200px) */
@media (max-width: 1200px) {
    .hero-esq-clean h1 { 
        font-size: 3rem; /* Encolhe o título H1 de 4rem para 3rem, evitando que quebre feio e suje a tela */
    }
}

/* Adaptável para dispositivos Mobile (celulares ou tablets em pé) (telas menores que 992px) */
@media (max-width: 992px) {
    .hero-clean { 
        flex-direction: column; /* Desativa a tela dividida lado a lado e empilha um em cima do outro */
        height: auto; /* Tira a altura amarrada de 100vh para a seção poder crescer com os textos */
    }
    .hero-esq-clean { 
        width: 100%; /* O fundo azul agora ocupa 100% da largura da tela */
        clip-path: none; /* Desativa o corte diagonal, a borda passa a ser um quadrado reto */
        padding: 100px 5%; /* Alinha os recuos de texto pro celular */
    }
    .hero-dir-clean { 
        position: relative; /* Volta para o fluxo normal (fica empilhado logo abaixo do bloco de textos) */
        width: 100%; /* A foto passa a ocupar 100% da largura do celular */
        height: 500px; /* Estipula uma altura fixa para a foto, já que ela não segue mais o tamanho total da tela */
    }
}

/* ================== MOTIVOS (CARDS 3D) ================== */

:root {
    --laranja: #F15730;
    --azul-escuro: #192C57;
    --cinza-claro: #EBF1F2;
    --cinza-medio: #515F73;
    --gradiente-card: linear-gradient(135deg, var(--azul-escuro), #0A1A3A);
    --sombra-laranja: rgba(241, 87, 48, 0.3);
    --sombra-padrao: rgba(0, 0, 0, 0.3);
}

/* Seção completa */
.secao-clara {
    background-color: var(--cinza-claro);
    padding: 100px 0;
    position: relative;
    overflow: hidden;
}

.secao-clara::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: radial-gradient(circle at 10% 20%, rgba(241, 87, 48, 0.03), transparent 50%);
    pointer-events: none;
}

/* Cabeçalho da seção */
.cabecalho-secao {
    text-align: center;
    margin-bottom: 60px;
    position: relative;
    z-index: 1;
}

.cabecalho-secao h2 {
    font-size: 2.5rem;
    color: var(--azul-escuro);
    margin-bottom: 15px;
    font-weight: 700;
}

.destaque-laranja {
    color: var(--laranja);
    position: relative;
    display: inline-block;
}

/* ================== RESET E VARIAVEIS ================== */
* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
    font-family: 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
}

html { scroll-behavior: smooth; }

:root {
    --azul-escuro: #192C57;
    --azul-cinza: #515F73;
    --laranja: #F15730;
    --texto-claro: #f8f9fa;
    --texto-escuro: #333333;
}

/* ================== BASE ================== */
body {
    background-color: var(--texto-claro);
    color: var(--texto-escuro);
}

.container {
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 20px;
}

/* ================== PADRÕES DE SEÇÕES ================== */
.secao-clara {
    background-color: #ffffff;
    padding: 100px 0;
}

.secao-escura {
    background-color: var(--azul-escuro);
    padding: 100px 0;
    color: #fff;
}

.cabecalho-secao {
    text-align: center;
    margin-bottom: 60px;
}

.cabecalho-secao h2 {
    font-size: 2.5rem;
    margin-bottom: 15px;
}

.cabecalho-secao.dark-text h2 {
    color: var(--azul-escuro);
}

.destaque-laranja {
    color: var(--laranja);
    font-weight: 900;
}

/* ================== HERO SECTION ================== */
.hero-impacto {
    position: relative;
    display: flex;
    height: 100vh;
    min-height: 700px;
    overflow: hidden;
    background-color: #111;
}

.hero-esquerda {
    width: 55%;
    background: linear-gradient(135deg, var(--azul-cinza), #1f2937);
    padding: 5% 5% 15% 8%;
    z-index: 2;
    clip-path: polygon(0 0, 100% 0, 85% 100%, 0% 100%);
    display: flex;
    flex-direction: column;
    justify-content: center;
}

/* Logo */
.logo-hero {
    max-width: 320px;
    height: auto;
    margin-bottom: 40px;
    display: block;
}

/* Textos hero */
.subtitulo {
    font-size: 1.1rem;
    font-weight: 500;
    letter-spacing: 0.1em;
    color: #e0e0e0;
    margin-bottom: 10px;
    text-transform: uppercase;
}

.hero-esquerda h1 {
    font-size: 3.2rem;
    font-weight: 900;
    color: #ffffff;
    line-height: 1.1;
    margin-bottom: 25px;
}

.hero-esquerda h1 strong {
    color: var(--laranja);
}

.hero-esquerda p.hero-lead {
    font-size: 1.15rem; /* Fonte um pouco maior */
    color: #f3f4f6; /* Cor ligeiramente mais clara para melhorar o contraste */
    line-height: 1.6; /* Maior espaçamento entre as linhas para facilitar a leitura */
    max-width: 480px; /* Um pouco mais largo para que a quebra de linha fique mais suave */
    margin-bottom: 40px; /* Mais espaço antes de chegar no botão */
    
    /* Opcional: Adiciona um detalhe visual à esquerda do texto */
    border-left: 3px solid var(--laranja); 
    padding-left: 15px;
    font-weight: 300; /* Deixa a fonte mais elegante, se a família de fontes suportar */
}


/* Lado direito hero */
.hero-direita {
    position: absolute;
    top: 0;
    right: 0;
    width: 60%;
    height: 100%;
    background: linear-gradient(120deg, rgba(25,44,87,0.6), rgba(0,0,0,0.7)),
                url('../imagens/foco.jpg') center/cover no-repeat;
    z-index: 1;
}

/* Botão CTA */
.btn-laranja-cta {
    background: linear-gradient(135deg, #ff7b3b, var(--laranja));
    color: #fff;
    font-weight: 800;
    font-size: 1.05rem;
    padding: 14px 10px;
    text-decoration: none;
    border-radius: 999px;
    text-transform: uppercase;
    border: none;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 5px;
    text-align: center;
    box-shadow: 0 12px 30px rgba(241, 87, 48, 0.45);
    transition: transform 0.2s ease, box-shadow 0.2s ease, filter 0.2s ease;
    width: fit-content;
    align-self: flex-start;
    margin-left: 0;
}

.btn-laranja-cta:hover {
    transform: translateY(-2px);
    box-shadow: 0 18px 40px rgba(241, 87, 48, 0.6);
    filter: brightness(1.05);
}

/* Faixas animadas */
.faixa-animada {
    position: absolute;
    left: -10%;
    width: 120%;
    padding: 10px 0;
    z-index: 3;
    white-space: nowrap;
    overflow: hidden;
    font-weight: bold;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.faixa-escura {
    bottom: 8%;
    background-color: #000;
    color: #fff;
    transform: rotate(-3deg);
}

.faixa-clara {
    bottom: 2%;
    background-color: #f1f1f1;
    color: #000;
    transform: rotate(-3deg);
}

.faixa-conteudo {
    display: inline-block;
    animation: rolarLetreiro 25s linear infinite;
}

.faixa-conteudo.reverso {
    animation: rolarLetreiro 30s linear infinite reverse;
}

@keyframes rolarLetreiro {
    0%   { transform: translateX(0); }
    100% { transform: translateX(-50%); }
}

/* ================== MOTIVOS (CARDS 3D) ================== */

/* ================== POR QUE NOS ESCOLHER (CARDS COM FOTOS - FUNDO AZUL) ================== */

.secao-clara {
    background-color: var(--azul-cinza-contraste); 
    padding: 100px 0;
    width: 100%;
}

.cabecalho-secao {
    text-align: center;
    margin-bottom: 60px;
    padding: 0 20px;
}

.cabecalho-secao h2 {
    font-size: 2.8rem;
    color: var(--texto-branco);
    font-weight: 800;
    margin-bottom: 15px;
}

/* O subtítulo agora é totalmente branco */
.cabecalho-secao p {
    font-size: 1.25rem;
    color: #ffffff; 
}

.cabecalho-secao strong, .destaque-laranja {
    color: var(--laranja);
}

/* O Grid que organiza as fotos lado a lado */
.grid-motivos-fotos {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
    gap: 30px;
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 20px;
}

/* O Card em si (Todos padronizados na cor branca) */
.card-foto {
    background: #ffffff;
    border-radius: 16px;
    overflow: hidden; 
    box-shadow: 0 15px 35px rgba(0, 0, 0, 0.2); 
    transition: all 0.4s ease;
    cursor: pointer;
    border: none; 
    display: flex;
    flex-direction: column;
}

/* Efeito de flutuar o card inteiro */
.card-foto:hover {
    transform: translateY(-8px);
    box-shadow: 0 25px 50px rgba(0, 0, 0, 0.35);
}

/* Área da Imagem */
.card-imagem {
    width: 100%;
    height: 200px; 
    overflow: hidden; 
    position: relative;
}

.card-imagem img {
    width: 100%;
    height: 100%;
    object-fit: cover; 
    transition: transform 0.6s ease; 
}

/* Efeito de zoom sutil na foto ao passar o mouse */
.card-foto:hover .card-imagem img {
    transform: scale(1.1);
}

/* Área de Texto abaixo da foto */
.card-texto {
    padding: 25px 20px;
    text-align: center;
    flex-grow: 1; 
    display: flex;
    align-items: center;
    justify-content: center;
    background-color: #ffffff;
}

.card-texto h3 {
    font-size: 1.35rem;
    color: var(--azul-escuro-profundo); 
    font-weight: 700;
    margin: 0;
    transition: color 0.3s ease;
}

/* O título fica laranja no hover em todos os cards */
.card-foto:hover .card-texto h3 {
    color: var(--laranja);
}

/* ================== RESPONSIVIDADE ================== */
@media (max-width: 992px) {
    .grid-motivos-fotos {
        grid-template-columns: repeat(2, 1fr); 
    }
}

@media (max-width: 768px) {
    .cabecalho-secao h2 {
        font-size: 2.2rem;
    }
    
    .grid-motivos-fotos {
        grid-template-columns: 1fr; 
        max-width: 400px; 
        margin: 0 auto; /* Garante que os cards fiquem centralizados no celular */
    }
    
    .card-imagem {
        height: 220px; 
    }
}
/* ================== FORMULÁRIO DE CAPTURA ================== */
.secao-formulario {
    background: radial-gradient(circle at top left, #ffffff 0, #e5e7eb 40%, #cbd5f5 100%);
    padding: 90px 0;
}

.form-wrapper {
    max-width: 1100px;
    margin: 0 auto;
    display: grid;
    grid-template-columns: minmax(0, 1.2fr) minmax(0, 1fr);
    gap: 40px;
    align-items: center;
}

/* Bloco de texto ao lado do form */
.form-info h2 {
    font-size: 2.3rem;
    color: var(--azul-escuro);
    margin-bottom: 15px;
}

.form-info p {
    font-size: 1rem;
    color: #4b5563;
    line-height: 1.6;
    margin-bottom: 20px;
    
    /* Novas regras para a borda lateral */
    border-left: 3px solid var(--laranja);
    padding-left: 15px;
}

.form-badges {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-top: 10px;
}

.badge {
    background-color: #fff;
    color: var(--azul-escuro);
    border-radius: 999px;
    padding: 6px 14px;
    font-size: 0.8rem;
    font-weight: 600;
    box-shadow: 0 8px 18px rgba(15, 23, 42, 0.1);
}

/* Card do form */
.form-card {
    background: rgba(255,255,255,0.9);
    border-radius: 20px;
    padding: 30px 28px;
    box-shadow:
        0 24px 60px rgba(15, 23, 42, 0.18),
        0 0 0 1px rgba(148, 163, 184, 0.25);
    backdrop-filter: blur(16px);
    border: 1px solid rgba(255,255,255,0.8);
}

.form-card h3 {
    font-size: 1.4rem;
    color: var(--azul-escuro);
    margin-bottom: 8px;
}

.form-card p {
    font-size: 0.95rem;
    color: #6b7280;
    margin-bottom: 20px;
}

/* Form */
.form-captura {
    display: grid;
    grid-template-columns: 1fr;
    gap: 14px;
}

.input-group {
    display: flex;
    flex-direction: column;
    gap: 6px;
}

.input-group label {
    font-size: 0.9rem;
    font-weight: 600;
    color: #374151;
}

.input-group small {
    font-size: 0.75rem;
    color: #9ca3af;
}

/* Inputs e select */
.input-group input,
.select-field {
    width: 100%;
    padding: 13px 14px;
    border: 1px solid #d1d5db;
    border-radius: 10px;
    font-size: 0.95rem;
    background-color: #f9fafb;
    color: #111827;
    transition: border-color 0.15s ease, box-shadow 0.15s ease, background-color 0.15s ease, transform 0.05s ease;
    appearance: none;
    -webkit-appearance: none;
    background-image: url('data:image/svg+xml;charset=US-ASCII,<svg%20xmlns="http://www.w3.org/2000/svg"%20width="24"%20height="24"%20viewBox="0%200%2024%2024"><path%20fill="%23192C57"%20d="M7%2010l5%205%205-5z"/></svg>');
    background-repeat: no-repeat;
    background-position: right 14px center;
    background-size: 18px;
}

.input-group input::placeholder {
    color: #9ca3af;
}

.input-group input:focus,
.select-field:focus {
    border-color: var(--laranja);
    background-color: #fff;
    outline: none;
    box-shadow: 0 0 0 3px rgba(241, 87, 48, 0.16);
    transform: translateY(-1px);
}

/* Botão do form */
.form-captura button {
    width: 100%;
    margin-top: 8px;
}

/* ================== RELATOS E VÍDEO ================== */
:root {
    --cor-destaque: #F15730; /* Laranja/Vermelho */
    --cor-primaria: #192C57; /* Azul Escuro */
    --cor-fundo: #EBF1F2;    /* Gelo/Azul Claro */
    --cor-texto: #515F73;    /* Cinza Azulado */
}

.cabecalho-depoimentos {
    text-align: center;
    margin-bottom: 50px; /* Espaço entre o título e os vídeos */
}

.titulo-principal {
    color: var(--cor-primaria); /* #192C57 */
    font-size: 2.8rem;
    font-weight: 800;
    margin-bottom: 15px;
}

/* O efeito da caixa clarinha atrás da palavra */
.destaque-fundo {
    color: var(--cor-destaque); /* #F15730 */
    /* Usando RGBA para criar uma versão bem transparente do seu laranja para o fundo */
    background-color: rgba(241, 87, 48, 0.15); 
    padding: 2px 8px;
    border-radius: 4px; /* Deixa as pontinhas do fundo levemente arredondadas */
    display: inline-block;
}

.subtitulo {
    color: var(--cor-texto); /* #515F73 */
    font-size: 1.3rem;
    font-weight: 400;
    margin: 0;
}

/* Apenas a cor do texto sem fundo para o subtítulo */
.destaque-texto {
    color: var(--cor-destaque); /* #F15730 */
    font-weight: 700;
}

/* Ajuste para telas menores (celulares) */
@media (max-width: 600px) {
    .titulo-principal {
        font-size: 2rem;
    }
    .subtitulo {
        font-size: 1.1rem;
    }
}

.secao-depoimentos {
    background-color: var(--cor-fundo);
    padding: 60px 20px;
    font-family: sans-serif;
    text-align: center;
}

.titulo-depoimentos {
    color: var(--cor-primaria);
    font-size: 2rem;
    margin-bottom: 40px;
}

.carrossel-container {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 15px;
    max-width: 800px;
    margin: 0 auto 30px auto;
}

.video-wrapper {
    flex: 1;
    background-color: #000;
    border-radius: 12px;
    overflow: hidden;
    box-shadow: 0 10px 20px rgba(25, 44, 87, 0.15); /* Sombra com a cor azul escura */
}

.video-wrapper video {
    width: 100%;
    display: block;
    max-height: 400px;
    object-fit: cover;
}

.comentario-wrapper {
    flex: 1;
    background: #ffffff;
    padding: 30px;
    border-radius: 12px;
    border-left: 6px solid var(--cor-destaque);
    box-shadow: 0 8px 20px rgba(25, 44, 87, 0.1);
    min-height: 120px;
    display: flex;
    flex-direction: column;
    justify-content: center;
}

.comentario-wrapper blockquote {
    font-size: 1.15rem;
    color: var(--cor-texto);
    margin: 0 0 15px 0;
    font-style: italic;
    line-height: 1.5;
}

.comentario-wrapper cite {
    font-weight: 700;
    color: var(--cor-primaria);
    font-style: normal;
}

.btn-navegacao {
    background-color: var(--cor-destaque);
    color: #ffffff;
    border: none;
    width: 45px;
    height: 45px;
    border-radius: 50%;
    font-size: 1.2rem;
    cursor: pointer;
    transition: background-color 0.3s ease, transform 0.2s ease;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

.btn-navegacao:hover {
    background-color: var(--cor-primaria);
    transform: scale(1.05);
}

/* Responsividade para telas menores */
@media (max-width: 600px) {
    .carrossel-container {
        gap: 10px;
    }
    .btn-navegacao {
        width: 35px;
        height: 35px;
        font-size: 1rem;
    }
    .comentario-wrapper blockquote {
        font-size: 1rem;
    }
}
/* ================== O QUE FAZEMOS (SERVIÇOS) ================== */
/* ================== CLIENTES PARCEIROS ================== */

/* Define a área total da seção de clientes */
.clientes-clean {
    background-color: var(--azul-cinza-contraste); 
    padding: 80px 0; 
    width: 100%;
}

/* Centraliza o conteúdo e não deixa ele encostar nas bordas da tela */
.clientes-container {
    max-width: 1200px; 
    margin: 0 auto; 
    padding: 0 20px; 
    text-align: center; 
}

/* Estilo do título da seção */
.clientes-titulo {
    color: var(--texto-branco); 
    font-size: 2rem;
    font-weight: 700;
    margin-bottom: 50px; 
}

.clientes-titulo span {
    color: var(--laranja);
}

/* ================== GRID DE LOGOS (COMPUTADOR) ================== */

.clientes-grid {
    display: flex; 
    flex-wrap: wrap; 
    justify-content: center; 
    align-items: center; 
    gap: 40px 60px; /* Espaço entre as logos no PC */
}

/* Estilo individual de cada logo */
.cliente-item {
    width: 150px; 
    height: 80px; 
    display: flex;
    justify-content: center;
    align-items: center;
}

.cliente-item img {
    max-width: 100%; 
    max-height: 100%; 
    object-fit: contain; 
    transition: all 0.3s ease; 
}

/* Efeito Hover: Quando o mouse passa por cima */
.cliente-item img:hover {
    transform: translateY(-5px) scale(1.05); 
}

/* ================== RESPONSIVIDADE CLIENTES (MOBILE) ================== */

@media (max-width: 768px) {
    .clientes-titulo {
        font-size: 1.8rem; /* Tamanho ideal para celular */
    }
    
    /* Força exatamente 2 colunas lado a lado no celular */
    .clientes-grid {
        display: grid;
        grid-template-columns: repeat(2, 1fr); 
        gap: 25px; /* Espaçamento entre as logos */
        justify-items: center; 
        align-items: center;
        padding: 0 10px; 
    }

    /* Ajuste no tamanho individual da logo para o celular */
    .cliente-item {
        width: 100%; 
        max-width: 120px; /* Garante que caibam bem as duas */
        height: 60px; 
    }
}

/* ================== FAQ ================== */
/* ================== FAQ ================== */
:root {
    --azul-escuro-profundo: #0A1C44;
    --azul-escuro: #142a5c;
    --azul-cinza: #3b82f6;
    --cinza-texto: #cbd5e1;
    --branco: #ffffff;
    --laranja: #f97316;
}

/* SEÇÃO FAQ */
#faq {
    background-color: var(--azul-escuro-profundo);
    padding: 80px 20px;
    color: var(--branco);
}

.container {
    max-width: 1200px;
    margin: 0 auto;
}

/* TÍTULO */
.cabecalho-secao h2 {
    font-size: 2.5rem;
    text-align: center;
    margin-bottom: 48px;
    color: var(--branco);
    font-weight: 700;
}

.destaque-laranja {
    color: var(--laranja);
}

/* CONTAINER */
.faq-container {
    max-width: 800px;
    margin: 0 auto;
    display: flex;
    flex-direction: column;
    gap: 16px;
}

/* CARD DO ITEM */
.faq-item {
    background: rgba(255, 255, 255, 0.03); /* Fundo escuro fixo */
    border-radius: 12px;
    overflow: hidden;
    border: 1px solid rgba(255, 255, 255, 0.05); /* Borda bem discreta */
    transition: all 0.3s ease;
}

/* HOVER - Sem fundo branco */
.faq-item:hover {
    /* Mantém o fundo igual, apenas adiciona sombra e movimento */
    box-shadow: 0 10px 30px rgba(0, 0, 0, 0.3);
    transform: translateY(-2px);
    border-color: rgba(255, 255, 255, 0.08);
}

/* PERGUNTA (Estado Inicial) */
.faq-item summary {
    font-weight: 600;
    font-size: 1.1rem;
    padding: 20px 24px;
    cursor: pointer;
    color: var(--branco);
    list-style: none;
    display: flex;
    justify-content: space-between;
    align-items: center;
    transition: color 0.3s ease;
}

/* REMOVE SETA PADRÃO DO NAVEGADOR */
.faq-item summary::-webkit-details-marker {
    display: none;
}

/* ÍCONE (+) */
.faq-item summary::after {
    content: "+";
    font-size: 1.5rem;
    font-weight: 400;
    color: var(--laranja);
    transition: transform 0.3s ease;
    line-height: 1;
}

/* Muda a cor da pergunta no Hover */
.faq-item:hover summary {
    color: var(--laranja); 
}

/* CARD ABERTO */
.faq-item[open] {
    border-left: 4px solid var(--laranja);
    background: rgba(255, 255, 255, 0.03); /* Mantém o fundo escuro original */
}

/* PERGUNTA ABERTA */
.faq-item[open] summary {
    color: var(--laranja);
}

/* ÍCONE ABERTO (-) */
.faq-item[open] summary::after {
    content: "−";
    transform: rotate(180deg);
}

/* RESPOSTA - MAIS BONITA E ELEGANTE */
.faq-item p {
    padding: 20px 24px 24px 24px;
    margin: 0 24px; /* Margem lateral para a linha divisória não encostar nas bordas */
    color: #e2e8f0; /* Um cinza mais claro e iluminado */
    line-height: 1.8; /* Mais espaço entre as linhas para leitura agradável */
    font-size: 1.05rem;
    font-weight: 300; /* Fonte mais elegante/fina */
    letter-spacing: 0.3px; /* Leve espaçamento entre letras */
    border-top: 1px solid rgba(255, 255, 255, 0.08); /* Linha divisória sutil */
    animation: fadeInDown 0.4s ease-out forwards;
}

/* ANIMAÇÃO DA RESPOSTA */
@keyframes fadeInDown {
    from {
        opacity: 0;
        transform: translateY(-5px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

/* MOBILE */
@media (max-width: 768px) {
    .cabecalho-secao h2 {
        font-size: 2rem;
        margin-bottom: 32px;
    }

    .faq-item summary {
        font-size: 1rem;
        padding: 16px 20px;
    }

    .faq-item p {
        padding: 16px 0 20px 0;
        margin: 0 20px;
        font-size: 0.95rem;
    }
}

/* RESPOSTA - AGORA BRANCA E EM NEGRITO */
.faq-item p {
    padding: 20px 24px 24px 24px;
    margin: 0 24px; 
    color: #ffffff; /* <-- Alterado para branco puro */
    line-height: 1.8; 
    font-size: 1.05rem;
    font-weight: bold; /* <-- Alterado para negrito (você também pode usar 700) */
    letter-spacing: 0.3px; 
    border-top: 1px solid rgba(255, 255, 255, 0.08); 
    animation: fadeInDown 0.4s ease-out forwards;
}
/* ================== FOOTER ================== */
.rodape {
    background-color: #0b1836;
    color: #a0aec0;
    padding: 60px 20px 20px;
    border-top: 4px solid var(--laranja);
}

.footer-content {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
    gap: 40px;
    margin-bottom: 40px;
    align-items: start; /* Alinha TODAS colunas no TOPO */
}

.footer-logo {
    display: flex;
    flex-direction: column;
    justify-content: flex-start; /* Logo e texto no topo */
    align-items: flex-start;
}

.footer-logo img {
    max-width: 200px; /* Logo maior */
    width: 100%;
    height: auto;
    margin-bottom: 12px; /* Espaço fixo entre logo e texto */
}

.footer-logo p {
    line-height: 1.2;
    white-space: nowrap; /* Uma linha */
    font-size: 0.95rem;
    max-width: 100%; /* Não quebra container */
}

.rodape h3 {
    color: #fff;
    margin-bottom: 20px;
}

.rodape a,
.rodape p {
    color: #a0aec0;
    text-decoration: none;
    display: block;
    margin-bottom: 10px;
}

.rodape a:hover {
    color: var(--laranja);
}

.footer-bottom {
    text-align: center;
    padding-top: 20px;
    border-top: 1px solid rgba(255,255,255,0.1);
}

/* Links com ícones (já tem funcionando) */
.footer-social a,
.endereco-link,
.email-link,
.telefone-link {
    display: flex !important;
    align-items: center;
    gap: 10px;
}

.social-icon {
    font-size: 20px;
    width: 24px;
    height: 24px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: inherit;
}

/* Grid 4 colunas desktop */
@media (min-width: 992px) {
    .footer-content {
        grid-template-columns: repeat(4, 1fr);
        gap: 30px;
    }
}

/* PUXA LOGO PRA CIMA - alinhamento perfeito */
.footer-logo {
    position: relative;
    top: -40px; /* Puxa 15px pra cima */
    display: flex;
    flex-direction: column;
    align-items: flex-start;
}

.footer-logo img {
    max-width: 200px;
    width: 100%;
    height: auto;
    margin-bottom: 8px; /* Menos espaço entre logo e texto */
}

.footer-logo p {
    line-height: 1.2;
    white-space: nowrap;
    font-size: 0.95rem;
    margin: 0; /* Zero margem extra */
}

/* Garante que TODAS colunas fiquem altura igual */
.footer-content > div {
    display: flex;
    flex-direction: column;
    justify-content: flex-start;
}



/* Mobile empilha */
@media (max-width: 991px) {
    .footer-content {
        grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
        gap: 40px;
    }
    
    .footer-logo p {
        white-space: normal; /* Quebra em mobile */
    }
}


/* Ajusta o grid para 4 colunas em telas grandes */
@media (min-width: 992px) {
    .footer-content {
        grid-template-columns: repeat(4, 1fr); /* 4 colunas iguais */
        gap: 30px;
    }
}

/* Em tablets/mobile, volta para auto-fit (empilha) */
@media (max-width: 991px) {
    .footer-content {
        grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
        gap: 40px;
    }
}
/* Link do endereço com ícone */
.endereco-link {
    display: flex;
    align-items: flex-start; /* Alinha ícone no topo */
    gap: 12px;
    color: #a0aec0;
    text-decoration: none;
    margin-bottom: 12px;
    line-height: 1.4;
}

.endereco-link:hover {
    color: var(--laranja);
}

.endereco-link span {
    flex: 1;
}

/* Ícone do endereço (um pouco maior) */
.endereco-link .social-icon {
    font-size: 22px;
    margin-top: 2px; /* Alinha perfeitamente com o texto */
    color: inherit;
}

/* Logo do footer MAIOR */
.footer-logo img {
    max-width: 200px !important; /* Aumenta de 150px para 200px */
    width: 100%;
    height: auto;
}

/* Frase em UMA LINHA */
.footer-logo p {
    margin-top: 15px;
    line-height: 1.2; /* Espaço menor entre linhas */
    white-space: nowrap; /* FORÇA uma linha só */
    font-size: 0.95rem; /* Fonte um pouco menor pra caber */
    overflow: hidden; /* Esconde texto que vazar */
}


/* ================== RESPONSIVIDADE ================== */
@media (max-width: 992px) {
    .hero-impacto {
        flex-direction: column;
        height: auto;
    }

    .hero-esquerda {
        width: 100%;
        clip-path: none;
        padding: 70px 20px 40px 20px;
    }

    .hero-direita {
        position: relative;
        width: 100%;
        height: 320px;
    }

    .hero-esquerda h1 {
        font-size: 2.6rem;
    }

    .logo-hero {
        max-width: 260px;
    }

    .form-wrapper {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 768px) {
    .card-sci-fi {
        flex-direction: column;
        clip-path: polygon(5% 0, 100% 0, 100% 90%, 95% 100%, 0 100%, 0 10%);
        padding: 30px 20px;
        text-align: center;
    }

    .video-placeholder {
        aspect-ratio: 4 / 3;
    }

    .cabecalho-secao h2 {
        font-size: 2rem;
    }
}


.cabecalho-secao p {
    font-size: 1.2rem;
    color: var(--cinza-medio);
}

.cabecalho-secao strong {
    color: var(--laranja);
    font-weight: 700;
}

/* Grid Container */
.grid-motivos {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
    gap: 30px;
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 20px;
    position: relative;
    z-index: 1;
}

/* Container 3D com animação de entrada */
.container-3d {
    perspective: 1200px;
    opacity: 0;
    transform: translateY(30px);
    transition: opacity 0.8s ease, transform 0.8s ease;
}

.container-3d.mostrar {
    opacity: 1;
    transform: translateY(0);
}

.container-3d:nth-child(1) { transition-delay: 0.1s; }
.container-3d:nth-child(2) { transition-delay: 0.2s; }
.container-3d:nth-child(3) { transition-delay: 0.3s; }
.container-3d:nth-child(4) { transition-delay: 0.4s; }
.container-3d:nth-child(5) { transition-delay: 0.5s; }

/* Card Principal */
.card-sci-fi {
    position: relative;
    width: 100%;
    min-height: 180px;
    padding: 30px 25px;
    display: flex;
    align-items: center;
    gap: 20px;
    background: var(--gradiente-card);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    border: 1px solid rgba(241, 87, 48, 0.2);
    border-radius: 24px;
    box-shadow: 
        0 15px 35px rgba(25, 44, 87, 0.2),
        0 0 0 1px rgba(241, 87, 48, 0.1) inset;
    transform-style: preserve-3d;
    transition: all 0.5s cubic-bezier(0.2, 0.9, 0.3, 1.1);
    cursor: pointer;
    overflow: hidden;
}

.card-sci-fi::before {
    content: '';
    position: absolute;
    top: 0;
    left: -100%;
    width: 100%;
    height: 100%;
    background: linear-gradient(90deg, transparent, rgba(241, 87, 48, 0.1), transparent);
    transition: left 0.7s ease;
}

.card-sci-fi:hover::before {
    left: 100%;
}

.card-sci-fi:hover {
    transform: translateY(-8px) rotateX(2deg);
    border-color: var(--laranja);
    box-shadow: 
        0 20px 40px rgba(25, 44, 87, 0.4),
        0 0 30px rgba(241, 87, 48, 0.3);
}

/* Card Destaque Metodologia */
.card-sci-fi.destaque-metodologia {
    background: linear-gradient(135deg, var(--azul-escuro), #1A1F35);
    border: 2px solid var(--laranja);
    box-shadow: 
        0 15px 35px rgba(241, 87, 48, 0.25),
        0 0 30px rgba(241, 87, 48, 0.2);
}

.card-sci-fi.destaque-metodologia:hover {
    transform: translateY(-10px) rotateX(3deg);
    border-color: var(--laranja);
    box-shadow: 
        0 25px 45px rgba(241, 87, 48, 0.35),
        0 0 40px rgba(241, 87, 48, 0.25);
}

/* Reator Holográfico - SEM ANIMAÇÕES DE GIRO */
.reator-holografico {
    position: relative;
    width: 90px;
    height: 90px;
    display: flex;
    justify-content: center;
    align-items: center;
    flex-shrink: 0;
}

.icone-nucleo {
    font-size: 2.2rem;
    color: var(--cinza-claro);
    z-index: 10;
    filter: drop-shadow(0 0 15px var(--laranja));
    transition: all 0.4s ease;
}

.card-sci-fi:hover .icone-nucleo {
    transform: scale(1.1);
    color: var(--laranja);
    filter: drop-shadow(0 0 25px var(--laranja));
}

/* Anéis estáticos - SEM ANIMAÇÃO */
.anel {
    position: absolute;
    border-radius: 50%;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
}

.anel-1 {
    width: 90px;
    height: 90px;
    border: 2px solid transparent;
    border-top: 3px solid var(--laranja);
    border-right: 3px solid rgba(241, 87, 48, 0.3);
    /* animation removida */
}

.anel-2 {
    width: 70px;
    height: 70px;
    border: 1px solid transparent;
    border-bottom: 2px solid var(--cinza-claro);
    border-left: 2px solid rgba(255, 255, 255, 0.2);
    /* animation removida */
}

.anel-3 {
    width: 50px;
    height: 50px;
    border: 1px solid transparent;
    border-right: 2px solid var(--laranja);
    border-left: 2px solid rgba(241, 87, 48, 0.3);
    /* animation removida */
}

/* Efeito de brilho pulsante suave (opcional - substitui os giros) */
@keyframes pulsar {
    0%, 100% { opacity: 0.6; }
    50% { opacity: 1; }
}

.card-sci-fi:hover .anel-1 {
    animation: pulsar 2s ease-in-out infinite;
}

/* Conteúdo do Card */
.conteudo-holografico {
    flex: 1;
    color: var(--cinza-claro);
}

.conteudo-holografico h3 {
    font-size: 1.5rem;
    font-weight: 600;
    margin-bottom: 8px;
    color: var(--cinza-claro);
    transition: color 0.3s ease;
    line-height: 1.3;
}

.card-sci-fi:hover .conteudo-holografico h3 {
    color: var(--laranja);
}

.conteudo-holografico p {
    font-size: 0.95rem;
    line-height: 1.5;
    opacity: 0.9;
    color: var(--cinza-claro);
    margin: 0;
}

.conteudo-holografico strong {
    color: var(--laranja);
    font-weight: 700;
}

/* Animações removidas - apenas mantive o pulsar opcional no hover */
@keyframes flutuar {
    0%, 100% { transform: translateY(0); }
    50% { transform: translateY(-8px); }
}

/* Responsividade */
@media (max-width: 1024px) {
    .grid-motivos {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 768px) {
    .secao-clara {
        padding: 60px 0;
    }

    .cabecalho-secao h2 {
        font-size: 2rem;
    }

    .cabecalho-secao p {
        font-size: 1.1rem;
        padding: 0 20px;
    }

    .grid-motivos {
        grid-template-columns: 1fr;
        gap: 25px;
        padding: 0 15px;
    }

    .card-sci-fi {
        min-height: 160px;
        padding: 25px 20px;
    }

    .reator-holografico {
        width: 70px;
        height: 70px;
    }

    .icone-nucleo {
        font-size: 1.8rem;
    }

    .anel-1 { width: 70px; height: 70px; }
    .anel-2 { width: 55px; height: 55px; }
    .anel-3 { width: 40px; height: 40px; }

    .conteudo-holografico h3 {
        font-size: 1.3rem;
    }

    .conteudo-holografico p {
        font-size: 0.9rem;
    }
}

@media (max-width: 480px) {
    .card-sci-fi {
        flex-direction: column;
        text-align: center;
        padding: 25px 20px;
    }

    .reator-holografico {
        margin-bottom: 10px;
    }

    .conteudo-holografico h3 {
        font-size: 1.2rem;
    }
}

/* Classe para ativar animação via JavaScript */
.container-3d.mostrar {
    opacity: 1;
    transform: translateY(0);
}

/* Efeito de brilho no hover */
.card-sci-fi::after {
    content: '';
    position: absolute;
    top: -50%;
    left: -50%;
    width: 200%;
    height: 200%;
    background: radial-gradient(circle, rgba(241, 87, 48, 0.1) 0%, transparent 70%);
    opacity: 0;
    transition: opacity 0.5s ease;
    pointer-events: none;
}

.card-sci-fi:hover::after {
    opacity: 1;
}

/* === RESPONSIVO MOBILE PERFEITO === */

/* Tablet */
@media (max-width: 1024px) {
    .grid-motivos {
        grid-template-columns: repeat(2, 1fr);
        gap: 35px;
    }
    
    .card-sci-fi {
        height: 200px;
        padding: 35px 30px;
        gap: 25px;
        overflow: visible !important;
    }
}

/* TODOS MOBILES - TEXTOS GARANTIDOS */
@media (max-width: 768px) {
    .secao-clara {
        padding: 70px 0;
    }
    
    .grid-motivos {
        grid-template-columns: 1fr;
        gap: 30px;
        padding: 0 15px;
        max-width: 500px;
    }
    
    .card-sci-fi {
        height: 180px !important;
        padding: 30px 25px !important;
        gap: 25px !important;
        align-items: center !important;
        overflow: visible !important;
        background: var(--gradiente-card) !important;
        border-radius: 24px !important;
    }
    
    .reator-holografico {
        width: 85px !important;
        height: 85px !important;
        flex-shrink: 0 !important;
        transform: none !important;
    }
    
    .icone-nucleo { 
        font-size: 2.2rem !important; 
        color: var(--cinza-claro) !important;
        filter: drop-shadow(0 0 15px var(--laranja)) !important;
        background: none !important;
        -webkit-text-fill-color: var(--cinza-claro) !important;
    }
    
    .conteudo-holografico {
        flex: 1 !important;
        transform: none !important;
        color: var(--cinza-claro) !important;
        z-index: 30 !important;
        min-width: 0;
        padding: 0 5px;
    }
    
    .conteudo-holografico h3 {
        font-size: 1.45rem !important;
        color: var(--cinza-claro) !important;
        opacity: 1 !important;
        text-shadow: 0 2px 10px rgba(25,44,87,0.9) !important;
        margin-bottom: 8px !important;
        line-height: 1.3 !important;
        transform: none !important;
    }
    
    .conteudo-holografico p {
        font-size: 1rem !important;
        color: var(--cinza-claro) !important;
        opacity: 0.98 !important;
        text-shadow: 0 1px 8px rgba(25,44,87,0.9) !important;
        line-height: 1.45 !important;
    }
    
    .anel-1 { width: 80px !important; height: 80px !important; }
    .anel-2 { width: 65px !important; height: 65px !important; }
    .anel-3 { width: 50px !important; height: 50px !important; }
}

/* Mobile Pequeno */
@media (max-width: 480px) {
    .card-sci-fi {
        height: 170px !important;
        padding: 25px 20px !important;
        gap: 20px !important;
    }
    
    .reator-holografico {
        width: 75px !important;
        height: 75px !important;
    }
    
    .icone-nucleo { font-size: 2rem !important; }
    
    .conteudo-holografico h3 { font-size: 1.35rem !important; }
    .conteudo-holografico p { font-size: 0.98rem !important; }
}

/* Scroll suave */
html {
    scroll-behavior: smooth;
}


/* === RESPONSIVO CORRIGIDO - TEXTOS SEMPRE VISÍVEIS === */

/* Tablet */
@media (max-width: 1024px) {
    .grid-motivos {
        grid-template-columns: repeat(2, 1fr);
        gap: 35px;
        max-width: 1000px;
    }
    
    .card-sci-fi {
        height: 200px;
        padding: 35px 30px;
        gap: 25px;
    }
    
    .conteudo-holografico {
        transform: translateZ(20px);
    }
}

/* Mobile Grande (mantém horizontal) */
@media (max-width: 768px) {
    .secao-clara {
        padding: 70px 0;
    }
    
    .grid-motivos {
        grid-template-columns: 1fr;
        gap: 30px;
        padding: 0 15px;
        max-width: 500px;
    }
    
    .card-sci-fi {
        height: 180px;
        padding: 30px 25px;
        gap: 25px;
        align-items: center;
        overflow: visible !important;
    }
    
    .reator-holografico {
        width: 85px;
        height: 85px;
        transform: translateZ(30px);
    }
    
    .icone-nucleo { font-size: 2.2rem; }
    
    .anel-1 { width: 80px; height: 80px; }
    .anel-2 { width: 65px; height: 65px; }
    .anel-3 { width: 50px; height: 50px; }
    
    .conteudo-holografico {
        flex: 1;
        transform: translateZ(20px) !important;
        color: var(--cinza-claro) !important;
        min-width: 0;
        padding-right: 10px;
    }
    
    .conteudo-holografico h3 {
        font-size: 1.4rem !important;
        color: var(--cinza-claro) !important;
        opacity: 1 !important;
        text-shadow: 0 1px 5px rgba(25,44,87,0.8) !important;
        margin-bottom: 5px;
        max-width: none;
    }
    
    .conteudo-holografico p {
        font-size: 1rem !important;
        color: var(--cinza-claro) !important;
        opacity: 0.95 !important;
        text-shadow: 0 1px 5px rgba(25,44,87,0.7) !important;
        line-height: 1.4;
        max-width: none;
        margin: 0 !important;
    }
}

/* Mobile Pequeno (vertical apenas se necessário) */
@media (max-width: 480px) {
    .card-sci-fi {
        flex-direction: row !important; /* Mantém horizontal sempre */
        height: 170px;
        padding: 25px 20px;
        gap: 20px;
        text-align: left;
        overflow: visible !important;
    }
    
    .reator-holografico {
        width: 70px;
        height: 70px;
        transform: translateZ(20px);
        flex-shrink: 0;
    }
    
    .icone-nucleo { font-size: 1.9rem; }
    
    .conteudo-holografico {
        flex: 1;
        transform: translateZ(10px) !important;
        padding-left: 5px;
    }
    
    .conteudo-holografico h3 { 
        font-size: 1.3rem !important;
        margin-bottom: 3px;
    }
    
    .conteudo-holografico p { 
        font-size: 0.95rem !important;
    }
}

/* Garantia extra para textos sempre visíveis */
@media (max-width: 768px) {
    .conteudo-holografico,
    .conteudo-holografico h3,
    .conteudo-holografico p {
        position: relative !important;
        z-index: 20 !important;
        color: var(--cinza-claro) !important;
        opacity: 1 !important;
        visibility: visible !important;
        transform: none !important;
        text-shadow: 0 1px 8px rgba(25,44,87,0.9) !important;
        background: none !important;
        -webkit-text-fill-color: var(--cinza-claro) !important;
    }
    
    .card-sci-fi {
        background: var(--gradiente-card) !important;
        overflow: visible !important;
    }
}

/* Scroll suave */
html {
    scroll-behavior: smooth;
}

/* ================== FORMULÁRIO DE CAPTURA ================== */
/* ================== ALERTAS DE FORMULÁRIO (SUCESSO/ERRO) ================== */
.alerta-sucesso, .alerta-erro {
    padding: 16px 20px;
    border-radius: 8px;
    margin-bottom: 24px; /* Dá um respiro antes do primeiro campo do form */
    text-align: center;
    font-weight: 600;
    font-size: 0.95rem;
    animation: fadeInDown 0.4s ease-out;
    color: var(--branco);
}

.alerta-sucesso {
    background-color: rgba(255, 255, 255, 0.05); /* Fundo escuro sutil combinando com o site */
    border-left: 4px solid var(--laranja); /* Detalhe laranja da identidade */
    border-right: 1px solid rgba(255, 255, 255, 0.05);
    border-top: 1px solid rgba(255, 255, 255, 0.05);
    border-bottom: 1px solid rgba(255, 255, 255, 0.05);
}

.alerta-erro {
    background-color: rgba(220, 38, 38, 0.1); 
    border-left: 4px solid #dc2626; /* Vermelho padrão para erros */
}

/* Animação suave para a mensagem aparecer */
@keyframes fadeInDown {
    from {
        opacity: 0;
        transform: translateY(-10px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}



.secao-formulario {
    background: radial-gradient(circle at top left, #ffffff 0, #e5e7eb 40%, #cbd5f5 100%);
    padding: 90px 0;
}

.form-wrapper {
    max-width: 1100px;
    margin: 0 auto;
    display: grid;
    grid-template-columns: minmax(0, 1.2fr) minmax(0, 1fr);
    gap: 40px;
    align-items: center;
}

/* Bloco de texto ao lado do form */
.form-info h2 {
    font-size: 2.3rem;
    color: var(--azul-escuro);
    margin-bottom: 15px;
}

.form-info p {
    font-size: 1rem;
    color: #4b5563;
    line-height: 1.6;
    margin-bottom: 20px;
    
    /* Novas regras para a borda lateral */
    border-left: 3px solid var(--laranja);
    padding-left: 15px;
}

.form-badges {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-top: 10px;
}

.badge {
    background-color: #fff;
    color: var(--azul-escuro);
    border-radius: 999px;
    padding: 6px 14px;
    font-size: 0.8rem;
    font-weight: 600;
    box-shadow: 0 8px 18px rgba(15, 23, 42, 0.1);
}

/* Card do form */
.form-card {
    background: rgba(255,255,255,0.9);
    border-radius: 20px;
    padding: 30px 28px;
    box-shadow:
        0 24px 60px rgba(15, 23, 42, 0.18),
        0 0 0 1px rgba(148, 163, 184, 0.25);
    backdrop-filter: blur(16px);
    border: 1px solid rgba(255,255,255,0.8);
}

.form-card h3 {
    font-size: 1.4rem;
    color: var(--azul-escuro);
    margin-bottom: 8px;
}

.form-card p {
    font-size: 0.95rem;
    color: #6b7280;
    margin-bottom: 20px;
}

/* Form */
.form-captura {
    display: grid;
    grid-template-columns: 1fr;
    gap: 14px;
}

.input-group {
    display: flex;
    flex-direction: column;
    gap: 6px;
}

.input-group label {
    font-size: 0.9rem;
    font-weight: 600;
    color: #374151;
}

.input-group small {
    font-size: 0.75rem;
    color: #9ca3af;
}
/* Inputs e select (Visual padrão para ambos) */
.input-group input,
.select-field {
    width: 100%;
    padding: 13px 14px;
    border: 1px solid #d1d5db;
    border-radius: 10px;
    font-size: 0.95rem;
    background-color: #f9fafb;
    color: #111827;
    transition: border-color 0.15s ease, box-shadow 0.15s ease, background-color 0.15s ease, transform 0.05s ease;
}

/* Coloca a setinha APENAS no campo de Faturamento (Select) */
.select-field {
    appearance: none;
    -webkit-appearance: none;
    background-image: url('data:image/svg+xml;charset=US-ASCII,<svg%20xmlns="http://www.w3.org/2000/svg"%20width="24"%20height="24"%20viewBox="0%200%2024%2024"><path%20fill="%23192C57"%20d="M7%2010l5%205%205-5z"/></svg>');
    background-repeat: no-repeat;
    background-position: right 14px center;
    background-size: 18px;
    padding-right: 35px; /* Evita que o texto encoste na setinha */
}

.input-group input::placeholder {
    color: #9ca3af;
}

.input-group input:focus,
.select-field:focus {
    border-color: var(--laranja);
    background-color: #fff;
    outline: none;
    box-shadow: 0 0 0 3px rgba(241, 87, 48, 0.16);
    transform: translateY(-1px);
}


}

.input-group input::placeholder {
    color: #9ca3af;
}

.input-group input:focus,
.select-field:focus {
    border-color: var(--laranja);
    background-color: #fff;
    outline: none;
    box-shadow: 0 0 0 3px rgba(241, 87, 48, 0.16);
    transform: translateY(-1px);
}

/* Botão do form */
.form-captura button {
    width: 100%;
    margin-top: 8px;
}

/* ================== RELATOS E VÍDEO ================== */

/* ================== SEÇÃO TEXTO (ESQUERDA) + VÍDEO (DIREITA) ================== */

.sobre-nos-clean {
    background-color: var(--azul-escuro-profundo); 
    padding: 140px 5%; /* Aumentamos o respiro vertical (de 100px para 140px) para dar mais presença */
    width: 100%;
    color: var(--texto-branco);
}

/* O container que segura os dois lados */
.sobre-container {
    max-width: 1400px; /* Aumentamos de 1200px para 1400px para preencher monitores grandes */
    margin: 0 auto; 
    display: flex; 
    align-items: center; 
    justify-content: space-between; 
    gap: 80px; /* Mais espaço entre o texto e o vídeo (de 60px para 80px) */
}

/* --- Lado Esquerdo: Textos --- */
.sobre-textos {
    flex: 1; 
    max-width: 650px; /* Permite que o texto se espalhe mais (era 500px) */
}

.sobre-textos h2 {
    font-size: 3.8rem; /* Título gigante e impactante (era 3rem) */
    line-height: 1.1; 
    font-weight: 800;
    margin-bottom: 35px; /* Mais espaço pro parágrafo */
}

.sobre-textos .destaque-laranja {
    color: var(--laranja);
}

.sobre-textos p {
    font-size: 1.35rem; /* Letra maior para leitura super confortável (era 1.15rem) */
    color: #e5e7eb; 
    line-height: 1.7;
    border-left: 4px solid var(--laranja); /* Borda um pouco mais grossa para acompanhar o tamanho */
    padding-left: 25px;
}

/* --- Lado Direito: Vídeo --- */
.sobre-video {
    flex: 1; 
    display: flex;
    justify-content: flex-end; 
}

.video-wrapper {
    width: 100%;
    max-width: 750px; /* O vídeo agora fica bem maior na tela do PC (era 600px) */
    border-radius: 16px; 
    overflow: hidden; 
    box-shadow: 0 25px 50px rgba(0, 0, 0, 0.5); /* Sombra mais espalhada por ser maior */
    
    border: 2px solid var(--laranja); 
    aspect-ratio: 16 / 9; 
    background-color: #000;
}

.video-wrapper video {
    width: 100%;
    height: 100%;
    object-fit: cover; 
    display: block;
}

/* ================== RESPONSIVIDADE MOBILE E TABLET ================== */
@media (max-width: 1100px) {
    /* Ajuste extra para tablets e notebooks pequenos */
    .sobre-textos h2 { font-size: 3rem; }
    .sobre-textos p { font-size: 1.15rem; }
}

@media (max-width: 992px) {
    .sobre-container {
        flex-direction: column; 
        text-align: center; 
        gap: 60px;
    }
    .sobre-textos { max-width: 100%; }
    .sobre-textos p {
        border-left: none;
        padding-left: 0;
    }
    .sobre-video {
        justify-content: center; 
        width: 100%;
    }
}

@media (max-width: 768px) {
    .sobre-textos h2 { font-size: 2.2rem; }
}
/* ================== O QUE FAZEMOS (SERVIÇOS) ================== */
.grid-servicos {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
    gap: clamp(28px, 5vw, 40px);
    max-width: 1200px;
    margin: 0 auto;
}

.card-servico {
    position: relative;
    background: linear-gradient(145deg, 
        rgba(255,255,255,0.12) 0%, 
        rgba(15,23,42,0.7) 50%, 
        rgba(25,44,87,0.9) 100%);
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
    padding: clamp(28px, 5vw, 36px) clamp(24px, 4vw, 32px);
    border-radius: clamp(18px, 2.5vw, 24px);
    border: 1px solid rgba(241,87,48,0.2);
    text-align: left;
    box-shadow: 
        0 clamp(15px, 3vw, 20px) clamp(35px, 6vw, 50px) rgba(15,23,42,0.6),
        inset 0 1px 0 rgba(255,255,255,0.1),
        0 0 clamp(0px, 0vw, 0px) rgba(241,87,48,0.1);
    transition: all 0.4s cubic-bezier(0.25, 0.46, 0.45, 0.94);
    overflow: hidden;
}

.card-servico::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 3px;
    background: linear-gradient(90deg, transparent, var(--laranja), transparent);
    transform: scaleX(0);
    transition: transform 0.6s ease-out;
}

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

.card-servico:hover {
    transform: translateY(-8px) scale(1.02);
    border-color: rgba(241,87,48,0.4);
    box-shadow: 
        0 clamp(25px, 4vw, 35px) clamp(55px, 8vw, 80px) rgba(15,23,42,0.8),
        inset 0 1px 0 rgba(255,255,255,0.2),
        0 0 clamp(20px, 3vw, 30px) rgba(241,87,48,0.25);
}

.card-servico h3 {
    font-size: clamp(1.35rem, 3.5vw, 1.55rem);
    margin-bottom: clamp(12px, 2vw, 16px);
    color: #ffffff !important;
    font-weight: 700;
    line-height: 1.3;
    letter-spacing: -0.02em;
    position: relative;
    z-index: 2;
}

.card-servico h3::before {
    content: '';
    position: absolute;
    bottom: -6px;
    left: 0;
    width: 40px;
    height: 3px;
    background: var(--laranja);
    border-radius: 2px;
    transition: width 0.4s ease;
}

.card-servico:hover h3::before {
    width: 60px;
}

.card-servico p {
    color: #f8fafc !important;
    line-height: 1.65;
    font-size: clamp(0.95rem, 2.2vw, 1.05rem);
    margin: 0;
    text-shadow: 0 1px 4px rgba(15,23,42,0.8);
    z-index: 2;
    position: relative;
}

/* Destaque especial para o último card se necessário */
.card-servico:nth-child(3) {
    background: linear-gradient(145deg, 
        rgba(241,87,48,0.15) 0%, 
        rgba(15,23,42,0.75) 50%, 
        rgba(25,44,87,0.95) 100%);
    border-color: rgba(241,87,48,0.35);
}

/* Responsivo Extra */
@media (max-width: 768px) {
    .grid-servicos {
        grid-template-columns: 1fr;
        gap: 24px;
        padding: 0 8px;
    }
    
    .card-servico {
        padding: 28px 24px;
        text-align: center;
    }
    
    .card-servico h3 {
        font-size: 1.45rem;
        margin-bottom: 12px;
    }
    
    .card-servico p {
        font-size: 1rem;
        line-height: 1.6;
    }
}


/* ================== FAQ ================== */
/* ================== FAQ ================== */
:root {
    --azul-escuro-profundo: #0A1C44;
    --azul-escuro: #142a5c;
    --azul-cinza: #3b82f6;
    --cinza-texto: #cbd5e1;
    --branco: #ffffff;
    --laranja: #f97316;
}

/* SEÇÃO FAQ */
#faq {
    background-color: var(--azul-escuro-profundo);
    padding: 80px 20px;
    color: var(--branco);
}

.container {
    max-width: 1200px;
    margin: 0 auto;
}

/* TÍTULO */
.cabecalho-secao h2 {
    font-size: 2.5rem;
    text-align: center;
    margin-bottom: 48px;
    color: var(--branco);
    font-weight: 700;
}

.destaque-laranja {
    color: var(--laranja);
}

/* CONTAINER */
.faq-container {
    max-width: 800px;
    margin: 0 auto;
    display: flex;
    flex-direction: column;
    gap: 16px;
}

/* CARD DO ITEM (Estado Inicial) */
.faq-item {
    background: rgba(255, 255, 255, 0.03); /* Fundo sutil e escuro */
    border-radius: 12px;
    overflow: hidden;
    border: 1px solid rgba(255, 255, 255, 0.08);
    transition: all 0.3s ease;
}

/* INTERAÇÃO DO CARD AO PASSAR O MOUSE (Hover) */
.faq-item:hover {
    /* REMOVI: background: rgba(255, 255, 255, 0.06); que causava o problema */
    /* Mantenho o fundo escuro do card e adiciono apenas a sombra e movimento */
    border-color: rgba(255, 255, 255, 0.15);
    box-shadow: 0 10px 30px rgba(0, 0, 0, 0.2);
    transform: translateY(-2px);
}

/* PERGUNTA (Estado Inicial) */
.faq-item summary {
    font-weight: 600;
    font-size: 1.1rem;
    padding: 20px 24px;
    cursor: pointer;
    color: var(--branco);
    list-style: none;
    display: flex;
    justify-content: space-between;
    align-items: center;
    transition: color 0.3s ease; /* Adicionado para suavizar a troca de cor do texto */
}

/* REMOVE SETA PADRÃO DO NAVEGADOR */
.faq-item summary::-webkit-details-marker {
    display: none;
}

/* ÍCONE (+) */
.faq-item summary::after {
    content: "+";
    font-size: 1.5rem;
    font-weight: 400;
    color: var(--laranja);
    transition: transform 0.3s ease;
    line-height: 1;
}

/* NOVA REGRA: Mudar cor da pergunta no Hover do Card */
.faq-item:hover summary {
    color: var(--laranja); /* O texto agora fica laranja para máximo contraste */
}

/* CARD ABERTO */
.faq-item[open] {
    border-left: 4px solid var(--laranja);
    background: rgba(255, 255, 255, 0.05);
    border-color: rgba(255, 255, 255, 0.1);
}

/* PERGUNTA ABERTA (Destaca o texto) */
.faq-item[open] summary {
    color: var(--laranja);
    padding-bottom: 12px;
}

/* ÍCONE ABERTO (Gira o ícone e transforma em menos) */
.faq-item[open] summary::after {
    content: "−";
    transform: rotate(180deg);
}

/* RESPOSTA */
.faq-item p {
    padding: 0 24px 24px;
    margin: 0;
    color: var(--cinza-texto);
    line-height: 1.7;
    font-size: 1rem;
    animation: fadeInDown 0.4s ease-out forwards;
}

/* ANIMAÇÃO DA RESPOSTA */
@keyframes fadeInDown {
    from {
        opacity: 0;
        transform: translateY(-8px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

/* MOBILE */
@media (max-width: 768px) {
    .cabecalho-secao h2 {
        font-size: 2rem;
        margin-bottom: 32px;
    }

    .faq-item summary {
        font-size: 1rem;
        padding: 16px 20px;
    }

    .faq-item p {
        padding: 0 20px 20px;
        font-size: 0.95rem;
    }
}
/* ================== FOOTER ================== */
.rodape {
    background-color: #0b1836;
    color: #a0aec0;
    padding: 60px 20px 20px;
    border-top: 4px solid var(--laranja);
}

.footer-content {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
    gap: 40px;
    margin-bottom: 40px;
    align-items: start; /* Alinha TODAS colunas no TOPO */
}

.footer-logo {
    display: flex;
    flex-direction: column;
    justify-content: flex-start; /* Logo e texto no topo */
    align-items: flex-start;
}

.footer-logo img {
    max-width: 200px; /* Logo maior */
    width: 100%;
    height: auto;
    margin-bottom: 12px; /* Espaço fixo entre logo e texto */
}

.footer-logo p {
    line-height: 1.2;
    white-space: nowrap; /* Uma linha */
    font-size: 0.95rem;
    max-width: 100%; /* Não quebra container */
}

.rodape h3 {
    color: #fff;
    margin-bottom: 20px;
}

.rodape a,
.rodape p {
    color: #a0aec0;
    text-decoration: none;
    display: block;
    margin-bottom: 10px;
}

.rodape a:hover {
    color: var(--laranja);
}

.footer-bottom {
    text-align: center;
    padding-top: 20px;
    border-top: 1px solid rgba(255,255,255,0.1);
}

/* Links com ícones (já tem funcionando) */
.footer-social a,
.endereco-link,
.email-link,
.telefone-link {
    display: flex !important;
    align-items: center;
    gap: 10px;
}

.social-icon {
    font-size: 20px;
    width: 24px;
    height: 24px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: inherit;
}

/* Grid 4 colunas desktop */
@media (min-width: 992px) {
    .footer-content {
        grid-template-columns: repeat(4, 1fr);
        gap: 30px;
    }
}

/* PUXA LOGO PRA CIMA - alinhamento perfeito */
.footer-logo {
    position: relative;
    top: -40px; /* Puxa 15px pra cima */
    display: flex;
    flex-direction: column;
    align-items: flex-start;
}

.footer-logo img {
    max-width: 200px;
    width: 100%;
    height: auto;
    margin-bottom: 8px; /* Menos espaço entre logo e texto */
}

.footer-logo p {
    line-height: 1.2;
    white-space: nowrap;
    font-size: 0.95rem;
    margin: 0; /* Zero margem extra */
}

/* Garante que TODAS colunas fiquem altura igual */
.footer-content > div {
    display: flex;
    flex-direction: column;
    justify-content: flex-start;
}



/* Mobile empilha */
@media (max-width: 991px) {
    .footer-content {
        grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
        gap: 40px;
    }
    
    .footer-logo p {
        white-space: normal; /* Quebra em mobile */
    }
}


/* Ajusta o grid para 4 colunas em telas grandes */
@media (min-width: 992px) {
    .footer-content {
        grid-template-columns: repeat(4, 1fr); /* 4 colunas iguais */
        gap: 30px;
    }
}

/* Em tablets/mobile, volta para auto-fit (empilha) */
@media (max-width: 991px) {
    .footer-content {
        grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
        gap: 40px;
    }
}
/* Link do endereço com ícone */
.endereco-link {
    display: flex;
    align-items: flex-start; /* Alinha ícone no topo */
    gap: 12px;
    color: #a0aec0;
    text-decoration: none;
    margin-bottom: 12px;
    line-height: 1.4;
}

.endereco-link:hover {
    color: var(--laranja);
}

.endereco-link span {
    flex: 1;
}

/* Ícone do endereço (um pouco maior) */
.endereco-link .social-icon {
    font-size: 22px;
    margin-top: 2px; /* Alinha perfeitamente com o texto */
    color: inherit;
}

/* Logo do footer MAIOR */
.footer-logo img {
    max-width: 200px !important; /* Aumenta de 150px para 200px */
    width: 100%;
    height: auto;
}

/* Frase em UMA LINHA */
.footer-logo p {
    margin-top: 15px;
    line-height: 1.2; /* Espaço menor entre linhas */
    white-space: nowrap; /* FORÇA uma linha só */
    font-size: 0.95rem; /* Fonte um pouco menor pra caber */
    overflow: hidden; /* Esconde texto que vazar */
}


/* ================== RESPONSIVIDADE ================== */
@media (max-width: 992px) {
    .hero-impacto {
        flex-direction: column;
        height: auto;
    }

    .hero-esquerda {
        width: 100%;
        clip-path: none;
        padding: 70px 20px 40px 20px;
    }

    .hero-direita {
        position: relative;
        width: 100%;
        height: 320px;
    }

    .hero-esquerda h1 {
        font-size: 2.6rem;
    }

    .logo-hero {
        max-width: 260px;
    }

    .form-wrapper {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 768px) {
    .card-sci-fi {
        flex-direction: column;
        clip-path: polygon(5% 0, 100% 0, 100% 90%, 95% 100%, 0 100%, 0 10%);
        padding: 30px 20px;
        text-align: center;
    }

    .video-placeholder {
        aspect-ratio: 4 / 3;
    }

    .cabecalho-secao h2 {
        font-size: 2rem;
    }
}

/* --- FORÇA A REMOÇÃO DA SETA NOS INPUTS DE TEXTO --- */
/* Isso anula qualquer regra de códigos antigos duplicados no arquivo */
.input-group input {
    background-image: none !important;
}


/* --- CORREÇÃO DO TEXTO DO RODAPÉ (NÃO CORTAR NO CELULAR) --- */
.footer-logo p {
    white-space: normal !important; /* Permite que o texto quebre para a linha de baixo */
    overflow: visible !important; /* Evita que a ponta do texto seja apagada */
    line-height: 1.4 !important; /* Dá um respiro entre as linhas caso quebre */
}

/* Centraliza o texto e a logo no celular para ficar mais bonito */
@media (max-width: 768px) {
    .footer-logo {
        align-items: center;
        text-align: center;
    }
}
