/* Otimizações específicas para mobile */
@media (prefers-reduced-motion: reduce) {
    .thumbnail,
    #mainImage {
        transition: none;
    }
}

/* Otimizações para touch devices */
@media (hover: none) and (pointer: coarse) {
    .thumbnail:hover {
        transform: none;
    }
    
    #mainImage:hover {
        transform: none;
    }
    
    .thumbnail {
        min-width: 44px;
        min-height: 44px;
        padding: 4px;
    }
}

/* Melhorar performance em telas pequenas */
@media (max-width: 768px) {
    img {
        image-rendering: optimizeSpeed;
    }
    
    .scrollbar-hide {
        -webkit-overflow-scrolling: touch;
        scroll-behavior: smooth;
    }
    
    .shadow-md {
        box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
    }
    
    .modal-overlay {
        backdrop-filter: none;
    }
}

/* Esconder scrollbar mas manter funcionalidade */
.scrollbar-hide {
    -ms-overflow-style: none;
    scrollbar-width: none;
    -webkit-overflow-scrolling: touch;
}
.scrollbar-hide::-webkit-scrollbar {
    display: none;
}

/* Transições otimizadas */
.thumbnail {
    transition: border-color 0.2s ease;
    transform: translate3d(0, 0, 0);
    will-change: border-color;
    box-sizing: border-box;
    overflow: hidden;
    padding: 2px;
}

.thumbnail img {
    width: calc(100% - 4px);
    height: calc(100% - 4px);
    object-fit: cover;
    border-radius: 6px;
}

.thumbnail:hover {
    transform: scale(1.05);
}

/* Efeito hover para a imagem principal - APENAS UMA VEZ */
#mainImage {
    will-change: transform;
    transition: transform 0.3s ease;
}

#mainImage:hover {
    transform: scale(1.05);
}

/* Logo customizada */
.header img {
    height: 64px !important;
    max-width: 208px !important;
    object-fit: contain !important;
}

@media (max-width: 768px) {
    .header img {
        height: 48px !important;
        max-width: 160px !important;
    }
}

/* Lazy loading placeholder */
.lazy-loading {
    background: #f0f0f0;
    animation: none;
}

@media (min-width: 769px) {
    .lazy-loading {
        background: linear-gradient(90deg, #f0f0f0 25%, #e0e0e0 50%, #f0f0f0 75%);
        background-size: 200% 100%;
        animation: loading 1.5s infinite;
    }
}

@keyframes loading {
    0% { background-position: 200% 0; }
    100% { background-position: -200% 0; }
}

/* Fallbacks */
svg {
    max-width: 100%;
    height: auto;
}

.w-6.h-6 {
    width: 1.5rem !important;
    height: 1.5rem !important;
}

.w-5.h-5 {
    width: 1.25rem !important;
    height: 1.25rem !important;
}

.w-4.h-4 {
    width: 1rem !important;
    height: 1rem !important;
}

header {
    background-color: #02013A !important;
    color: white !important;
}

button {
    cursor: pointer;
}

/* Correção para evitar sobreposição da imagem na borda das miniaturas */
.thumbnail {
    transition: border-color 0.3s ease, transform 0.2s ease;
    box-sizing: border-box;
    overflow: hidden;
    padding: 2px; /* Espaço interno para a borda */
}

.thumbnail img {
    width: calc(100% - 4px);
    height: calc(100% - 4px);
    object-fit: cover;
    border-radius: 6px; /* Arredondar a imagem interna */
}

.thumbnail:hover {
    transform: scale(1.05);
}

/* Efeito hover para a imagem principal */
#mainImage {
    will-change: transform;
    transition: transform 0.3s ease;
}

#mainImage:hover {
    transform: scale(1.05);
}

/* Logo customizada */
.header img {
    height: 64px !important;
    max-width: 208px !important;
    object-fit: contain !important;
}

/* Para mobile */
@media (max-width: 768px) {
    .header img {
        height: 48px !important;
        max-width: 160px !important;
    }
}

#mainImage:hover {
    transform: scale(1.05);
}

/* Lazy loading placeholder */
.lazy-loading {
    background: #f0f0f0;
    animation: none;
}

@media (min-width: 769px) {
    .lazy-loading {
        background: linear-gradient(90deg, #f0f0f0 25%, #e0e0e0 50%, #f0f0f0 75%);
        background-size: 200% 100%;
        animation: loading 1.5s infinite;
    }
}

@keyframes loading {
    0% { background-position: 200% 0; }
    100% { background-position: -200% 0; }
}

/* Fallbacks */
svg {
    max-width: 100%;
    height: auto;
}

.w-6.h-6 {
    width: 1.5rem !important;
    height: 1.5rem !important;
}

.w-5.h-5 {
    width: 1.25rem !important;
    height: 1.25rem !important;
}

.w-4.h-4 {
    width: 1rem !important;
    height: 1rem !important;
}

header {
    background-color: #02013A !important;
    color: white !important;
}

button {
    cursor: pointer;
}

/* Correção para evitar sobreposição da imagem na borda das miniaturas */
.thumbnail {
    transition: border-color 0.3s ease, transform 0.2s ease;
    box-sizing: border-box;
    overflow: hidden;
    padding: 2px; /* Espaço interno para a borda */
}

.thumbnail img {
    width: calc(100% - 4px);
    height: calc(100% - 4px);
    object-fit: cover;
    border-radius: 6px; /* Arredondar a imagem interna */
}

.thumbnail:hover {
    transform: scale(1.05);
}

/* Efeito hover para a imagem principal */
#mainImage {
    will-change: transform;
    transition: transform 0.3s ease;
}

#mainImage:hover {
    transform: scale(1.05);
}

/* Logo customizada */
.header img {
    height: 64px !important;
    max-width: 208px !important;
    object-fit: contain !important;
}

/* Para mobile */
@media (max-width: 768px) {
    .header img {
        height: 48px !important;
        max-width: 160px !important;
    }
}

#mainImage:hover {
    transform: scale(1.05);
}

/* Lazy loading placeholder */
.lazy-loading {
    background: #f0f0f0;
    animation: none;
}

