html,
body {
    width: 100%;
    overflow-x: hidden;
    padding-top: 43px;
}

/* Preloader */
.preloader {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: linear-gradient(0deg, #002036, #002036),
        linear-gradient(0deg, rgba(0, 32, 54, 0.2) 0%, rgba(0, 179, 255, 0.2) 100%);

    display: flex;
    justify-content: center;
    align-items: center;
    z-index: 9999;
    transition: all 0.6s ease;
}

.loader {
    width: 50px;
    height: 50px;
    border: 5px solid rgba(255, 255, 255, 0.3);
    border-top: 5px solid #fff;
    border-radius: 50%;
    animation: spin 1s linear infinite;
}

@keyframes spin {
    0% {
        transform: rotate(0deg);
    }

    100% {
        transform: rotate(360deg);
    }
}

.preloader.fade-out {
    opacity: 0;
    visibility: hidden;
}

/* Custom Styles */
:root {
    --primary-blue: #013957;
    --secondary-blue: #2a5298;
    --light-blue: #4a90e2;
    --dark-blue: #0f2347;
    --text-dark: #000;
    --text-light: #666;
}

body {
    /* Fonte alterada para Ubuntu */
    font-family: 'Ubuntu', sans-serif;
    line-height: 1.6;
    overflow-x: hidden;
    max-width: 100vw;
}

/* Navigation */
.navbar {
    /* Cor de fundo sólida que ficará por baixo */
    background-color: #002036;

    /* Gradiente semi-transparente que ficará por cima da cor */
    background-image: linear-gradient(0deg, rgba(0, 32, 54, 0.2) 0%, rgba(0, 179, 255, 0.2) 100%);
    /*background: rgba(30, 60, 114, 0.95);*/
    border-bottom: 1px solid rgba(255, 255, 255, 0.4);
    backdrop-filter: blur(5px);
    transition: all 0.3s ease;
    padding: 1rem 0;
}

.navbar.scrolled {
    /* Cor de fundo sólida que ficará por baixo */
    background-color: #002036;

    /* Gradiente semi-transparente que ficará por cima da cor */
    background-image: linear-gradient(0deg, rgba(0, 32, 54, 0.2) 0%, rgba(0, 179, 255, 0.2) 100%);
    padding: 0.5rem 0;
    box-shadow: 0 2px 20px rgba(0, 0, 0, 0.1);
}

.navbar-brand {
    font-size: 1.8rem;
    font-weight: bold;
    color: white !important;
    text-decoration: none;
}

.navbar-nav .nav-link {
    color: rgba(255, 255, 255, 0.9) !important;
    font-weight: 500;
    margin: 0 1rem;
    transition: all 0.3s ease;
    position: relative;
}

.navbar-nav .nav-link:hover {
    color: #fff !important;
}

.navbar-nav .nav-link::after {
    content: '';
    position: absolute;
    width: 0;
    height: 2px;
    bottom: 0;
    left: 50%;
    background: #fff;
    transition: all 0.3s ease;
}

.navbar-nav .nav-link:hover::after {
    width: 100%;
    left: 0;
}


/* Hero Section */
.hero-section {
    background: linear-gradient(360deg, rgba(0, 80, 136, 0.2) 28.55%, rgba(0, 20, 34, 0.8) 88.43%);

    /* url('../images/banner-1.jpg');

    background-size: cover;*/
    /* Faz a imagem cobrir todo o espaço, sem distorcer */
    background-position: center center;
    background-repeat: no-repeat;

    min-height: 95vh;
    display: flex;
    align-items: center;
    position: relative;
    overflow: hidden;
}

.hero-section-contact {

    background-size: cover !important;
    /* Faz a imagem cobrir todo o espaço, sem distorcer */
    background-position: center center;
    background-repeat: no-repeat;

    min-height: 85vh;
    display: flex;
    align-items: center;
    position: relative;
    overflow: hidden;
}

.hero-section-contact {
    /* Usa a imagem de desktop como padrão */
    background-image: var(--bg-desktop);
}

@media (max-width: 768px) {
    .hero-section-contact {
        /* Em telas menores, usa a imagem mobile. Se não houver, mantém a de desktop. */
        background-image: var(--bg-mobile, var(--bg-desktop));
    }
}

.hero-section-scmanaus {

    background-size: cover !important;
    /* Faz a imagem cobrir todo o espaço, sem distorcer */
    background-position: center center;
    background-repeat: no-repeat;

    min-height: 90vh;
    display: flex;
    align-items: center;
    position: relative;
    overflow: hidden;
}

.hero-section-scmanaus {
    /* Usa a imagem de desktop como padrão */
    background-image: var(--bg-desktop);
}

@media (max-width: 768px) {
    .hero-section-scmanaus {
        /* Em telas menores, usa a imagem mobile. Se não houver, mantém a de desktop. */
        background-image: var(--bg-mobile, var(--bg-desktop));
    }
}

.hero-section-jds {


    background-size: cover !important;
    /* Faz a imagem cobrir todo o espaço, sem distorcer */
    background-position: center center;
    background-repeat: no-repeat;

    min-height: 90vh;
    display: flex;
    align-items: center;
    position: relative;
    overflow: hidden;
}

.hero-section-jds {
    /* Usa a imagem de desktop como padrão */
    background-image: var(--bg-desktop);
}

@media (max-width: 768px) {
    .hero-section-jds {
        /* Em telas menores, usa a imagem mobile. Se não houver, mantém a de desktop. */
        background-image: var(--bg-mobile, var(--bg-desktop));
    }
}

.hero-section-dantar {


    background-size: cover !important;
    /* Faz a imagem cobrir todo o espaço, sem distorcer */
    background-position: center center;
    background-repeat: no-repeat;

    min-height: 90vh;
    display: flex;
    align-items: center;
    position: relative;
    overflow: hidden;
}

.hero-section-dantar {
    /* Usa a imagem de desktop como padrão */
    background-image: var(--bg-desktop);
}

@media (max-width: 768px) {
    .hero-section-dantar {
        /* Em telas menores, usa a imagem mobile. Se não houver, mantém a de desktop. */
        background-image: var(--bg-mobile, var(--bg-desktop));
    }
}

.hero-content {
    z-index: 2;
    position: relative;
    margin-left: 70px;
    min-width: 450px;
}

.hero-content-inner {
    z-index: 2;
    position: relative;
    min-width: 450px;
}

.hero-title {
    font-size: 2.5rem;
    font-weight: 600;
    color: white;
    margin-bottom: 1rem;

}

.hero-title span {
    font-weight: 300;
}

.hero-subtitle {
    font-size: 1.3rem;
    color: rgba(255, 255, 255, 0.9);
    margin-bottom: 2rem;
}

/* Brands Section */
.brands-section {
    /* Cor de fundo sólida que ficará por baixo */
    background-color: #002036;

    /* Gradiente semi-transparente que ficará por cima da cor */
    background-image: linear-gradient(0deg, rgba(0, 32, 54, 0.2) 0%, rgba(0, 179, 255, 0.2) 100%);
    padding: 2rem 0;
    color: white;
}

.brand-card {
    padding: 2rem;
    margin-bottom: 0rem;
    border-right: 1px solid rgba(255, 255, 255, 0.4);
    transition: all 0.3s ease;
    height: 100%;
}

.brands-section .row .col-lg-3:first-child .brand-card,
.brands-section .row .col-md-6:first-child .brand-card {
    border-left: 1px solid rgba(255, 255, 255, 0.4);
}

.brand-card:hover {
    transform: translateY(-10px);
    /*background: rgba(255, 255, 255, 0.2);*/
}

.brand-logo {
    font-size: 2rem;
    margin-bottom: 2rem;
    color: #4a90e2;
}

/* About Section */
.about-section {
    padding: 6rem 0;
    background: url('../images/bg-sobre.jpg') no-repeat center;
    background-size: cover;
}

.section-title {
    font-size: 2.5rem;
    font-weight: 700;
    color: var(--text-dark);
    margin-bottom: 1.5rem;
    margin-top: 30px;
}

.section-title-brands {
    font-size: 24px;
    font-weight: 700;
    color: var(--text-dark);
    margin-bottom: 1.5rem;
    margin-top: 30px;
}

.section-subtitle {
    font-size: 1.1rem;
    color: var(--text-dark);
    font-weight: 400;
    margin-bottom: 3rem;
}

.section-subheader {
    font-size: 16px;
    font-weight: 300;
    color: var(--text-dark);

}

.profile-card {
    background: white;
    border-radius: 20px;
    padding: 2rem;
    box-shadow: 0 15px 35px rgba(0, 0, 0, 0.1);
    border: none;
}

.profile-image {
    width: 120px;
    height: 120px;
    border-radius: 50%;
    object-fit: cover;
    border: 4px solid var(--light-blue);
}

.about-feature-item {
    font-size: 1.2rem;
    font-weight: 500;
    color: var(--text-dark);
    margin-bottom: 1rem;
    /* Reduz o espaço entre os itens */
    line-height: 1.4;
}

.about-feature-item:last-child {
    margin-bottom: 0;
}

/* Services Section */
.services-section {
    padding: 6rem 0;
    background: #EDF1FF;
}

/* ALTERAÇÃO: Novo bloco para conter as 3 marcas */
.services-block {
    background: white;
    border-radius: 15px;
    padding: 3rem 1.5rem;
    box-shadow: 0 10px 30px rgba(0, 0, 0, 0.1);
}

/* ALTERAÇÃO: Estilo do card individual removido/simplificado */
.service-card {
    text-align: left;
    border: none;
    height: 100%;
    padding-left: 45px;
    padding-right: 45px;
}

/* ALTERAÇÃO: Hover removido do card individual */
.service-card:hover {
    /* transform: translateY(-10px); */
    /* box-shadow: 0 20px 40px rgba(0, 0, 0, 0.15); */
}

.service-icon {
    width: 80px;
    height: 80px;
    margin: 0 auto 2rem;
    /*background: linear-gradient(135deg, var(--light-blue), var(--secondary-blue));
            border-radius: 50%;*/
    display: flex;
    align-items: center;
    justify-content: center;
    color: white;
    font-size: 2rem;
}

.btn-service {
    background: var(--primary-blue);
    color: white;
    border: none;
    padding: 0.8rem 2rem;
    border-radius: 25px;
    font-weight: 600;
    transition: all 0.3s ease;
    text-decoration: none;
    display: inline-block;
}

.btn-service:hover {
    background: var(--dark-blue);
    transform: translateY(-2px);
    color: white;
}

/* Map Section */
.map-section {
    padding: 6rem 0;
    background: #ffffff;
}

.brazil-map {
    width: 100%;
    max-width: 400px;
    height: auto;
    margin: 0 auto;
    display: block;
}

/* Partners Section - REMOVED */

/* CTA Section */
.cta-section {
    padding: 4rem 0;
    background: #EDF1FF;
}

.btn-cta {
    background: var(--primary-blue);
    color: white;
    border: none;
    padding: 1rem 2rem;
    padding-left: 18px;
    border-radius: 50px;
    font-weight: 700;
    font-size: 1.1rem;
    transition: all 0.3s ease;
    text-decoration: none;
    display: inline-block;
    margin-right: 130px;
}

.btn-cta:hover {
    background: var(--secondary-blue);
    transform: translateY(-3px);
    box-shadow: 0 10px 25px rgba(0, 0, 0, 0.2);
    color: white;
}

/* Footer */
.footer {
    /* Cor de fundo sólida que ficará por baixo */
    background-color: #002036;

    /* Gradiente semi-transparente que ficará por cima da cor */
    background-image: linear-gradient(0deg, rgba(0, 32, 54, 0.2) 0%, rgba(0, 179, 255, 0.2) 100%);
    color: white;
    padding: 0;
}

.footer h5 {
    color: white;
    margin-bottom: 1.5rem;
}

.footer a {
    color: rgba(255, 255, 255, 0.8);
    text-decoration: none;
    transition: all 0.3s ease;
}

.footer a:hover {
    color: white;
}

.social-icons a {
    display: inline-block;
    font-size: 23px;
    width: 40px;
    height: 40px;
    /*background: rgba(255, 255, 255, 0.1);
            border-radius: 50%;*/
    text-align: center;
    line-height: 40px;
    /*margin-right: 10px;*/
    transition: all 0.3s ease;
}

.social-icons a:hover {
    background: var(--light-blue);
    transform: translateY(-3px);
}

/* Responsive Design */
@media (max-width: 768px) {
    .hero-title {
        font-size: 2.5rem;
    }

    .section-title {
        font-size: 2rem;
    }

    .navbar-nav .nav-link {
        margin: 0 0.5rem;
    }
}

/* Floating Animation */
.floating {
    animation: floating 3s ease-in-out infinite;
}

@keyframes floating {

    0%,
    100% {
        transform: translateY(0px);
    }

    50% {
        transform: translateY(-10px);
    }
}

/* Pulse Animation */
.pulse {
    animation: pulse 2s infinite;
}

@keyframes pulse {
    0% {
        transform: scale(1);
    }

    50% {
        transform: scale(1.05);
    }

    100% {
        transform: scale(1);
    }
}

/* --- INÍCIO: NOVOS ESTILOS PARA O RODAPÉ --- */

/* Garante que a linha principal do rodapé seja um container flex,
   forçando as colunas filhas a terem a mesma altura. */
.footer .row {
    display: flex;
    flex-wrap: wrap;
    /* Permite que as colunas quebrem em telas menores */
}

/* Aplica a borda vertical à coluna da direita.
   Como a coluna agora tem 100% da altura (graças ao flex), a borda também terá. */
.footer-content-divider {
    border-left: 1px solid rgba(255, 255, 255, 0.4);
    /* Mantemos um padding interno para afastar o CONTEÚDO da borda. */
    padding-left: 2.5rem;
}

/* Área do copyright, onde a mágica acontece. */
.footer-copyright-area {
    /* 1. A borda superior que queremos esticar. */
    border-top: 1px solid rgba(255, 255, 255, 0.4);
    padding-top: 1.5rem;
    margin-top: 1rem;

    /* 2. Usamos margem negativa para fazer a área "escapar" do padding
       do seu container pai (.footer-content-divider). Isso estica a
       borda horizontal para a esquerda. */
    margin-left: -2.5rem;

    /* 3. Devolvemos o padding para o conteúdo de texto, para que ele
       fique alinhado corretamente com o resto. */
    padding-left: 2.5rem;
}


/* Ajuste para telas menores (desativa a borda e os truques de margem) */
@media (max-width: 992px) {
    .footer-content-divider {
        border-left: none;
        padding-left: 0.75rem;
        /* Padding padrão do bootstrap */
    }

    .footer-copyright-area {
        margin-left: 0;
        padding-left: 0;
    }
}

.footer-col-content {
    padding-top: 4rem;
    padding-bottom: 2rem;
}

/* Adiciona uma margem de 10 pixels na parte de baixo de cada item da lista */
.list-unstyled li {
    margin-bottom: 18px;
    /* Ajuste o valor para o espaçamento desejado */
}

/* Opcional: Remove a margem do último item para não ter espaço extra no final */
.list-unstyled li:last-child {
    margin-bottom: 0;
}

/* --- FIM: NOVOS ESTILOS PARA O RODAPÉ --- */
/* --- INÍCIO: ESTILOS PARA NOVA IMAGEM ABOUT --- */

.about-image-wrapper {
    position: relative;
    width: 100%;
    max-width: 400px;
    /* Ajuste o tamanho máximo conforme necessário */
    margin: 0 auto;
    min-height: 350px;
    /* Garante altura para posicionamento */
    display: flex;
    align-items: center;
    justify-content: center;
}

.about-image-wrapper-brands {
    position: relative;
    width: 100%;
    max-width: 493px;
    /* Ajuste o tamanho máximo conforme necessário */
    margin: 0 auto;
    min-height: 350px;
    /* Garante altura para posicionamento */
    display: flex;
    align-items: center;
    justify-content: center;
}

.about-img-bg {
    position: absolute;
    width: 100%;
    max-width: 274px;
    height: auto;
    top: 70%;
    left: 100%;
    transform: translate(-50%, -50%);
    z-index: 1;
    opacity: 0.8;
    /* Opcional: para dar um efeito mais suave */
}

.about-img-brands {
    position: relative;
    /* Mudado para relative para facilitar o alinhamento */
    width: 100%;
    max-width: 493px;
    /* A imagem do perfil terá 80% do tamanho do wrapper */
    z-index: 2;

    margin-top: -130px;
    /* Empurra a imagem um pouco para cima */
}

.about-img-profile {
    position: relative;
    /* Mudado para relative para facilitar o alinhamento */
    width: 100%;
    max-width: 335px;
    /* A imagem do perfil terá 80% do tamanho do wrapper */
    z-index: 2;

    margin-top: -130px;
    /* Empurra a imagem um pouco para cima */
}

.about-caption {
    position: absolute;
    bottom: 20px;
    /* Posição a partir do fundo */
    left: 0%;
    transform: translateX(0%);
    z-index: 3;
    text-align: center;
    width: 100%;
}

.about-caption h5 {
    color: #333;
    font-weight: 700;
    font-size: 0.8rem;
    margin: 0;
}

.about-caption p {
    color: #666;
    font-size: 0.8rem;
    margin: 0;
}

/* --- FIM: ESTILOS PARA NOVA IMAGEM ABOUT --- */

/* --- INÍCIO: ESTILOS GALERIA DE LÂMINAS --- */
.gallery-container {
    max-width: 100%;
    padding: 0 5%;
    margin: 3rem auto 0;
    position: relative;
}

.gallery-wrapper {
    display: flex;
    overflow-x: auto;
    scroll-behavior: smooth;
    -webkit-overflow-scrolling: touch;
    /* for smooth scrolling on iOS */
    scrollbar-width: none;
    /* Firefox */
    -ms-overflow-style: none;
    /* Internet Explorer 10+ */
    padding-bottom: 1rem;
    /* Space for scrollbar if it appears */
}

.gallery-wrapper::-webkit-scrollbar {
    display: none;
    /* Safari and Chrome */
}

.gallery-item {
    flex: 0 0 25%;
    /* Show 4 items on large screens */
    padding: 0 10px;
    box-sizing: border-box;
}

.gallery-item img {
    width: 100%;
    height: auto;
    border-radius: 10px;
    display: block;
    /*box-shadow: 0 4px 15px rgba(0, 0, 0, 0.1);*/
}

.gallery-nav {
    text-align: center;
    margin-top: 1.5rem;
}

.gallery-nav button {
    background-color: white;
    border: 1px solid black;
    color: black;
    border-radius: 50%;
    width: 45px;
    height: 45px;
    font-size: 1rem;
    cursor: pointer;
    transition: all 0.3s ease;
    margin: 0 10px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.gallery-nav button:hover {
    background-color: var(--primary-blue);
    border: 1px solid white;
    color: white;
    transform: scale(1.1);
}

/* Responsive adjustments for the gallery */
@media (max-width: 992px) {
    .gallery-item {
        flex: 0 0 33.33%;
        /* Show 3 items */
    }
}

@media (max-width: 768px) {
    .gallery-item {
        flex: 0 0 50%;
        /* Show 2 items */
    }
}

@media (max-width: 576px) {
    .gallery-item {
        flex: 0 0 90%;
        /* Show 1 item mostly */
    }
}

/* --- FIM: ESTILOS GALERIA DE LÂMINAS --- */

.navbar-nav .nav-link::after {
    content: '';
    position: absolute;
    width: 0;
    height: 2px;
    bottom: 0;
    left: 50%;
    background: #fff;
    transition: all 0.3s ease;
}

.navbar-nav .nav-link:hover::after {
    width: 100%;
    left: 0;
}

/* --- INÍCIO: ESTILOS PARA DROPDOWN DO MENU --- */

.navbar .dropdown-menu {
    background-color: #002036;
    /* Cor de fundo para combinar com a navbar */
    border: 1px solid rgba(255, 255, 255, 0.4);
    /* Borda sutil como a da navbar */
    border-radius: 0.5rem;
    /* Bordas arredondadas */
    margin-top: 0.5rem;
    /* Pequeno espaçamento do topo */
    padding: 0.5rem 0;
    backdrop-filter: blur(5px);
    /* Efeito de vidro para consistência */
}

.navbar .dropdown-item {
    color: rgba(255, 255, 255, 0.9);
    /* Cor do texto igual aos outros links */
    font-weight: 500;
    padding: 0.5rem 1.5rem;
    transition: all 0.3s ease;
}

.navbar .dropdown-item:hover,
.navbar .dropdown-item:focus {
    color: #ffffff;
    /* Texto mais claro no hover */
    background-color: rgba(0, 179, 255, 0.2);
    /* Fundo sutil no hover, usando cor do tema */
}

/* --- FIM: ESTILOS PARA DROPDOWN DO MENU --- */

.navbar-nav .nav-link::after {
    content: '';
    position: absolute;
    width: 0;
    height: 2px;
    bottom: 0;
    left: 50%;
    background: #fff;
    transition: all 0.3s ease;
}

.navbar-nav .nav-link:hover::after {
    width: 100%;
    left: 0;
}

/* Dropdown Styles */
.navbar-nav .dropdown-menu {
    background: rgba(0, 32, 54, 0.98);
    border: 1px solid rgba(255, 255, 255, 0.2);
    border-radius: 8px;
    padding: 0.5rem 0;
    margin-top: 0.5rem;
    box-shadow: 0 10px 30px rgba(0, 0, 0, 0.3);
    backdrop-filter: blur(10px);
}

.navbar-nav .dropdown-item {
    color: rgba(255, 255, 255, 0.9) !important;
    padding: 0.7rem 1.5rem;
    transition: all 0.3s ease;
    font-weight: 500;
}

.navbar-nav .dropdown-item:hover {
    background: rgba(255, 255, 255, 0.1);
    color: #fff !important;
    padding-left: 2rem;
}

.navbar-nav .dropdown-toggle::after {
    margin-left: 0.5rem;
    vertical-align: 0.15em;
}

.navbar-nav .nav-link.dropdown-toggle::after {
    border: none !important;
}

/* --- ABRIR DROPDOWN COM HOVER EM DESKTOPS --- */
@media (min-width: 992px) {
    .navbar .nav-item.dropdown:hover .dropdown-menu {
        display: block;
        margin-top: 0;
        margin-left: 15px;
    }
}

/* --- WHATSAPP BUTTON --- */
.whatsapp-fixed {
    position: fixed;
    bottom: 25px;
    right: 25px;
    z-index: 9;
}

.btn-whatsapp {
    background-color: #30bf39;
    color: #fff;
    border-radius: 100%;
    transition: background-color .5s;
    width: 60px !important;
    height: 60px !important;
    line-height: 70px;
    position: relative !important;
    display: block;
    transform: none !important;
    z-index: 9;
    text-align: center;
    box-shadow:
        0 1px 2px rgba(0, 0, 0, 0.07),
        0 2px 4px rgba(0, 0, 0, 0.07),
        0 4px 8px rgba(0, 0, 0, 0.07),
        0 8px 16px rgba(0, 0, 0, 0.07),
        0 16px 32px rgba(0, 0, 0, 0.07),
        0 32px 64px rgba(0, 0, 0, 0.07);
}

.btn-whatsapp:hover {
    background-color: #53ca5b;
}

.whatsapp-fixed a.video-vemo-icon.btn-whatsapp i {
    font-size: 32px;
    color: #fff;
    /*animation: sm-shake-animation linear 1.5s infinite;*/
    animation-delay: 3s;
}

.rs-video .animate-border .video-vemo-icon:before {
    content: "";
    border: 2px solid #fff;
    position: absolute;
    z-index: 0;
    left: 50%;
    top: 50%;
    opacity: 0;
    transform: translateX(-50%) translateY(-50%);
    display: block;
    width: 180px;
    height: 180px;
    border-radius: 50%;
    animation: zoomBig 3.25s linear infinite;
    -webkit-animation-delay: 4s;
    animation-delay: 4s;
}

.rs-video .animate-border .video-vemo-icon:after {
    content: "";
    border: 2px solid #fff;
    position: absolute;
    opacity: 0;
    z-index: 0;
    left: 50%;
    top: 50%;
    transform: translateX(-50%) translateY(-50%);
    display: block;
    width: 180px;
    height: 180px;
    border-radius: 50%;
    animation: zoomBig 3.25s linear infinite;
    -webkit-animation-delay: 3s;
    animation-delay: 3s;
}

.btn-whatsapp:after,
.btn-whatsapp:before {
    border: 2px solid #30bf39 !important;
    width: 130px !important;
    height: 130px !important;
}

.sm-red-dot {
    position: absolute;
    right: 4px;
    top: 4px;
    width: 12px;
    height: 12px;
    margin: 0 auto;
    background: red;
    transform: scale(0);
    border-radius: 50%;
    animation-name: notificationPoint;
    animation-duration: 300ms;
    animation-fill-mode: forwards;
    animation-delay: 3s;
}

.quick-message {
    position: absolute;
    bottom: 10px;
    right: 88px;
    width: max-content;
    border-radius: 30px;

    box-shadow: 0 1.93465px 7.73859px rgb(0 0 0 / 15%);
    background: #fff;
}

.line-up {
    opacity: 0;
    animation-name: anim-lineUp;
    animation-duration: 0.75s;
    animation-fill-mode: forwards;
    animation-delay: 5s;
}

.quick-message p {

    font-size: 15px;
    padding: 6px 16px;
    height: 40px;
    position: relative;
    color: #000;
    margin: 0;
}

.quick-message .seta-direita:before {
    display: inline-block;
    content: "";
    vertical-align: middle;
    margin-right: 21px;
    width: 0;
    height: 0;
    border-top: 12px solid transparent;
    border-bottom: 12px solid transparent;
    border-left: 12px solid #fff;
    position: absolute;
    bottom: 8px;
    right: -28px;
}

#hover-message {
    display: none;
}

.whatsapp-fixed:hover #hover-message {
    display: block;
}

