@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600&family=Space+Grotesk:wght@500;700&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Montserrat:ital,wght@0,100..900;1,100..900&display=swap');

:root {
    --p-purple: #4b3b70;
    --p-purple-deep: #1e1a27;
    --s-teal: #42b6a4;
    --ink: #31264a;
    --bg-light: #F8F8FA;
    --white: #FFFFFF;
    --container-max: width: 100%;
}

/* Reset Global */
* { margin: 0; padding: 0; box-sizing: border-box; cursor: default; }
a, a * { cursor: pointer; }
body { 
    background-color: var(--white); 
    color: var(--ink); 
    font-family: 'Montserrat', sans-serif; 
    line-height: 1.6; 
    font-size: 1.2rem;
    font-style: normal;
    letter-spacing: -.5px;
    -webkit-font-smoothing: antialiased;
}

/* Texture Pattern */
.dot-pattern { 
    background-image: radial-gradient(rgba(75, 59, 112, 0.12) 1px, transparent 1px); 
    background-size: 32px 32px; 
}

.container { max-width: var(--container-max); margin: 0 auto; padding: 0 40px; }
.section { padding: 100px 0; position: relative; }

/* Tipografia Editorial */
h1 { font-family: 'Montserrat', sans-serif; font-size: clamp(3.2rem, 5.5vw, 5.5rem); line-height: 0.95; letter-spacing: -0.06em; font-weight: 700; }
h2 { font-family: 'Montserrat', sans-serif; font-size: clamp(2.4rem, 4vw, 3.5rem); line-height: 1.05; font-weight: 700; color: var(--p-purple); }
h3 { font-family: 'Montserrat', sans-serif; font-size: 1.8rem; font-weight: 700; margin-bottom: 20px; }

/* Header Elite */
.header { height: 100px; display: flex; justify-content: space-between; align-items: center; }
.header nav { display: flex; gap: 40px; font-weight: 600; font-size: 14px; text-transform: uppercase; letter-spacing: 1.5px; }

/* Buttons & CTAs */
.btn { 
    font-family: "Montserrat", sans-serif; cursor: pointer; text-transform: uppercase;
    display: inline-flex; align-items: center; height: 58px; padding: 0 32px; 
    border-radius: 8px; font-weight: 600; text-decoration: none; 
    transition: all 0.3s cubic-bezier(0.16, 1, 0.3, 1); font-size: 12px; border: 1.5px solid transparent;
}
.btn-p { background: var(--s-teal); color: var(--ink); }
.btn-p:hover { transform: translateY(-3px); box-shadow: 0 15px 40px rgba(66, 182, 164, 0.4); }

.btn-s { border-color: rgba(255,255,255,0.2); color: white; background: rgba(255,255,255,0.05); backdrop-filter: blur(10px); }
.btn-s:hover { background: white; color: var(--ink); }

/* Cards Tech */
.card { 
    background: var(--white); border: 1px solid rgba(0,0,0,0.05); 
    border-radius: 24px; padding: 48px; transition: all 0.4s ease;
    box-shadow: 0 10px 30px rgba(0,0,0,0.03);
}
.card:hover { transform: translateY(-8px); border-color: var(--s-teal); box-shadow: 0 40px 80px rgba(75, 59, 112, 0.08); }