@media (min-width: 769px) {
    .lazy-loading {
        background: linear-gradient(90deg, #f0f0f0 25%, #e0e0e0 50%, #f0f0f0 75%);
        background-size: 200% 100%;
        animation: loading 1.5s infinite;
    }
}

@keyframes loading {
    0% { background-position: 200% 0; }
    100% { background-position: -200% 0; }
}

/* Fallbacks */
svg {
    max-width: 100%;
    height: auto;
}

.w-6.h-6 {
    width: 1.5rem !important;
    height: 1.5rem !important;
}

.w-5.h-5 {
    width: 1.25rem !important;
    height: 1.25rem !important;
}

.w-4.h-4 {
    width: 1rem !important;
    height: 1rem !important;
}

header {
    background-color: #02013A !important;
    color: white !important;
}

button {
    cursor: pointer;
}

/* Correção para evitar sobreposição da imagem na borda das miniaturas */
.thumbnail {
    transition: border-color 0.3s ease, transform 0.2s ease;
    box-sizing: border-box;
    overflow: hidden;
    padding: 2px; /* Espaço interno para a borda */
}

.thumbnail img {
    width: calc(100% - 4px);
    height: calc(100% - 4px);
    object-fit: cover;
    border-radius: 6px; /* Arredondar a imagem interna */
}

.thumbnail:hover {
    transform: scale(1.05);
}

/* Efeito hover para a imagem principal */
#mainImage {
    will-change: transform;
    transition: transform 0.3s ease;
}

#mainImage:hover {
    transform: scale(1.05);
}

/* Logo customizada */
.header img {
    height: 64px !important;
    max-width: 208px !important;
    object-fit: contain !important;
}

/* Para mobile */
@media (max-width: 768px) {
    .header img {
        height: 48px !important;
        max-width: 160px !important;
    }
}

#mainImage:hover {
    transform: scale(1.05);
}

/* Lazy loading placeholder */
.lazy-loading {
    background: #f0f0f0;
    animation: none;
}

@media (min-width: 769px) {
    .lazy-loading {
        background: linear-gradient(90deg, #f0f0f0 25%, #e0e0e0 50%, #f0f0f0 75%);
        background-size: 200% 100%;
        animation: loading 1.5s infinite;
    }
}

@keyframes loading {
    0% { background-position: 200% 0; }
    100% { background-position: -200% 0; }
}

/* Fallbacks */
svg {
    max-width: 100%;
    height: auto;
}

.w-6.h-6 {
    width: 1.5rem !important;
    height: 1.5rem !important;
}

.w-5.h-5 {
    width: 1.25rem !important;
    height: 1.25rem !important;
}

.w-4.h-4 {
    width: 1rem !important;
    height: 1rem !important;
}

header {
    background-color: #02013A !important;
    color: white !important;
}

button {
    cursor: pointer;
}

/* Correção para evitar sobreposição da imagem na borda das miniaturas */
.thumbnail {
    transition: border-color 0.3s ease, transform 0.2s ease;
    box-sizing: border-box;
    overflow: hidden;
    padding: 2px; /* Espaço interno para a borda */
}

.thumbnail img {
    width: calc(100% - 4px);
    height: calc(100% - 4px);
    object-fit: cover;
    border-radius: 6px; /* Arredondar a imagem interna */
}

.thumbnail:hover {
    transform: scale(1.05);
}

/* Efeito hover para a imagem principal */
#mainImage {
    will-change: transform;
    transition: transform 0.3s ease;
}

#mainImage:hover {
    transform: scale(1.05);
}

/* Logo customizada */
.header img {
    height: 64px !important;
    max-width: 208px !important;
    object-fit: contain !important;
}

/* Para mobile */
@media (max-width: 768px) {
    .header img {
        height: 48px !important;
        max-width: 160px !important;
    }
}

#mainImage:hover {
    transform: scale(1.05);
}

/* Lazy loading placeholder */
.lazy-loading {
    background: #f0f0f0;
    animation: none;
}

@media (min-width: 769px) {
    .lazy-loading {
        background: linear-gradient(90deg, #f0f0f0 25%, #e0e0e0 50%, #f0f0f0 75%);
        background-size: 200% 100%;
        animation: loading 1.5s infinite;
    }
}

@keyframes loading {
    0% { background-position: 200% 0; }
    100% { background-position: -200% 0; }
}

/* Fallbacks */
svg {
    max-width: 100%;
    height: auto;
}

.w-6.h-6 {
    width: 1.5rem !important;
    height: 1.5rem !important;
}

.w-5.h-5 {
    width: 1.25rem !important;
    height: 1.25rem !important;
}

.w-4.h-4 {
    width: 1rem !important;
    height: 1rem !important;
}

header {
    background-color: #02013A !important;
    color: white !important;
}

button {
    cursor: pointer;
}

/* Correção para evitar sobreposição da imagem na borda das miniaturas */
.thumbnail {
    transition: border-color 0.3s ease, transform 0.2s ease;
    box-sizing: border-box;
    overflow: hidden;
    padding: 2px; /* Espaço interno para a borda */
}

.thumbnail img {
    width: calc(100% - 4px);
    height: calc(100% - 4px);
    object-fit: cover;
    border-radius: 6px; /* Arredondar a imagem interna */
}

.thumbnail:hover {
    transform: scale(1.05);
}

/* Efeito hover para a imagem principal */
#mainImage {
    will-change: transform;
    transition: transform 0.3s ease;
}

#mainImage:hover {
    transform: scale(1.05);
}

/* Logo customizada */
.header img {
    height: 64px !important;
    max-width: 208px !important;
    object-fit: contain !important;
}

/* Para mobile */
@media (max-width: 768px) {
    .header img {
        height: 48px !important;
        max-width: 160px !important;
    }
}

#mainImage:hover {
    transform: scale(1.05);
}

/* Lazy loading placeholder */
.lazy-loading {
    background: #f0f0f0;
    animation: none;
}

@media (min-width: 769px) {
    .lazy-loading {
        background: linear-gradient(90deg, #f0f0f0 25%, #e0e0e0 50%, #f0f0f0 75%);
        background-size: 200% 100%;
        animation: loading 1.5s infinite;
    }
}

@keyframes loading {
    0% { background-position: 200% 0; }
    100% { background-position: -200% 0; }
}

/* Fallbacks */
svg {
    max-width: 100%;
    height: auto;
}

.w-6.h-6 {
    width: 1.5rem !important;
    height: 1.5rem !important;
}

.w-5.h-5 {
    width: 1.25rem !important;
    height: 1.25rem !important;
}

.w-4.h-4 {
    width: 1rem !important;
    height: 1rem !important;
}

header {
    background-color: #02013A !important;
    color: white !important;
}

button {
    cursor: pointer;
}

/* Correção para evitar sobreposição da imagem na borda das miniaturas */
.thumbnail {
    transition: border-color 0.3s ease, transform 0.2s ease;
    box-sizing: border-box;
    overflow: hidden;
    padding: 2px; /* Espaço interno para a borda */
}

.thumbnail img {
    width: calc(100% - 4px);
    height: calc(100% - 4px);
    object-fit: cover;
    border-radius: 6px; /* Arredondar a imagem interna */
}

.thumbnail:hover {
    transform: scale(1.05);
}

/* Efeito hover para a imagem principal */
#mainImage {
    will-change: transform;
    transition: transform 0.3s ease;
}

