.gallery-container{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.5rem;width:100%;padding:1rem 0;display:grid}.gallery-item{cursor:pointer;border-radius:1rem;width:100%;height:280px;transition:all .4s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden;box-shadow:0 4px 20px #00000014}.gallery-item:before{content:"";opacity:0;z-index:1;pointer-events:none;background:linear-gradient(#0000 0% 50%,#000000b3 100%);transition:opacity .4s;position:absolute;inset:0}.gallery-item:hover{transform:translateY(-8px)scale(1.02);box-shadow:0 20px 40px #00000026}.gallery-item:hover:before{opacity:1}.gallery-item:hover .gallery-item-img img{transform:scale(1.15)}.gallery-item-img{width:100%;height:100%;position:relative;overflow:hidden}.gallery-item-img img{-o-object-fit:cover;object-fit:cover;-o-object-position:center;object-position:center;width:100%;height:100%;transition:transform .6s cubic-bezier(.4,0,.2,1)}@media screen and (min-width:1024px){.gallery-container{grid-template-columns:repeat(4,1fr);grid-auto-rows:200px;gap:1rem}.gallery-item{height:100%}.gallery-item:nth-child(6n+1){grid-area:span 2/span 2}.gallery-item:nth-child(6n+4){grid-column:span 2}.gallery-item:nth-child(6n+5){grid-row:span 2}}@media screen and (max-width:1023px){.gallery-container{grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:1rem}.gallery-item{height:250px}}@media screen and (max-width:768px){.gallery-container{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:.75rem}.gallery-item{border-radius:.75rem;height:200px}}@media screen and (max-width:480px){.gallery-container{grid-template-columns:repeat(2,1fr);gap:.5rem}.gallery-item{height:180px}}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.animate-fadeIn{animation:.5s ease-out fadeIn}.gallery-loading{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.5rem;padding:1rem 0;display:grid}.gallery-skeleton{background:linear-gradient(90deg,#f0f0f0 25%,#e0e0e0 50%,#f0f0f0 75%) 0 0/200% 100%;border-radius:1rem;width:100%;height:280px;animation:1.5s infinite loading}@keyframes loading{0%{background-position:200% 0}to{background-position:-200% 0}}
