.container{max-width:1400px;margin:0 auto;padding:2rem;min-height:100vh;position:relative;z-index:1}.header{text-align:center;margin-bottom:4rem;padding:3rem 0;position:relative}.header:after{content:"";position:absolute;bottom:0;left:50%;transform:translateX(-50%);width:100px;height:4px;background:linear-gradient(90deg,transparent,var(--primary),var(--secondary),transparent);border-radius:2px}.title{font-size:4rem;font-weight:800;background:linear-gradient(135deg,var(--primary) 0,var(--secondary) 50%,var(--accent) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:1rem;display:flex;align-items:center;justify-content:center;gap:1rem;letter-spacing:-.02em;position:relative;animation:titleGlow 3s ease-in-out infinite}@keyframes titleGlow{0%,to{filter:drop-shadow(0 0 20px rgba(139,92,246,.5))}50%{filter:drop-shadow(0 0 30px rgba(236,72,153,.6))}}.title-icon{font-size:4rem;-webkit-text-fill-color:initial;animation:float 3s ease-in-out infinite;filter:drop-shadow(0 0 20px rgba(139,92,246,.6))}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.subtitle{color:var(--text-muted);font-size:1.3rem;font-weight:300;letter-spacing:.02em;margin-bottom:1.5rem}.header-badge{display:flex;justify-content:center;gap:1rem;flex-wrap:wrap;margin-top:2rem}.badge-text{background:var(--glass);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid var(--glass-border);padding:.5rem 1.2rem;border-radius:50px;font-size:.85rem;color:var(--text);font-weight:500;transition:all .3s ease}.badge-text:hover{background:rgba(139,92,246,.2);border-color:var(--primary);transform:translateY(-2px);box-shadow:0 5px 15px var(--shadow)}.main{display:flex;flex-direction:column;gap:3rem}.upload-section{width:100%}.upload-area{border:2px dashed var(--border);border-radius:2rem;padding:5rem 2rem;text-align:center;cursor:pointer;transition:all .4s cubic-bezier(.4,0,.2,1);background:var(--glass);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);position:relative;overflow:hidden;box-shadow:0 8px 32px rgba(0,0,0,.3)}.upload-area:before{content:"";position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:linear-gradient(45deg,transparent,rgba(139,92,246,.1),transparent);transform:rotate(45deg);animation:shine 3s infinite}@keyframes shine{0%{transform:translateX(-100%) translateY(-100%) rotate(45deg)}to{transform:translateX(100%) translateY(100%) rotate(45deg)}}.upload-area:hover{border-color:var(--primary);background:rgba(139,92,246,.1);transform:translateY(-5px);box-shadow:0 20px 60px var(--glow),0 0 40px rgba(139,92,246,.3)}.upload-area.drag-active{border-color:var(--secondary);background:rgba(236,72,153,.15);transform:scale(1.03);box-shadow:0 25px 70px var(--glow),0 0 50px rgba(236,72,153,.4);border-style:solid}.upload-area.uploading{cursor:not-allowed;opacity:.7}.file-input{display:none}.upload-content{display:flex;flex-direction:column;align-items:center;gap:1rem}.upload-icon{font-size:5rem;margin-bottom:1rem;filter:drop-shadow(0 0 20px rgba(139,92,246,.5));animation:pulseIcon 2s ease-in-out infinite}@keyframes pulseIcon{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.upload-text{font-size:1.4rem;color:var(--text);font-weight:600;margin-bottom:.5rem}.upload-hint{color:var(--text-muted);font-size:1rem;font-weight:400}.upload-spinner{width:50px;height:50px;border:4px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin 1s linear infinite;margin-bottom:1rem}@keyframes spin{to{transform:rotate(1turn)}}.progress-bar{width:100%;max-width:400px;height:10px;background:hsla(0,0%,100%,.1);margin-top:1.5rem;box-shadow:inset 0 2px 4px rgba(0,0,0,.3)}.progress-bar,.progress-fill{border-radius:10px;overflow:hidden}.progress-fill{height:100%;background:linear-gradient(90deg,var(--primary),var(--secondary),var(--accent));transition:width .3s ease;box-shadow:0 0 20px rgba(139,92,246,.6);position:relative}.progress-fill:after{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(90deg,transparent,hsla(0,0%,100%,.3),transparent);animation:shimmer 1.5s infinite}@keyframes shimmer{0%{transform:translateX(-100%)}to{transform:translateX(100%)}}.gallery-section{width:100%}.gallery-header{justify-content:space-between;margin-bottom:2rem}.gallery-header,.gallery-title{display:flex;align-items:center}.gallery-title{font-size:2.5rem;font-weight:700;color:var(--text);gap:1rem;background:linear-gradient(135deg,var(--text) 0,var(--text-muted) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.count-badge{background:linear-gradient(135deg,var(--primary),var(--secondary));color:#fff;padding:.25rem .75rem;border-radius:50px;font-size:1.2rem;font-weight:700;-webkit-text-fill-color:initial;box-shadow:0 4px 15px var(--shadow)}.refresh-btn{background:var(--glass);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid var(--glass-border);color:var(--text);padding:.75rem 1.25rem;border-radius:12px;cursor:pointer;font-size:1.3rem;transition:all .4s cubic-bezier(.4,0,.2,1);box-shadow:0 4px 15px rgba(0,0,0,.2)}.refresh-btn:hover{background:rgba(139,92,246,.2);border-color:var(--primary);transform:rotate(180deg) scale(1.1);box-shadow:0 8px 25px var(--shadow)}.empty-state{text-align:center;padding:5rem 2rem;color:var(--text-muted);background:var(--glass);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-radius:2rem;border:1px solid var(--glass-border)}.empty-icon{font-size:5rem;margin-bottom:1.5rem;filter:drop-shadow(0 0 20px rgba(139,92,246,.3));animation:float 3s ease-in-out infinite}.empty-text{font-size:1.8rem;margin-bottom:.75rem;color:var(--text);font-weight:600;background:linear-gradient(135deg,var(--text) 0,var(--text-muted) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.empty-hint{font-size:1.1rem;font-weight:400}.gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));grid-gap:2rem;gap:2rem}.gallery-item{background:var(--glass);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-radius:1.5rem;overflow:hidden;transition:all .4s cubic-bezier(.4,0,.2,1);border:1px solid var(--glass-border);box-shadow:0 8px 32px rgba(0,0,0,.3)}.gallery-item:hover{transform:translateY(-8px) scale(1.02);box-shadow:0 20px 60px var(--glow),0 0 40px rgba(139,92,246,.3);border-color:var(--primary)}.image-wrapper{position:relative;width:100%;aspect-ratio:16/9;overflow:hidden;cursor:pointer}.gallery-image{width:100%;height:100%;object-fit:cover;transition:transform .3s ease}.gallery-item:hover .gallery-image{transform:scale(1.1)}.image-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.7);display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .3s ease}.gallery-item:hover .image-overlay{opacity:1}.view-btn{background:linear-gradient(135deg,var(--primary),var(--secondary));color:#fff;border:none;padding:.875rem 2rem;border-radius:12px;cursor:pointer;font-size:1rem;font-weight:600;transition:all .3s ease;box-shadow:0 4px 15px rgba(139,92,246,.4);position:relative;overflow:hidden}.view-btn:before{content:"";position:absolute;top:50%;left:50%;width:0;height:0;border-radius:50%;background:hsla(0,0%,100%,.3);transform:translate(-50%,-50%);transition:width .6s,height .6s}.view-btn:hover:before{width:300px;height:300px}.view-btn:hover{transform:scale(1.08);box-shadow:0 8px 25px rgba(139,92,246,.6)}.image-info{padding:1.5rem}.image-name{font-weight:600;color:var(--text);margin-bottom:.75rem;font-size:.95rem;word-break:break-word}.image-meta{display:flex;align-items:center;gap:.5rem;color:var(--text-muted);font-size:.85rem;margin-bottom:1rem}.meta-separator{color:var(--border)}.download-btn{width:100%;background:linear-gradient(135deg,var(--primary) 0,var(--secondary) 100%);color:#fff;border:none;padding:.875rem;border-radius:12px;cursor:pointer;font-size:1rem;font-weight:600;transition:all .3s ease;box-shadow:0 4px 15px rgba(139,92,246,.4);position:relative;overflow:hidden}.download-btn:after{content:"";position:absolute;top:50%;left:50%;width:0;height:0;border-radius:50%;background:hsla(0,0%,100%,.2);transform:translate(-50%,-50%);transition:width .6s,height .6s}.download-btn:hover:after{width:300px;height:300px}.download-btn:hover{transform:translateY(-3px);box-shadow:0 8px 25px rgba(139,92,246,.6)}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.9);display:flex;align-items:center;justify-content:center;z-index:1000;padding:2rem;animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{background:var(--glass);backdrop-filter:blur(30px);-webkit-backdrop-filter:blur(30px);border-radius:2rem;max-width:90vw;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;border:1px solid var(--glass-border);animation:slideUp .4s cubic-bezier(.4,0,.2,1);position:relative;box-shadow:0 25px 80px rgba(0,0,0,.5),0 0 60px rgba(139,92,246,.3)}@keyframes slideUp{0%{transform:translateY(50px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-close{position:absolute;top:1.5rem;right:1.5rem;background:rgba(0,0,0,.6);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);color:#fff;border:1px solid hsla(0,0%,100%,.1);width:45px;height:45px;border-radius:50%;cursor:pointer;font-size:1.5rem;z-index:1001;transition:all .3s ease;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 15px rgba(0,0,0,.3)}.modal-close:hover{background:rgba(239,68,68,.9);transform:rotate(90deg) scale(1.1);box-shadow:0 6px 20px rgba(239,68,68,.5)}.modal-image{max-width:100%;max-height:70vh;object-fit:contain;display:block;margin:0 auto}.modal-info{padding:2rem;border-top:2px solid var(--border)}.modal-title{font-size:1.5rem;font-weight:600;margin-bottom:1rem;color:var(--text);word-break:break-word}.modal-meta{display:flex;gap:1.5rem;color:var(--text-muted);margin-bottom:1.5rem;font-size:.95rem}.modal-download-btn{width:100%;background:linear-gradient(135deg,var(--primary) 0,var(--secondary) 100%);color:#fff;border:none;padding:1.25rem;border-radius:12px;cursor:pointer;font-size:1.2rem;font-weight:700;transition:all .3s ease;box-shadow:0 6px 20px rgba(139,92,246,.5);position:relative;overflow:hidden}.modal-download-btn:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,hsla(0,0%,100%,.2),transparent);transition:left .5s}.modal-download-btn:hover:before{left:100%}.modal-download-btn:hover{transform:translateY(-3px);box-shadow:0 10px 30px rgba(139,92,246,.7)}@media (max-width:768px){.container{padding:1rem}.title,.title-icon{font-size:2.5rem}.subtitle{font-size:1.1rem}.header-badge{gap:.5rem}.badge-text{font-size:.75rem;padding:.4rem 1rem}.upload-area{padding:3rem 1.5rem;border-radius:1.5rem}.upload-icon{font-size:4rem}.upload-text{font-size:1.2rem}.gallery-title{font-size:1.8rem}.gallery-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1.5rem}.modal-content{max-width:95vw;max-height:95vh;border-radius:1.5rem}.modal-close{top:1rem;right:1rem;width:40px;height:40px}}