.elementor-520 .elementor-element.elementor-element-3054d64{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;--margin-top:0px;--margin-bottom:90px;--margin-left:0px;--margin-right:0px;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-widget-heading .elementor-heading-title{font-family:var( --e-global-typography-primary-font-family ), Sans-serif;font-weight:var( --e-global-typography-primary-font-weight );letter-spacing:var( --e-global-typography-primary-letter-spacing );color:var( --e-global-color-primary );}.elementor-520 .elementor-element.elementor-element-51abb44{padding:0px 0px 15px 0px;}.elementor-520 .elementor-element.elementor-element-51abb44 .elementor-heading-title{font-family:"Mulish", Sans-serif;font-size:19px;font-weight:300;letter-spacing:3px;color:#252525;}.elementor-520 .elementor-element.elementor-element-1422b17 .elementor-heading-title{font-family:"Barlow Condensed", Sans-serif;font-size:64px;font-weight:600;letter-spacing:6px;color:#0F0E0E;}.elementor-520 .elementor-element.elementor-element-42f7c61{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;--margin-top:0px;--margin-bottom:180px;--margin-left:0px;--margin-right:0px;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-520 .elementor-element.elementor-element-17e65ae{margin:0px 0px calc(var(--kit-widget-spacing, 0px) + 0px) 0px;padding:0px 0px 0px 0px;}@media(min-width:768px){.elementor-520 .elementor-element.elementor-element-3054d64{--content-width:1420px;}.elementor-520 .elementor-element.elementor-element-42f7c61{--content-width:1420px;}}@media(max-width:1366px){.elementor-520 .elementor-element.elementor-element-3054d64{--padding-top:0px;--padding-bottom:0px;--padding-left:60px;--padding-right:60px;}.elementor-widget-heading .elementor-heading-title{letter-spacing:var( --e-global-typography-primary-letter-spacing );}.elementor-520 .elementor-element.elementor-element-51abb44 .elementor-heading-title{font-size:14px;}.elementor-520 .elementor-element.elementor-element-1422b17{margin:0px 0px calc(var(--kit-widget-spacing, 0px) + 0px) 0px;padding:0px 0px 0px 0px;}.elementor-520 .elementor-element.elementor-element-1422b17 .elementor-heading-title{font-size:42px;}.elementor-520 .elementor-element.elementor-element-42f7c61{--padding-top:0px;--padding-bottom:0px;--padding-left:60px;--padding-right:60px;}}@media(max-width:1024px){.elementor-520 .elementor-element.elementor-element-3054d64{--margin-top:0px;--margin-bottom:30px;--margin-left:0px;--margin-right:0px;}.elementor-widget-heading .elementor-heading-title{letter-spacing:var( --e-global-typography-primary-letter-spacing );}.elementor-520 .elementor-element.elementor-element-1422b17 .elementor-heading-title{font-size:36px;}.elementor-520 .elementor-element.elementor-element-42f7c61{--margin-top:0px;--margin-bottom:112px;--margin-left:0px;--margin-right:0px;}}@media(max-width:767px){.elementor-520 .elementor-element.elementor-element-3054d64{--padding-top:0px;--padding-bottom:0px;--padding-left:30px;--padding-right:30px;}.elementor-widget-heading .elementor-heading-title{letter-spacing:var( --e-global-typography-primary-letter-spacing );}.elementor-520 .elementor-element.elementor-element-51abb44{text-align:center;}.elementor-520 .elementor-element.elementor-element-1422b17{text-align:center;}.elementor-520 .elementor-element.elementor-element-1422b17 .elementor-heading-title{font-size:24px;}.elementor-520 .elementor-element.elementor-element-42f7c61{--margin-top:0px;--margin-bottom:90px;--margin-left:0px;--margin-right:0px;--padding-top:0px;--padding-bottom:0px;--padding-left:30px;--padding-right:30px;}}/* Start custom CSS for html, class: .elementor-element-17e65ae *//* ============================================================
   1. COMPOSIÇÃO DO MOSAICO (AJUSTE 1: SANGRAMENTO TOTAL)
   ============================================================ */

.lucas-gallery-section {
    display: flex;
    gap: 30px;
    width: 100%;
    max-width: 1420px;
    /* AJUSTE DEFINITIVO: Zero margens e paddings para sangramento total */
    margin: 0 auto !important;
    padding: 0 !important;
}

.gallery-mosaic-group {
    flex: 1; 
}

.mosaic-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    grid-auto-rows: 250px; 
    gap: 15px;
}

.mosaic-item {
    position: relative;
    overflow: hidden;
    background: #f0f0f0;
}

/* --- IMAGEM E HOVER (MANTIDOS INTEGRALMENTE) --- */
.mosaic-item img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.5s ease;
    display: block;
}

.mosaic-item:hover img {
    transform: scale(1.05);
}

/* Classes de Variação (Desktop) */
.span-v2 { grid-row: span 2; } 
.span-h2 { grid-column: span 2; } 

/* ============================================================
   2. RESPONSIVIDADE (RESET RETANGULAR TOUCH)
   ============================================================ */

/* TABLET (Até 1024px) */
@media (max-width: 1024px) {
    .lucas-gallery-section {
        flex-direction: column;
        padding: 0 !important;
        margin: 0 !important;
    }

    .mosaic-grid {
        /* Ajuste: Reset Retangular para fluxo limpo no touch */
        grid-auto-rows: 250px; 
        gap: 15px;
    }

    /* Reset de Spans: Garante que as imagens fiquem justas e retangulares */
    .span-v2, .span-h2 { 
        grid-row: span 1 !important; 
        grid-column: span 2 !important; 
    }
}

/* MOBILE (Até 600px) */
@media (max-width: 600px) {
    .lucas-gallery-section {
        padding: 0 !important;
    }

    .mosaic-grid {
        grid-template-columns: 1fr; /* Uma coluna para sangramento real */
        grid-auto-rows: 250px;
        gap: 10px;
    }

    .span-v2, .span-h2 { 
        grid-row: span 1 !important; 
        grid-column: span 1 !important; 
    }
}/* End custom CSS */