/* --- CONFIGURAÇÕES BASE --- */
:root {
    --thb-width: 200px;
    --thb-height: 160px;
}

.br-sigpro-container { 
    margin: 20px 0; 
    width: 100%; 
    box-sizing: border-box; 
}

.br-sigpro-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, var(--thb-width));
    gap: 10px;
    justify-content: start;
    padding-left: 15px;
    padding-right: 15px;
    box-sizing: border-box;
}

.br-sigpro-item {
    width: var(--thb-width);
    height: var(--thb-height);
    position: relative;
    background: #fff;
    box-shadow: 1px 1px 4px rgba(0,0,0,0.18);
}

.br-sigpro-item img {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
    display: block;
}

@media (max-width: 768px) {
    .br-sigpro-grid {
        grid-template-columns: repeat(auto-fill, 140px);
        justify-content: start;
    }
    .br-sigpro-item {
        width: 140px;
        height: auto;
    }
}

/* --- ESTILO DAS LEGENDAS NAS THUMBS (Visível na Grade) --- */
.br-sigpro-label {
    padding: 10px;
    background: #fff;
    text-align: center;
    border-top: 1px solid rgba(0,0,0,0.05);
}

.br-sigpro-label .br-title {
    display: block;
    font-weight: bold;
    font-size: 14px;
    color: #333;
    word-wrap: break-word;
}

.br-sigpro-label .br-desc {
    display: block;
    font-size: 11px;
    color: #777;
    margin-top: 4px;
    line-height: 1.3;
}