@keyframes zoomBig {
    0% {
        transform: translate(-50%, -50%) scale(.5);
        opacity: 1;
        border-width: 3px
    }

    40% {
        opacity: .5;
        border-width: 2px
    }

    65% {
        border-width: 1px
    }

    100% {
        transform: translate(-50%, -50%) scale(1);
        opacity: 0;
        border-width: 1px
    }
}

@keyframes sm-shake-animation {
    0% {
        transform: rotate(0) scale(1) skew(0.017rad)
    }

    25% {
        transform: rotate(0) scale(1) skew(0.017rad)
    }

    35% {
        transform: rotate(-0.3rad) scale(1) skew(0.017rad)
    }

    45% {
        transform: rotate(0.3rad) scale(1) skew(0.017rad)
    }

    55% {
        transform: rotate(-0.3rad) scale(1) skew(0.017rad)
    }

    65% {
        transform: rotate(0.3rad) scale(1) skew(0.017rad)
    }

    75% {
        transform: rotate(0) scale(1) skew(0.017rad)
    }

    100% {
        transform: rotate(0) scale(1) skew(0.017rad)
    }
}

@keyframes notificationPoint {
    from {
        transform: scale(0)
    }

    to {
        transform: scale(1)
    }
}

@keyframes anim-lineUp {
    from {
        transform: translateY(100%);
    }

    to {
        opacity: 1;
        transform: translateY(0%);
    }
}

