.gallery-page{padding:3rem var(--page-pad)4rem;min-height:80vh}.gallery-grid{grid-template-columns:repeat(4,1fr);gap:.875rem;display:grid}@media (max-width:1000px){.gallery-grid{grid-template-columns:repeat(3,1fr)}}@media (max-width:640px){.gallery-page{padding:2rem 1.25rem 3rem}.gallery-grid{grid-template-columns:repeat(2,1fr);gap:.6rem}}.gallery-item{aspect-ratio:1;background:var(--primary-dark);cursor:zoom-in;border:1px solid #8bca5414;border-radius:.5rem;animation:.4s both galleryItemFadeIn;position:relative;overflow:hidden}.gallery-item:nth-child(4n+1){animation-delay:0s}.gallery-item:nth-child(4n+2){animation-delay:50ms}.gallery-item:nth-child(4n+3){animation-delay:.1s}.gallery-item:nth-child(4n+4){animation-delay:.15s}@keyframes galleryItemFadeIn{0%{opacity:0;transform:scale(.97)}to{opacity:1;transform:scale(1)}}.gallery-item img,.gallery-item>div{object-fit:cover;width:100%;height:100%;transition:transform .35s;display:block}.gallery-item:hover img,.gallery-item:hover>div{transform:scale(1.06)}.gallery-item-overlay{opacity:0;pointer-events:none;background:linear-gradient(#0000 50%,#271e16cc 100%);align-items:flex-end;padding:.75rem;transition:opacity .25s;display:flex;position:absolute;inset:0}.gallery-item:hover .gallery-item-overlay{opacity:1}.gallery-item-caption{color:#ffffffe6;font-family:Comfortaa,sans-serif;font-size:.78rem;line-height:1.3}.gallery-empty{color:#ffffff4d;text-align:center;padding:6rem 0;font-family:Comfortaa,sans-serif;font-size:1rem}.gallery-lightbox{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);z-index:1000;cursor:zoom-out;background:#120d09f2;justify-content:center;align-items:center;animation:.2s forwards lightboxFadeIn;display:flex;position:fixed;inset:0}.gallery-lightbox-content{cursor:default;flex-direction:column;align-items:center;gap:1rem;max-width:min(88vw,1000px);animation:.25s forwards lightboxScale;display:flex}.gallery-lightbox-img-wrap{border-radius:.75rem;line-height:0;position:relative;overflow:hidden;box-shadow:0 24px 80px #000000b3}.gallery-lightbox-img-wrap img,.gallery-lightbox-img-wrap>div{width:auto;max-width:min(88vw,1000px);height:auto;max-height:75vh;display:block}.gallery-lightbox-caption{color:#ffffffd9;text-align:center;font-family:Comfortaa,sans-serif;font-size:.88rem;font-style:italic}.gallery-lightbox-close{color:#ffffffb3;cursor:pointer;z-index:1001;background:#271e16cc;border:1px solid #8bca5440;border-radius:50%;justify-content:center;align-items:center;width:2.5rem;height:2.5rem;font-size:1.1rem;transition:background .2s,color .2s,border-color .2s;display:flex;position:fixed;top:1.25rem;right:1.5rem}.gallery-lightbox-close:hover{background:var(--primary);color:var(--background);border-color:var(--primary)}.gallery-lightbox-counter{color:#fff6;letter-spacing:.08em;z-index:1001;pointer-events:none;font-family:Comfortaa,sans-serif;font-size:.8rem;position:fixed;top:1.4rem;left:50%;transform:translate(-50%)}.gallery-lightbox-arrow{color:#fff9;cursor:pointer;z-index:1001;background:#271e16b3;border:1px solid #8bca5433;border-radius:50%;justify-content:center;align-items:center;width:3rem;height:3rem;font-size:1.25rem;transition:background .2s,border-color .2s,color .2s;display:flex;position:fixed;top:50%;transform:translateY(-50%)}.gallery-lightbox-arrow:hover{background:var(--primary);border-color:var(--primary);color:var(--background)}.gallery-lightbox-arrow--prev{left:1.25rem}.gallery-lightbox-arrow--next{right:1.25rem}