#mainImage:hover {
    transform: scale(1.05);
}

/* Logo customizada */
.header img {
    height: 64px !important;
    max-width: 208px !important;
    object-fit: contain !important;
}

/* Para mobile */
@media (max-width: 768px) {
    .header img {
        height: 48px !important;
        max-width: 160px !important;
    }
}

#mainImage:hover {
    transform: scale(1.05);
}

/* Lazy loading placeholder */
.lazy-loading {
    background: #f0f0f0;
    animation: none;
}

@media (min-width: 769px) {
    .lazy-loading {
        background: linear-gradient(90deg, #f0f0f0 25%, #e0e0e0 50%, #f0f0f0 75%);
        background-size: 200% 100%;
        animation: loading 1.5s infinite;
    }
}

@keyframes loading {
    0% { background-position: 200% 0; }
    100% { background-position: -200% 0; }
}

/* Fallbacks */
svg {
    max-width: 100%;
    height: auto;
}

.w-6.h-6 {
    width: 1.5rem !important;
    height: 1.5rem !important;
}

.w-5.h-5 {
    width: 1.25rem !important;
    height: 1.25rem !important;
}

.w-4.h-4 {
    width: 1rem !important;
    height: 1rem !important;
}

header {
    background-color: #02013A !important;
    color: white !important;
}

button {
    cursor: pointer;
}

/* Correção para evitar sobreposição da imagem na borda das miniaturas */
.thumbnail {
    transition: border-color 0.3s ease, transform 0.2s ease;
    box-sizing: border-box;
    overflow: hidden;
    padding: 2px; /* Espaço interno para a borda */
}

.thumbnail img {
    width: calc(100% - 4px);
    height: calc(100% - 4px);
    object-fit: cover;
    border-radius: 6px; /* Arredondar a imagem interna */
}

.thumbnail:hover {
    transform: scale(1.05);
}

/* Efeito hover para a imagem principal */
#mainImage {
    will-change: transform;
    transition: transform 0.3s ease;
}

#mainImage:hover {
    transform: scale(1.05);
}

/* Logo customizada */
.header img {
    height: 64px !important;
    max-width: 208px !important;
    object-fit: contain !important;
}

/* Para mobile */
@media (max-width: 768px) {
    .header img {
        height: 48px !important;
        max-width: 160px !important;
    }
}

#mainImage:hover {
    transform: scale(1.05);
}

/* Lazy loading placeholder */
.lazy-loading {
    background: #f0f0f0;
    animation: none;
}

@media (min-width: 769px) {
    .lazy-loading {
        background: linear-gradient(90deg, #f0f0f0 25%, #e0e0e0 50%, #f0f0f0 75%);
        background-size: 200% 100%;
        animation: loading 1.5s infinite;
    }
}

@keyframes loading {
    0% { background-position: 200% 0; }
    100% { background-position: -200% 0; }
}

/* Fallbacks */
svg {
    max-width: 100%;
    height: auto;
}

.w-6.h-6 {
    width: 1.5rem !important;
    height: 1.5rem !important;
}

.w-5.h-5 {
    width: 1.25rem !important;
    height: 1.25rem !important;
}

.w-4.h-4 {
    width: 1rem !important;
    height: 1rem !important;
}

header {
    background-color: #02013A !important;
    color: white !important;
}

button {
    cursor: pointer;
}

/* Correção para evitar sobreposição da imagem na borda das miniaturas */
.thumbnail {
    transition: border-color 0.3s ease, transform 0.2s ease;
    box-sizing: border-box;
    overflow: hidden;
    padding: 2px; /* Espaço interno para a borda */
}

.thumbnail img {
    width: calc(100% - 4px);
    height: calc(100% - 4px);
    object-fit: cover;
    border-radius: 6px; /* Arredondar a imagem interna */
}

.thumbnail:hover {
    transform: scale(1.05);
}

/* Efeito hover para a imagem principal */
#mainImage {
    will-change: transform;
    transition: transform 0.3s ease;
}

#mainImage:hover {
    transform: scale(1.05);
}

/* Logo customizada */
.header img {
    height: 64px !important;
    max-width: 208px !important;
    object-fit: contain !important;
}

/* Para mobile */
@media (max-width: 768px) {
    .header img {
        height: 48px !important;
        max-width: 160px !important;
    }
}

#mainImage:hover {
    transform: scale(1.05);
}

/* Lazy loading placeholder */
.lazy-loading {
    background: #f0f0f0;
    animation: none;
}

@media (min-width: 769px) {
    .lazy-loading {
        background: linear-gradient(90deg, #f0f0f0 25%, #e0e0e0 50%, #f0f0f0 75%);
        background-size: 200% 100%;
        animation: loading 1.5s infinite;
    }
}

@keyframes loading {
    0% { background-position: 200% 0; }
    100% { background-position: -200% 0; }
}

/* Fallbacks */
svg {
    max-width: 100%;
    height: auto;
}

.w-6.h-6 {
    width: 1.5rem !important;
    height: 1.5rem !important;
}

.w-5.h-5 {
    width: 1.25rem !important;
    height: 1.25rem !important;
}

.w-4.h-4 {
    width: 1rem !important;
    height: 1rem !important;
}

header {
    background-color: #02013A !important;
    color: white !important;
}

button {
    cursor: pointer;
}

/* Correção para evitar sobreposição da imagem na borda das miniaturas */
.thumbnail {
    transition: border-color 0.3s ease, transform 0.2s ease;
    box-sizing: border-box;
    overflow: hidden;
    padding: 2px; /* Espaço interno para a borda */
}

.thumbnail img {
    width: calc(100% - 4px);
    height: calc(100% - 4px);
    object-fit: cover;
    border-radius: 6px; /* Arredondar a imagem interna */
}

.thumbnail:hover {
    transform: scale(1.05);
}

/* Efeito hover para a imagem principal */
#mainImage {
    will-change: transform;
    transition: transform 0.3s ease;
}

#mainImage:hover {
    transform: scale(1.05);
}

/* Logo customizada */
.header img {
    height: 64px !important;
    max-width: 208px !important;
    object-fit: contain !important;
}

/* Para mobile */
@media (max-width: 768px) {
    .header img {
        height: 48px !important;
        max-width: 160px !important;
    }
}

#mainImage:hover {
    transform: scale(1.05);
}

