/* ============ Filterable Gallery — frontend styles ============ */
.fg-wrap{max-width:100%;}

/* Filter bar (most visual styling is controlled from Elementor) */
.fg-filters{display:flex;flex-wrap:wrap;}
.fg-btn{cursor:pointer;line-height:1.2;transition:all .25s ease;background:transparent;}

/* ---------- Masonry (CSS columns) ---------- */
.fg-grid{column-count:4;column-gap:14px;}
.fg-item{
  break-inside:avoid;display:block;overflow:hidden;border-radius:10px;
  cursor:pointer;background:#f2f2f2;margin-bottom:14px;width:100%;
}
.fg-item img{width:100%;height:auto;display:block;transition:transform .4s ease;opacity:0;}
.fg-item img.fg-loaded{opacity:1;}

/* ---------- Grid (equal squares) ---------- */
.fg-grid.fg-grid-mode{
  display:grid;grid-template-columns:repeat(4,1fr);gap:14px;column-count:initial;
}
.fg-grid-mode .fg-item{margin-bottom:0;aspect-ratio:1/1;}
.fg-grid-mode .fg-item img{height:100%;object-fit:cover;}

/* Hover zoom */
.fg-zoom .fg-item:hover img{transform:scale(1.06);}

/* Filter fade-in */
.fg-item.fg-show{animation:fgfade .4s ease;}
@keyframes fgfade{from{opacity:0;transform:translateY(8px);}to{opacity:1;transform:translateY(0);}}
.fg-item.fg-hide{display:none;}

/* ---------- Lightbox ---------- */
.fg-box{
  position:fixed;inset:0;background:rgba(0,0,0,.92);display:none;
  align-items:center;justify-content:center;z-index:99999;
}
.fg-box.fg-open{display:flex;}
.fg-box .fg-box-img{max-width:92vw;max-height:90vh;border-radius:6px;box-shadow:0 10px 40px rgba(0,0,0,.5);}
.fg-box .fg-close{position:absolute;top:20px;right:28px;font-size:40px;cursor:pointer;line-height:1;font-weight:300;user-select:none;color:#fff;}
.fg-box .fg-nav{position:absolute;top:50%;transform:translateY(-50%);font-size:50px;cursor:pointer;padding:0 20px;user-select:none;opacity:.8;transition:opacity .2s;color:#fff;}
.fg-box .fg-nav:hover{opacity:1;}
.fg-box .fg-prev{left:10px;}
.fg-box .fg-next{right:10px;}

@media(max-width:1024px){.fg-grid{column-count:3;}.fg-grid.fg-grid-mode{grid-template-columns:repeat(3,1fr);}}
@media(max-width:600px){
  .fg-grid{column-count:2;}
  .fg-grid.fg-grid-mode{grid-template-columns:repeat(2,1fr);}
  .fg-box .fg-nav{font-size:36px;padding:0 12px;}
}
