body {
    font-family: 'Inter', sans-serif;
    background-color: #f8f8f8;
    /* Fundo cinza claro */
    color: #333;
    /* Texto cinza escuro */
    padding-top: 70px;
    /* Padding inicial, será atualizado pelo JS */
    transition: padding-top 0.3s ease-in-out;
    /* Transição suave para o padding */

}

.depoimentos {
max-width: 900px;        /* Equivalente ao max-w-4xl */
  margin-left: auto;       /* mx-auto: centraliza horizontalmente */
  margin-right: auto;
  padding-left: 24px;      /* px-6: padding horizontal */
  padding-right: 24px;
  text-align: auto;
}

/* Estilo para títulos de seção com linha inferior */
.section-title {
    position: relative;
    display: inline-block;
    padding-bottom: 8px;
}

.section-title::after {
    content: '';
    position: absolute;
    left: 50%;
    /* Centraliza a linha */
    transform: translateX(-50%);
    /* Ajusta para centralizar perfeitamente */
    bottom: 0;
    width: 50%;
    height: 3px;
    background-color: #6b7280;
    /* Cinza 500 para destaque */
    border-radius: 9999px;
}

/* Estilos de animação do menu hambúrguer */
.hamburger-icon {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    width: 30px;
    height: 20px;
    cursor: pointer;
    transition: transform 0.3s ease-in-out;
}

.hamburger-icon span {
    display: block;
    width: 100%;
    height: 3px;
    background-color: white;
    border-radius: 2px;
    transition: all 0.3s ease-in-out;
}

.hamburger-icon.open span:nth-child(1) {
    transform: translateY(8.5px) rotate(45deg);
}

.hamburger-icon.open span:nth-child(2) {
    opacity: 0;
}

.hamburger-icon.open span:nth-child(3) {
    transform: translateY(-8.5px) rotate(-45deg);
}

/* Animação de slide do menu móvel */
#mobile-menu {
    max-height: 0;
    opacity: 0;
    overflow: hidden;
    transition: max-height 0.5s ease-out, opacity 0.3s ease-out;
    position: absolute;
    /* Posiciona absolutamente para sobrepor */
    top: 100%;
    /* Posiciona abaixo do cabeçalho */
    left: 0;
    width: 100%;
    background-color: rgba(31, 41, 55, 0.95);
    /* Fundo ligeiramente transparente para sobreposição */
    box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.1), 0 2px 4px -1px rgba(0, 0, 0, 0.06);
}

#mobile-menu.open-menu {
    max-height: 500px;
    /* Ajuste este valor se o conteúdo do seu menu for mais alto */
    opacity: 1;
}

/* Estilos específicos do carrossel de notícias (banner) */
#news-banner-carousel {
    position: relative;
    width: 100%;
    background-color: #f8f8f8;
    /* Fundo cinza claro */
    box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.1), 0 2px 4px -1px rgba(0, 0, 0, 0.06);
    /* shadow-md */
}

.carousel-container-banner {
    width: 100%;
    margin: 0 auto;
    overflow: hidden;
    position: relative;
    /* Necessário para posicionamento absoluto das setas */
}

.carousel-track-banner {
    display: flex;
    transition: transform 0.5s ease-in-out;
}

.carousel-slide-banner {
    min-width: 100%;
    flex-shrink: 0;
    position: relative;
    /* Adicionado para sobreposição e posicionamento de conteúdo */
    height: 550px;
    /* Altura aumentada para desktop */
}

.carousel-slide-banner img {
    position: absolute;
    /* Posiciona a imagem absolutamente para permitir sobreposição */
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    /* Preenche a altura do slide pai */
    object-fit: cover;
    object-position: center center;
    /* Garante que o conteúdo seja centralizado ao cortar */
    z-index: 1;
    /* Garante que a imagem esteja atrás da sobreposição e do texto */
}

/* Estilo de sobreposição (mantido para uso futuro ou se o usuário quiser adicionar novamente) */
.banner-overlay {
    position: absolute;
    inset: 0;
    /* Top, right, bottom, left para 0 */
    background-color: rgba(0, 0, 0, 0.4);
    /* Sobreposição escura semi-transparente */
    z-index: 2;
    /* Acima da imagem, abaixo do texto */
}

