/* Box-sizing global para melhor controle de layout */
html {
    box-sizing: border-box;
}
*, *::before, *::after {
    box-sizing: inherit;
}

/* Variáveis de cores personalizadas */
:root {
    --primary-color: #5fe0e5; /* Azul - Nova cor primária */
    --secondary-color: #f99351; /* Laranja - Nova cor secundária */
    --light-bg: #fafcfc; /* Quase branco para fundos */
    --dark-bg: #5fe0e5; /* Azul para seções escuras */
    --text-color: #93b7a1; /* Verde para texto padrão */
    --white: #fff; /* Branco */
    --shadow: rgba(0, 0, 0, 0.1);
    --hover-color: #f99351; /* Cor de hover para botões e links */

    --whatsapp-color: #25D366; /* Cor oficial do WhatsApp */
    --whatsapp-darker: #1DA851; /* Tom mais escuro para hover do WhatsApp */

    /* Sobrescrever variáveis de cor do Bootstrap para manter a paleta */
    --bs-primary: var(--primary-color);
    --bs-secondary: var(--secondary-color);
    --bs-success: var(--whatsapp-color);
    --bs-light: var(--light-bg);
    --bs-body-color: var(--text-color);
    --bs-body-bg: var(--light-bg);
}

/* Ajuste do body para compensar a navbar fixa */
body {
    padding-top: 120px; /* Valor seguro para a navbar em todas as telas */
    font-family: 'Arial', sans-serif;
    line-height: 1.6;
    color: var(--text-color);
    scroll-behavior: smooth;
    background-color: var(--light-bg);
}

a {
    text-decoration: none;
    color: var(--primary-color);
}

a:hover {
    text-decoration: underline; /* Adiciona o sublinhado ao passar o mouse */
}

/* Base Headings */
h1 {
    font-size: 3em;
    color: var(--white);
    text-shadow: 2px 2px 4px var(--shadow);
    line-height: 1.2;
}

h2 {
    font-size: 2.2em;
    font-weight: bold;
    text-align: center;
    margin-top: 0;
    margin-bottom: 40px;
    color: var(--secondary-color); /* Título de seção na cor laranja */
    position: relative;
    padding-top: 20px;
}

h2::after {
    content: '';
    display: block;
    width: 70px;
    height: 4px;
    background-color: var(--secondary-color);
    margin: 15px auto 0;
    border-radius: 2px;
}

/* Cores específicas para H2 em seções com background escuro */
.custom-h2-white {
    color: var(--white);
}
.custom-h2-white::after {
    background-color: var(--white);
}

h3 {
    font-size: 1.2em;
    color: var(--white);
    margin-bottom: 10px;
}

p {
    margin-bottom: 1em;
}

/* Nova regra para a classe lead text-justify */
.lead.text-justify {
    color: black;
}

/* Header (Navbar Bootstrap Customização) */
.navbar {
    background-color: var(--white) !important; /* Força o branco no navbar */
    padding: 15px 40px;
    box-shadow: 0 2px 8px var(--shadow);
}

.navbar-brand.logo {
    font-weight: bold;
    font-size: 1.9em;
    letter-spacing: 1px;
    color: var(--secondary-color) !important; /* Cor do logo */
}

/* Centraliza a navbar-brand em telas pequenas (mobile) */
@media (max-width: 991.98px) {
    .navbar-brand.logo {
        margin-right: auto;
        margin-left: auto;
    }
    .custom-header-container {
        flex-direction: column;
        align-items: center;
        justify-content: center;
        text-align: center; /* Adicionado para garantir o alinhamento de texto */
    }
    .contact-info-nav {
        flex-direction: column;
        align-items: center !important;
        width: 100%;
        margin-top: 10px;
    }
    .contact-info-nav .btn, .contact-info-nav .phone {
        width: 100%;
        justify-content: center;
    }
    .contact-info-nav .mb-2.mb-lg-0.me-lg-3 {
        margin-right: 0 !important;
    }

    .custom-vantagem .icon {
        font-size: 3em;
    }
}

.contact-info-nav {
    gap: 25px;
}

.contact-info-nav .phone {
    font-size: 1.5em;
    color: var(--secondary-color);
    white-space: nowrap;
}

.contact-info-nav .phone i {
    font-size: 1.2em;
}

/* Botões Customizados */
.custom-cta-button {
    background-color: var(--whatsapp-color);
    border-color: var(--whatsapp-color);
    color: var(--white);
    padding: 12px 25px;
    border-radius: 50px;
    font-weight: bold;
    transition: background-color 0.3s ease, transform 0.2s ease, border-color 0.3s ease;
}

.custom-cta-button:hover {
    background-color: var(--whatsapp-darker);
    border-color: var(--whatsapp-darker);
    transform: translateY(-2px);
    text-decoration: none;
}

.custom-cta-large-button {
    padding: 18px 40px;
    font-size: 1.3em;
}