.bullet-list { list-style: none; margin-top: 24px; }
.bullet-list li { position: relative; padding-left: 32px; margin-bottom: 16px; font-size: 1.05rem; color: #4A4E57; }
.bullet-list li::before { 
    content: ""; position: absolute; left: 0; top: 12px; width: 14px; height: 1px; 
    background: var(--s-teal); box-shadow: 0 0 10px var(--s-teal);
}

/* O NOVO COMPONENTE DE AUDITORIA (Substituindo o roxo infantil) */
.audit-ready-bar {
    margin-top: 60px;
    background: rgba(255, 255, 255, 0.03);
    border: 1px solid rgba(255, 255, 255, 0.1);
    padding: 32px 48px;
    border-radius: 16px;
    display: flex;
    justify-content: space-between;
    align-items: center;
    backdrop-filter: blur(10px);
}
.audit-ready-bar .status-info { display: flex; align-items: center; gap: 20px; }
.audit-ready-bar .status-indicator { width: 12px; height: 12px; border-radius: 50%; background: var(--s-teal); box-shadow: 0 0 15px var(--s-teal); }
.audit-ready-bar h4 { font-family: 'Montserrat'; font-size: 1.4rem; color: white; }
.audit-ready-bar p { font-size: 0.95rem; color: rgba(255,255,255,0.5); margin: 0; }

.cta-ghost {
    color: white; font-weight: 700; text-decoration: none; font-size: 0.9rem;
    text-transform: uppercase; letter-spacing: 2px; display: flex; align-items: center; gap: 8px;
    padding: 12px 24px; border: 1px solid rgba(255,255,255,0.2); border-radius: 4px; transition: 0.3s;
}
.cta-ghost:hover { background: white; color: var(--ink); border-color: white; }

/* Dark Sections */
.bg-dark-tech { background: #050505; color: white; background-image: radial-gradient(circle at 50% 50%, #161221 0%, #050505 100%); }
.bg-dark-tech h2, .bg-dark-tech h3 { color: white; }
.bg-dark-tech .card { background: rgba(255,255,255,0.02); border: 1px solid rgba(255,255,255,0.08); }



/* Reutilizando as bases anteriores e adicionando especificidades de Soluções */

.solutions-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 32px;
    margin-top: 60px;
}

.persona-section {
    border-radius: 40px;
    padding: 80px;
    margin-bottom: 40px;
    transition: all 0.4s ease;
}

/* Tints sutilíssimos para não infantilizar, apenas para criar "clima" de separação */
.bg-legal { background-color: #F6F5F9; border: 1px solid rgba(75, 59, 112, 0.05); }
.bg-sesmt { background-color: #FFFFFF; border: 1px solid var(--border-ui); }
.bg-rh { background-color: #F2F8F7; border: 1px solid rgba(66, 182, 164, 0.05); }

.component-tag {
    background: white;
    border: 1px solid var(--border-ui);
    padding: 24px;
    border-radius: 16px;
    display: flex;
    flex-direction: column;
    gap: 12px;
    transition: 0.3s;
}
.component-tag:hover {
    border-color: var(--s-teal);
    transform: scale(1.02);
}

.feature-icon-box {
    width: 48px;
    height: 48px;
    background: var(--p-purple-soft);
    border-radius: 12px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--p-purple);
    font-weight: 700;
    margin-bottom: 20px;
}

/* Específicos para a página SOBRE */
.mission-box {
    border-left: 4px solid var(--s-teal);
    padding: 40px 60px;
    background: var(--bg-soft-teal);
    border-radius: 0 32px 32px 0;
    margin-top: 40px;
}

.team-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 40px;
    margin-top: 80px;
}

.profile-card {
    background: var(--white);
    border: 1px solid var(--border-ui);
    padding: 50px;
    border-radius: 32px;
    display: flex;
    flex-direction: column;
    gap: 24px;
    transition: 0.4s var(--ease);
}
.profile-card:hover {
    border-color: var(--p-purple);
    box-shadow: var(--shadow-float);
}

.profile-card h3 { margin-bottom: 5px; }
.profile-card .role {
    font-size: 14px;
    font-weight: 800;
    color: var(--s-teal);
    text-transform: uppercase;
    letter-spacing: 2px;
}

.principle-item {
    padding: 40px;
    border-bottom: 1px solid rgba(255,255,255,0.1);
    display: grid;
    grid-template-columns: 0.4fr 1fr 1.5fr;
    gap: 40px;
    align-items: center;
}
.principle-item:last-child { border-bottom: none; }


/* --- UI DE ALTO NÍVEL PARA CONTATO --- */

.contact-layout {
    display: grid;
    grid-template-columns: 1.2fr 0.8fr; /* Proporção mais elegante */
    gap: 60px;
    align-items: start;
}

.form-surface {
    background: var(--white);
    border: 1px solid var(--border-ui);
    padding: 64px;
    border-radius: 32px;
    box-shadow: 0 10px 40px rgba(0,0,0,0.02);
}

/* Sidebar Técnica unificada */
.contact-sidebar {
    background: var(--p-purple-deep);
    border-radius: 32px;
    padding: 48px;
    color: white;
    position: relative;
    overflow: hidden;
    border: 1px solid rgba(255,255,255,0.05);
}

.sidebar-module {
    padding-bottom: 40px;
    margin-bottom: 40px;
    border-bottom: 1px solid rgba(255,255,255,0.1);
    position: relative;
    z-index: 2;
}

.sidebar-module:last-child {
    border-bottom: none;
    margin-bottom: 0;
    padding-bottom: 0;
}

.eval-step {
    display: flex;
    gap: 16px;
    margin-bottom: 24px;
}

.step-marker {
    width: 24px;
    height: 24px;
    background: var(--s-teal);
    color: var(--ink);
    border-radius: 6px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 12px;
    font-weight: 800;
    flex-shrink: 0;
}

.channel-card {
    background: rgba(255,255,255,0.03);
    border: 1px solid rgba(255,255,255,0.08);
    padding: 24px;
    border-radius: 16px;
    margin-bottom: 16px;
    transition: 0.3s;
}

.channel-card:hover {
    background: rgba(255,255,255,0.06);
    border-color: var(--s-teal);
}

.channel-label {
    font-size: 10px;
    font-weight: 800;
    color: var(--s-teal);
    letter-spacing: 2px;
    text-transform: uppercase;
    margin-bottom: 8px;
    display: block;
}

.channel-value {
    font-family: 'Montserrat';
    font-size: 1.1rem;
    font-weight: 600;
    color: white;
}


/* --- ESTILIZAÇÃO DOS CAMPOS DO FORMULÁRIO (O QUE ESTAVA FALTANDO) --- */

.form-group { 
    margin-bottom: 24px; 
}

.form-label { 
    display: block; 
    font-size: 13px; 
    font-weight: 800; 
    text-transform: uppercase; 
    letter-spacing: 1px; 
    margin-bottom: 10px;
    color: var(--p-purple); /* Usa o roxo da sua marca */
}

.form-input, .form-select, .form-textarea {
    width: 100%;
    padding: 16px 20px;
    border-radius: 10px;
    border: 1.5px solid #E5E4E9;
    font-family: 'Montserrat', sans-serif;
    font-size: 15px;
    transition: 0.3s;
    background: #F9FAFB;
    color: var(--ink);
}

/* Efeito quando o usuário clica no campo */
.form-input:focus, .form-select:focus, .form-textarea:focus {
    outline: none;
    border-color: var(--s-teal); /* Borda fica verde Tiffany */
    background: white;
    box-shadow: 0 0 0 4px rgba(66, 182, 164, 0.1); /* Brilho verde sutil */
}

.form-textarea {
    resize: vertical; /* Permite aumentar a altura, mas não a largura */
    min-height: 120px;
}

/* Ajuste para o grid do formulário no mobile */
@media (max-width: 768px) {
    .contact-layout {
        grid-template-columns: 1fr; /* Empilha o formulário e a lateral no celular */
    }
    .form-surface {
        padding: 32px; /* Reduz o respiro interno no celular */
    }
}

/* Estilização básica para o FAQ que também estava incompleta */
.faq-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 40px;
    margin-top: 80px;
}
@media (max-width: 768px) {
    .faq-grid { grid-template-columns: 1fr; }
}
.faq-item {
    padding-bottom: 30px;
    border-bottom: 1px solid rgba(0,0,0,0.05);
}


/* --- AJUSTE PREMIUM DO BOTÃO DE ENVIO --- */

.form-surface .btn-p {
    display: flex;             /* Ativa o modo flex */
    justify-content: center;    /* Centraliza o texto horizontalmente */
    align-items: center;        /* Centraliza o texto verticalmente */
    width: 100%;                /* Ocupa a largura toda do card */
    height: 64px;               /* Altura um pouco maior para dar mais peso */
    padding: 0;                 /* Remove paddings laterais para não espremer o texto */
    font-size: 1.1rem;          /* Tamanho ideal para leitura rápida */
    font-weight: 700;           /* Texto bem negrito (Enterprise Style) */
    letter-spacing: -0.01em;    /* Ajuste fino de tipografia */
    text-align: center;         /* Garante que o texto não alinhe à esquerda */
    border: none;               /* Remove bordas residuais */
    cursor: pointer;
    
    /* Cores do seu branding */
    background-color: var(--s-teal);
    color: var(--ink); 
    
    /* Sombra técnica (Glow sutil) */
    box-shadow: 0 10px 25px rgba(66, 182, 164, 0.2);
    transition: all 0.4s cubic-bezier(0.16, 1, 0.3, 1);
}

.form-surface .btn-p:hover {
    transform: translateY(-4px); /* Levanta o botão ao passar o mouse */
    box-shadow: 0 20px 40px rgba(66, 182, 164, 0.35);
    background-color: #3bbfa8;   /* Um verde levemente mais vibrante no hover */
}

.form-surface .btn-p:active {
    transform: translateY(-1px); /* Efeito de clique físico */
}


/* --- FIX PARA O NAV NÃO SE MEXER --- */

.header nav {
    display: flex;
    gap: 40px;
    align-items: center;
    /* Força o menu a ter uma posição estável */
    justify-content: center; 
}

.header nav a {
    text-decoration: none;
    color: white;
    font-weight: 600; /* Peso fixo para todos */
    font-size: 14px;
    text-transform: uppercase;
    letter-spacing: 1px;
    transition: opacity 0.3s ease;
    /* Evita que o link mude de tamanho se for negrito */
    display: inline-block;
    text-align: center;
}

/* Em vez de mudar o peso da fonte, usamos apenas a opacidade para indicar a página ativa */
.header nav a.active {
    opacity: 1 !important;
}

.header nav a.inactive {
    opacity: 0.5;
}

.header nav a:hover {
    opacity: 1;
}

/* Garante que o bloco da direita tenha sempre o mesmo tamanho aproximado */
.header .header-actions {
    display: flex;
    gap: 15px;
    align-items: center;
    min-width: 320px; /* Ajuste esse valor conforme o tamanho dos seus botões */
    justify-content: flex-end;
}

/* --- UI DE LOGIN HIGH-END --- */

.login-page {
    display: grid;
    grid-template-columns: 1fr 1fr; /* Divide a tela ao meio */
    min-height: 100vh;
    background: var(--white);
}

.login-form-side {
    display: flex;
    flex-direction: column;
    justify-content: center;
    padding: 80px;
    background: var(--white);
}

.login-visual-side {
    background: var(--p-purple-deep);
    display: flex;
    flex-direction: column;
    justify-content: center;
    padding: 80px;
    color: white;
    position: relative;
    overflow: hidden;
}

.login-card {
    max-width: 420px;
    width: 100%;
    margin: 0 auto;
}

.login-visual-content {
    position: relative;
    z-index: 2;
    max-width: 500px;
}

.back-link {
    position: absolute;
    top: 40px;
    left: 80px;
    text-decoration: none;
    color: var(--p-purple);
    font-size: 14px;
    font-weight: 700;
    display: flex;
    align-items: center;
    gap: 8px;
    transition: 0.3s;
}
.back-link:hover { transform: translateX(-5px); color: var(--s-teal); }

.login-input-group {
    margin-bottom: 20px;
}

.form-footer-links {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-top: 15px;
    font-size: 14px;
}

.form-footer-links a {
    color: var(--p-purple);
    text-decoration: none;
    font-weight: 600;
}

.login-divider {
    height: 1px;
    background: var(--border-ui);
    margin: 40px 0;
    position: relative;
}

@media (max-width: 1024px) {
    .login-page { grid-template-columns: 1fr; }
    .login-visual-side { display: none; } /* Esconde o visual em telas pequenas */
    .login-form-side { padding: 40px; }
}


/* --- FOOTER REFINADO (STATUS E SOCIAIS) --- */

.status-indicator-mini {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 6px 12px;
    background: rgba(66, 182, 164, 0.1);
    border-radius: 6px;
    color: var(--s-teal);
    font-size: 10px;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 1.5px;
    border: 1px solid rgba(66, 182, 164, 0.2);
}

.dot-on {
    width: 6px;
    height: 6px;
    background-color: var(--s-teal);
    border-radius: 50%;
    box-shadow: 0 0 10px var(--s-teal);
    animation: blink-status 2s infinite;
}

@keyframes blink-status {
    0% { opacity: 1; transform: scale(1); }
    50% { opacity: 0.4; transform: scale(0.9); }
    100% { opacity: 1; transform: scale(1); }
}

.social-links {
    display: flex;
    gap: 15px;
    margin-top: 25px;
}

.social-icon {
    width: 36px;
    height: 36px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 8px;
    background: rgba(255, 255, 255, 0.03);
    border: 1px solid rgba(255, 255, 255, 0.08);
    color: rgba(255, 255, 255, 0.6);
    text-decoration: none;
    transition: 0.3s;
}

.social-icon:hover {
    background: var(--s-teal);
    color: var(--ink);
    border-color: var(--s-teal);
    transform: translateY(-3px);
}


/* --- AJUSTE FINAL DE SEGURANÇA --- */

/* 1. Ajusta a proporção e impede que colunas 'vazem' */
.dark-hero-wrap .section .container {
    display: grid !important;
    /* minmax(0, ...) impede que o texto longo estoure a largura da coluna */
    grid-template-columns: minmax(0, 1.3fr) 0.7fr !important; 
    gap: 50px !important;
    align-items: center !important;
    width: 100% !important;
}

/* 2. Reduz o tamanho do H1 para a frase longa caber em uma linha */
h1 {
    /* Diminuí o máximo para 4.2rem. Se ficar pequeno, aumente para 4.4rem */
    font-size: clamp(2.4rem, 4vw, 4.2rem) !important; 
    line-height: 1.1 !important;
    word-break: normal !important; /* Impede que ele corte palavras ao meio */
}

/* 3. Dá prioridade total para a imagem não ser espremida */
div[style*="backdrop-filter: blur(30px)"] {
    min-width: 480px !important; /* Espaço sagrado da imagem */
    width: 100% !important;
    flex-shrink: 0 !important;
}

/* Ajuste para telas menores */
@media (max-width: 1300px) {
    .dark-hero-wrap .section .container {
        grid-template-columns: 1fr 1fr !important; /* Volta para meio a meio */
    }
    div[style*="backdrop-filter: blur(30px)"] {
        min-width: 400px !important;
    }
}

/* --- ESTILO DOS BADGES TÉCNICOS --- */
.hero-badges-container {
    display: flex;
    gap: 12px;            /* Espaço entre os badges */
    margin-top: 24px;     /* Espaço em relação à imagem/card acima */
    flex-wrap: wrap;      /* Permite quebrar linha se a tela for pequena */
}

.badge-tech {
    border: 1.5px solid var(--s-teal); /* Borda verde Tiffany */
    background: transparent;           /* Fundo transparente */
    color: var(--s-teal);              /* Fonte verde Tiffany */
    text-transform: uppercase;         /* Força maiúsculas */
    font-size: 11px;                   /* Fonte pequena e elegante */
    font-weight: 800;                  /* Fonte bem marcada */
    letter-spacing: 1.5px;             /* Espaçamento entre letras técnico */
    padding: 6px 14px;                 /* Respiro interno */
    border-radius: 6px;                /* Cantos levemente arredondados */
    display: inline-block;
}

/* =============================================
   SISTEMA DE RESPONSIVIDADE ULTRA-FLUIDO
   ============================================= */

/* 1. Ajustes para Telas Médias (Notebooks pequenos e Tablets) */
@media (max-width: 1200px) {
    .container {
        padding: 0 40px; /* Reduz margem lateral */
    }
    
    /* Hero: Dá mais espaço pro texto respirar */
    .dark-hero-wrap .section .container {
        grid-template-columns: 1fr !important; /* Empilha: Texto em cima, Imagem embaixo */
        text-align: center;
        gap: 60px !important;
    }

    .dark-hero-wrap .bullet-list {
        display: inline-block;
        text-align: left; /* Mantém os bullets alinhados à esquerda mesmo com título centralizado */
    }

    div[style*="backdrop-filter: blur(30px)"] {
        min-width: auto !important; /* Libera a imagem para encolher */
        max-width: 550px;
        margin: 0 auto;
    }
}

/* 2. Ajustes para Celulares (Telas pequenas) */
@media (max-width: 768px) {
    .section {
        padding: 80px 0 !important; /* Reduz o "buraco" entre as dobras no celular */
    }

    .container {
        padding: 0 24px;
    }

    /* Títulos: Diminui o tamanho da letra para não "estourar" a tela */
    h1 {
        font-size: 2.6rem !important; 
        line-height: 1.1 !important;
    }

    h2 {
        font-size: 1.8rem !important;
    }

    /* Grids: Faz com que todos os cards de 3 ou 4 colunas fiquem em uma coluna só */
    div[style*="display: grid"] {
        grid-template-columns: 1fr !important;
        gap: 30px !important;
    }

    /* Header: Organiza o menu para não embolar */
    .header {
        height: auto;
        padding: 20px 0;
        flex-direction: column;
        gap: 20px;
    }

    .header nav {
        gap: 15px;
        flex-wrap: wrap; /* Permite que os links pulem linha se faltar espaço */
        justify-content: center;
    }

    .header .header-actions {
        min-width: auto !important;
        justify-content: center;
        width: 100%;
    }

    /* Ajuste de Cards */
    .card {
        padding: 32px !important; /* Reduz o preenchimento interno do card no celular */
    }

    /* Banner de Auditoria */
    .audit-ready-bar {
        flex-direction: column; /* Texto em cima, botão embaixo */
        text-align: center;
        gap: 24px;
        padding: 32px 24px !important;
    }

    .audit-ready-bar .status-info {
        flex-direction: column;
    }
}

/* 3. Ajuste Extra para o Comparativo */
@media (max-width: 1024px) {
    div[style*="grid-template-columns: 1fr 1.3fr 1fr"] {
        grid-template-columns: 1fr !important;
    }
    
    .comp-fluir {
        transform: scale(1) !important; /* Remove o aumento de tamanho no mobile para não cortar */
        margin: 20px 0;
    }
}

/* =============================================
   RE-ESTRUTURAÇÃO DO MENU MOBILE (ENTERPRISE)
   ============================================= */

/* 1. Reset do Header para manter linha única */
@media (max-width: 1100px) {
    .header {
        flex-direction: row !important; /* Força ficar um ao lado do outro */
        justify-content: space-between !important;
        height: 80px !important;
        padding: 0 24px !important;
    }

    /* Esconde os botões soltos no topo do celular */
    .header .header-actions {
        display: none !important;
    }

    /* Mostra o botão hambúrguer */
    .menu-toggle {
        display: flex !important;
        order: 2; /* Garante que fique na direita */
    }

    /* Ajuste do Menu Lateral */
    .header nav {
        position: fixed;
        top: 0;
        right: -100%; /* Começa fora da tela */
        width: 100%;  /* Ocupa a tela toda para impacto */
        height: 100vh;
        background: var(--p-purple-deep);
        display: flex !important;
        flex-direction: column !important;
        justify-content: center;
        align-items: center;
        gap: 40px !important;
        transition: 0.5s cubic-bezier(0.16, 1, 0.3, 1);
        z-index: 1000;
    }

    .header nav.mobile-open {
        right: 0; /* Desliza para dentro */
    }

    /* Estilo dos Links dentro do menu mobile */
    .header nav a {
        font-size: 24px !important; /* Fonte maior no celular */
        font-family: 'Montserrat', sans-serif;
    }

    /* Estilo dos Botões dentro do menu mobile */
    .nav-mobile-actions {
        display: flex !important;
        flex-direction: column;
        gap: 15px;
        width: 100%;
        max-width: 280px;
        margin-top: 20px;
        border-top: 1px solid rgba(255,255,255,0.1);
        padding-top: 40px;
    }

    .nav-mobile-actions .btn {
        width: 100% !important;
        height: 56px !important;
        justify-content: center;
    }
}

/* Esconde as ações mobile se estiver no PC */
@media (min-width: 1101px) {
    .nav-mobile-actions {
        display: none !important;
    }
}


/* =============================================
   CORREÇÃO DEFINITIVA DO BOTÃO HAMBÚRGUER
   ============================================= */

/* Garante que o botão apareça e tenha as proporções certas */
.menu-toggle {
    display: none; /* Escondido por padrão no PC */
    flex-direction: column;
    justify-content: space-between;
    width: 30px;
    height: 21px;
    background: transparent;
    border: none;
    cursor: pointer;
    padding: 0;
    z-index: 1100; /* Fica acima de tudo */
    position: relative;
}

/* Estilo dos 3 risquinhos */
.menu-toggle span {
    display: block;
    width: 100%;
    height: 3px; /* Grossura do risco */
    background-color: #42b6a4 !important; /* Força o Verde Tiffany */
    border-radius: 10px;
    transition: all 0.3s ease;
}

/* Regras para Celular (Mobile) */
@media (max-width: 1100px) {
    .header {
        display: flex !important;
        flex-direction: row !important;
        justify-content: space-between !important;
        align-items: center !important;
        padding: 0 24px !important;
        height: 80px !important;
    }

    .menu-toggle {
        display: flex !important; /* Mostra no celular */
    }

    .header-actions {
        display: none !important; /* Esconde os botões soltos */
    }

    /* O Menu que abre */
    #nav-menu {
        position: fixed;
        top: 0;
        right: -100%; /* Começa escondido */
        width: 100%;
        height: 100vh;
        background: #0a0812; /* Roxo ultra escuro */
        display: flex !important;
        flex-direction: column !important;
        justify-content: center !important;
        align-items: center !important;
        gap: 30px !important;
        transition: 0.5s cubic-bezier(0.16, 1, 0.3, 1);
        z-index: 1000;
    }

    #nav-menu.mobile-open {
        right: 0; /* Desliza para dentro */
    }
}