/* Estilo do contêiner de conteúdo (mantido para uso futuro ou se o usuário quiser adicionar novamente) */
.banner-content {
    position: relative;
    /* Torna o conteúdo relativo para ficar acima da sobreposição */
    z-index: 3;
    /* Acima da sobreposição */
    color: white;
    /* Cor do texto */
    padding: 1rem;
    /* Padding para o conteúdo */
    max-width: 90%;
    /* Limita a largura do conteúdo */
}

/* Media queries para altura responsiva do banner em telas menores */
@media (max-width: 768px) {

    /* Para tablets e telefones maiores */
    .carousel-slide-banner {
        height: 400px;
        /* Altura reduzida para melhor ajuste em dispositivos móveis */
    }
}

@media (max-width: 480px) {

    /* Para dispositivos móveis menores */
    .carousel-slide-banner {
        height: 300px;
        /* Altura ainda mais reduzida para telas muito pequenas */
    }
}

/* Esconde a barra de rolagem para o track do carrossel do banner */
.carousel-track-banner::-webkit-scrollbar {
    display: none;
}

.carousel-track-banner {
    -ms-overflow-style: none;
    scrollbar-width: none;
}

/* Estilos dos indicadores do banner */
.banner-indicators {
    position: absolute;
    bottom: 20px;
    left: 50%;
    transform: translateX(-50%);
    display: flex;
    justify-content: center;
    z-index: 10;
}

.banner-indicator-dot {
    width: 20px;
    height: 3px;
    background-color: rgba(255, 255, 255, 0.5);
    border-radius: 20%;
    margin: 0 5%;
    cursor: pointer;
    transition: background-color 0.3s ease, transform 0.3s ease;
   
}

.banner-indicator-dot.active {
    background-color: white;
    
}

/* Setas de navegação do banner */
.banner-arrow {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    background-color: rgba(0, 0, 0, 0.05);
    color: white;
    padding: 4px 8px;
    cursor: pointer;
    z-index: 10;
    font-size: 0.8rem;
    border-radius: 0.25rem;
    transition: background-color 0.3s ease;
}

.banner-arrow:hover {
    background-color: rgba(0, 0, 0, 0.2);
}

.banner-arrow.left {
    left: 10px;
}

.banner-arrow.right {
    right: 10px;
}

/* Estilo personalizado para contêiner de iframe de vídeo */
.video-responsive-container {
    position: relative;
    width: 100%;
    padding-bottom: 56.25%;
    height: 0;
    overflow: hidden;
    background-color: black;
    border-radius: 1rem;
    box-shadow: 0 10px 15px -3px rgba(0, 0, 0, 0.1), 0 4px 6px -2px rgba(0, 0, 0, 0.05);
}

.video-responsive-container iframe {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    border: 0;
}

.gallery-indicator-dot {
    width: 10px;
    height: 10px;
    background-color: rgba(107, 114, 128, 0.5);
    border-radius: 50%;
    margin: 0 5px;
    cursor: pointer;
    transition: background-color 0.3s ease, transform 0.3s ease;
    border: 1px solid rgba(0, 0, 0, 0.1);
}

.gallery-indicator-dot.active {
    background-color: #6b7280;
    transform: scale(1.2);
}

/* --- Novos estilos para o Efeito de Foco dos Cartões de Produto --- */
.product-card {
  filter: blur(0);
  box-shadow: 0 10px 15px -3px rgba(0, 0, 0, 0.1), 0 4px 6px -2px rgba(0, 0, 0, 0.05);
  transform: scale(1.02);
  transition: all 0.3s ease-in-out;

}

.product-card.blurred {
    filter: blur(4px);
    box-shadow: none;
    transform: scale(1);
}

.teste {
    height: 190px;
    width: 100%;
    object-fit: cover;
}

.grid-item-produtos {
    height: 200px;
    width: 100%;
    object-fit: cover;
    overflow: hidden;
    /* Garante que a imagem não transborde */
    transition: transform 0.3s ease, box-shadow 0.3s ease;
    /* Transição suave para hover */
    outline: none;
    /* Remove o contorno padrão do item do grid */

}

