.gallery-hero{text-align:center;padding:3rem 0 1.5rem}.gallery-hero h1{margin-bottom:1rem;font-size:3.5rem;font-weight:700}.hero-subtitle{color:#94a3b8e6;max-width:600px;margin:0 auto;font-size:1.25rem}.gallery-section{min-height:60vh;padding:1.5rem 0 4rem}.gallery-grid{grid-template-columns:repeat(3,1fr);gap:1.5rem;margin-top:2rem;display:grid}.gallery-item{cursor:pointer;aspect-ratio:4/3;background:#ffffff08;border:1px solid #ffffff1a;border-radius:16px;transition:all .3s;position:relative;overflow:hidden}.gallery-item:hover{border-color:#3b82f64d;transform:translateY(-8px);box-shadow:0 20px 60px #00000080,0 0 40px #3b82f633}.gallery-item img{object-fit:cover;width:100%;height:100%;transition:transform .3s;display:block}.gallery-item:hover img{transform:scale(1.05)}.gallery-item-overlay{opacity:0;background:linear-gradient(#0000,#000c);padding:1.5rem;transition:opacity .3s;position:absolute;bottom:0;left:0;right:0}.gallery-item:hover .gallery-item-overlay{opacity:1}.gallery-item-date{color:#fffc;font-size:.875rem}.gallery-loading{flex-direction:column;justify-content:center;align-items:center;gap:1.5rem;padding:4rem 0;display:flex}.loading-spinner{border:4px solid #3b82f633;border-top-color:var(--primary-blue);border-radius:50%;width:50px;height:50px;animation:1s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.gallery-loading p{color:#94a3b8e6;font-size:1.125rem}.gallery-error{text-align:center;padding:4rem 0}.gallery-error p{color:#ef4444e6;font-size:1.125rem}.gallery-empty{text-align:center;padding:4rem 0}.gallery-empty p{color:#94a3b8e6;margin-bottom:2rem;font-size:1.125rem}.lightbox{z-index:10000;background:#000000f2;justify-content:center;align-items:center;width:100%;height:100%;display:none;position:fixed;top:0;left:0}.lightbox.active{display:flex}.lightbox img{object-fit:contain;border-radius:8px;max-width:90%;max-height:90%}.lightbox-close,.lightbox-prev,.lightbox-next{color:#fff;cursor:pointer;background:#ffffff1a;border:1px solid #fff3;border-radius:50%;justify-content:center;align-items:center;width:50px;height:50px;font-size:2rem;transition:all .3s;display:flex;position:absolute}.lightbox-close:hover,.lightbox-prev:hover,.lightbox-next:hover{background:#fff3;transform:scale(1.1)}.lightbox-close{top:2rem;right:2rem}.lightbox-prev{top:50%;left:2rem;transform:translateY(-50%)}.lightbox-next{top:50%;right:2rem;transform:translateY(-50%)}.lightbox-prev:hover,.lightbox-next:hover{transform:translateY(-50%)scale(1.1)}@media (max-width:1024px){.gallery-grid{grid-template-columns:repeat(3,1fr);gap:1rem}}@media (max-width:768px){.gallery-hero h1{font-size:2rem}.gallery-grid{grid-template-columns:repeat(3,1fr);gap:.6rem;margin-top:.5rem}.gallery-hero{padding:1.5rem 0 .75rem}.gallery-section{padding:.75rem 0 2rem}.gallery-tabs-container{margin-bottom:1rem}.lightbox-prev,.lightbox-next{width:40px;height:40px;font-size:1.5rem}.lightbox-prev{left:.5rem}.lightbox-next{right:.5rem}.lightbox-close{top:1rem;right:1rem}}.gallery-tabs-container{justify-content:center;margin-bottom:2rem;display:flex}.gallery-tabs{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff0d;border:1px solid #ffffff1a;border-radius:50px;gap:5px;padding:6px;display:flex}.tab-btn{color:#ffffffb3;cursor:pointer;background:0 0;border:none;border-radius:40px;padding:.75rem 2rem;font-family:inherit;font-size:1rem;font-weight:500;transition:all .3s}.tab-btn:hover{color:#fff}.tab-btn.active{background:var(--primary-blue);color:#fff;box-shadow:0 4px 15px #3b82f666}