/* Transformação para o X quando o menu abre */
.menu-toggle.open span:nth-child(1) {
    transform: translateY(9px) rotate(45deg);
}
.menu-toggle.open span:nth-child(2) {
    opacity: 0;
}
.menu-toggle.open span:nth-child(3) {
    transform: translateY(-9px) rotate(-45deg);
}

/* --- AJUSTE FINAL: ALINHAMENTO E TAMANHO DOS BOTÕES MOBILE --- */

@media (max-width: 1100px) {
    .nav-mobile-actions {
        width: 100%;
        max-width: 280px; /* Um pouco mais estreito para elegância */
        display: flex !important;
        flex-direction: column !important;
        gap: 12px !important;
        margin-top: 20px !important;
        padding-top: 30px !important;
        border-top: 1px solid rgba(255, 255, 255, 0.1);
        align-items: center;
    }

    .nav-mobile-actions .btn {
        width: 100% !important;
        height: 52px !important; /* Altura padrão de app premium */
        
        /* O SEGREDO DO ALINHAMENTO CENTRAL */
        display: flex !important;
        align-items: center !important;    /* Centraliza verticalmente */
        justify-content: center !important; /* Centraliza horizontalmente */
        
        /* Ajuste fino da fonte */
        font-size: 13px !important; /* Um ponto menor para respirar melhor */
        line-height: 1 !important;  /* Remove alturas de linha que empurram o texto pra baixo */
        padding: 0 20px !important;
        text-align: center !important;
        letter-spacing: 0.5px !important;
    }

    /* Opcional: Diminuir o texto se ainda achar grande */
    #nav-menu a {
        font-size: 18px !important; 
        font-weight: 500 !important;
    }
}