/* --- INÍCIO: ESTILOS PARA O NOVO MENU MOBILE LATERAL --- */

/* Botão de abrir o menu (hambúrguer) */
.menu-toggle-btn {
    background: none !important;
    border: none !important;
    color: white;
    font-size: 2.2rem;
    line-height: 1;
    padding: 0 0.5rem;
    transition: all 0.3s ease;
    z-index: 1051;
    /* Para ficar acima de outros elementos da navbar */
}

.menu-toggle-btn:hover {
    transform: scale(1.1);
    color: #4a90e2;
}

/* O menu lateral em si (escondido por padrão) */
.side-menu {
    position: fixed;
    top: 0;
    right: -100%;
    /* Começa fora da tela */
    width: 100%;
    max-width: 380px;
    /* Largura máxima em telas maiores */
    height: 100vh;
    background: linear-gradient(160deg, #002036, #0f2347);
    /* Usando cores do seu tema */
    color: white;
    z-index: 1050;
    box-shadow: -10px 0 30px rgba(0, 0, 0, 0.3);
    transition: right 0.4s cubic-bezier(0.25, 0.46, 0.45, 0.94);
    display: flex;
    flex-direction: column;
}

/* Classe que torna o menu visível */
.side-menu.open {
    right: 0;
}

/* Cabeçalho do menu lateral */
.side-menu-header {
    padding: 1.5rem;
    border-bottom: 1px solid rgba(255, 255, 255, 0.1);
    display: flex;
    justify-content: space-between;
    align-items: center;
}

/* Botão de fechar (X) */
.side-menu-close-btn {
    background: none;
    border: none;
    color: white;
    font-size: 2rem;
    line-height: 1;
    transition: all 0.3s ease;
}

.side-menu-close-btn:hover {
    transform: rotate(90deg);
    color: #4a90e2;
}

/* Lista de itens do menu */
.side-menu-items {
    list-style: none;
    padding: 1rem 0;
    margin: 0;
    flex-grow: 1;
    /* Faz a lista ocupar o espaço disponível */
    overflow-y: auto;
}

.side-menu-items li {
    border-bottom: 1px solid rgba(255, 255, 255, 0.08);
}

.side-menu-items a {
    color: rgba(255, 255, 255, 0.9);
    font-size: 1.1rem;
    font-weight: 500;
    text-decoration: none;
    padding: 1.2rem 1.5rem;
    display: block;
    transition: all 0.3s ease;
}

.side-menu-items a:hover {
    background: rgba(74, 144, 226, 0.1);
    color: white;
    padding-left: 2rem;
}

/* Estilos para o dropdown dentro do menu lateral */
.side-menu-items .dropdown>a {
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.side-menu-items .dropdown-toggle i {
    transition: transform 0.3s ease;
}

.side-menu-items .dropdown.show>a {
    background: rgba(74, 144, 226, 0.15);
    color: white;
}

.side-menu-items .dropdown.show .dropdown-toggle i {
    transform: rotate(180deg);
}

.dropdown-menu-custom {
    background: rgba(0, 0, 0, 0.2);
    padding-left: 1.5rem;
    max-height: 0;
    /* Escondido por padrão */
    overflow: hidden;
    transition: max-height 0.3s ease-out;
}

.side-menu-items .dropdown.show .dropdown-menu-custom {
    max-height: 200px;
    /* Altura máxima para animação */
}

.dropdown-menu-custom a {
    font-size: 1rem;
    font-weight: 400;
}

/* Rodapé do menu lateral com ícones sociais */
.side-menu-footer {
    padding: 1.5rem;
    border-top: 1px solid rgba(255, 255, 255, 0.1);
}

.side-menu-footer p {
    margin-bottom: 0.5rem;
    color: rgba(255, 255, 255, 0.7);
}

.social-icons-side a {
    color: white;
    font-size: 1.5rem;
    margin-right: 1rem;
    transition: color 0.3s ease;
}

.social-icons-side a:hover {
    color: #4a90e2;
}

/* --- FIM: ESTILOS PARA O NOVO MENU MOBILE LATERAL --- */
@media (max-width: 1399px) {
    .btn-cta {
        margin-right: 30px;
    }
}

/* Ajustes para a imagem da seção "Sobre" no mobile */
@media (max-width: 992px) {
    .row-about {
        overflow-x: hidden;
    }

    /* Adiciona um espaço acima da imagem quando as colunas empilham */
    .about-section .col-lg-6:last-child {
        margin-top: 4rem;

    }

    /* Remove a altura mínima para que o conteúdo defina o tamanho */
    .about-image-wrapper {
        min-height: auto;
        padding-bottom: 4rem;
        /* Garante espaço para a legenda não cortar */
    }

    .about-image-wrapper-brands {
        min-height: auto;
        padding-bottom: 4rem;
        /* Garante espaço para a legenda não cortar */
    }

    /* Reseta a margem negativa da foto do perfil */
    .about-img-profile {
        margin-top: 0;
    }

    /* Recentraliza a forma geométrica de fundo */
    .about-img-bg {
        top: 250px;
        /*left: 50%;
        /* O transform: translate(-50%, -50%) existente já fará o resto */
    }

    .about-img-brands {
        top: 120px;
    }

    /* Ajusta a posição da legenda para o novo layout */
    .about-caption {
        bottom: 0;
    }

    .btn-cta {
        margin-right: 0;
    }
}

@media (max-width: 768px) {

    /* --- AJUSTES HERO SECTION (INDEX E PÁGINAS INTERNAS) --- */
    .hero-title {
        font-size: 2.2rem;
        line-height: 1.3;
    }

    .hero-content {
        margin-left: 0;
        min-width: auto;
        /* <-- Correção que passará a funcionar */
        padding: 0 15px;
        text-align: center;
    }

    .hero-section .row {
        justify-content: center !important;
    }

    .hero-content-inner {
        min-width: auto;
        /* <-- Correção que passará a funcionar */
        padding: 0 15px;
    }

    /* --- OUTROS AJUSTES MOBILE EXISTENTES --- */
    .section-title {
        font-size: 2rem;
    }

    .navbar-nav .nav-link {
        margin: 0 0.5rem;
    }

    .gallery-item {
        flex: 0 0 50%;
    }

    .btn-cta {
        margin-right: 0;
    }

    .contact-heading {
        font-size: 28px !important;
        /* Reduz o tamanho da fonte para mobile */
    }
}

/* <--- Apenas uma chave fechando a media query */