/* Lazy loading placeholder */
.lazy-loading {
    background: #f0f0f0;
    animation: none;
}

@media (min-width: 769px) {
    .lazy-loading {
        background: linear-gradient(90deg, #f0f0f0 25%, #e0e0e0 50%, #f0f0f0 75%);
        background-size: 200% 100%;
        animation: loading 1.5s infinite;
    }
}

@keyframes loading {
    0% { background-position: 200% 0; }
    100% { background-position: -200% 0; }
}

/* Fallbacks */
svg {
    max-width: 100%;
    height: auto;
}

.w-6.h-6 {
    width: 1.5rem !important;
    height: 1.5rem !important;
}

.w-5.h-5 {
    width: 1.25rem !important;
    height: 1.25rem !important;
}

.w-4.h-4 {
    width: 1rem !important;
    height: 1rem !important;
}

header {
    background-color: #02013A !important;
    color: white !important;
}

button {
    cursor: pointer;
}

/* Correção para evitar sobreposição da imagem na borda das miniaturas */
.thumbnail {
    transition: border-color 0.3s ease, transform 0.2s ease;
    box-sizing: border-box;
    overflow: hidden;
    padding: 2px; /* Espaço interno para a borda */
}

.thumbnail img {
    width: calc(100% - 4px);
    height: calc(100% - 4px);
    object-fit: cover;
    border-radius: 6px; /* Arredondar a imagem interna */
}

.thumbnail:hover {
    transform: scale(1.05);
}

/* Efeito hover para a imagem principal */
#mainImage {
    will-change: transform;
    transition: transform 0.3s ease;
}

#mainImage:hover {
    transform: scale(1.05);
}

/* Logo customizada */
.header img {
    height: 64px !important;
    max-width: 208px !important;
    object-fit: contain !important;
}

/* Para mobile */
@media (max-width: 768px) {
    .header img {
        height: 48px !important;
        max-width: 160px !important;
    }
}

#mainImage:hover {
    transform: scale(1.05);
}

/* Lazy loading placeholder */
.lazy-loading {
    background: #f0f0f0;
    animation: none;
}

@media (min-width: 769px) {
    .lazy-loading {
        background: linear-gradient(90deg, #f0f0f0 25%, #e0e0e0 50%, #f0f0f0 75%);
        background-size: 200% 100%;
        animation: loading 1.5s infinite;
    }
}

@keyframes loading {
    0% { background-position: 200% 0; }
    100% { background-position: -200% 0; }
}

/* Fallbacks */
svg {
    max-width: 100%;
    height: auto;
}

.w-6.h-6 {
    width: 1.5rem !important;
    height: 1.5rem !important;
}

.w-5.h-5 {
    width: 1.25rem !important;
    height: 1.25rem !important;
}

.w-4.h-4 {
    width: 1rem !important;
    height: 1rem !important;
}

header {
    background-color: #02013A !important;
    color: white !important;
}

button {
    cursor: pointer;
}

/* Correção para evitar sobreposição da imagem na borda das miniaturas */
.thumbnail {
    transition: border-color 0.3s ease, transform 0.2s ease;
    box-sizing: border-box;
    overflow: hidden;
    padding: 2px; /* Espaço interno para a borda */
}

.thumbnail img {
    width: calc(100% - 4px);
    height: calc(100% - 4px);
    object-fit: cover;
    border-radius: 6px; /* Arredondar a imagem interna */
}

.thumbnail:hover {
    transform: scale(1.05);
}

/* Efeito hover para a imagem principal */
#mainImage {
    will-change: transform;
    transition: transform 0.3s ease;
}

#mainImage:hover {
    transform: scale(1.05);
}

/* Logo customizada */
.header img {
    height: 64px !important;
    max-width: 208px !important;
    object-fit: contain !important;
}

/* Para mobile */
@media (max-width: 768px) {
    .header img {
        height: 48px !important;
        max-width: 160px !important;
    }
}

#mainImage:hover {
    transform: scale(1.05);
}

/* Lazy loading placeholder */
.lazy-loading {
    background: #f0f0f0;
    animation: none;
}

@media (min-width: 769px) {
    .lazy-loading {
        background: linear-gradient(90deg, #f0f0f0 25%, #e0e0e0 50%, #f0f0f0 75%);
        background-size: 200% 100%;
        animation: loading 1.5s infinite;
    }
}

@keyframes loading {
    0% { background-position: 200% 0; }
    100% { background-position: -200% 0; }
}

/* Fallbacks */
svg {
    max-width: 100%;
    height: auto;
}

.w-6.h-6 {
    width: 1.5rem !important;
    height: 1.5rem !important;
}

.w-5.h-5 {
    width: 1.25rem !important;
    height: 1.25rem !important;
}

.w-4.h-4 {
    width: 1rem !important;
    height: 1rem !important;
}

header {
    background-color: #02013A !important;
    color: white !important;
}

button {
    cursor: pointer;
}

/* Correção para evitar sobreposição da imagem na borda das miniaturas */
.thumbnail {
    transition: border-color 0.3s ease, transform 0.2s ease;
    box-sizing: border-box;
    overflow: hidden;
    padding: 2px; /* Espaço interno para a borda */
}

.thumbnail img {
    width: calc(100% - 4px);
    height: calc(100% - 4px);
    object-fit: cover;
    border-radius: 6px; /* Arredondar a imagem interna */
}

.thumbnail:hover {
    transform: scale(1.05);
}

/* Efeito hover para a imagem principal */
#mainImage {
    will-change: transform;
    transition: transform 0.3s ease;
}

#mainImage:hover {
    transform: scale(1.05);
}

/* Logo customizada */
.header img {
    height: 64px !important;
    max-width: 208px !important;
    object-fit: contain !important;
}

/* Para mobile */
@media (max-width: 768px) {
    .header img {
        height: 48px !important;
        max-width: 160px !important;
    }
}

#mainImage:hover {
    transform: scale(1.05);
}

/* Lazy loading placeholder */
.lazy-loading {
    background: #f0f0f0;
    animation: none;
}