/* --- AJUSTE DE LARGURA DO TEXTO NO CALLOUT MOBILE --- */

@media (max-width: 768px) {
    /* Localiza o card branco no final do FAQ */
    section[style*="background-color: #F6F8FA"] div[style*="background: white"] {
        padding: 40px 20px !important; /* Diminui o respiro lateral de 60px para 20px */
        border-radius: 24px !important; /* Arredondamento um pouco menor para o mobile */
    }

    /* Garante que o título use toda a largura disponível */
    section[style*="background-color: #F6F8FA"] h3 {
        font-size: 1.8rem !important; /* Diminui levemente a fonte se necessário */
        padding: 0 10px;
    }
}


/* --- ADIÇÕES ESPECÍFICAS PARA O HERO --- */

/* Estilo das Badges Técnicas */
.hero-badges-container {
    display: flex;
    gap: 12px;
    margin-bottom: 30px;
    flex-wrap: wrap;
}

.badge-tech {
    border: 1.5px solid var(--s-teal); /* Borda verde Tiffany */
    background: transparent;           /* Fundo transparente */
    color: var(--s-teal);              /* Fonte verde Tiffany */
    text-transform: uppercase;         /* Maiúsculas */
    font-size: 11px;
    font-weight: 800;
    letter-spacing: 1.5px;
    padding: 6px 14px;
    border-radius: 6px;
    display: inline-block;
}