/* Media query para dispositivos móveis (telas com largura máxima de 768px) */
@media (max-width: 768px) {
.grid-item-produtos {
    height: 240px;
    width: 100%;
    object-fit: cover;

}
}

.grid-item-produtos:focus {
    outline: none;
    /* Garante que o contorno seja removido ao focar o item do grid */
}

.grid-item-produtos:hover {
    transform: translateY(-5px) scale(1.02);
    /* Pequeno levantamento e aumento no hover */
}

.grid-item-produtos img {
    height: 190px;
    width: 100%;
    object-fit: cover;

}

.grid-item-produtos img:focus {
    outline: none;
    /* Garante que o contorno seja removido ao focar a imagem */
}

.grid-item-produtos:hover img {
    transform: scale(1.05);
    /* Pequeno zoom na imagem no hover */
}



/* --- Fim dos Novos estilos para o Efeito de Foco dos Cartões de Produto --- */

.feedback {
    display: flex;
    flex-direction: column;
    margin: 0 2rem;

}


/* --- Estilos Específicos do Cabeçalho Móvel --- */
@media (max-width: 767px) {
    #main-nav {
        padding-top: 0.5rem;
        padding-bottom: 0.5rem;
    }

    #header-logo {
        height: 48px;
    }

    /* Ajusta o padding-top para o body em dispositivos móveis para acomodar o cabeçalho menor */
    body {
        padding-top: 60px;
    }

    /* Reduz ainda mais o padding-top ao rolar para dispositivos móveis */
    .scrolled-header #main-nav {
        padding-top: 0.125rem;
        padding-bottom: 0.125rem;
    }

    .scrolled-header #header-logo {
        height: 32px;
    }

    .scrolled-header body {
        padding-top: 40px;
    }
}

/* --- Fim dos Estilos Específicos do Cabeçalho Móvel --- */

