.gallery-filters{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;margin:32px 0 40px}
.gf-btn{padding:9px 22px;border-radius:30px;font-size:.82rem;font-weight:600;font-family:'Poppins',sans-serif;cursor:pointer;background:transparent;color:var(--primary-blue);border:2px solid var(--primary-blue);transition:all .3s ease}
.gf-btn:hover,.gf-btn.active{background:var(--primary-blue);color:var(--white)}
.gallery-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.gallery-item{border-radius:var(--radius-md);overflow:hidden;background:var(--white);box-shadow:var(--shadow-sm);cursor:pointer;transition:transform .3s,box-shadow .3s}
.gallery-item:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.gallery-item.hidden{display:none}
.gi-img{height:220px;overflow:hidden;position:relative}
.gi-img img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}
.gallery-item:hover .gi-img img{transform:scale(1.08)}
.gi-img::after{content:'\f065';font-family:'Font Awesome 6 Free';font-weight:900;position:absolute;inset:0;background:rgba(11,87,164,.5);color:var(--white);font-size:1.5rem;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .3s}
.gallery-item:hover .gi-img::after{opacity:1}
.gi-info{padding:14px 16px;display:flex;align-items:center;gap:10px}
.gi-cat{display:inline-block;background:rgba(11,87,164,.1);color:var(--primary-blue);font-size:.68rem;font-weight:700;padding:3px 10px;border-radius:20px;text-transform:uppercase;letter-spacing:.06em;flex-shrink:0}
.gi-info p{font-size:.82rem;color:#444;font-weight:500;line-height:1.4}
.gallery-empty{text-align:center;padding:80px 0;color:#aaa}
.gallery-empty i{font-size:3rem;margin-bottom:16px;display:block}
.gallery-empty p{font-size:1rem}
/* LIGHTBOX */
.lightbox{position:fixed;inset:0;z-index:99998;display:flex;align-items:center;justify-content:center;opacity:0;visibility:hidden;transition:opacity .35s,visibility .35s}
.lightbox.active{opacity:1;visibility:visible}
.lb-overlay{position:absolute;inset:0;background:rgba(0,0,0,.92);cursor:pointer}
.lb-content{position:relative;z-index:1;display:flex;align-items:center;gap:16px;max-width:90vw;max-height:90vh;padding:0 16px}
.lb-img-wrap{position:relative}
.lb-img-wrap img{max-width:70vw;max-height:80vh;object-fit:contain;border-radius:var(--radius-sm);box-shadow:0 8px 40px rgba(0,0,0,.6);transition:opacity .3s}
.lb-caption{background:rgba(0,0,0,.7);color:var(--white);font-size:.85rem;padding:10px 16px;border-radius:0 0 var(--radius-sm) var(--radius-sm);text-align:center}
.lb-close{position:fixed;top:24px;right:28px;width:44px;height:44px;border-radius:50%;background:rgba(255,255,255,.15);color:var(--white);font-size:1.1rem;display:flex;align-items:center;justify-content:center;transition:background .3s;cursor:pointer;border:1px solid rgba(255,255,255,.2)}
.lb-close:hover{background:var(--accent-pink)}
.lb-prev,.lb-next{width:52px;height:52px;border-radius:50%;background:rgba(255,255,255,.12);color:var(--white);font-size:1.1rem;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background .3s;cursor:pointer;border:1px solid rgba(255,255,255,.2)}
.lb-prev:hover,.lb-next:hover{background:var(--primary-blue)}
@media(max-width:768px){.gallery-grid{grid-template-columns:repeat(2,1fr);gap:14px}.gi-img{height:180px}}
@media(max-width:500px){.gallery-grid{grid-template-columns:1fr}.gi-img{height:200px}.lb-content{flex-direction:column;gap:8px;padding:0 8px}.lb-img-wrap img{max-width:95vw}.lb-prev,.lb-next{width:44px;height:44px}}