@media (min-width: 769px) {
    .lazy-loading {
        background: linear-gradient(90deg, #f0f0f0 25%, #e0e0e0 50%, #f0f0f0 75%);
        background-size: 200% 100%;
        animation: loading 1.5s infinite;
    }
}

@keyframes loading {
    0% { background-position: 200% 0; }
    100% { background-position: -200% 0; }
}

/* Fallbacks */
svg {
    max-width: 100%;
    height: auto;
}

.w-6.h-6 {
    width: 1.5rem !important;
    height: 1.5rem !important;
}

.w-5.h-5 {
    width: 1.25rem !important;
    height: 1.25rem !important;
}

.w-4.h-4 {
    width: 1rem !important;
    height: 1rem !important;
}

header {
    background-color: #02013A !important;
    color: white !important;
}

button {
    cursor: pointer;
}

/* Correção para evitar sobreposição da imagem na borda das miniaturas */
.thumbnail {
    transition: border-color 0.3s ease, transform 0.2s ease;
    box-sizing: border-box;
    overflow: hidden;
    padding: 2px; /* Espaço interno para a borda */
}

.thumbnail img {
    width: calc(100% - 4px);
    height: calc(100% - 4px);
    object-fit: cover;
    border-radius: 6px; /* Arredondar a imagem interna */
}

.thumbnail:hover {
    transform: scale(1.05);
}

/* Efeito hover para a imagem principal */
#mainImage {
    will-change: transform;
    transition: transform 0.3s ease;
}

#mainImage:hover {
    transform: scale(1.05);
}

/* Logo customizada */
.header img {
    height: 64px !important;
    max-width: 208px !important;
    object-fit: contain !important;
}

/* Para mobile */
@media (max-width: 768px) {
    .header img {
        height: 48px !important;
        max-width: 160px !important;
    }
}

#mainImage:hover {
    transform: scale(1.05);
}

/* Lazy loading placeholder */
.lazy-loading {
    background: #f0f0f0;
    animation: none;
}

@media (min-width: 769px) {
    .lazy-loading {
        background: linear-gradient(90deg, #f0f0f0 25%, #e0e0e0 50%, #f0f0f0 75%);
        background-size: 200% 100%;
        animation: loading 1.5s infinite;
    }
}

@keyframes loading {
    0% { background-position: 200% 0; }
    100% { background-position: -200% 0; }
}

/* Fallbacks */
svg {
    max-width: 100%;
    height: auto;
}

.w-6.h-6 {
    width: 1.5rem !important;
    height: 1.5rem !important;
}

.w-5.h-5 {
    width: 1.25rem !important;
    height: 1.25rem !important;
}

.w-4.h-4 {
    width: 1rem !important;
    height: 1rem !important;
}

header {
    background-color: #02013A !important;
    color: white !important;
}

button {
    cursor: pointer;
}

/* Correção para evitar sobreposição da imagem na borda das miniaturas */
.thumbnail {
    transition: border-color 0.3s ease, transform 0.2s ease;
    box-sizing: border-box;
    overflow: hidden;
    padding: 2px; /* Espaço interno para a borda */
}

.thumbnail img {
    width: calc(100% - 4px);
    height: calc(100% - 4px);
    object-fit: cover;
    border-radius: 6px; /* Arredondar a imagem interna */
}

.thumbnail:hover {
    transform: scale(1.05);
}

/* Efeito hover para a imagem principal */
#mainImage {
    will-change: transform;
    transition: transform 0.3s ease;
}

#mainImage:hover {
    transform: scale(1.05);
}

/* Logo customizada */
.header img {
    height: 64px !important;
    max-width: 208px !important;
    object-fit: contain !important;
}

/* Para mobile */
@media (max-width: 768px) {
    .header img {
        height: 48px !important;
        max-width: 160px !important;
    }
}

#mainImage:hover {
    transform: scale(1.05);
}

/* Lazy loading placeholder */
.lazy-loading {
    background: #f0f0f0;
    animation: none;
}

@media (min-width: 769px) {
    .lazy-loading {
        background: linear-gradient(90deg, #f0f0f0 25%, #e0e0e0 50%, #f0f0f0 75%);
        background-size: 200% 100%;
        animation: loading 1.5s infinite;
    }
}

@keyframes loading {
    0% { background-position: 200% 0; }
    100% { background-position: -200% 0; }
}

/* Fallbacks */
svg {
    max-width: 100%;
    height: auto;
}

.w-6.h-6 {
    width: 1.5rem !important;
    height: 1.5rem !important;
}

.w-5.h-5 {
    width: 1.25rem !important;
    height: 1.25rem !important;
}

.w-4.h-4 {
    width: 1rem !important;
    height: 1rem !important;
}

header {
    background-color: #02013A !important;
    color: white !important;
}

button {
    cursor: pointer;
}

/* Correção para evitar sobreposição da imagem na borda das miniaturas */
.thumbnail {
    transition: border-color 0.3s ease, transform 0.2s ease;
    box-sizing: border-box;
    overflow: hidden;
    padding: 2px; /* Espaço interno para a borda */
}

.thumbnail img {
    width: calc(100% - 4px);
    height: calc(100% - 4px);
    object-fit: cover;
    border-radius: 6px; /* Arredondar a imagem interna */
}

.thumbnail:hover {
    transform: scale(1.05);
}

/* Efeito hover para a imagem principal */
#mainImage {
    will-change: transform;
    transition: transform 0.3s ease;
}

#mainImage:hover {
    transform: scale(1.05);
}

/* Logo customizada */
.header img {
    height: 64px !important;
    max-width: 208px !important;
    object-fit: contain !important;
}

/* Para mobile */
@media (max-width: 768px) {
    .header img {
        height: 48px !important;
        max-width: 160px !important;
    }
}

#mainImage:hover {
    transform: scale(1.05);
}

/* Lazy loading placeholder */
.lazy-loading {
    background: #f0f0f0;
    animation: none;
}

@media (min-width: 769px) {
    .lazy-loading {
        background: linear-gradient(90deg, #f0f0f0 25%, #e0e0e0 50%, #f0f0f0 75%);
        background-size: 200% 100%;
        animation: loading 1.5s infinite;
    }
}

@keyframes loading {
    0% { background-position: 200% 0; }
    100% { background-position: -200% 0; }
}

/* Fallbacks */
svg {
    max-width: 100%;
    height: auto;
}

.w-6.h-6 {
    width: 1.5rem !important;
    height: 1.5rem !important;
}

.w-5.h-5 {
    width: 1.25rem !important;
    height: 1.25rem !important;
}

.w-4.h-4 {
    width: 1rem !important;
    height: 1rem !important;
}

header {
    background-color: #02013A !important;
    color: white !important;
}

button {
    cursor: pointer;
}

/* Correção para evitar sobreposição da imagem na borda das miniaturas */
.thumbnail {
    transition: border-color 0.3s ease, transform 0.2s ease;
    box-sizing: border-box;
    overflow: hidden;
    padding: 2px; /* Espaço interno para a borda */
}

.thumbnail img {
    width: calc(100% - 4px);
    height: calc(100% - 4px);
    object-fit: cover;
    border-radius: 6px; /* Arredondar a imagem interna */
}

.thumbnail:hover {
    transform: scale(1.05);
}

/* Efeito hover para a imagem principal */
#mainImage {
    will-change: transform;
    transition: transform 0.3s ease;
}