/* --- AJUSTE DE ALINHAMENTO MOBILE (BADGES + HEADLINE) --- */

@media (max-width: 1100px) {
    /* Esconde a coluna da imagem */
    .hero-mockup-col {
        display: none !important;
    }

    /* Garante que o texto e o título fiquem alinhados à ESQUERDA no mobile */
    .dark-hero-wrap .section .container {
        grid-template-columns: 1fr !important;
        text-align: left !important; /* Mudado de center para left */
        padding: 0 24px !important;
    }

    /* Alinha as badges à ESQUERDA para acompanhar o Headline */
    .hero-badges-container {
        justify-content: flex-start !important; /* Alinhamento à esquerda */
        margin-bottom: 24px !important;
        gap: 8px !important; /* Diminui um pouco o espaço entre elas no celular */
    }

    /* Garante que o parágrafo e a lista também sigam o alinhamento */
    .dark-hero-wrap p, 
    .dark-hero-wrap .bullet-list {
        text-align: left !important;
        margin-left: 0 !important;
    }

    /* Ajusta os botões para ficarem um embaixo do outro ou alinhados à esquerda */
    .dark-hero-wrap div[style*="display: flex"] {
        flex-direction: column !important;
        align-items: flex-start !important;
        gap: 16px !important;
    }

    .dark-hero-wrap .btn {
        width: 100% !important;
        max-width: 300px; /* Não deixa o botão ficar gigante no celular */
    }
}

/* --- AJUSTE DA SEÇÃO DE MODELOS (BENCHMARK) --- */

/* Estilo do título riscado */
.title-strikethrough {
    text-decoration: line-through;
    opacity: 0.5;
    font-size: 1.1rem !important; /* Diminui um pouco para dar menos foco */
}

/* Etiquetas de Status (Inadequado / Complexo) */
.model-tag {
    display: inline-block;
    padding: 4px 10px;
    border-radius: 4px;
    font-size: 10px;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 1px;
    margin-bottom: 15px;
}