.custom-whatsapp-button {
    background-color: var(--whatsapp-color) !important;
    border-color: var(--whatsapp-color) !important;
    color: var(--white) !important;
    padding: 12px 25px;
    border-radius: 50px;
    font-weight: bold;
    transition: background-color 0.3s ease, transform 0.2s ease, border-color 0.3s ease;
}

.custom-whatsapp-button:hover {
    background-color: var(--whatsapp-darker) !important;
    border-color: var(--whatsapp-darker) !important;
    transform: translateY(-2px);
    text-decoration: none;
}

.custom-whatsapp-card-button {
    background-color: var(--whatsapp-color) !important;
    border-color: var(--whatsapp-color) !important;
    color: var(--white) !important;
    width: 100%;
    padding: 10px 0;
    font-size: 1.1em;
    border-radius: 50px;
    transition: background-color 0.3s ease, transform 0.2s ease, border-color 0.3s ease;
}

.custom-whatsapp-card-button:hover {
    background-color: var(--whatsapp-darker) !important;
    border-color: var(--whatsapp-darker) !important;
    transform: translateY(-2px);
    text-decoration: none;
}

/* Hero Banner */
.hero-banner {
    background: linear-gradient(rgba(43, 58, 83, 0.8), rgba(43, 58, 83, 0.8)), url('bg-hero.webp');
    background-size: 100% auto;
    background-repeat: no-repeat;
    background-position: center center;
    padding-top: 100px;
    padding-bottom: 80px;
    min-height: 60vh;
}

/* Corrigi a cor dos títulos no hero banner */
.hero-banner h1, .hero-banner h2 {
    color: var(--white);
}

/* Seções de Conteúdo - Backgrounds */
.bg-light-gray {
    background-color: var(--light-bg);
}

.custom-light-green-bg {
    background-color: var(--light-bg);
}

.custom-black-bg {
    background-color: var(--dark-bg);
}

/* Cards de Serviço */
.custom-card {
    border: none;
    border-radius: 12px;
    transition: transform 0.3s ease, box-shadow 0.3s ease;
    background-color: #fff;
}
.custom-card:hover {
    transform: translateY(-10px);
    box-shadow: 0 8px 20px rgba(0, 0, 0, 0.2) !important;
}
.custom-card img {
    height: 160px;
    object-fit: cover;
    border-top-left-radius: 12px;
    border-top-right-radius: 12px;
}
.custom-card .card-body {
    padding: 25px;
}
.custom-card .card-title {
    line-height: 1.2;
    color: var(--secondary-color); /* Título do card na cor laranja */
    font-size: 1.5em;
    text-align: center;
}
.custom-card .card-text {
    color: black; /* Parágrafos dos cards em preto */
    font-size: 1.2em;
    text-align: center;
}

/* Quem Somos */
.quem-somos-content img {
    border-radius: 12px;
}

.quem-somos-content p {
    color: black; /* Parágrafos da seção "Quem Somos" em preto */
}

/* Vantagens */
.custom-vantagem {
    border-radius: 10px;
    transition: transform 0.3s ease;
}
.custom-vantagem:hover {
    transform: translateY(-5px);
}
.custom-icon-color {
    color: var(--primary-color);
}
.custom-vantagem .icon {
    font-size: 3.8em;
}

/* Footer */
.custom-primary-bg {
    background-color: var(--primary-color);
}

.custom-footer-border {
    border-bottom: 1px solid rgba(255, 255, 255, 0.2) !important;
}

.footer-logo {
    font-weight: bold;
    font-size: 1.6em;
    margin-bottom: 30px;
    text-align: center;
    color: #000;
}

.footer-copy p {
    font-size: 1em;
    opacity: 0.8;
    color: #000;
}

/* Ajustes para links e ícones no footer */
.custom-primary-bg .col-md-4 h4 {
    color: var(--secondary-color); /* Títulos do footer em laranja */
    font-weight: bold; /* Títulos do footer em negrito */
}

.custom-primary-bg .col-md-4 p,
.custom-primary-bg .col-md-4 a {
    color: black; /* Restante do texto do footer em preto */
}

.custom-primary-bg .col-md-4 a:hover {
    color: var(--hover-color) !important;
    text-decoration: none;
}

.custom-primary-bg .social-icons a {
    color: black!important; /* Ícones sociais em preto */
    font-size: 1.6em;
    margin-right: 15px;
    transition: color 0.3s ease;
}

.custom-primary-bg .social-icons a:hover {
    color: var(--hover-color) !important;
    text-decoration: none;
}

/* Botões Flutuantes (mantidos como estavam, pois não são componentes Bootstrap) */
.back-to-top-btn {
    display: none;
    position: fixed;
    bottom: 30px;
    right: 30px;
    background-color: var(--secondary-color);
    color: var(--white);
    width: 55px;
    height: 55px;
    border-radius: 8px;
    text-align: center;
    font-size: 1.5em;
    display: flex;
    justify-content: center;
    align-items: center;
    box-shadow: 0 4px 10px rgba(0, 0, 0, 0.2);
    z-index: 999;
    transition: background-color 0.3s ease, transform 0.2s ease;
}