#mainImage:hover {
    transform: scale(1.05);
}

/* Logo customizada */
.header img {
    height: 64px !important;
    max-width: 208px !important;
    object-fit: contain !important;
}

/* Para mobile */
@media (max-width: 768px) {
    .header img {
        height: 48px !important;
        max-width: 160px !important;
    }
}

#mainImage:hover {
    transform: scale(1.05);
}

/* Lazy loading placeholder */
.lazy-loading {
    background: #f0f0f0;
    animation: none;
}

@media (min-width: 769px) {
    .lazy-loading {
        background: linear-gradient(90deg, #f0f0f0 25%, #e0e0e0 50%, #f0f0f0 75%);
        background-size: 200% 100%;
        animation: loading 1.5s infinite;
    }
}

@keyframes loading {
    0% { background-position: 200% 0; }
    100% { background-position: -200% 0; }
}

/* Fallbacks */
svg {
    max-width: 100%;
    height: auto;
}

.w-6.h-6 {
    width: 1.5rem !important;
    height: 1.5rem !important;
}

.w-5.h-5 {
    width: 1.25rem !important;
    height: 1.25rem !important;
}

.w-4.h-4 {
    width: 1rem !important;
    height: 1rem !important;
}

header {
    background-color: #02013A !important;
    color: white !important;
}

button {
    cursor: pointer;
}

/* Correção para evitar sobreposição da imagem na borda das miniaturas */
.thumbnail {
    transition: border-color 0.3s ease, transform 0.2s ease;
    box-sizing: border-box;
    overflow: hidden;
    padding: 2px; /* Espaço interno para a borda */
}

.thumbnail img {
    width: calc(100% - 4px);
    height: calc(100% - 4px);
    object-fit: cover;
    border-radius: 6px; /* Arredondar a imagem interna */
}

.thumbnail:hover {
    transform: scale(1.05);
}

/* Efeito hover para a imagem principal */
#mainImage {
    will-change: transform;
    transition: transform 0.3s ease;
}

#mainImage:hover {
    transform: scale(1.05);
}

/* Logo customizada */
.header img {
    height: 64px !important;
    max-width: 208px !important;
    object-fit: contain !important;
}

/* Para mobile */
@media (max-width: 768px) {
    .header img {
        height: 48px !important;
        max-width: 160px !important;
    }
}

#mainImage:hover {
    transform: scale(1.05);
}

/* Lazy loading placeholder */
.lazy-loading {
    background: #f0f0f0;
    animation: none;
}

@media (min-width: 769px) {
    .lazy-loading {
        background: linear-gradient(90deg, #f0f0f0 25%, #e0e0e0 50%, #f0f0f0 75%);
        background-size: 200% 100%;
        animation: loading 1.5s infinite;
    }
}

@keyframes loading {
    0% { background-position: 200% 0; }
    100% { background-position: -200% 0; }
}

/* Fallbacks */
svg {
    max-width: 100%;
    height: auto;
}

.w-6.h-6 {
    width: 1.5rem !important;
    height: 1.5rem !important;
}

.w-5.h-5 {
    width: 1.25rem !important;
    height: 1.25rem !important;
}

.w-4.h-4 {
    width: 1rem !important;
    height: 1rem !important;
}

header {
    background-color: #02013A !important;
    color: white !important;
}

button {
    cursor: pointer;
}

/* Correção para evitar sobreposição da imagem na borda das miniaturas */
.thumbnail {
    transition: border-color 0.3s ease, transform 0.2s ease;
    box-sizing: border-box;
    overflow: hidden;
    padding: 2px; /* Espaço interno para a borda */
}

.thumbnail img {
    width: calc(100% - 4px);
    height: calc(100% - 4px);
    object-fit: cover;
    border-radius: 6px; /* Arredondar a imagem interna */
}

.thumbnail:hover {
    transform: scale(1.05);
}

/* Efeito hover para a imagem principal */
#mainImage {
    will-change: transform;
    transition: transform 0.3s ease;
}

#mainImage:hover {
    transform: scale(1.05);
}

/* Logo customizada */
.header img {
    height: 64px !important;
    max-width: 208px !important;
    object-fit: contain !important;
}

/* Para mobile */
@media (max-width: 768px) {
    .header img {
        height: 48px !important;
        max-width: 160px !important;
    }
}

#mainImage:hover {
    transform: scale(1.05);
}

/* Lazy loading placeholder */
.lazy-loading {
    background: #f0f0f0;
    animation: none;
}

@media (min-width: 769px) {
    .lazy-loading {
        background: linear-gradient(90deg, #f0f0f0 25%, #e0e0e0 50%, #f0f0f0 75%);
        background-size: 200% 100%;
        animation: loading 1.5s infinite;
    }
}

@keyframes loading {
    0% { background-position: 200% 0; }
    100% { background-position: -200% 0; }
}

/* Fallbacks */
svg {
    max-width: 100%;
    height: auto;
}

.w-6.h-6 {
    width: 1.5rem !important;
    height: 1.5rem !important;
}

.w-5.h-5 {
    width: 1.25rem !important;
    height: 1.25rem !important;
}

.w-4.h-4 {
    width: 1rem !important;
    height: 1rem !important;
}

header {
    background-color: #02013A !important;
    color: white !important;
}

button {
    cursor: pointer;
}

/* Correção para evitar sobreposição da imagem na borda das miniaturas */
.thumbnail {
    transition: border-color 0.3s ease, transform 0.2s ease;
    box-sizing: border-box;
    overflow: hidden;
    padding: 2px; /* Espaço interno para a borda */
}

.thumbnail img {
    width: calc(100% - 4px);
    height: calc(100% - 4px);
    object-fit: cover;
    border-radius: 6px; /* Arredondar a imagem interna */
}

.thumbnail:hover {
    transform: scale(1.05);
}

/* Efeito hover para a imagem principal */
#mainImage {
    will-change: transform;
    transition: transform 0.3s ease;
}

#mainImage:hover {
    transform: scale(1.05);
}

/* Logo customizada */
.header img {
    height: 64px !important;
    max-width: 208px !important;
    object-fit: contain !important;
}

/* Para mobile */
@media (max-width: 768px) {
    .header img {
        height: 48px !important;
        max-width: 160px !important;
    }
}

#mainImage:hover {
    transform: scale(1.05);
}