/* --- 1. CLASSIC --- */
.layout-Classic .br-sigpro-item { border: 1px solid #ccc; padding: 4px; background: #fff; }
.layout-Classic img { border: 1px solid #eee; }

/* --- 2. ARTISTIC --- */
.layout-Artistic .br-sigpro-item { 
    padding: 8px; 
    background: #fdfdfd; 
    border: 1px solid #d2d2d2;
    box-shadow: 3px 3px 10px rgba(0,0,0,0.1); 
    border-radius: 20px 0 20px 0; 
    overflow: hidden;
}
.layout-Artistic img { border-radius: 15px 0 15px 0; }
.layout-Artistic .br-sigpro-label { background: transparent; border: none; }

/* --- 3. ELEGANT --- */
.layout-Elegant .br-sigpro-item { 
    background-color: #f4f2ed; 
    border: 14px solid #f4f2ed; 
    transition: all 0.2s; 
}
.layout-Elegant .br-sigpro-item:hover { 
    background-color: #333; 
    border: 14px solid #333; 
}
.layout-Elegant .br-sigpro-label { background: transparent; border: none; }
.layout-Elegant .br-title { 
    font-family: Georgia, "Times New Roman", Times, serif; 
    font-size: 11px; 
    color: #333;
}
.layout-Elegant .br-sigpro-item:hover .br-title { color: #eee; }

/* FIX DEFINITIVO ELEGANT */
.br-sigpro-container.layout-Elegant .br-sigpro-item {
    height: auto !important;
    overflow: hidden !important;
    position: relative !important;
}
.br-sigpro-container.layout-Elegant .br-sigpro-item img {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
    display: block !important;
}

/* --- 4. GALLERIA --- */
.layout-Galleria { background: #000; padding: 16px; }
.layout-Galleria .br-sigpro-item { 
    background-color: #333; 
    border: 4px solid #333; 
    transition: all 0.2s;
}
.layout-Galleria .br-sigpro-item:hover { border-color: #999; }
.layout-Galleria .br-sigpro-label { 
    background: rgba(51, 51, 51, 0.8); 
    border: none; 
    color: #eee; 
}
.layout-Galleria .br-title, .layout-Galleria .br-desc { color: #eee; }

/* --- 5. GALLERIAWHITE --- */
.layout-GalleriaWhite { background: #f9f9f9; padding: 20px; }
.layout-GalleriaWhite img { border: 1px solid rgba(128,128,128,0.3); }

/* --- 6. MASONRY (Pinterest) --- */
.layout-Masonry .br-sigpro-grid {
    display: block !important;
    columns: 4 var(--thb-width);
    column-gap: 15px;
}
.layout-Masonry .br-sigpro-item { 
    display: inline-block; 
    width: 100%; 
    margin-bottom: 15px; 
    background: #fff; 
    border-radius: 8px; 
    box-shadow: 0 2px 8px rgba(0,0,0,0.1); 
    overflow: hidden; 
}
.layout-Masonry img { height: auto !important; border-radius: 8px 8px 0 0; }

/* --- 7. POLAROIDS --- */
.layout-Polaroids .br-sigpro-grid { 
    display: flex !important; 
    flex-wrap: wrap !important; 
    justify-content: center !important; 
    gap: 30px !important; 
}
.layout-Polaroids .br-sigpro-item {
    background: #fff; 
    padding: 12px 12px 15px 12px;
    box-shadow: 0 4px 15px rgba(0,0,0,0.15); 
    transform: rotate(-2deg);
    border: 1px solid #eee; 
    width: var(--thb-width);
}
.layout-Polaroids .br-sigpro-item:nth-child(even) { transform: rotate(2deg); }
.layout-Polaroids .br-sigpro-item:hover { transform: rotate(0) scale(1.1); z-index: 5; }
.layout-Polaroids .br-sigpro-label { 
    background: transparent; 
    border: none; 
    font-family: 'Courier New', Courier, monospace; 
}

/* --- 8. RESPONSIVEBLUE --- */
.layout-ResponsiveBlue img { border: 2px solid #2196F3; }
.layout-ResponsiveBlue .br-sigpro-item:hover img { border-color: #0d47a1; box-shadow: 0 0 10px #2196F3; }

/* --- 9. SEAMLESS --- */
.layout-Seamless .br-sigpro-grid { gap: 1px !important; }
.layout-Seamless .br-sigpro-item { border: 0; position: relative; }
.layout-Seamless img { border-radius: 0; }
.layout-Seamless .br-sigpro-item:hover img { opacity: 0.7; }
.layout-Seamless .br-sigpro-label { display: none; }

/* --- 10. SEAMLESS_CSS_GRID --- */
.layout-Seamless_CSS_Grid { gap: 0 !important; }
.layout-Seamless_CSS_Grid img { border-radius: 0; }

/* --- 11. SLEEK --- */
.layout-Sleek .br-sigpro-item { 
    border: 6px solid #222; 
    background: #000; 
    position: relative; 
    transition: all 0.2s;
}
.layout-Sleek .br-sigpro-item:hover { border-color: #444; }
.layout-Sleek .br-sigpro-label { 
    position: absolute; 
    bottom: 10%; 
    right: 0; 
    background: rgba(0,0,0,0.7); 
    border: none; 
    text-align: right; 
    padding: 2px 8px;
}
.layout-Sleek .br-title, .layout-Sleek .br-desc { 
    color: #fff; 
    font-family: "Trebuchet MS", sans-serif; 
    font-size: 11px; 
}

/* --- 12. SLICKSHOW1 --- */
.layout-SlickShow1 .br-sigpro-item { padding: 10px; background: #000; border: 1px solid #444; }
.layout-SlickShow1 img { border: 1px solid #000; outline: 1px solid #fff; outline-offset: -5px; }

/* --- PREVIEWER & SLIDERPREVIEW --- */
.br-sigpro-viewer-container { width: 100%; margin: 0 auto 20px auto; text-align: center; }

.br-sigpro-main-display { 
    width: 100%; 
    background: transparent !important; 
    margin: 0 auto; 
    position: relative; 
    overflow: hidden; 
    display: flex; 
    align-items: center; 
    justify-content: center; 
}
.br-sigpro-main-display img { 
    max-width: 100%; 
    max-height: 100%; 
    object-fit: contain; 
    transition: opacity 0.3s; 
}

/* Thumbnails do Previewer */
.layout-Previewer .br-sigpro-grid { 
    display: flex !important; 
    flex-wrap: wrap !important; 
    gap: 8px !important; 
    justify-content: center !important;
}

/* Thumbnails do SliderPreview */
.layout-SliderPreview .br-sigpro-grid { 
    display: flex !important; 
    flex-wrap: nowrap !important; 
    gap: 8px !important; 
    overflow-x: auto !important; 
    padding: 10px 0; 
    justify-content: center !important; 
    scrollbar-width: thin; 
    scroll-snap-type: x mandatory; 
    -webkit-overflow-scrolling: touch;
}
.layout-SliderPreview .br-sigpro-item { flex: 0 0 auto; scroll-snap-align: center; }

/* Estilo da Thumb Ativa/Hover */
.br-sigpro-item img.br-thumb-nav { 
    width: 74px !important; 
    height: 50px !important; 
    object-fit: cover !important; 
    cursor: pointer; 
    opacity: 0.6; 
    border: 2px solid transparent; 
    transition: 0.2s; 
}
.br-sigpro-item img.active, .br-sigpro-item img.br-thumb-nav:hover { 
    opacity: 1; 
    border-color: #333; 
}

/* --- COMPATIBILIDADE BACKEND --- */
body#tinymce, .page-details, #config-form { all: revert !important; }
body.tmpl-component { padding-top: 20px !important; background-color: #f4f6f9 !important; }
body.tmpl-component #toolbar-box { margin-bottom: 20px !important; position: sticky; top: 0; z-index: 1000; background: #fff; padding: 10px; border-bottom: 1px solid #ddd; }
.modal-header .btn-close { z-index: 9999 !important; opacity: 1 !important; }

/* === JW CLASSIC FORCE === */
.br-sigpro-container.layout-Classic .br-sigpro-grid {
    display: flex !important;
    flex-wrap: wrap !important;
    justify-content: flex-start !important;
    align-items: flex-start !important;
    gap: 12px !important;
    padding: 0 !important;
    margin: 0 !important;
}
.br-sigpro-container.layout-Classic .br-sigpro-item {
    width: var(--thb-width) !important;
    height: var(--thb-height) !important;
    margin: 0px !important;
    background: #fff !important;
    border: 1px solid #ccc !important;
    box-shadow: 3px 3px 5px #888 !important;
    overflow: hidden !important; 
    position: relative !important;
}
.br-sigpro-container.layout-Classic .br-sigpro-item img {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important; 
    display: block !important;
}

/* === MOBILE: AJUSTES GERAIS (INCLUINDO ELEGANT FIX) === */
@media (max-width: 768px) {
    .br-sigpro-container.layout-Classic .br-sigpro-grid,
    .br-sigpro-container.layout-Artistic .br-sigpro-grid { justify-content: center !important; grid-template-columns: none !important; display: flex !important; }
    
    .br-sigpro-container.layout-Elegant .br-sigpro-grid { justify-content: center !important; grid-template-columns: none !important; display: flex !important; gap: 12px !important; padding: 0 !important; }
    .br-sigpro-container.layout-Elegant .br-sigpro-item { width: var(--thb-width) !important; max-width: var(--thb-width) !important; flex: 0 0 auto !important; }

    .br-sigpro-item { flex: 0 0 auto !important; width: var(--thb-width) !important; max-width: var(--thb-width) !important; }
    .br-sigpro-img { width: var(--thb-width) !important; height: var(--thb-height) !important; max-width: none !important; object-fit: cover !important; display: block !important; }
}

/* === MASONRY RESET === */
.layout-Masonry .br-sigpro-item { width: 100% !important; height: auto !important; max-width: 100% !important; }
.layout-Masonry .br-sigpro-item img { width: 100% !important; height: auto !important; object-fit: unset !important; }
.layout-Masonry .br-sigpro-grid { display: block !important; columns: 4 var(--thb-width); column-gap: 15px; }
@media (max-width: 768px) { .layout-Masonry .br-sigpro-grid { columns: 2 var(--thb-width); } }