/* ======================================================
   ARQUIVO CSS (style.css) - VERSÃO 5.0 (FINAL COM LPs)
   - Inclui todos os estilos do site + estilos das Landing Pages
========================================================= */

/* --- 1. IMPORTAÇÃO DE FONTE E VARIÁVEIS --- */
@import url('https://fonts.googleapis.com/css2?family=Poppins:wght@300;400;500;600;700&display=swap');

:root {
    /* Paleta de Cores */
    --primary-gold: #cca353;
    --cta-green: #00b050;
    --dark-bg: #111111;
    --dark-warm: #1a1a1a;
    --dark-footer: #000000;
    --light-bg: #f7f3ed;
    --text-dark: #222222;
    --text-light: #eeeeee;
    --text-muted: #999999;
    --white: #ffffff;
    
    --font-family: 'Poppins', sans-serif;
}

/* --- 2. RESET GLOBAL E ESTILO DO BODY --- */
* { margin: 0; padding: 0; box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { font-family: var(--font-family); line-height: 1.7; background-color: var(--dark-bg); color: var(--text-light); overflow-x: hidden; position: relative; }
.sub-page { /* padding-top removido */ }
.container { width: 90%; max-width: 1200px; margin: 0 auto; }

/* --- 3. HELPERS DE SEÇÃO --- */
.section-light-bg { background-color: var(--light-bg); color: var(--text-dark); padding: 80px 0; }
.section-dark-warm { background-color: var(--dark-warm); color: var(--text-light); padding: 80px 0; }
.section-dark-bg { background-color: var(--dark-bg); color: var(--text-light); padding: 80px 0; }

/* --- 4. TÍTULOS, TEXTOS E LINKS --- */
h1, h2, h3, h4 { font-weight: 600; line-height: 1.3; }
h2 { text-align: center; font-size: 2.4rem; margin-bottom: 50px; color: var(--primary-gold); }
h3 { font-size: 1.8rem; color: var(--white); }
h4 { font-size: 1.2rem; color: var(--white); }
p { font-size: 1rem; color: var(--text-light); margin-bottom: 15px; }
a { text-decoration: none; transition: color 0.3s ease; }
img { max-width: 100%; height: auto; display: block; } /* Add display: block */
ul { list-style: none; }
.section-light-bg h2, .section-light-bg h3, .section-light-bg h4 { color: var(--text-dark); }
.section-light-bg h2 { color: var(--primary-gold); } 
.section-light-bg p { color: var(--text-dark); }

/* --- 5. BOTÕES --- */
.cta-button { display: inline-block; padding: 12px 28px; border-radius: 5px; font-weight: 600; font-size: 0.9rem; text-transform: uppercase; letter-spacing: 0.5px; transition: all 0.3s ease; cursor: pointer; border: none; }
.cta-gold { background-color: var(--primary-gold); color: var(--dark-bg); }
.cta-gold:hover { background-color: var(--white); transform: translateY(-2px); }
.cta-green { background-color: var(--cta-green); color: var(--white); }
.cta-green:hover { background-color: #00d661; transform: translateY(-2px); }
.cta-outline { background-color: transparent; color: var(--primary-gold); border: 2px solid var(--primary-gold); }
.cta-outline:hover { background-color: var(--primary-gold); color: var(--dark-bg); }
.section-cta { text-align: center; margin-top: 50px; }

/* --- 6. HEADER (NÃO FIXO) --- */
#header { width: 100%; padding: 20px 0; top: 0; left: 0; z-index: 1000; background: var(--dark-bg); box-shadow: 0 2px 10px rgba(0, 0, 0, 0.3); transition: padding 0.4s ease; }
#header .container { display: flex; justify-content: space-between; align-items: center; }
#header .logo img { height: 90px; width: auto; transition: height 0.4s ease; }
#header.scrolled { padding: 15px 0; }
#header.scrolled .logo img { height: 90px; } 
.sub-page #header { padding: 15px 0; background: var(--dark-bg); box-shadow: 0 2px 10px rgba(0, 0, 0, 0.3); }
.sub-page #header .logo img { height: 90px; } 
#nav-menu { display: block; }
#nav-menu ul { display: flex; }
#nav-menu li { margin-left: 30px; }
#nav-menu a { color: var(--white); font-weight: 500; font-size: 0.95rem; padding-bottom: 5px; border-bottom: 2px solid transparent; transition: color 0.3s ease, border-bottom 0.3s ease; }
#nav-menu a:hover { color: var(--primary-gold); border-bottom-color: var(--primary-gold); }
#mobile-menu-toggle { display: none; color: var(--white); font-size: 1.8rem; cursor: pointer; }

/* --- 7. SEÇÃO HERO (HOMEPAGE) --- */
#hero { height: 100vh; min-height: 600px; display: flex; align-items: center; justify-content: center; text-align: center; padding: 0; background-size: cover; background-position: center; position: relative; }
#hero::after { content: ''; position: absolute; top: 0; left: 0; width: 100%; height: 100%; background: linear-gradient(rgba(0,0,0,0.6), rgba(0,0,0,0.6)); }
#hero .hero-content { position: relative; z-index: 2; color: var(--white); }
#hero h1 { color: var(--primary-gold); font-size: 3.2rem; font-weight: 700; margin-bottom: 15px; }
#hero p { font-size: 1.3rem; color: var(--white); margin-bottom: 30px; }

/* --- 8. GRADE DE ÍCONES (HOMEPAGE) --- */
.icon-card-grid { display: grid; grid-template-columns: repeat(6, 1fr); gap: 20px; }
.icon-card { background-color: var(--dark-footer); border: 1px solid #222; border-radius: 8px; padding: 25px 20px; text-align: center; transition: all 0.3s ease; }
.icon-card:hover { background-color: var(--dark-warm); border-color: var(--primary-gold); transform: translateY(-5px); }
.icon-card i { color: var(--primary-gold); font-size: 2.5rem; margin-bottom: 20px; display: block; }
.icon-card h4 { color: var(--primary-gold); font-size: 0.9rem; font-weight: 500; line-height: 1.4; }

/* --- 9. CARDS DE SERVIÇO (ESTILO EXECUTIVA) --- */
.services-grid-executiva { display: grid; grid-template-columns: repeat(3, 1fr); gap: 30px; }
.service-card-executiva { position: relative; height: 400px; border-radius: 8px; overflow: hidden; background-size: cover; background-position: center; transition: transform 0.4s ease, box-shadow 0.4s ease; box-shadow: 0 5px 15px rgba(0,0,0,0.2); }
.service-card-executiva:hover { transform: scale(1.03) translateY(-5px); box-shadow: 0 10px 30px rgba(0,0,0,0.3); }
.service-card-executiva::after { content: ''; position: absolute; top: 0; left: 0; width: 100%; height: 100%; background: linear-gradient(to top, rgba(0,0,0,0.85), transparent 60%); }
.service-card-content { position: absolute; bottom: 25px; left: 25px; right: 25px; z-index: 2; }
.service-card-content h3 { color: var(--white); font-size: 1.6rem; margin-bottom: 10px; }
.service-card-content p { color: var(--text-light); margin-bottom: 15px; font-size: 0.95rem; }
.service-card-content a, .service-card-content a:visited { color: var(--primary-gold) !important; font-weight: 600; font-size: 0.9rem; text-decoration: none; }
.service-card-content a:hover { text-decoration: underline; }
.service-card-cta { padding: 8px 18px; font-size: 0.8rem; margin-top: 10px; }
.service-card-cta.cta-outline:hover { color: var(--dark-bg) !important; }

/* --- 10. CARDS DE BENEFÍCIOS (DIFERENCIAIS) --- */
.benefits-grid-company { display: grid; grid-template-columns: repeat(3, 1fr); gap: 30px; }
.benefit-card { background: var(--white); padding: 30px; border-radius: 8px; box-shadow: 0 5px 25px rgba(0,0,0,0.07); transition: transform 0.3s ease, box-shadow 0.3s ease; }
.benefit-card:hover { transform: translateY(-5px); box-shadow: 0 10px 30px rgba(0,0,0,0.1); }
.benefit-card i { font-size: 2.5rem; color: var(--primary-gold); margin-bottom: 20px; }
.benefit-card h4 { color: var(--text-dark); font-size: 1.3rem; margin-bottom: 10px; }
.benefit-card p { color: var(--text-dark); font-size: 0.95rem; line-height: 1.6; }
.benefit-card .values-list { list-style: none; padding: 0; margin-top: 10px; text-align: left; }
.benefit-card .values-list li { color: var(--text-dark); font-size: 0.95rem; margin-bottom: 8px; display: flex; align-items: flex-start; }
.benefit-card .values-list li i { font-size: 0.9rem; color: var(--primary-gold); margin-right: 10px; margin-top: 4px; font-weight: 600; margin-bottom: 0; }

/* --- 11. DEPOIMENTOS --- */
.testimonials-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 30px; }
.testimonial-card { background-color: var(--white); padding: 30px; border-radius: 8px; box-shadow: 0 5px 20px rgba(0,0,0,0.05); }
.testimonial-card .stars { color: var(--primary-gold); font-size: 1.1rem; margin-bottom: 15px; }
.testimonial-card .author { display: flex; align-items: center; margin-top: 20px; }
.testimonial-card .author img { height: 50px; width: 50px; border-radius: 50%; margin-right: 15px; object-fit: cover; }
.testimonial-card .author span { font-weight: 600; font-size: 0.9rem; color: var(--text-dark); }


/* --- 12. SEÇÃO CTA --- */
#cta { text-align: center; padding: 100px 0; background-size: cover; background-position: center; background-attachment: fixed; position: relative; }
#cta::after { content: ''; position: absolute; top: 0; left: 0; width: 100%; height: 100%; background: linear-gradient(rgba(0,0,0,0.7), rgba(0,0,0,0.7)); }
#cta .container { position: relative; z-index: 2; }
#cta h2 { color: var(--white); font-size: 2.5rem; margin-bottom: 15px; }
#cta p { color: var(--text-light); font-size: 1.2rem; margin-bottom: 30px; }

/* --- 13. CABEÇALHO DE PÁGINA INTERNA --- */
.page-title-header { padding: 60px 0; text-align: center; color: var(--white); background-size: cover; background-position: center; position: relative; }
.page-title-header::after { content: ''; position: absolute; top: 0; left: 0; width: 100%; height: 100%; background: linear-gradient(rgba(0,0,0,0.7), rgba(0,0,0,0.7)); }
.page-title-header .container { position: relative; z-index: 2; }
.page-title-header h1 { color: var(--primary-gold); font-size: 2.8rem; margin-bottom: 0; }

/* --- 14. PÁGINA "QUEM SOMOS" --- */
.about-us-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 50px; align-items: center; }
.about-us-image img { border-radius: 8px; box-shadow: 0 10px 30px rgba(0,0,0,0.2); }

/* --- 15. PÁGINA "CONTATO" --- */
.contact-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 50px; }
.contact-form h3, .contact-info h3 { color: var(--text-dark); margin-bottom: 30px; }
.form-group { margin-bottom: 20px; }
.form-group label { display: block; margin-bottom: 8px; font-weight: 500; }
.form-group input, .form-group textarea { width: 100%; padding: 14px; border: 1px solid #ddd; border-radius: 5px; font-family: var(--font-family); font-size: 1rem; background: var(--white); color: var(--text-dark); }
.form-group input:focus, .form-group textarea:focus { outline: none; border-color: var(--primary-gold); box-shadow: 0 0 5px rgba(204, 163, 83, 0.5); }
.info-item { display: flex; align-items: flex-start; gap: 20px; margin-bottom: 25px; }
.info-item i { font-size: 1.8rem; color: var(--primary-gold); margin-top: 5px; }
.info-item h4 { margin-bottom: 5px; }
.info-item p, .info-item a { margin-bottom: 0; font-size: 1rem; line-height: 1.5; color: var(--text-dark); }
.info-item a:hover { color: var(--primary-gold); }


/* --- 16. MAPA --- */
#map { padding: 0; line-height: 0; }
#map iframe { width: 100%; height: 450px; border: 0; }

/* --- 17. RODAPÉ (FOOTER) --- */
#contact-footer { background-color: var(--dark-footer); color: var(--text-muted); padding-top: 70px; padding-bottom: 0; }
.footer-grid { display: grid; grid-template-columns: 2fr 1fr 2fr; gap: 50px; }
.footer-column h3 { color: var(--primary-gold); font-size: 1.2rem; margin-bottom: 25px; }
.footer-column p { color: var(--text-muted); font-size: 0.95rem; margin-bottom: 10px; line-height: 1.8; }
.footer-column .footer-logo { height: 90px; width: auto; margin-bottom: 20px; }
.social-icons { margin-top: 20px; }
.social-icons a { color: var(--text-muted); font-size: 1.4rem; margin-right: 15px; transition: color 0.3s ease; }
.social-icons a:hover { color: var(--primary-gold); }
.footer-column ul li { margin-bottom: 12px; }
.footer-column ul a { color: var(--text-muted); font-size: 0.95rem; transition: color 0.3s ease, padding-left 0.3s ease; }
.footer-column ul a:hover { color: var(--white); padding-left: 5px; }
.footer-contact-item { display: flex; align-items: flex-start; gap: 15px; margin-bottom: 15px; }
.footer-contact-item i { color: var(--primary-gold); font-size: 1.1rem; margin-top: 5px; }
.footer-contact-item p { margin: 0; }
.footer-contact-item a { color: var(--text-muted); font-size: 0.95rem; }
.footer-contact-item a:hover { color: var(--white); }
.footer-column .cta-green { width: 100%; max-width: 250px; text-align: center; padding: 14px; font-size: 1rem; }
.footer-bottom { text-align: center; padding: 25px 0; margin-top: 40px; border-top: 1px solid #222; font-size: 0.9rem; color: #777; }


/* --- 18. BOTÃO WHATSAPP FLUTUANTE --- */
.whatsapp-float { position: fixed; bottom: 30px; right: 30px; background-color: var(--cta-green); color: var(--white); width: 60px; height: 60px; border-radius: 50%; display: flex; justify-content: center; align-items: center; font-size: 2.5rem; box-shadow: 0 4px 15px rgba(0,0,0,0.3); z-index: 99; transition: transform 0.3s ease; }
.whatsapp-float:hover { transform: scale(1.1); }

/* --- 19. SEÇÃO: GRID DE LOGOS (MARCAS, CLIENTES) --- */
.logo-grid { display: flex; flex-wrap: wrap; justify-content: center; align-items: center; gap: 40px; }
.logo-grid img { height: 50px; width: auto; opacity: 0.9; transition: opacity 0.3s ease; }
.logo-grid img:hover { opacity: 1; }

/* ======================================================
   --- ESTILOS ADICIONAIS PARA LANDING PAGES (LP) ---
========================================================= */

/* Hero Específico da LP */
.lp-hero { padding: 80px 0; text-align: center; }
.lp-hero h1 { font-size: 3rem; color: var(--primary-gold); }
.lp-subtitle { font-size: 1.2rem; color: var(--white); max-width: 700px; margin: 15px auto 0 auto; }

/* Seção Problema/Solução LP */
.lp-problem-solution { display: flex; align-items: center; gap: 30px; text-align: left; }
.lp-problem-solution.reverse { flex-direction: row-reverse; }
.lp-ps-icon { flex: 0 0 80px; text-align: center; }
.lp-ps-icon i { font-size: 3.5rem; color: var(--primary-gold); }
.lp-problem-solution h2 { text-align: left; margin-bottom: 10px; }
.lp-problem-solution p { color: var(--text-dark); } /* Texto escuro no fundo bege */

/* Benefícios Detalhados LP (Grid de Cards) */
.lp-benefits-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 30px; }
.lp-benefit-card { background-color: var(--dark-bg); color: var(--text-light); padding: 30px; border-radius: 8px; text-align: center; box-shadow: 0 5px 15px rgba(0,0,0,0.2); }
.lp-benefit-card .icon { margin-bottom: 20px; }
.lp-benefit-card .icon i { font-size: 2.8rem; color: var(--primary-gold); }
.lp-benefit-card h4 { color: var(--white); font-size: 1.3rem; margin-bottom: 10px; }
.lp-benefit-card p { color: var(--text-muted); font-size: 0.95rem; }

/* Layout 2 Colunas LP (Texto + Imagem) */
.lp-two-columns { display: flex; align-items: center; gap: 50px; }
.lp-column-text { flex: 1; }
.lp-column-image { flex: 0 0 45%; text-align: center; }
.lp-column-image img { border-radius: 8px; box-shadow: 0 10px 30px rgba(0,0,0,0.1); max-width: 100%; }

/* Checklist LP */
.lp-checklist { list-style: none; padding: 0; margin: 25px 0; }
.lp-checklist li { display: flex; align-items: flex-start; margin-bottom: 12px; font-size: 1rem; color: var(--text-dark); }
.lp-checklist li i { color: var(--cta-green); margin-right: 12px; margin-top: 5px; }

/* Cards Escuros (Reutiliza .benefit-card) */
.benefit-card.dark-card { background-color: var(--dark-bg); box-shadow: 0 5px 15px rgba(0,0,0,0.2); }
.benefit-card.dark-card:hover { box-shadow: 0 10px 25px rgba(0,0,0,0.3); }
.benefit-card.dark-card h4, .benefit-card.dark-card p { color: var(--text-light); }
.benefit-card.dark-card i { color: var(--primary-gold); }


/* ======================================================
   --- RESPONSIVIDADE (Incluindo LPs) ---
========================================================= */

@media (max-width: 992px) {
    .icon-card-grid { grid-template-columns: repeat(4, 1fr); }
    .services-grid-executiva { grid-template-columns: repeat(2, 1fr); }
    .testimonials-grid { grid-template-columns: 1fr; }
    .benefits-grid-company { grid-template-columns: repeat(2, 1fr); }
    .about-us-grid { grid-template-columns: 1fr; }
    .footer-grid { grid-template-columns: 1fr 1fr; }
    .contact-grid { grid-template-columns: 1fr; }
    .lp-benefits-grid { grid-template-columns: 1fr; } /* Benefícios LP em 1 coluna */
}

@media (max-width: 768px) {
    h1 { font-size: 2.2rem; }
    h2 { font-size: 2rem; }
    #hero { height: 80vh; }
    #hero h1 { font-size: 2.4rem; }
    
    #header, .sub-page #header { padding: 10px 0; }
    #header .logo img, .sub-page #header .logo img { height: 70px; }
    #header.scrolled { padding: 10px 0; }
    #header.scrolled .logo img { height: 70px; } 
    
    #nav-menu { display: none; position: absolute; top: 90px; left: 0; width: 100%; background-color: var(--dark-bg); box-shadow: 0 5px 10px rgba(0,0,0,0.2); z-index: 1001; }
    #nav-menu.active { display: block; }
    #nav-menu ul { flex-direction: column; }
    #nav-menu li { margin: 0; border-bottom: 1px solid #333; }
    #nav-menu a { display: block; padding: 15px 20px; color: var(--white); border: none; }
    #nav-menu a:hover { background-color: var(--primary-gold); color: var(--dark-bg); }
    #mobile-menu-toggle { display: block; }

    /* Responsividade LPs */
    .lp-hero h1 { font-size: 2.5rem; }
    .lp-subtitle { font-size: 1.1rem; }
    .lp-problem-solution { flex-direction: column; text-align: center; }
    .lp-problem-solution.reverse { flex-direction: column; } /* Mantém coluna */
    .lp-ps-icon { margin-bottom: 20px; flex: 0 0 auto; }
    .lp-problem-solution h2 { text-align: center; }
    .lp-two-columns { flex-direction: column; }
    .lp-column-image { order: -1; margin-bottom: 30px; flex: 0 0 auto; width: 100%; }
    
    /* Outras responsividades */
    .icon-card-grid { grid-template-columns: repeat(3, 1fr); gap: 15px; }
    .icon-card { padding: 20px 10px; }
    .icon-card i { font-size: 2rem; margin-bottom: 15px; }
    .icon-card h4 { font-size: 0.8rem; }
    .services-grid-executiva { grid-template-columns: 1fr; }
    .benefits-grid-company { grid-template-columns: 1fr; }
    .footer-grid { grid-template-columns: 1fr; text-align: center; }
    .footer-column .cta-green { max-width: 100%; }
    .footer-contact-item { justify-content: center; text-align: left; }
    .social-icons { justify-content: center; }
    .logo-grid img { height: 35px; }
}

@media (max-width: 480px) {
    .icon-card-grid { grid-template-columns: repeat(2, 1fr); }
    .icon-card h4 { font-size: 0.85rem; }
    .logo-grid img { height: 30px; } 
    .lp-hero h1 { font-size: 2.2rem; }
}