/* Lazy loading placeholder */
.lazy-loading {
    background: #f0f0f0;
    animation: none;
}

@media (min-width: 769px) {
    .lazy-loading {
        background: linear-gradient(90deg, #f0f0f0 25%, #e0e0e0 50%, #f0f0f0 75%);
        background-size: 200% 100%;
        animation: loading 1.5s infinite;
    }
}

@keyframes loading {
    0% { background-position: 200% 0; }
    100% { background-position: -200% 0; }
}

/* Fallbacks */
svg {
    max-width: 100%;
    height: auto;
}

.w-6.h-6 {
    width: 1.5rem !important;
    height: 1.5rem !important;
}

.w-5.h-5 {
    width: 1.25rem !important;
    height: 1.25rem !important;
}

.w-4.h-4 {
    width: 1rem !important;
    height: 1rem !important;
}

header {
    background-color: #02013A !important;
    color: white !important;
}

button {
    cursor: pointer;
}

/* Correção para evitar sobreposição da imagem na borda das miniaturas */
.thumbnail {
    transition: border-color 0.3s ease, transform 0.2s ease;
    box-sizing: border-box;
    overflow: hidden;
    padding: 2px; /* Espaço interno para a borda */
}

.thumbnail img {
    width: calc(100% - 4px);
    height: calc(100% - 4px);
    object-fit: cover;
    border-radius: 6px; /* Arredondar a imagem interna */
}

.thumbnail:hover {
    transform: scale(1.05);
}

/* Efeito hover para a imagem principal */
#mainImage {
    will-change: transform;
    transition: transform 0.3s ease;
}

#mainImage:hover {
    transform: scale(1.05);
}

/* Logo customizada */
.header img {
    height: 64px !important;
    max-width: 208px !important;
    object-fit: contain !important;
}

/* Para mobile */
@media (max-width: 768px) {
    .header img {
        height: 48px !important;
        max-width: 160px !important;
    }
}

#mainImage:hover {
    transform: scale(1.05);
}

/* Lazy loading placeholder */
.lazy-loading {
    background: #f0f0f0;
    animation: none;
}

@media (min-width: 769px) {
    .lazy-loading {
        background: linear-gradient(90deg, #f0f0f0 25%, #e0e0e0 50%, #f0f0f0 75%);
        background-size: 200% 100%;
        animation: loading 1.5s infinite;
    }
}

@keyframes loading {
    0% { background-position: 200% 0; }
    100% { background-position: -200% 0; }
}

/* Fallbacks */
svg {
    max-width: 100%;
    height: auto;
}

.w-6.h-6 {
    width: 1.5rem !important;
    height: 1.5rem !important;
}

.w-5.h-5 {
    width: 1.25rem !important;
    height: 1.25rem !important;
}

.w-4.h-4 {
    width: 1rem !important;
    height: 1rem !important;
}

header {
    background-color: #02013A !important;
    color: white !important;
}

button {
    cursor: pointer;
}

/* Correção para evitar sobreposição da imagem na borda das miniaturas */
.thumbnail {
    transition: border-color 0.3s ease, transform 0.2s ease;
    box-sizing: border-box;
    overflow: hidden;
    padding: 2px; /* Espaço interno para a borda */
}

.thumbnail img {
    width: calc(100% - 4px);
    height: calc(100% - 4px);
    object-fit: cover;
    border-radius: 6px; /* Arredondar a imagem interna */
}

.thumbnail:hover {
    transform: scale(1.05);
}

/* Efeito hover para a imagem principal */
#mainImage {
    will-change: transform;
    transition: transform 0.3s ease;
}

#mainImage:hover {
    transform: scale(1.05);
}

/* Logo customizada */
.header img {
    height: 64px !important;
    max-width: 208px !important;
    object-fit: contain !important;
}

/* Para mobile */
@media (max-width: 768px) {
    .header img {
        height: 48px !important;
        max-width: 160px !important;
    }
}

#mainImage:hover {
    transform: scale(1.05);
}

/* Lazy loading placeholder */
.lazy-loading {
    background: #f0f0f0;
    animation: none;
}

@media (min-width: 769px) {
    .lazy-loading {
        background: linear-gradient(90deg, #f0f0f0 25%, #e0e0e0 50%, #f0f0f0 75%);
        background-size: 200% 100%;
        animation: loading 1.5s infinite;
    }
}

@keyframes loading {
    0% { background-position: 200% 0; }
    100% { background-position: -200% 0; }
}

/* Fallbacks */
svg {
    max-width: 100%;
    height: auto;
}

.w-6.h-6 {
    width: 1.5rem !important;
    height: 1.5rem !important;
}

.w-5.h-5 {
    width: 1.25rem !important;
    height: 1.25rem !important;
}

.w-4.h-4 {
    width: 1rem !important;
    height: 1rem !important;
}

header {
    background-color: #02013A !important;
    color: white !important;
}

button {
    cursor: pointer;
}

/* Correção para evitar sobreposição da imagem na borda das miniaturas */
.thumbnail {
    transition: border-color 0.3s ease, transform 0.2s ease;
    box-sizing: border-box;
    overflow: hidden;
    padding: 2px; /* Espaço interno para a borda */
}

.thumbnail img {
    width: calc(100% - 4px);
    height: calc(100% - 4px);
    object-fit: cover;
    border-radius: 6px; /* Arredondar a imagem interna */
}

.thumbnail:hover {
    transform: scale(1.05);
}

/* Efeito hover para a imagem principal */
#mainImage {
    will-change: transform;
    transition: transform 0.3s ease;
}

#mainImage:hover {
    transform: scale(1.05);
}

/* Logo customizada */
.header img {
    height: 64px !important;
    max-width: 208px !important;
    object-fit: contain !important;
}

/* Para mobile */
@media (max-width: 768px) {
    .header img {
        height: 48px !important;
        max-width: 160px !important;
    }
}

#mainImage:hover {
    transform: scale(1.05);
}

/* Lazy loading placeholder */
.lazy-loading {
    background: #f0f0f0;
    animation: none;
}