/* --- Efeito de Texto Gradiente (Similar ao Cabeçalho) --- */
.header-gradient-text {
    background-image: linear-gradient(to right, #4b5563, #1f2937);
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
    transition: all 0.5s ease-in-out;
}

.header-gradient-text:hover {
    background-image: linear-gradient(to right, #6b7280, #374151);
}

/* --- Fim do Efeito de Texto Gradiente --- */

/* --- Estilos Personalizados para Efeito Hover do Logo --- */
.logo-link {
    transition: transform 0.3s ease-in-out;
}

.logo-link:hover {
    transform: scale(1.05);
}

/* --- Fim dos Estilos Personalizados para Efeito Hover do Logo --- */

/* --- Estilos Personalizados para Efeito Hover de Link de Navegação (Salto) --- */
.nav-link-jump {
    position: relative;
    transition: transform 0.3s ease-in-out;
}

.nav-link-jump:hover {
    transform: translateY(-5px);
}

/* --- Fim dos Estilos Personalizados para Efeito Hover de Link de Navegação (Salto) --- */

/* --- Estilo para fonte tipo escrita --- */
.writing-font {
    font-family: 'Dancing Script', cursive;
    font-weight: 700;
}

/* --- Estilos para animações de escala no hover --- */
.scale-on-hover {
    transition: transform 0.3s ease-in-out;
}

.scale-on-hover:hover {
    transform: scale(1.02);
}

.shrink-on-hover {
    transition: transform 0.3s ease-in-out;
}

.shrink-on-hover:hover {
    transform: scale(0.98);
}

/* Novas linhas */

 .grid-container {
    display: grid;
    gap: 1rem;
    /* Espaçamento entre as imagens */
    width: 100%;
    max-width: 1200px;
    /* Largura máxima para o grid */
    margin: 1rem auto;
    /* Centraliza o container */
    padding: auto;
    margin-bottom: 1rem;
    /* Espaçamento entre o grid e o botão */
}

/* Container para o botão para alinhar com a largura do grid */
.button-wrapper {
    width: 100%;
    max-width: 1200px;
    /* Mesma largura máxima do grid */
    margin: 0 auto;
    /* Centraliza o wrapper do botão */
    padding: 0 1rem;
    /* Adiciona padding para alinhar com o grid */
    box-sizing: border-box;
    display: flex;
    /* Transforma o wrapper em um container flex */
    justify-content: flex-end;
    /* Alinha o conteúdo (botão) à direita */
}

/* Mobile-first: Layout específico para telas pequenas (até 767px) */
@media (max-width: 767px) {
    .grid-container {
        /* Define 3 colunas para o layout mobile, permitindo as 3 fotos lado a lado na parte inferior */
        grid-template-columns: repeat(3, 1fr);
        /* Define 3 linhas: 2 para a parte superior (Foto 1, 2, 3) e 1 para a parte inferior (Foto 4, 5, 6) */
        grid-template-rows: auto auto auto;
        gap: 1rem;
    }

    .grid-container>div:nth-child(1) {
        /* Foto 1: Maior, ocupa 2 colunas e 2 linhas no lado esquerdo */
        grid-column: 1 / span 2;
        grid-row: 1 / span 2;
    }

    .grid-container>div:nth-child(1) {
        height: 220px;
        object-fit: cover;
        /* Altura ajustada para a Foto 1 no mobile */
    }



    .grid-container>div:nth-child(2) {
        /* Foto 2: Canto superior direito */
        height: 100px;
        grid-column: 3;
        grid-row: 1;
    }

    .grid-container>div:nth-child(2) img {
        height: 150px;
        /* Altura menor para as fotos do canto direito */
    }

    .grid-container>div:nth-child(3) {
        /* Foto 3: Canto inferior direito (abaixo da Foto 2) */
        height: 100px;
        grid-column: 3;
        grid-row: 2;
    }

    .grid-container>div:nth-child(3) img {
        height: 100px;
        /* Altura menor para as fotos do canto direito */
    }

    /* Fotos 4, 5 e 6: Embaixo, lado a lado, cada uma em sua coluna */
    .grid-container>div:nth-child(4) {
        grid-column: 1;
        grid-row: 3;
    }

    .grid-container>div:nth-child(5) {
        grid-column: 2;
        grid-row: 3;
    }

    .grid-container>div:nth-child(6) {
        grid-column: 3;
        grid-row: 3;
    }

    .grid-container>div:nth-child(4) img,
    .grid-container>div:nth-child(5) img,
    .grid-container>div:nth-child(6) img {
        height: 100px;
        /* Altura para as imagens de baixo */
    }
}

/* Tablet e telas médias (md): A partir de 768px */
@media (min-width: 768px) {
    .grid-container {
        grid-template-columns: repeat(2, 1fr);
        /* Duas colunas */
        grid-template-rows: auto;
        /* Reseta as linhas para o fluxo normal */
    }

    /* Reseta estilos específicos de mobile para todas as imagens */
    .grid-container>div:nth-child(1),
    .grid-container>div:nth-child(2),
    .grid-container>div:nth-child(3),
    .grid-container>div:nth-child(4),
    .grid-container>div:nth-child(5),
    .grid-container>div:nth-child(6) {
        grid-column: auto;
        grid-row: auto;
    }

    .grid-item img {
        object-fit: cover;
        /* Altura padrão para imagens em telas maiores */
    }
}

/* Desktop e telas maiores (lg): A partir de 1024px */
@media (min-width: 1024px) {
    .grid-container {
        grid-template-columns: repeat(3, 1fr);
        /* Três colunas */
    }

    /* Estilo específico para a primeira imagem para ocupar mais espaço no desktop */
    .grid-container>div:nth-child(1) {
        grid-column: span 2;
        /* A primeira imagem ocupa duas colunas */
        grid-row: span 2;
        /* E duas linhas */
    }

    .grid-container>div:nth-child(1) img {
        height: 320px;
        /* Ajusta a altura para a imagem maior no desktop */
    }

    /* Garante que as outras imagens voltem ao tamanho padrão */
    .grid-container>div:not(:nth-child(1)) img {
        height: 150px;
    }
}

.grid-item {
    overflow: hidden;
    /* Garante que a imagem não transborde */
    border-radius: 0.5rem;
    /* Cantos arredondados para cada item */
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.08);
    /* Sombra para cada item */
    transition: transform 0.3s ease, box-shadow 0.3s ease;
    /* Transição suave para hover */
    outline: none;
    /* Remove o contorno padrão do item do grid */
    cursor: pointer;
    /* Indica que o item é clicável */
}

.grid-item:focus {
    outline: none;
    /* Garante que o contorno seja removido ao focar o item do grid */
}

.grid-item:hover {
    transform: translateY(-5px) scale(1.02);
    /* Pequeno levantamento e aumento no hover */
    box-shadow: 0 8px 16px rgba(0, 0, 0, 0.15);
    /* Sombra mais pronunciada no hover */
}

.grid-item img {
    height: 100%;
    width: 100%;
    /* Garante que a imagem ocupe toda a largura do item */
    object-fit: cover;
    /* Garante que a imagem cubra o espaço sem distorcer */
    display: block;
    /* Remove espaço extra abaixo da imagem */
    transition: transform 0.3s ease;
    /* Transição para o efeito de zoom na imagem */
    outline: none;
    /* Remove o contorno padrão da imagem */
}

.grid-item img:focus {
    outline: none;
    /* Garante que o contorno seja removido ao focar a imagem */
}

.grid-item:hover img {
    transform: scale(1.05);
    /* Pequeno zoom na imagem no hover */
}

.view-more-button {
    background-color: transparent;
    /* Fundo transparente */
    color: #4F46E5;
    /* Cor do texto roxa */
    padding: 0.5rem 0.8rem;
    /* Padding menor */
    border-radius: 0.5rem;
    /* Cantos levemente arredondados */
    text-decoration: none;
    /* Remove sublinhado do link */
    font-weight: 500;
    /* Peso da fonte mais leve */
    font-size: 1rem;
    /* Tamanho da fonte menor */
    transition: color 0.3s ease, background-color 0.3s ease;
    /* Transição suave */
    box-shadow: none;
    /* Remove a sombra */
    display: inline-block;
    /* Para que o padding e margin funcionem corretamente */
}

.view-more-button:hover {
    color: #6366F1;
    /* Cor do texto mais clara no hover */
    background-color: rgba(79, 70, 229, 0.05);
    /* Fundo muito sutil no hover */
    transform: none;
    /* Remove qualquer transformação no hover */
    box-shadow: none;
    /* Garante que não haja sombra no hover */
}

.view-more-button:active {
    transform: none;
    /* Volta à posição original ao clicar */
    box-shadow: none;
    /* Garante que não haja sombra ao clicar */
}

/* Estilos para o Modal de Visualização */
.modal-overlay {
    display: none;
    /* Escondido por padrão */
    position: fixed;
    /* Fixado na tela */
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(0, 0, 0, 0.8);
    /* Fundo semi-transparente escuro */
    justify-content: center;
    align-items: center;
    z-index: 1001;
    /* Garante que fique acima de outros elementos */
    backdrop-filter: blur(5px);
    /* Efeito de desfoque no fundo */
}

.modal-content {
    position: relative;
    /* O modal-content agora é apenas um wrapper para a imagem, não um quadrado com fundo */
    width: 95v;
    /* Ocupa quase toda a largura da viewport */
    height: 95vh;
    /* Ocupa quase toda a altura da viewport */
    display: flex;
    justify-content: center;
    align-items: center;
    overflow: hidden;
    /* Garante que a imagem não transborde */
    /* Removido background-color, border-radius e box-shadow daqui */
}

.modal-content img {
    max-width: 80vw;
    /* A imagem se ajusta à largura do modal-content */
    max-height: 80vh;
    /* A imagem se ajusta à altura do modal-content */
    object-fit: contain;
    /* Mostra a imagem inteira, sem cortar, dentro do modal-content */
    border-radius: 1rem;
    /* Cantos arredondados para a imagem no modal */
    outline: none;
    /* Remove contorno ao focar */
}

.image-counter {
    position: absolute;
    bottom: 2rem;
    left: 50%;
    transform: translateX(-50%);
    color: white;
    font-size: 1.2rem;
    background-color: rgba(0, 0, 0, 0.5);
    padding: 0.5rem 1rem;
    border-radius: 0.5rem;
    z-index: 1001;

}

/* Estilos para alto contraste */

#toggleContraste {
            position: fixed; /* Botão fixo na tela */
            right: 0.6rem; /* 20px da margem direita */
            top: 38%; /* Centraliza verticalmente */

            width: 40px; /* Largura para o botão redondo */
            
            border-radius: 8px; /* Torna o botão redondo */
            background-color: #007bff; /* Azul para botões padrão */
            color: #ffffff;
            border: none;
            cursor: pointer;
            font-size: 24px; /* Tamanho do ícone */
            display: flex; /* Para centralizar o ícone */
          
            justify-content: center; /* Centraliza horizontalmente o ícone */
            box-shadow: 0 4px 8px rgba(0,0,0,0.2); /* Sombra mais pronunciada para botão fixo */
            transition: background-color 0.3s ease, box-shadow 0.3s ease, transform 0.3s ease; /* Transição suave */
            z-index: 1000; /* Garante que o botão fique acima de outros elementos */
}