.tag-red { background: rgba(255, 0, 0, 0.1); color: #ff4d4d; border: 1px solid rgba(255, 0, 0, 0.2); }
.tag-warning { background: rgba(255, 165, 0, 0.1); color: #ffa500; border: 1px solid rgba(255, 165, 0, 0.2); }

/* ORDENAÇÃO MOBILE: Fluir Primeiro */
@media (max-width: 1100px) {
    /* Identifica o container dos 3 cards */
    div[style*="grid-template-columns: 1fr 1.3fr 1fr"] {
        display: flex !important;
        flex-direction: column !important;
    }

    /* Card 1 (Pesquisas) vai para o fim */
    div[style*="grid-template-columns: 1fr 1.3fr 1fr"] > div:nth-child(1) {
        order: 2;
    }

    /* Card 2 (FLUIR) SOBE PARA O TOPO */
    div[style*="grid-template-columns: 1fr 1.3fr 1fr"] > div:nth-child(2) {
        order: 1;
        transform: scale(1) !important; /* Ajuste para não cortar no mobile */
        margin-bottom: 20px;
    }

    /* Card 3 (ERPs) vai para o fim */
    div[style*="grid-template-columns: 1fr 1.3fr 1fr"] > div:nth-child(3) {
        order: 3;
    }
}

/* --- FORÇAR SUBIDA DO CONTEÚDO DO HERO --- */

/* Alvos: A primeira seção que vem logo depois do header escuro */
.dot-pattern .section {
    padding-top: 30px !important; /* Estava 140px, baixamos para 20px */
}

/* Remove qualquer margem extra que o H1 possa ter no topo */
.dot-pattern h1 {
    margin-top: 10px !important;
}

/* Ajuste específico para o Mobile */
@media (max-width: 1100px) {
    .dot-pattern .section {
        padding-top: 30px !important;
    }
    
    .hero-badges-container {
        margin-bottom: 20px !important;
    }
}


/* --- AJUSTE DE CENTRALIZAÇÃO: BOTÃO LOGIN --- */

.login-card .btn-p {
    display: flex !important;
    justify-content: center !important; /* Centraliza horizontalmente */
    align-items: center !important;     /* Centraliza verticalmente */
    width: 100% !important;
    height: 56px !important;            /* Altura fixa para impacto */
    text-align: center !important;
    padding: 0 !important;              /* Remove paddings que podem empurrar o texto */
    font-size: 12px !important;
    font-weight: 700 !important;
    letter-spacing: -0.01em !important;
    line-height: 1 !important;          /* Garante que a linha não empurre o texto para baixo */
}

/* --- CENTRALIZAÇÃO CIRÚRGICA DO TEXTO DO BOTÃO LOGIN --- */
.login-card .btn-p {
    text-align: center !important;
    display: block !important;    /* Garante que ele se comporte como um bloco */
    line-height: 56px !important;  /* Força o texto a ficar no meio da altura de 56px */
    padding-top: 0 !important;
    padding-bottom: 0 !important;
}

/* --- LÓGICA DE VISIBILIDADE DAS BADGES E AJUSTE HERO --- */

/* Esconde as badges mobile no Computador */
.badges-mobile {
    display: none !important;
}

@media (max-width: 1100px) {
    /* Esconde a coluna da imagem inteira (e as badges de desktop que estão nela) */
    .hero-mockup-col {
        display: none !important;
    }

    /* Garante alinhamento à ESQUERDA de todo o texto no mobile */
    .dark-hero-wrap .section .container {
        grid-template-columns: 1fr !important;
        text-align: left !important;
    }

    /* Mostra as badges mobile abaixo do botão, alinhadas à esquerda */
    .badges-mobile {
        display: flex !important;
        justify-content: flex-start !important; /* Alinhado ao headline */
        margin-top: 40px !important;
    }
}

/* Reduz o buraco entre o Header e o Início do Texto no Hero */
.dot-pattern .section {
    padding-top: 30px !important;
}

/* --- SHIELD TOTAL: PROTEÇÃO DA LARGURA DO HERO --- */

/* 1. Força a coluna da direita a ter 520px fixos (espaço ideal para os badges) */
.dark-hero-wrap .section .container {
    display: grid !important;
    /* O lado esquerdo pega o que sobrar (1fr), o lado direito fica travado em 520px */
    grid-template-columns: 1fr 520px !important; 
    gap: 80px !important;
    align-items: center !important;
}

/* 2. Garante que o card de vidro ocupe esses 520px sem encolher */
.hero-mockup-col {
    width: 520px !important;
    flex-shrink: 0 !important;
}

/* 3. Força os badges a ficarem em uma linha só, sem quebrar */
.hero-badges-container {
    display: flex !important;
    flex-wrap: nowrap !important; /* Proíbe o texto de pular linha */
    gap: 10px !important;
}

.badge-tech {
    white-space: nowrap !important; /* Garante que o texto de cada badge não quebre */
}

/* 4. Ajuste para Telas de Notebook (Abaixo de 1300px) */
@media (max-width: 1300px) {
    .dark-hero-wrap .section .container {
        /* Em telas menores, dividimos meio a meio (50% / 50%) */
        grid-template-columns: 1fr 1fr !important;
        gap: 40px !important;
    }
    
    .hero-mockup-col {
        width: auto !important;
        min-width: 450px !important;
    }
    
    /* Se mesmo assim não couber, diminuímos um pouco a letra dos badges */
    .badge-tech {
        font-size: 10px !important;
        padding: 5px 10px !important;
    }
}

/* 5. Mantém a regra de sumir no mobile */
@media (max-width: 1100px) {
    .hero-mockup-col {
        display: none !important;
    }
    .dark-hero-wrap .section .container {
        grid-template-columns: 1fr !important;
    }
}

/* --- AJUSTE DE RESPIRO PARA A SEÇÃO DE ETAPAS (MOBILE) --- */

@media (max-width: 1100px) {
    /* 1. Aumenta o recuo lateral do container no mobile para o conteúdo não 'sufocar' */
    .section .container {
        padding: 0 32px !important; /* Aumentamos de 24px para 32px */
    }

    /* 2. Ajusta as colunas dos Steps para dar distância da borda esquerda */
    div[style*="border-top: 2px solid var(--p-purple)"],
    div[style*="border-top: 2px solid var(--border-ui)"] {
        padding-left: 10px !important; /* Pequeno recuo interno para o texto não colar na linha */
        padding-right: 10px !important;
        margin-bottom: 40px !important; /* Espaço maior entre um passo e outro */
    }

    /* 3. Garante que os números dos passos fiquem bem posicionados */
    .step-num {
        font-size: 52px !important; /* Um pouco menor no celular para não ser agressivo */
        margin-bottom: 10px !important;
    }

    /* 4. Ajusta os títulos dos passos para não quebrarem de forma feia */
    .section h3 {
        font-size: 1.5rem !important;
        line-height: 1.2 !important;
    }
}

/* --- AJUSTE DE IMPACTO: SEÇÃO SESMT MOBILE --- */

@media (max-width: 1100px) {
    /* 1. Reduz o recuo gigante de 100px para 40px no mobile */
    div[style*="background-color: var(--p-purple-deep)"] {
        padding: 60px 24px !important; /* Respiro vertical de 60, lateral de 24 */
        border-radius: 24px !important; /* Arredondamento mais elegante para celular */
    }

    /* 2. Ajusta o grid interno para não espremer os itens */
    div[style*="background-color: var(--p-purple-deep)"] > div {
        grid-template-columns: 1fr !important;
        gap: 40px !important;
    }

    /* 3. Ajusta o card que está dentro desta seção dark */
    div[style*="background-color: var(--p-purple-deep)"] .card {
        padding: 32px 20px !important; /* Reduz o padding interno do card branco/transparente */
        background: rgba(255, 255, 255, 0.05) !important; /* Garante que fique moderno */
    }

    /* 4. Melhora a leitura dos mini-blocos (Matriz e PGR) */
    div[style*="border-left: 2px solid var(--s-teal)"] {
        margin-bottom: 30px;
        padding-left: 16px !important;
    }

    div[style*="border-left: 2px solid var(--s-teal)"] h4 {
        font-size: 1.1rem !important;
        line-height: 1.2 !important;
    }
}

/* --- BLINDAGEM GLOBAL DE BOTÕES (CENTRALIZAÇÃO TOTAL) --- */

.btn {
    display: inline-flex !important;
    align-items: center !important;      /* Centraliza verticalmente */
    justify-content: center !important;   /* Centraliza horizontalmente */
    text-align: center !important;        /* Garante centralização em textos multi-linha */
    vertical-align: middle;
    
    /* Previne que o texto encoste nas bordas em botões pequenos */
    padding-left: 24px !important;
    padding-right: 24px !important;
    
    /* Impede deformações de altura de linha */
    line-height: 1 !important; 
}

/* Ajuste específico para garantir que no mobile eles não fiquem "tortos" */
@media (max-width: 1100px) {
    .btn {
        width: 100% !important; /* Opcional: faz o botão ocupar a largura toda no mobile, que é melhor para o polegar */
        max-width: 320px;       /* Mas limita para não ficar gigante em tablets */
        margin-left: auto !important;
        margin-right: auto !important;
        display: flex !important; /* No mobile o flex costuma ser mais estável que inline-flex */
    }
    
    /* Se você quiser que o botão NÃO ocupe a largura toda, 
       mas apenas centralize o texto, remova o 'width: 100%' acima. */
}

/* --- AJUSTE DE POUSO DO SCROLL --- */

html {
    scroll-behavior: smooth !important;
}

/* Isso diz: quando este ID for o alvo, pare 140px antes de chegar nele */
#falar-com-especialista {
    scroll-margin-top: 140px !important;
}


/* --- CORREÇÃO DO HEADER "CARD" NO MOBILE --- */

@media (max-width: 1100px) {
    /* Localiza o primeiro bloco escuro do site (Header + Hero) e força a borda a ser reta */
    body > div:first-child[style*="background-color"] {
        border-radius: 0 !important; /* Remove o arredondamento */
        margin-top: 0 !important;
        border-top: none !important;
    }

    /* Caso você tenha usado a classe dark-hero-wrap, garantimos aqui também */
    .dark-hero-wrap {
        border-radius: 0 !important;
    }
}

/* --- ALINHAMENTO CENTRAL DAS BADGES NO MOBILE --- */

@media (max-width: 1100px) {
    /* Força o contêiner de badges a centralizar os itens */
    .hero-badges-container.badges-mobile {
        display: flex !important;
        justify-content: center !important; /* Centraliza horizontalmente */
        align-items: center !important;
        gap: 10px !important; /* Espaço entre elas */
        width: 100% !important;
        margin-left: auto !important;
        margin-right: auto !important;
    }

    /* Garante que elas não tentem ocupar largura total individualmente */
    .badge-tech {
        flex: 0 1 auto !important; 
        white-space: nowrap !important;
    }
}


/* Ajuste para telas menores (Notebooks) */
@media (min-width: 1101px) and (max-width: 1400px) {
    .dark-hero-wrap .section .container {
        grid-template-columns: 1fr 520px !important;
        gap: 50px !important;
        padding-top: 120px !important;
    }
    .hero-mockup-col {
        width: 520px !important;
        min-width: 520px !important;
    }
}

/* --- AJUSTE DEFINITIVO DE EQUILÍBRIO DO HERO --- */

@media (min-width: 1101px) {
    /* 1. ABAIXA O TEXTO: Aumenta o espaço entre o Menu (Nav) e o Headline */
    .dark-hero-wrap .section {
        padding-top: 220px !important; /* Estava 140px, subimos para 220px para o texto descer bem */
    }

    /* 2. NIVELA POR CIMA: Força texto e imagem a começarem na mesma linha lá no alto */
    .dark-hero-wrap .section .container, 
    .hero-grid-main {
        display: grid !important;
        align-items: flex-start !important; /* Alinhamento fixo no topo */
    }

    /* 3. SOBE A IMAGEM: Garante que ela acompanhe o topo do texto com o recuo solicitado */
    .hero-mockup-col {
        margin-top: 20px !important; /* Exatamente 20px abaixo do início da primeira linha do título */
        padding-top: 0 !important;
    }

    /* 4. Zera qualquer margem automática do H1 que possa estar empurrando ele pra baixo */
    .dark-hero-wrap h1 {
        margin-top: 0 !important;
    }
}

/* Ajuste para telas um pouco menores (Notebooks comuns) */
@media (min-width: 1101px) and (max-width: 1400px) {
    .dark-hero-wrap .section {
        padding-top: 180px !important; /* Um pouco menos de recuo em telas menores */
    }
}


/* ============================================================
   PATCH DE CORREÇÃO FINAL: HERO E NAVEGAÇÃO
   ============================================================ */

/* 1. ACERTA O HEADER: Esconde os botões duplicados dependendo da tela */
@media (min-width: 1101px) {
    .nav-mobile-actions { display: none !important; }
    .header-actions { display: flex !important; }
}
@media (max-width: 1100px) {
    .header-actions { display: none !important; }
    .nav-mobile-actions { display: flex !important; }
}

/* 2. ACERTA O HERO (DESKTOP): Alarga a imagem e posiciona o texto */
@media (min-width: 1101px) {
    /* Alinha o texto e a imagem pelo topo e afasta do menu */
    .dot-pattern .section .container {
        display: grid !important;
        grid-template-columns: 1fr 540px !important; /* Trava a imagem em 540px */
        gap: 80px !important;
        align-items: flex-start !important; /* Alinhamento por cima */
        padding-top: 10px !important; /* Empurra o texto para baixo do Nav */
        width: 100% !important;
    }

    /* Blindagem da imagem: impede que ela encolha */
    .hero-mockup-col {
        min-width: 540px !important;
        margin-top: 20px !important; /* Desce a imagem 20px em relação ao texto */
        flex-shrink: 0 !important;
    }

    /* Força os badges do desktop a ficarem em uma linha só */
    .badges-desktop {
        display: flex !important;
        flex-wrap: nowrap !important;
    }
}

/* 3. ACERTA O HERO (MOBILE): Esconde a imagem e organiza as badges */
@media (max-width: 1100px) {
    .hero-grid-main {
        grid-template-columns: 1fr !important;
        text-align: left !important;
        padding-top: 40px !important;
    }

    .hero-mockup-col {
        display: none !important; /* Some imagem no mobile */
    }

    .badges-mobile {
        display: flex !important; /* Mostra badges abaixo do botão */
        justify-content: center !important; /* Alinhamento central como você pediu por último */
        margin-top: 40px !important;
    }

    .badges-desktop {
        display: none !important;
    }
}

/* 4. FIX DE BOTÃO DE LOGIN: Centralização do texto */
.login-card .btn-p {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    text-align: center !important;
    line-height: 1 !important;
}

/* 5. FIX DE SCROLL: Margem para o Nav não tampar o formulário */
#falar-com-especialista {
    scroll-margin-top: 140px !important;
}