@media (min-width: 769px) {
    .lazy-loading {
        background: linear-gradient(90deg, #f0f0f0 25%, #e0e0e0 50%, #f0f0f0 75%);
        background-size: 200% 100%;
        animation: loading 1.5s infinite;
    }
}

@keyframes loading {
    0% { background-position: 200% 0; }
    100% { background-position: -200% 0; }
}

/* Fallbacks */
svg {
    max-width: 100%;
    height: auto;
}

.w-6.h-6 {
    width: 1.5rem !important;
    height: 1.5rem !important;
}

.w-5.h-5 {
    width: 1.25rem !important;
    height: 1.25rem !important;
}

.w-4.h-4 {
    width: 1rem !important;
    height: 1rem !important;
}

header {
    background-color: #02013A !important;
    color: white !important;
}

button {
    cursor: pointer;
}

/* Correção para evitar sobreposição da imagem na borda das miniaturas */
.thumbnail {
    transition: border-color 0.3s ease, transform 0.2s ease;
    box-sizing: border-box;
    overflow: hidden;
    padding: 2px; /* Espaço interno para a borda */
}

.thumbnail img {
    width: calc(100% - 4px);
    height: calc(100% - 4px);
    object-fit: cover;
    border-radius: 6px; /* Arredondar a imagem interna */
}

.thumbnail:hover {
    transform: scale(1.05);
}

/* Efeito hover para a imagem principal */
#mainImage {
    will-change: transform;
    transition: transform 0.3s ease;
}

#mainImage:hover {
    transform: scale(1.05);
}

/* Logo customizada */
.header img {
    height: 64px !important;
    max-width: 208px !important;
    object-fit: contain !important;
}

/* Para mobile */
@media (max-width: 768px) {
    .header img {
        height: 48px !important;
        max-width: 160px !important;
    }
}

#mainImage:hover {
    transform: scale(1.05);
}

/* Lazy loading placeholder */
.lazy-loading {
    background: #f0f0f0;
    animation: none;
}

@media (min-width: 769px) {
    .lazy-loading {
        background: linear-gradient(90deg, #f0f0f0 25%, #e0e0e0 50%, #f0f0f0 75%);
        background-size: 200% 100%;
        animation: loading 1.5s infinite;
    }
}

@keyframes loading {
    0% { background-position: 200% 0; }
    100% { background-position: -200% 0; }
}

/* Fallbacks */
svg {
    max-width: 100%;
    height: auto;
}

.w-6.h-6 {
    width: 1.5rem !important;
    height: 1.5rem !important;
}

.w-5.h-5 {
    width: 1.25rem !important;
    height: 1.25rem !important;
}

.w-4.h-4 {
    width: 1rem !important;
    height: 1rem !important;
}

header {
    background-color: #02013A !important;
    color: white !important;
}

button {
    cursor: pointer;
}

/* Correção para evitar sobreposição da imagem na borda das miniaturas */
.thumbnail {
    transition: border-color 0.3s ease, transform 0.2s ease;
    box-sizing: border-box;
    overflow: hidden;
    padding: 2px; /* Espaço interno para a borda */
}

.thumbnail img {
    width: calc(100% - 4px);
    height: calc(100% - 4px);
    object-fit: cover;
    border-radius: 6px; /* Arredondar a imagem interna */
}

.thumbnail:hover {
    transform: scale(1.05);
}

/* Efeito hover para a imagem principal */
#mainImage {
    will-change: transform;
    transition: transform 0.3s ease;
}

#mainImage:hover {
    transform: scale(1.05);
}

/* Logo customizada */
.header img {
    height: 64px !important;
    max-width: 208px !important;
    object-fit: contain !important;
}

/* Para mobile */
@media (max-width: 768px) {
    .header img {
        height: 48px !important;
        max-width: 160px !important;
    }
}

#mainImage:hover {
    transform: scale(1.05);
}

/* Lazy loading placeholder */
.lazy-loading {
    background: #f0f0f0;
    animation: none;
}

@media (min-width: 769px) {
    .lazy-loading {
        background: linear-gradient(90deg, #f0f0f0 25%, #e0e0e0 50%, #f0f0f0 75%);
        background-size: 200% 100%;
        animation: loading 1.5s infinite;
    }
}

@keyframes loading {
    0% { background-position: 200% 0; }
    100% { background-position: -200% 0; }
}

/* Fallbacks */
svg {
    max-width: 100%;
    height: auto;
}

.w-6.h-6 {
    width: 1.5rem !important;
    height: 1.5rem !important;
}

.w-5.h-5 {
    width: 1.25rem !important;
    height: 1.25rem !important;
}

.w-4.h-4 {
    width: 1rem !important;
    height: 1rem !important;
}

header {
    background-color: #02013A !important;
    color: white !important;
}

button {
    cursor: pointer;
}

/* Correção para evitar sobreposição da imagem na borda das miniaturas */
.thumbnail {
    transition: border-color 0.3s ease, transform 0.2s ease;
    box-sizing: border-box;
    overflow: hidden;
    padding: 2px; /* Espaço interno para a borda */
}

.thumbnail img {
    width: calc(100% - 4px);
    height: calc(100% - 4px);
    object-fit: cover;
    border-radius: 6px; /* Arredondar a imagem interna */
}

.thumbnail:hover {
    transform: scale(1.05);
}

/* Efeito hover para a imagem principal */
#mainImage {
    will-change: transform;
    transition: transform 0.3s ease;
}

#mainImage:hover {
    transform: scale(1.05);
}

/* Logo customizada */
.header img {
    height: 64px !important;
    max-width: 208px !important;
    object-fit: contain !important;
}

/* Para mobile */
@media (max-width: 768px) {
    .header img {
        height: 48px !important;
        max-width: 160px !important;
    }
}

#mainImage:hover {
    transform: scale(1.05);
}

/* Lazy loading placeholder */
.lazy-loading {
    background: #f0f0f0;
    animation: none;
}

@media (min-width: 769px) {
    .lazy-loading {
        background: linear-gradient(90deg, #f0f0f0 25%, #e0e0e0 50%, #f0f0f0 75%);
        background-size: 200% 100%;
        animation: loading 1.5s infinite;
    }
}

@keyframes loading {
    0% { background-position: 200% 0; }
    100% { background-position: -200% 0; }
}

/* Fallbacks */
svg {
    max-width: 100%;
    height: auto;
}

.w-6.h-6 {
    width: 1.5rem !important;
    height: 1.5rem !important;
}

.w-5.h-5 {
    width: 1.25rem !important;
    height: 1.25rem !important;
}

.w-4.h-4 {
    width: 1rem !important;
    height: 1rem !important;
}

header {
    background-color: #02013A !important;
    color: white !important;
}

button {
    cursor: pointer;
}

/* Correção para evitar sobreposição da imagem na borda das miniaturas */
.thumbnail {
    transition: border-color 0.3s ease, transform 0.2s ease;
    box-sizing: border-box;
    overflow: hidden;
    padding: 2px; /* Espaço interno para a borda */
}

.thumbnail img {
    width: calc(100% - 4px);
    height: calc(100% - 4px);
    object-fit: cover;
    border-radius: 6px; /* Arredondar a imagem interna */
}