.gallery-title{text-align:center;margin-top:80px;margin-bottom:10px;font-size:3.5rem;font-weight:700;color:#333;animation:fadeInDown .8s ease-out}.gallery-subtitle{text-align:center;font-size:1.2rem;color:#666;margin-bottom:60px;animation:fadeIn 1s ease-out .3s both}.animate-title{position:relative;display:inline-block}.animate-title:after{content:"";position:absolute;bottom:-10px;left:50%;transform:translateX(-50%);width:100px;height:4px;background:linear-gradient(90deg,#667eea,#764ba2);animation:expandWidth .8s ease-out .5s both}.gallery-container{max-width:1400px;margin:0 auto;padding:20px}.gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));grid-auto-rows:300px;grid-gap:20px;gap:20px;grid-auto-flow:dense}.gallery-item{position:relative;overflow:hidden;border-radius:12px;cursor:pointer;box-shadow:0 4px 15px rgba(0,0,0,.1);transition:all .4s cubic-bezier(.4,0,.2,1);opacity:0;transform:translateY(30px) scale(.95);animation:fadeInUp .6s ease-out forwards;background:#e0e0e0}.gallery-item.visible{opacity:1;transform:translateY(0) scale(1)}.gallery-item-wide{grid-column:span 2}.gallery-item img{width:100%;height:100%;object-fit:cover;object-position:center;display:block;transition:transform .5s cubic-bezier(.4,0,.2,1);min-height:100%;min-width:100%}.gallery-item:hover{transform:translateY(-8px);box-shadow:0 12px 30px rgba(0,0,0,.2)}.gallery-item:hover img{transform:scale(1.1)}.gallery-item-overlay{position:absolute;top:0;left:0;right:0;bottom:0;width:100%;height:100%;background:linear-gradient(135deg,rgba(102,126,234,.9),rgba(118,75,162,.9));display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .4s ease;z-index:2}.gallery-item:hover .gallery-item-overlay{opacity:1}.gallery-item-overlay i{color:#fff;font-size:3rem;transform:scale(.5);transition:transform .4s cubic-bezier(.68,-.55,.265,1.55)}.gallery-item:hover .gallery-item-overlay i{transform:scale(1)}.lightbox-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.95);z-index:9999;display:flex;align-items:center;justify-content:center;animation:fadeIn .3s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.lightbox-content{max-width:90vw;max-height:90vh;position:relative;animation:zoomIn .4s cubic-bezier(.68,-.55,.265,1.55)}.lightbox-content img{max-width:100%;max-height:90vh;object-fit:contain;border-radius:8px;box-shadow:0 20px 60px rgba(0,0,0,.5)}.lightbox-close{position:absolute;top:20px;right:30px;background:transparent;border:2px solid #fff;color:#fff;font-size:2rem;width:50px;height:50px;border-radius:50%;cursor:pointer;z-index:10000;display:flex;align-items:center;justify-content:center;transition:all .3s ease}.lightbox-close:hover{background:#fff;color:#000;transform:rotate(90deg)}.lightbox-nav{position:absolute;top:50%;transform:translateY(-50%);background:hsla(0,0%,100%,.1);border:2px solid #fff;color:#fff;font-size:2rem;width:60px;height:60px;border-radius:50%;cursor:pointer;z-index:10000;display:flex;align-items:center;justify-content:center;transition:all .3s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.lightbox-prev{left:30px}.lightbox-next{right:30px}.lightbox-nav:hover{background:#fff;color:#000;transform:translateY(-50%) scale(1.1)}.lightbox-counter{position:absolute;bottom:30px;left:50%;transform:translateX(-50%);background:hsla(0,0%,100%,.2);color:#fff;padding:10px 25px;border-radius:25px;font-size:1rem;font-weight:600;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid hsla(0,0%,100%,.3)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-30px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes zoomIn{0%{opacity:0;transform:scale(.8)}to{opacity:1;transform:scale(1)}}@keyframes expandWidth{0%{width:0}to{width:100px}}@media screen and (max-width:1200px){.gallery-grid{grid-template-columns:repeat(auto-fill,minmax(250px,1fr));grid-auto-rows:250px}.gallery-title{font-size:2.8rem}}@media screen and (max-width:768px){.gallery-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));grid-auto-rows:220px;gap:15px}.gallery-item-wide{grid-column:span 1}.gallery-title{font-size:2.2rem;margin-top:60px}.gallery-subtitle{font-size:1rem;margin-bottom:40px}.lightbox-nav{width:50px;height:50px;font-size:1.5rem}.lightbox-prev{left:15px}.lightbox-next{right:15px}.lightbox-close{top:15px;right:15px;width:45px;height:45px;font-size:1.5rem}.lightbox-counter{bottom:20px;padding:8px 20px;font-size:.9rem}}@media screen and (max-width:480px){.gallery-grid{grid-template-columns:1fr;grid-auto-rows:280px}.gallery-container{padding:10px}.gallery-title{font-size:1.8rem}.gallery-item-overlay i{font-size:2rem}}@keyframes loading{0%{background-position:200% 0}to{background-position:-200% 0}}