/* =============================================
   REPARO DE RESPONSIVIDADE: PÁGINA SOBRE
   ============================================= */

@media (max-width: 1100px) {
    /* 1. Ajusta o Grid da Equipe para 1 coluna */
    .team-grid {
        grid-template-columns: 1fr !important;
        gap: 20px !important;
    }

    /* 2. Ajusta os Cards de Perfil (Idealizadores) */
    .profile-card {
        padding: 30px 24px !important; /* Reduz o padding interno */
        border-radius: 20px !important;
    }

    /* 3. Ajusta a seção "Razão de existir" */
    section .container[style*="grid-template-columns: 0.8fr 1.2fr"] {
        grid-template-columns: 1fr !important;
        gap: 40px !important;
    }

    /* 4. Ajusta o Box da Missão */
    .mission-box {
        padding: 30px !important;
        margin-top: 30px !important;
        border-radius: 20px !important; /* Arredonda tudo no mobile */
        border-left: 4px solid var(--s-teal) !important;
    }

    .mission-box h3 {
        font-size: 1.6rem !important;
    }

    /* 5. Ajusta os Princípios de Atuação (Lista técnica) */
    .principle-item {
        grid-template-columns: 1fr !important; /* Empilha: Número, Título e Texto */
        gap: 15px !important;
        padding: 32px 0 !important;
        text-align: left;
    }

    .principle-item span {
        font-size: 32px !important; /* Número maior para destaque */
        margin-bottom: 5px;
    }

    .principle-item h3 {
        margin-bottom: 10px !important;
    }
}

