.elementor-635 .elementor-element.elementor-element-c7ede2e{--display:flex;--flex-direction:row;--container-widget-width:initial;--container-widget-height:100%;--container-widget-flex-grow:1;--container-widget-align-self:stretch;--flex-wrap-mobile:wrap;--gap:0px 0px;--row-gap:0px;--column-gap:0px;--margin-top:0px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-635 .elementor-element.elementor-element-001ca2c{--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:0px;--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-635 .elementor-element.elementor-element-420da05{padding:0px 0px 15px 0px;}.elementor-635 .elementor-element.elementor-element-420da05 .elementor-heading-title{font-family:"Mulish", Sans-serif;font-size:19px;font-weight:300;letter-spacing:3px;color:#252525;}.elementor-635 .elementor-element.elementor-element-3c3f75b .elementor-heading-title{font-family:"Barlow Condensed", Sans-serif;font-size:64px;font-weight:600;letter-spacing:6px;color:#0F0E0E;}.elementor-635 .elementor-element.elementor-element-f83ebbf{--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:0px;--margin-left:0px;--margin-right:0px;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-635 .elementor-element.elementor-element-f83ebbf.e-con{--align-self:flex-end;}.elementor-widget-text-editor{font-family:var( --e-global-typography-text-font-family ), Sans-serif;font-weight:var( --e-global-typography-text-font-weight );letter-spacing:var( --e-global-typography-text-letter-spacing );color:var( --e-global-color-text );}.elementor-widget-text-editor.elementor-drop-cap-view-stacked .elementor-drop-cap{background-color:var( --e-global-color-primary );}.elementor-widget-text-editor.elementor-drop-cap-view-framed .elementor-drop-cap, .elementor-widget-text-editor.elementor-drop-cap-view-default .elementor-drop-cap{color:var( --e-global-color-primary );border-color:var( --e-global-color-primary );}.elementor-635 .elementor-element.elementor-element-9c0bfd7{margin:0px 0px calc(var(--kit-widget-spacing, 0px) + 0px) 60px;padding:0px 0px 0px 0px;column-gap:0px;font-family:"Mulish", Sans-serif;font-size:16px;font-weight:400;letter-spacing:1px;}.elementor-635 .elementor-element.elementor-element-9c0bfd7 p{margin-block-end:0px;}.elementor-635 .elementor-element.elementor-element-3c9f56a{--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:90px;--margin-bottom:180px;--margin-left:0px;--margin-right:0px;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}@media(max-width:1366px){.elementor-635 .elementor-element.elementor-element-c7ede2e{--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-635 .elementor-element.elementor-element-420da05 .elementor-heading-title{font-size:14px;}.elementor-635 .elementor-element.elementor-element-3c3f75b .elementor-heading-title{font-size:42px;}.elementor-widget-text-editor{letter-spacing:var( --e-global-typography-text-letter-spacing );}.elementor-635 .elementor-element.elementor-element-9c0bfd7{font-size:14px;}.elementor-635 .elementor-element.elementor-element-3c9f56a{--padding-top:0px;--padding-bottom:0px;--padding-left:60px;--padding-right:60px;}}@media(max-width:1024px){.elementor-widget-heading .elementor-heading-title{letter-spacing:var( --e-global-typography-primary-letter-spacing );}.elementor-635 .elementor-element.elementor-element-3c3f75b .elementor-heading-title{font-size:36px;}.elementor-widget-text-editor{letter-spacing:var( --e-global-typography-text-letter-spacing );}.elementor-635 .elementor-element.elementor-element-3c9f56a{--margin-top:30px;--margin-bottom:112px;--margin-left:0px;--margin-right:0px;}}@media(max-width:767px){.elementor-635 .elementor-element.elementor-element-c7ede2e{--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-635 .elementor-element.elementor-element-420da05{text-align:center;}.elementor-635 .elementor-element.elementor-element-3c3f75b{padding:0px 0px 15px 0px;text-align:center;}.elementor-635 .elementor-element.elementor-element-3c3f75b .elementor-heading-title{font-size:24px;}.elementor-widget-text-editor{letter-spacing:var( --e-global-typography-text-letter-spacing );}.elementor-635 .elementor-element.elementor-element-9c0bfd7{margin:0px 0px calc(var(--kit-widget-spacing, 0px) + 0px) 0px;text-align:center;}.elementor-635 .elementor-element.elementor-element-3c9f56a{--margin-top:30px;--margin-bottom:90px;--margin-left:0px;--margin-right:0px;--padding-top:0px;--padding-bottom:0px;--padding-left:30px;--padding-right:30px;}}@media(min-width:768px){.elementor-635 .elementor-element.elementor-element-c7ede2e{--content-width:1420px;}.elementor-635 .elementor-element.elementor-element-001ca2c{--width:50%;}.elementor-635 .elementor-element.elementor-element-f83ebbf{--width:50%;}.elementor-635 .elementor-element.elementor-element-3c9f56a{--content-width:1420px;}}/* Start custom CSS for html, class: .elementor-element-6a3abb1 *//* ============================================================
   GALERIA PROJETOS - COMPOSIÇÃO DENSA (SANGRAMENTO TOTAL)
   ============================================================ */

.lucas-project-wrapper {
    --max-width: 1420px;
    --img-gap: 30px; 
    --row-height: 350px; 
    
    width: 100%; 
    max-width: var(--max-width); 
    margin: 0 auto; 
    /* AJUSTE 1: Sangramento total (Zero respiros laterais/verticais) */
    padding: 0 !important; 
    display: flow-root;
}

.lucas-project-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    grid-auto-rows: var(--row-height);
    grid-auto-flow: dense;
    gap: var(--img-gap);
    width: 100%;
    margin: 0;
}

.gallery-item {
    position: relative; 
    display: block; 
    width: 100%; 
    height: 100%;
    overflow: hidden; 
    cursor: pointer; 
    margin: 0; 
    background-color: #f4f4f4;
}

/* --- DICIONÁRIO DE TAMANHOS (DESKTOP) --- */
.item-small { grid-column: span 1; grid-row: span 1; } /* C */
.item-big   { grid-column: span 2; grid-row: span 2; } /* CG */
.item-wide  { grid-column: span 2; grid-row: span 1; } /* R */
.item-tall  { grid-column: span 1; grid-row: span 2; } /* V */
.item-full  { grid-column: span 4; grid-row: span 1; } /* RT */

/* --- IMAGENS E EFEITOS --- */
.gallery-item img {
    width: 100%; 
    height: 100%; 
    object-fit: cover; 
    display: block;
    transition: transform 0.8s cubic-bezier(0.25, 0.46, 0.45, 0.94);
    will-change: transform;
}
.gallery-item:hover img { transform: scale(1.05); }

/* ============================================================
   RESPONSIVIDADE (RESET RETANGULAR E TOUCH)
   ============================================================ */

/* TABLET (Até 1024px) */
@media (max-width: 1024px) {
    .lucas-project-wrapper {
        max-width: 100%;
        padding: 0 !important;
        margin: 0 !important;
    }

    .lucas-project-grid { 
        grid-template-columns: repeat(2, 1fr); 
        grid-auto-rows: 280px; /* Altura padronizada para o toque */
        gap: 20px; 
    }

    /* RESET RETANGULAR SENIOR: 
       Forçamos itens grandes e totais a ocuparem a largura total (2 colunas)
       e itens verticais/pequenos a ficarem lado a lado, mas todos com 
       apenas 1 linha de altura (span 1).
    */
    .item-big, 
    .item-wide, 
    .item-full { 
        grid-column: span 2 !important; 
        grid-row: span 1 !important; /* Fim do erro vertical */
    }

    .item-tall, 
    .item-small { 
        grid-column: span 1 !important; 
        grid-row: span 1 !important; /* Fim do erro vertical */
    }
}

/* MOBILE (Até 600px) */
@media (max-width: 600px) {
    .lucas-project-grid { 
        grid-template-columns: 1fr; 
        grid-auto-rows: 250px; 
        gap: 15px; 
    }

    /* Mobile: 1 coluna absoluta em tudo para sangramento real */
    .item-big, .item-wide, .item-tall, .item-full, .item-small { 
        grid-column: span 1 !important; 
        grid-row: span 1 !important; 
    }
}/* End custom CSS */