.back-to-top-btn:hover {
    background-color: var(--hover-color);
    transform: translateY(-3px);
    text-decoration: none;
}

.whatsapp-float-btn {
    position: fixed;
    bottom: 30px;
    left: 30px;
    width: 60px;
    height: 60px;
    border-radius: 50%;
    text-align: center;
    line-height: 60px;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.3);
    z-index: 999;
    transition: background-color 0.3s ease, transform 0.2s ease;
    background-color: var(--whatsapp-color);
    color: var(--white);
}
.whatsapp-float-btn i {
    font-size: 2.2em;
    line-height: 1;
    vertical-align: middle;
}

.whatsapp-float-btn:hover {
    background-color: var(--whatsapp-darker);
    transform: translateY(-2px);
}

/* --- Responsividade (Ajustes finos para o Bootstrap) --- */

@media (max-width: 991.98px) {
    /* Centraliza o conteúdo da navbar */
    .navbar .container-fluid, .navbar .custom-header-container {
        display: flex;
        flex-direction: column;
        justify-content: center;
        align-items: center;
    }

    .navbar-brand.logo {
        margin-right: auto;
        margin-left: auto;
    }
    .custom-header-container {
        flex-direction: column;
        align-items: center;
        justify-content: center;
    }
    .contact-info-nav {
        flex-direction: column;
        align-items: center !important;
        width: 100%;
        margin-top: 10px;
    }
    .contact-info-nav .btn, .contact-info-nav .phone {
        width: 100%;
        justify-content: center;
    }
    .contact-info-nav .mb-2.mb-lg-0.me-lg-3 {
        margin-right: 0 !important;
    }

    .custom-vantagem .icon {
        font-size: 3em;
    }
}

@media (max-width: 767.98px) {
    h1 {
        font-size: 2.2em;
    }
    h2 {
        font-size: 1.8em;
    }

    /* Reduz o tamanho do texto do hero banner em mobile */
    .hero-banner .lead {
        font-size: 1.2em;
    }

    /* Faz todos os containers ocuparem a largura total da tela em mobile */
    .container {
        width: 100% !important;
        max-width: 100% !important;
    }

    /* Centraliza o texto da seção "Quem Somos" */
    .quem-somos-content p {
        text-align: center;
    }

    /* Ajusta o padding do container dentro do hero banner */
    .hero-banner .container {
        padding-top: calc(1.5rem + 15px); /* Aumenta em 15px */
        padding-bottom: calc(1.5rem - 5px); /* Diminui em 5px */
    }

    .custom-vantagem .icon {
        font-size: 2.5em;
    }

    .whatsapp-float-btn, .back-to-top-btn {
        width: 50px;
        height: 50px;
        font-size: 1.8em;
        line-height: 50px;
        bottom: 20px;
    }
    /* Otimização para o botão do WhatsApp */
    .whatsapp-float-btn {
        left: 20px; /* Mantém o botão na esquerda */
        right: auto; /* Remove o conflito de posicionamento */
    }
    .back-to-top-btn {
        right: 20px;
    }
}

@media (max-width: 575.98px) {
    h1 {
        font-size: 1.8em;
    }
    .hero-banner p {
        font-size: 1em;
    }
    .navbar {
        padding: 10px 15px;
    }
    .footer-column {
        text-align: center !important;
    }
    .footer-column h4, .footer-column p {
        justify-content: center !important;
    }
    .social-icons {
        justify-content: center;
        display: flex;
    }
}

/* Estilização específica para a imagem da logo na navbar */
.navbar-brand .logo-img {
    height: 128px; /* Define uma altura fixa para a logo. Ajuste conforme necessário. */
    width: auto; /* Mantém a proporção da imagem */
}

/* Ajuste para telas menores se a logo ficar grande demais */
@media (max-width: 575.98px) {
    .navbar-brand .logo-img {
        height: 64px; /* Diminui a altura da logo em telas pequenas */
    }
}

/* --- Ajustes de responsividade adicionados --- */

/* Centraliza navbar e seu conteúdo no mobile */
@media (max-width: 767.98px) {
  .navbar .container-fluid {
    flex-direction: column;
    align-items: center;
    justify-content: center;
    text-align: center;
  }

  .contact-info-nav {
    flex-direction: column;
    align-items: center !important;
    width: 100%;
    margin-top: 10px;
    gap: 10px;
  }

  .contact-info-nav .btn,
  .contact-info-nav .phone {
    width: 100%;
    justify-content: center;
  }
}

/* Reduz o tamanho do subtítulo no hero banner em telas menores */
@media (max-width: 767.98px) {
  .hero-banner h2 {
    font-size: 1.5em !important;
    line-height: 1.3;
    margin-bottom: 20px;
  }
}

/* Centraliza texto da seção "Quem Somos" em telas pequenas */
@media (max-width: 767.98px) {
  #quem-somos p {
    text-align: center !important;
  }
}