.modern-gallery{min-height:100vh;background:linear-gradient(135deg,#0c0c0c,#1a1a2e 50%,#16213e);color:white;position:relative;overflow-x:hidden}.bg-blobs{position:fixed;top:0;left:0;width:100%;height:100%;z-index:0;pointer-events:none}.blob{position:absolute;border-radius:50%;filter:blur(40px);opacity:.1;animation:float 20s linear infinite}.blob-1{width:300px;height:300px;background:#ff6b6b;top:10%;left:10%;animation-delay:0s}.blob-2{width:400px;height:400px;background:#4ecdc4;top:60%;right:10%;animation-delay:-7s}.blob-3{width:250px;height:250px;background:#45b7d1;bottom:10%;left:20%;animation-delay:-14s}@keyframes float{0%,to{transform:translate(0) rotate(0deg)}25%{transform:translate(50px,50px) rotate(90deg)}50%{transform:translateY(100px) rotate(180deg)}75%{transform:translate(-50px,50px) rotate(270deg)}}.gallery-hero{position:relative;z-index:1;padding:120px 20px 80px;text-align:center}.hero-content{max-width:800px;margin:0 auto}.hero-title{font-size:4.5rem;font-weight:800;margin-bottom:20px;display:flex;flex-direction:column;line-height:1.1}.title-sub{font-size:3rem;opacity:.9}.hero-description{font-size:1.3rem;opacity:.8;max-width:500px;margin:0 auto;line-height:1.6}.filter-tabs{position:relative;z-index:2;display:flex;justify-content:center;gap:15px;padding:30px 20px;flex-wrap:wrap}.filter-btn{background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.2);color:white;padding:12px 25px;border-radius:50px;cursor:pointer;transition:all .3s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.filter-btn:hover{background:rgba(255,255,255,.2);transform:translateY(-2px)}.filter-btn.active{background:linear-gradient(135deg,#ff6b6b,#4ecdc4);border-color:transparent;box-shadow:0 10px 30px rgba(255,107,107,.3)}.masonry-grid{position:relative;z-index:2;padding:0 20px 100px;column-count:4;column-gap:20px;max-width:1400px;margin:0 auto}.gallery-item{page-break-inside:avoid;break-inside:avoid;margin-bottom:20px;border-radius:20px;overflow:hidden;position:relative;cursor:pointer;transition:all .4s cubic-bezier(.25,.46,.45,.94);background:rgba(255,255,255,.05);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.1)}.gallery-item:hover{transform:translateY(-10px) scale(1.02);box-shadow:0 25px 50px rgba(0,0,0,.5),0 0 0 1px rgba(255,255,255,.1)}.item-image{position:relative;overflow:hidden}.item-image img{width:100%;height:auto;display:block;transition:transform .6s ease}.gallery-item:hover .item-image img{transform:scale(1.1)}.item-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(180deg,transparent 0,rgba(0,0,0,.8));display:flex;align-items:flex-end;padding:30px;opacity:0;transition:all .4s ease}.gallery-item:hover .item-overlay{opacity:1}.overlay-content{transform:translateY(30px);transition:transform .4s ease}.gallery-item:hover .overlay-content{transform:translateY(0)}.item-title{font-size:1.4rem;font-weight:700;margin-bottom:10px}.item-desc{opacity:.9;margin-bottom:15px;font-size:.9rem;line-height:1.4}.explore-btn{background:rgba(255,255,255,.2);border:1px solid rgba(255,255,255,.3);color:white;padding:10px 20px;border-radius:25px;cursor:pointer;transition:all .3s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.explore-btn:hover{background:rgba(255,255,255,.3);transform:translateX(5px)}.fab{position:fixed;bottom:30px;right:30px;width:60px;height:60px;font-size:1.5rem;z-index:1000;box-shadow:0 10px 30px rgba(255,107,107,.4)}.fab:hover{transform:translateY(-5px) scale(1.1);box-shadow:0 15px 40px rgba(255,107,107,.6)}.modern-modal{position:fixed;inset:0;z-index:9999;display:flex;align-items:center;justify-content:center;padding:20px}.modal-backdrop{background:rgba(0,0,0,.8)}.modal-container{position:relative;max-width:1200px;width:100%;max-height:90vh}.modal-glass{background:rgba(255,255,255,.1);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:25px;border:1px solid rgba(255,255,255,.2);padding:40px;position:relative;animation:glassAppear .5s cubic-bezier(.25,.46,.45,.94)}@keyframes glassAppear{0%{opacity:0;transform:scale(.8) translateY(50px)}to{opacity:1;transform:scale(1) translateY(0)}}.modal-close{top:20px;right:20px;z-index:1}.modal-header{text-align:center;margin-bottom:40px}.modal-header h2{font-size:2.5rem;margin-bottom:15px;background:linear-gradient(135deg,#ff6b6b,#4ecdc4);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.modal-gallery{display:grid;grid-gap:30px;gap:30px}.main-image{border-radius:20px;overflow:hidden;box-shadow:0 20px 40px rgba(0,0,0,.3)}.main-image img{width:100%;height:400px;object-fit:cover}.image-stack{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));grid-gap:20px;gap:20px}.stack-item{background:rgba(255,255,255,.05);border-radius:15px;overflow:hidden;animation:stackSlide .6s ease-out forwards;opacity:0;transform:translateY(30px)}@keyframes stackSlide{to{opacity:1;transform:translateY(0)}}.stack-item img{width:100%;height:150px;object-fit:cover}.stack-item span{display:block;padding:15px;font-size:.9rem;opacity:.8}.modern-loader{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;background:linear-gradient(135deg,#0c0c0c,#1a1a2e)}.floating-img:nth-child(2){animation-delay:-.5s;background:linear-gradient(135deg,#4ecdc4,#45b7d1)}.floating-img:nth-child(3){animation-delay:-1s;background:linear-gradient(135deg,#45b7d1,#ff6b6b)}.modern-error{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;background:linear-gradient(135deg,#0c0c0c,#1a1a2e);text-align:center;padding:20px}.error-illustration{font-size:4rem;margin-bottom:20px}@media (max-width:1200px){.masonry-grid{column-count:3}.hero-title{font-size:3.5rem}.title-sub{font-size:2.5rem}}@media (max-width:768px){.masonry-grid{column-count:2}.hero-title{font-size:2.8rem}.title-sub{font-size:2rem}.modal-glass{padding:30px 20px;margin:10px}.main-image img{height:250px}}@media (max-width:480px){.masonry-grid{column-count:1}.hero-title{font-size:2.2rem}.title-sub{font-size:1.8rem}.filter-tabs{justify-content:center;overflow-x:auto;padding-bottom:20px}.gallery-hero{padding:100px 20px 60px}}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:#1a1a2e}::-webkit-scrollbar-thumb{background:linear-gradient(135deg,#ff6b6b,#4ecdc4);border-radius:10px}::-webkit-scrollbar-thumb:hover{background:linear-gradient(135deg,#ff5252,#26a69a)}.single-gallery-container{min-height:100vh;background:linear-gradient(135deg,#0c0c0c,#1a1a2e 50%,#16213e);color:white;position:relative;padding:20px}.gallery-detail-header{max-width:1200px;margin:0 auto 40px;padding-top:40px}.back-btn{background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.2);color:white;padding:12px 20px;border-radius:50px;cursor:pointer;display:inline-flex;align-items:center;gap:8px;margin-bottom:30px;transition:all .3s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.back-btn:hover{background:rgba(255,255,255,.2);transform:translateX(-5px)}.gallery-title-section{text-align:center;padding:0 20px}.gallery-main-title{font-size:3.5rem;font-weight:800;margin-bottom:20px;line-height:1.1}.title-gradient{background:linear-gradient(135deg,#ff6b6b,#4ecdc4 50%,#45b7d1);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.gallery-subtitle{font-size:1.3rem;opacity:.9;max-width:600px;margin:0 auto 20px;line-height:1.6}.gallery-stats{display:flex;align-items:center;justify-content:center;gap:15px;flex-wrap:wrap;opacity:.8}.stat{font-size:.9rem}.stat strong{color:#4ecdc4}.stat-divider{opacity:.5}.gallery-content{max-width:1200px;margin:0 auto}.featured-image-container{position:relative;margin-bottom:50px;cursor:pointer;border-radius:20px;overflow:hidden;transition:all .4s ease}.featured-image-container:hover{transform:translateY(-5px);box-shadow:0 25px 50px rgba(0,0,0,.5)}.featured-image-wrapper{position:relative;height:500px;overflow:hidden}.featured-image{width:100%;height:100%;object-fit:cover;transition:transform .6s ease}.featured-image-container:hover .featured-image{transform:scale(1.05)}.image-badge{position:absolute;top:20px;left:20px;background:linear-gradient(135deg,#ff6b6b,#4ecdc4);color:white;padding:8px 16px;border-radius:20px;font-size:.8rem;font-weight:600}.image-overlay-text{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(transparent,rgba(0,0,0,.8));padding:30px 20px 20px;text-align:center;opacity:0;transition:opacity .3s ease}.featured-image-container:hover .image-overlay-text{opacity:1}.thumbnail-section{margin-top:60px}.section-title{font-size:1.8rem;font-weight:700;margin-bottom:30px;text-align:center;background:linear-gradient(135deg,#4ecdc4,#45b7d1);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.thumbnail-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));grid-gap:25px;gap:25px}.thumbnail-item{cursor:pointer;border-radius:15px;overflow:hidden;transition:all .4s ease;background:rgba(255,255,255,.05);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.1)}.thumbnail-item:hover{transform:translateY(-8px) scale(1.02);box-shadow:0 20px 40px rgba(0,0,0,.4)}.thumbnail-wrapper{position:relative;height:250px;overflow:hidden}.thumbnail-image{width:100%;height:100%;object-fit:cover;transition:transform .6s ease}.thumbnail-item:hover .thumbnail-image{transform:scale(1.1)}.thumbnail-caption{padding:15px;background:rgba(0,0,0,.7);font-size:.9rem;opacity:.9;text-align:center}.image-modal{position:fixed;inset:0;background:rgba(0,0,0,.85);z-index:99999;display:flex;align-items:center;justify-content:center;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px)}.modal-backdrop{position:absolute;inset:0;background:rgba(0,0,0,.95);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px)}.modal-content{position:relative;background:#fff;border-radius:12px;padding:20px;width:90%;max-width:900px;z-index:100000;animation:fadeIn .3s ease}@keyframes modalSlideIn{0%{opacity:0;transform:scale(.8) translateY(50px)}to{opacity:1;transform:scale(1) translateY(0)}}.modal-close{position:absolute;top:15px;right:15px;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.2);color:white;width:40px;height:40px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:1.5rem;transition:all .3s ease;z-index:10}.modal-close:hover{background:rgba(255,255,255,.2);transform:rotate(90deg)}.modal-navigation{gap:20px;height:500px}.modal-navigation,.nav-btn{display:flex;align-items:center}.nav-btn{background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.2);color:white;width:50px;height:50px;border-radius:50%;cursor:pointer;justify-content:center;font-size:1.5rem;transition:all .3s ease;flex-shrink:0}.nav-btn:hover{background:rgba(255,255,255,.2);transform:scale(1.1)}.modal-image-container{flex:1 1;height:100%;position:relative;border-radius:15px;overflow:hidden}.modal-image{width:100%;height:100%;object-fit:contain}.image-info{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(transparent,rgba(0,0,0,.8));padding:30px 20px 20px;text-align:center}.image-title{font-size:1.3rem;font-weight:600;margin-bottom:5px}.image-counter{opacity:.8;font-size:.9rem}.modal-thumbnails{display:flex;gap:10px;margin-top:20px;padding:10px;overflow-x:auto}.thumbnail-preview{width:80px;height:80px;border-radius:10px;overflow:hidden;cursor:pointer;opacity:.6;transition:all .3s ease;flex-shrink:0;border:2px solid transparent}.thumbnail-preview:hover{opacity:.8;transform:scale(1.05)}.thumbnail-preview.active{opacity:1;border-color:#4ecdc4;transform:scale(1.1)}.thumbnail-preview img{width:100%;height:100%;object-fit:cover}.floating-actions{position:fixed;bottom:30px;right:30px;display:flex;flex-direction:column;gap:15px;z-index:100}.fab{width:50px;height:50px;border-radius:50%;border:none;background:linear-gradient(135deg,#ff6b6b,#4ecdc4);color:white;font-size:1.2rem;cursor:pointer;transition:all .3s ease;box-shadow:0 8px 25px rgba(255,107,107,.3);display:flex;align-items:center;justify-content:center}.fab:hover{transform:translateY(-3px) scale(1.1);box-shadow:0 12px 35px rgba(255,107,107,.5)}@media (max-width:768px){.single-gallery-container{padding:15px}.gallery-main-title{font-size:2.5rem}.gallery-subtitle{font-size:1.1rem}.featured-image-wrapper{height:300px}.thumbnail-grid{grid-template-columns:1fr}.modal-content{padding:20px;margin:10px}.modal-navigation{height:300px;flex-direction:column}.nav-btn{width:40px;height:40px}.floating-actions{bottom:20px;right:20px}.fab{width:45px;height:45px}}@media (max-width:480px){.gallery-main-title{font-size:2rem}.gallery-detail-header{padding-top:20px}.featured-image-wrapper{height:250px}.thumbnail-wrapper{height:200px}}.modal-thumbnails::-webkit-scrollbar{height:6px}.modal-thumbnails::-webkit-scrollbar-track{background:rgba(255,255,255,.1);border-radius:3px}.modal-thumbnails::-webkit-scrollbar-thumb{background:linear-gradient(135deg,#ff6b6b,#4ecdc4);border-radius:3px}.empty-state,.modern-error,.modern-loader{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;background:linear-gradient(135deg,#0c0c0c,#1a1a2e);text-align:center;padding:20px}.floating-images{display:flex;gap:20px;margin-bottom:30px}.floating-img{width:60px;height:60px;background:linear-gradient(135deg,#ff6b6b,#4ecdc4);border-radius:15px;animation:float 2s ease-in-out infinite}.empty-icon,.error-illustration{font-size:4rem;margin-bottom:20px}.glow-btn{background:linear-gradient(135deg,#ff6b6b,#4ecdc4);border:none;color:white;padding:15px 30px;border-radius:25px;cursor:pointer;font-weight:600;transition:all .3s ease;box-shadow:0 10px 30px rgba(255,107,107,.3);margin-top:20px}.glow-btn:hover{transform:translateY(-3px);box-shadow:0 15px 40px rgba(255,107,107,.5)}