#toggleContraste:hover {
            background-color: #636363;
            box-shadow: 0 6px 12px rgba(0,0,0,0.3);
            transform: scale(1.05); /* Pequeno efeito de escala ao passar o mouse */
        }

        #toggleContraste svg {
            fill: currentColor; /* Usa a cor do texto do botão */
            padding: 0.2rem; /* Espaçamento interno para o ícone */
        }

        body.alto-contraste {
            background-color: #181717; /* Fundo cinza escuro */
            color: #000000; /* Texto branco */
        }

        .alto-contraste h1,
        .alto-contraste h2,
        .alto-contraste h3 {
            color: #ffffff; /* Amarelo vibrante para títulos no modo de alto contraste */
        }

        .alto-contraste #toggleContraste {
            background-color: #555555; /* Um cinza mais escuro para o botão fixo */
            color: #ffffff; /* Texto branco no botão fixo */
            border: 1px solid #ffffff; /* Borda branca para contraste */
            box-shadow: 0 4px 8px rgba(255,255,255,0.2); /* Sombra mais clara */
        }

        .alto-contraste #toggleContraste:hover {
            background-color: #777777;
            box-shadow: 0 6px 10px rgba(255,255,255,0.3);
        }

        .alto-contraste a {
            color: #ffffff; /* Amarelo vibrante para links */
        }

        .alto-contraste .bg-white {
            background-color: #181717; /* Um cinza quase preto para cards */
            color: #ffffff; /* Texto branco nos cards */
            box-shadow: rgb(255, 255, 255); /* Remover sombra se preferir no alto contraste */
        }
        .alto-contraste .bg-gray-50 {
            background-color: #222222; /* Um cinza quase preto para cards */
            color: #ffffff; /* Texto branco nos cards */
            box-shadow: none; /* Remover sombra se preferir no alto contraste */
        }

        .alto-contraste .text-gray-900 {
            background-color: #22222200; /* Um cinza quase preto para cards */
            color: #ffffff; /* Texto branco nos cards */
        }
        .alto-contraste .bg-gray-100 {
            background-color: #222222; /* Um cinza quase preto para cards */
            color: #ffffff; /* Texto branco nos cards */
        }

        .alto-contraste .text-gray-700 {
            color: #ffffff; /* Texto branco nos cards */
        }
        .alto-contraste .text-gray-600 {
            color: #ffffff; /* Texto branco nos cards */
        }


        /* Estilos paginas produtos*/


        /* Definindo uma variável CSS para o espaçamento entre as imagens */
        :root {
            --image-gap: 1rem; /* Tamanho do espaçamento entre as imagens */
        }

        /* Styles for the section title underline effect */
        .section-title {
            position: relative;
            display: inline-block;
            padding-bottom: 8px; /* Space for the underline */
        }

        .section-title::after {
            content: '';
            position: absolute;
            left: 50%;
            transform: translateX(-50%); /* Center the underline */
            bottom: 0;
            width: 30%; /* Smaller width for the underline */
            height: 3px;
            background-color: rgba(107, 114, 128, 0.5); /* More transparent gray color for the underline */
            border-radius: 9999px; /* Rounded ends for the underline */
        }

            /* Further reduce padding-top on scroll for mobile */
            .scrolled-header #main-nav {
                padding-top: 0.125rem;
                padding-bottom: 0.125rem;
            }

            .scrolled-header #header-logo {
                height: 32px;
            }

            .scrolled-header body {
                padding-top: 40px;
            }
        
        /* Custom Styles for Logo Hover Effect */
        .logo-link {
            transition: transform 0.3s ease-in-out;
        }

        .logo-link:hover {
            transform: scale(1.05); /* Slightly enlarge logo on hover */
        }

        /* Custom Styles for Navigation Link Hover Effect (Jump) */
        .nav-link-jump {
            position: relative;
            transition: transform 0.3s ease-in-out;
        }

        .nav-link-jump:hover {
            transform: translateY(-5px); /* Move link up slightly on hover */
        }
        
        /* Cards Produtos */
        .page-produto-card {
        width: 500px;
        height: 320px;
        object-fit: cover;
        border-radius: 0.5rem; /* Or adjust to 0.75rem or another value if 0.5rem isn't the desired "lg" */
        margin-bottom: 1.5rem;
        }
        
        /* Custom Styles for Mug Card Hover Effect - Increased Effect */
        .mug-card-hover {
            transition: transform 0.3s ease-in-out, box-shadow 0.3s ease-in-out;
        }

        .mug-card-hover:hover {
            transform: translateY(-5px) scale(1.02); /* Move up more and enlarge more on hover */
            box-shadow: 0 15px 25px -5px rgba(0, 0, 0, 0.2), 0 8px 10px -6px rgba(0, 0, 0, 0.1); /* Add a much stronger shadow */
        }

        /* New CSS for image strip */
        .image-animation-viewport {
            position: relative;
            width: 100%;
            max-width: 960px; /* Max width for desktop */
            margin: 0 auto;
            /* Removed overflow: hidden to allow hover scale */
        }

        .image-strip-animated {
            display: flex;
            gap: var(--image-gap); /* Espaçamento entre as imagens */
            width: 100%; /* A faixa ocupa 100% da largura do viewport */
            justify-content: center; /* Centraliza as imagens */
            flex-wrap: wrap; /* Permite que as imagens quebrem para a próxima linha em telas menores */
            /* Removed animation properties */
        }

        .image-strip-item {
            flex-shrink: 0; /* Impede que os itens encolham */
            /* Adiciona transição para o efeito de hover */
            transition: transform 0.3s ease-in-out;
        }

        /* Mobile: 1 imagem visível por vez */
        @media (max-width: 767px) {
            .image-strip-item {
                width: calc(100% - var(--image-gap)); /* 100% da largura do viewport menos o gap */
            }
        }

        /* Desktop: 3 imagens visíveis por vez */
        @media (min-width: 768px) {
            .image-strip-item {
                width: calc((100% - 2 * var(--image-gap)) / 3); /* Largura do viewport menos 2 gaps, dividido por 3 imagens */
            }
        }

        /* Efeito de aumentar ao passar o mouse */
        .image-aspect-ratio-container:hover {
            transform: scale(1.05); /* Aumenta a imagem em 5% */
            z-index: 10; /* Garante que a imagem ampliada fique acima das outras */
        }

        .image-aspect-ratio-container {
            position: relative;
            width: 100%;
            padding-bottom: 85%; /* Proporção da imagem (altura é 85% da largura) */
            overflow: hidden;
            border-radius: 0.75rem; /* Cantos arredondados para o contêiner */
            cursor: pointer; /* Indica que é clicável */
            transition: transform 0.3s ease-in-out; /* Transição para o efeito de hover */
        }

        .image-aspect-ratio-container img {
            position: absolute;
            top: 0;
            left: 0;
            width: 100%;
            height: 100%;
            object-fit: cover; /* Garante que a imagem preencha o contêiner */
            object-position: center;
            border-radius: 0.75rem; /* Garante que a própria imagem seja arredondada */
        }

        /* Lightbox Styles */
        .lightbox-overlay  {
            position: fixed;
            top: 0;
            left: 0;
            width: 100%;
            height: 100%;
            background-color: rgba(0, 0, 0, 0.9); /* Fundo escuro*/
            display: flex;
            justify-content: center;
            align-items: center;
            z-index: 1001 /*  Garante que fique acima de outros elementos */;
            opacity: 0;
            visibility: hidden;
            transition: opacity 0.3s ease-in-out, visibility 0.3s ease-in-out;
        }

        .lightbox-overlay.active {
            opacity: 1;
            visibility: visible;
        }

        .lightbox-content {
            position: relative;
            max-width: 90%;
            max-height: 90%;
            display: flex;
            justify-content: center;
            align-items: center;
        }

        .lightbox-content img {
            max-height: 90vh; /* Limita a altura máxima da imagem */
            width: 100%;
            object-fit: cover; /* Garante que a imagem se ajuste ao contêiner */
            border-radius: 0.75rem;
            box-shadow: 0 0 20px rgba(0, 0, 0, 0.5);
        }

        #lightbox-img {
        transition: opacity 0.9s ease;
        }

        .lightbox-nav {
            opacity: 0;
            transition: opacity 0.3s ease;
            pointer-events: none; /* impede clique quando invisível */
            position: fixed;
            background-color: rgba(255, 255, 255, 0.2); /* Semi-transparent white */
            color: white;
            border: none;
            padding: 1rem;
            border-radius: 9999px; /* Fully rounded */
            cursor: pointer;
            font-size: 1rem;
            transform: translateY(-50%);
            transition: background-color 0.3s ease-in-out, transform 0.2s ease-in-out;
            display: flex;
            align-items: center;
            justify-content: center;
            width: 1rem; /* Fixed width for buttons */
            height: 1rem;                 
        }
        
        
        .lightbox-close {
            position: fixed;
            background-color: rgba(255, 255, 255, 0.2); /* Semi-transparent white */
            color: white;
            border: none;
            padding: 1rem;
            border-radius: 9999px; /* Fully rounded */
            cursor: pointer;
            font-size: 1rem;
            transition: background-color 0.3s ease-in-out, transform 0.2s ease-in-out;
            display: flex;
            align-items: center;
            justify-content: center;
            width: 1rem; /* Fixed width for buttons */
            height: 1rem;                 /
        }

        .lightbox-close:hover, .lightbox-nav:hover {
            background-color: rgba(255, 255, 255, 0.4);
            transform: scale(1.1);

        }

        .lightbox-close {
            top: 16px;
            right: 16px;
        }

        .lightbox-nav.prev {
        left: 5rem; /* Posiciona a partir da borda esquerda */
        top: 75%; /* <--- Experimente este valor! Exemplo: 70% do topo */
        transform: translateY(-50%); /* Ajusta para centralizar verticalmente em relação ao 'top' */
        transition: opacity 0.5s ease;
      }

        .lightbox-nav.next {
        right: 5rem; /* Posiciona a partir da borda direita */
        top: 75%; /* <--- Experimente este valor! Exemplo: 70% do topo */
        transform: translateY(-50%); /* Ajusta para centralizar verticalmente em relação ao 'top' */
        transition: opacity 0.5s ease;
      }

    /* Mostra os botões ao passar o mouse no modal */
    #imageModal:hover .lightbox-nav {
    opacity: 1;
    pointer-events: auto;
}

    /* Mostra os botões ao passar o mouse no modal */
    #lightbox:hover .lightbox-nav {
    opacity: 1;
    pointer-events: auto;
}

        /* Media queries for responsive lightbox navigation */
        @media (max-width: 768px) {
            .lightbox-nav.prev {
                left: 3rem;
                font-size: 1rem;
                width: 1rem;
                height: 1rem;
            }
            .lightbox-nav.next {
                right: 3rem;
                font-size: 1rem;
                width: 1rem;
                height: 1rem;
            }
            .lightbox-close {
                top: 0.5rem;
                right: 0.5rem;
                font-size: 1rem;
                width: 1rem;
                height: 1rem;
            }
        }

#vw-access-button {
  z-index: 10 !important;
  max-width: 10% !important;
}

.image-aspect-ratio-container {
    box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.1), 0 2px 4px -1px rgba(0, 0, 0, 0.06);

}