/* --- CORREÇÃO DA PÁGINA SOBRE: LINHA TÉCNICA E PRINCÍPIOS --- */

@media (max-width: 1100px) {
    /* 1. Restaura a Missão: Remove bordas de card e mantém a linha vertical */
    .mission-box {
        border-top: none !important;
        border-right: none !important;
        border-bottom: none !important;
        /* Força apenas a linha vertical na esquerda */
        border-left: 4px solid var(--s-teal) !important; 
        border-radius: 0 !important; /* Remove o visual de 'bolacha' arredondada */
        padding: 20px 0 20px 24px !important; /* Texto com recuo elegante da linha */
        background: transparent !important; /* Deixa o fundo limpo para não parecer card */
        margin-top: 30px !important;
    }

    .mission-box h3 {
        font-size: 1.5rem !important; /* Fonte mais séria para o celular */
        line-height: 1.2 !important;
    }

    /* 2. Corrige a seção de Princípios para não ficar 'espremida' */
    .principle-item {
        display: flex !important;
        flex-direction: column !important;
        align-items: flex-start !important;
        text-align: left !important;
        padding: 40px 0 !important;
        gap: 10px !important;
    }

    .principle-item span {
        margin-bottom: 5px !important;
    }
}

/* --- FIX GLOBAL: HEADER RETO E BOTÕES ÚNICOS --- */

/* No Desktop: Esconde botões do menu hamburguer */
@media (min-width: 1101px) {
    .nav-mobile-actions { display: none !important; }
    .header-actions { display: flex !important; }
}

/* No Mobile: Regras de Ouro */
@media (max-width: 1100px) {
    /* 1. Esconde botões de desktop */
    .header-actions { display: none !important; }
    .nav-mobile-actions { display: flex !important; }

    /* 2. FIX DO HEADER "CARD": Força o topo a ser reto */
    .dark-header-bg { 
        border-radius: 0 !important; 
        margin: 0 !important;
    }

    /* 3. FIX DO SESMT ESPREMIDO: Reduz padding de 100px para 24px */
    .bento-impact {
        padding: 60px 24px !important;
        border-radius: 24px !important;
    }
    
    /* Garante que o grid interno do SESMT vire 1 coluna */
    .bento-impact > div {
        grid-template-columns: 1fr !important;
        gap: 40px !important;
    }
}

/* ============================================================
   CONTROLE DE VISIBILIDADE DAS BADGES (DESKTOP VS MOBILE)
   ============================================================ */

/* 1. REGRA PARA COMPUTADOR (Telas maiores que 1100px) */
@media (min-width: 1101px) {
    /* Esconde as badges que estão embaixo do botão */
    .badges-mobile {
        display: none !important;
    }
    /* Garante que as badges apareçam dentro do card da direita */
    .badges-desktop {
        display: flex !important;
    }
}

/* 2. REGRA PARA CELULAR (Telas menores que 1100px) */
@media (max-width: 1100px) {
    /* Mostra as badges embaixo do botão */
    .badges-mobile {
        display: flex !important;
        justify-content: center !important; /* Centraliza no mobile como você pediu */
        margin-top: 30px !important;
    }
    /* Esconde as badges que estariam no card (que sumiu) */
    .badges-desktop {
        display: none !important;
    }
}

/* --- AJUSTE DE TAMANHO DOS BOTÕES NO MENU MOBILE --- */

@media (max-width: 1100px) {
    .nav-mobile-actions .btn {
        /* Diminui o tamanho da fonte (estava provavelmente em 14px ou 15px) */
        font-size: 11px !important; 
        
        /* Se você quiser tirar o MAIÚSCULO, mude para 'none'. 
           Se quiser manter maiúsculo mas apenas menor, deixe 'uppercase' */
        text-transform: none !important; 
        
        /* Ajuste do espaçamento entre letras para ficar mais elegante */
        letter-spacing: 0.5px !important;
        
        /* Garante que o texto caiba em uma linha só sem apertar */
        padding: 0 10px !important;
        height: 48px !important; /* Altura um pouco mais compacta */
    }
}