:root{font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;line-height:1.5;font-weight:400;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box}body{margin:0;padding:0;min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2)}#root{width:100%;min-height:100vh}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:#ffffff1a}::-webkit-scrollbar-thumb{background:#ffffff4d;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#ffffff80}html,body{margin:0;padding:0;width:100%;min-height:100vh;overflow-x:hidden;scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;-webkit-overflow-scrolling:touch;overscroll-behavior-y:contain;height:100vh;height:-webkit-fill-available;background:#0d1117;color:#f0f6fc;transition:background-color .3s ease,color .3s ease}#root{width:100%;min-height:100vh;min-height:-webkit-fill-available;background:transparent}*:focus{outline:2px solid var(--accent-primary);outline-offset:2px}*:focus:not(:focus-visible){outline:none}*:focus-visible{outline:3px solid var(--accent-primary);outline-offset:2px;border-radius:4px}@media (prefers-contrast: high){:root{--border-color: rgba(0, 0, 0, .8);--shadow-light: rgba(0, 0, 0, .3);--shadow-medium: rgba(0, 0, 0, .5)}.dark-theme{--border-color: rgba(255, 255, 255, .8);--shadow-light: rgba(255, 255, 255, .3);--shadow-medium: rgba(255, 255, 255, .5)}}@media (hover: none) and (pointer: coarse){button,.filter-btn,.photo-card{min-height:44px;min-width:44px}}@media (prefers-reduced-motion: reduce){*{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}:root{--bg-primary: #0d1117;--bg-secondary: #161b22;--bg-tertiary: #21262d;--bg-card: rgba(33, 38, 45, .95);--bg-header: rgba(13, 17, 23, .98);--text-primary: #f0f6fc;--text-secondary: #e6edf3;--text-muted: rgba(240, 246, 252, .7);--border-color: rgba(48, 54, 61, .6);--shadow-light: rgba(0, 0, 0, .5);--shadow-medium: rgba(0, 0, 0, .7);--shadow-heavy: rgba(0, 0, 0, .9);--accent-primary: #58a6ff;--accent-secondary: #8b949e;--accent-tertiary: #f0f6fc;--accent-quaternary: #e6edf3;--accent-success: #3fb950;--accent-warning: #d29922;--accent-error: #f85149;--gradient-primary: linear-gradient(135deg, #58a6ff 0%, #388bfd 100%);--gradient-secondary: linear-gradient(135deg, #21262d 0%, #161b22 100%);--gradient-tertiary: linear-gradient(135deg, #161b22 0%, #0d1117 100%);--gradient-warm: linear-gradient(135deg, #d29922 0%, #f0883e 100%);--gradient-cool: linear-gradient(135deg, #58a6ff 0%, #388bfd 100%);--gradient-dark: linear-gradient(135deg, #0d1117 0%, #161b22 100%);--glass-bg: rgba(33, 38, 45, .4);--glass-border: rgba(88, 166, 255, .3);--glass-shadow: 0 8px 32px 0 rgba(0, 0, 0, .8);--space-xs: clamp(.25rem, 1vw, .5rem);--space-sm: clamp(.5rem, 2vw, 1rem);--space-md: clamp(1rem, 3vw, 2rem);--space-lg: clamp(1.5rem, 4vw, 3rem);--space-xl: clamp(2rem, 5vw, 4rem);--font-xs: clamp(.75rem, 2vw, .875rem);--font-sm: clamp(.875rem, 2.5vw, 1rem);--font-md: clamp(1rem, 3vw, 1.125rem);--font-lg: clamp(1.125rem, 3.5vw, 1.25rem);--font-xl: clamp(1.25rem, 4vw, 1.5rem);--font-2xl: clamp(1.5rem, 5vw, 2rem);--font-3xl: clamp(2rem, 6vw, 3rem)}.photo-album{min-height:100vh;width:100%;padding:var(--space-md);font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;position:relative;overflow-x:hidden;transition:all .3s cubic-bezier(.25,.46,.45,.94);background:radial-gradient(circle at 20% 80%,rgba(88,166,255,.08) 0%,transparent 50%),radial-gradient(circle at 80% 20%,rgba(88,166,255,.05) 0%,transparent 50%),var(--bg-primary);-webkit-overflow-scrolling:touch;-webkit-tap-highlight-color:transparent;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overscroll-behavior:contain;scroll-snap-type:y proximity}.photo-album:before{content:"";position:fixed;top:0;left:0;width:100%;height:100%;background:radial-gradient(circle at 30% 40%,rgba(88,166,255,.04) 0%,transparent 60%),radial-gradient(circle at 70% 80%,rgba(88,166,255,.025) 0%,transparent 60%);pointer-events:none;z-index:-1;animation:backgroundFloat 20s ease-in-out infinite}@keyframes backgroundFloat{0%,to{transform:translate(0) translateY(0) scale(1)}25%{transform:translate(20px) translateY(-15px) scale(1.02)}50%{transform:translate(-10px) translateY(10px) scale(.98)}75%{transform:translate(15px) translateY(-5px) scale(1.01)}}*{transition:background-color .3s ease,color .3s ease,border-color .3s ease,box-shadow .3s ease}.photo-album:hover .floating-element{animation-play-state:paused}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.loading-spinner{width:40px;height:40px;border:3px solid var(--border-color);border-top:3px solid var(--accent-primary);border-radius:50%;animation:spin 1s linear infinite;margin:20px auto}.photo-album:before{content:"";position:fixed;top:0;left:0;width:100vw;height:100vh;background:var(--bg-primary);pointer-events:none;z-index:-2;transition:all .3s ease}@keyframes fadeInBounce{0%{opacity:0;transform:scale(.8) translateY(-20px)}50%{opacity:.8;transform:scale(1.05) translateY(-5px)}to{opacity:1;transform:scale(1) translateY(0)}}@keyframes pulse{0%,to{opacity:.8;transform:scale(1)}50%{opacity:1;transform:scale(1.05)}}@keyframes float{0%{transform:translateY(0) translate(0) rotate(0)}33%{transform:translateY(-15px) translate(8px) rotate(1deg)}66%{transform:translateY(8px) translate(-8px) rotate(-1deg)}to{transform:translateY(0) translate(0) rotate(0)}}@keyframes slideInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.floating-elements{display:none}.album-header{text-align:center;margin-bottom:var(--space-lg);color:var(--text-primary);position:sticky;top:0;z-index:100;padding:var(--space-lg) var(--space-md);background:var(--bg-header);-webkit-backdrop-filter:blur(25px) saturate(180%);backdrop-filter:blur(25px) saturate(180%);border-bottom:1px solid var(--border-color);transition:all .4s cubic-bezier(.4,0,.2,1);box-shadow:var(--shadow-light);border-radius:0 0 28px 28px;position:relative;overflow:hidden}:root .album-header{background:#fffffff2;border-bottom-color:#3b82f61a;box-shadow:0 8px 32px #00000014,0 1px 3px #0000000d}.dark-theme .album-header{background:var(--glass-bg);border-bottom-color:var(--glass-border);box-shadow:var(--glass-shadow)}.album-header:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--gradient-primary);animation:gradientShift 8s ease-in-out infinite}.album-header.scrolled{padding:var(--space-md) var(--space-md);box-shadow:0 16px 64px var(--shadow-medium),0 8px 32px var(--shadow-light);transform:translateY(-1px)}:root .album-header.scrolled{box-shadow:0 16px 64px #0000001f,0 8px 32px #3b82f61a}.dark-theme .album-header.scrolled{box-shadow:var(--glass-shadow),0 16px 64px #667eea26}.header-top{display:flex;justify-content:space-between;align-items:center;gap:var(--space-md);margin-bottom:var(--space-sm);max-width:1200px;margin-left:auto;margin-right:auto;flex-wrap:wrap}.header-content{max-width:1200px;margin:0 auto}.header-actions{display:flex;align-items:center;gap:var(--space-md);flex-wrap:wrap}.header-badge{display:none}.search-container{position:relative;z-index:10}.search-wrapper{position:relative;display:flex;align-items:center;background:var(--bg-card);border:2px solid var(--border-color);border-radius:50px;padding:.75rem 1rem;transition:all .3s cubic-bezier(.4,0,.2,1);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);min-width:280px;box-shadow:0 4px 20px var(--shadow-light)}.search-wrapper:hover{border-color:var(--accent-primary);box-shadow:0 8px 30px var(--shadow-medium);transform:translateY(-2px)}.search-wrapper:focus-within{border-color:var(--accent-primary);box-shadow:0 0 0 4px #64748b1a;transform:translateY(-2px)}.search-icon{color:var(--text-muted);margin-right:.75rem;transition:color .3s ease}.search-wrapper:focus-within .search-icon{color:var(--accent-primary)}.search-input{flex:1;border:none;outline:none;background:transparent;color:var(--text-primary);font-size:var(--font-md);font-weight:500;letter-spacing:.01em}.search-input::placeholder{color:var(--text-muted);font-weight:400}.search-clear{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:.25rem;border-radius:50%;transition:all .2s ease;display:flex;align-items:center;justify-content:center;margin-left:.5rem}.search-clear:hover{background:var(--accent-primary);color:#fff;transform:scale(1.1)}.header-title-section{flex:1;text-align:left}.title-container{display:flex;align-items:center;gap:var(--space-md)}.title-decoration{display:flex;flex-direction:column;align-items:center;gap:.5rem}.camera-icon{color:var(--accent-primary);background:var(--bg-card);padding:.75rem;border-radius:50%;border:2px solid var(--border-color);box-shadow:0 4px 20px var(--shadow-light);transition:all .3s ease;animation:float 6s ease-in-out infinite}.camera-icon:hover{transform:scale(1.1) rotate(5deg);box-shadow:0 8px 30px var(--shadow-medium)}.title-line{width:2px;height:40px;background:var(--gradient-secondary);border-radius:2px;opacity:.8}.title-text{flex:1}.album-header h1{font-size:clamp(2rem,5vw,3.5rem);margin:0 0 var(--space-xs) 0;font-weight:800;line-height:1.1;letter-spacing:-.03em;display:flex;flex-direction:column;gap:.25rem}.title-main{color:var(--text-primary);text-shadow:0 2px 4px var(--shadow-light)}.title-accent{background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;position:relative}.title-accent:after{content:"";position:absolute;bottom:-4px;left:0;width:100%;height:3px;background:var(--gradient-primary);border-radius:2px;opacity:.6}.subtitle{font-size:var(--font-md);color:var(--text-muted);margin:var(--space-xs) 0 var(--space-sm) 0;font-weight:400;line-height:1.5;max-width:500px}.title-stats{display:flex;align-items:center;gap:var(--space-sm);margin-top:var(--space-sm)}.stat-item{display:flex;flex-direction:column;align-items:flex-start;gap:.25rem}.stat-number{font-size:var(--font-lg);font-weight:700;color:var(--accent-primary);line-height:1}.stat-label{font-size:var(--font-xs);color:var(--text-muted);text-transform:uppercase;letter-spacing:.1em;font-weight:600}.stat-divider{color:var(--text-muted);font-size:var(--font-lg);opacity:.5}@keyframes float{0%,to{transform:translateY(0) rotate(0)}50%{transform:translateY(-10px) rotate(2deg)}}@keyframes titleSlideIn{0%{opacity:0;transform:translate(-30px)}to{opacity:1;transform:translate(0)}}@keyframes statsCountUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.title-text{animation:titleSlideIn .8s ease-out}.title-stats{animation:statsCountUp 1s ease-out .3s both}.stat-number{counter-reset:num var(--num, 0);animation:statsCountUp 1.2s ease-out .5s both}.header-stats{display:none}.header-stat{display:flex;align-items:center;justify-content:center;background:linear-gradient(145deg,#ffffff26,#ffffff0d);-webkit-backdrop-filter:blur(15px);backdrop-filter:blur(15px);border:1px solid rgba(151,28,28,.2);border-radius:20px;padding:.8rem 1.5rem;transition:all .3s ease}.header-stat:hover{transform:translateY(-3px);box-shadow:0 8px 25px #0003;border-color:#fff6}.stat-text{font-weight:700;color:#f5f3f3e6}.filter-section{margin-bottom:var(--space-xl);position:relative;z-index:2;background:var(--bg-card);border-radius:28px;border:1px solid var(--border-color);box-shadow:0 8px 32px var(--shadow-light),0 1px 3px var(--shadow-light);-webkit-backdrop-filter:blur(25px) saturate(180%);backdrop-filter:blur(25px) saturate(180%);overflow:hidden;padding:0;transition:all .4s cubic-bezier(.23,1,.32,1)}:root .filter-section{background:#fffffff2;border-color:#3b82f626;box-shadow:0 8px 32px #0000001a,0 1px 3px #00000014}.dark-theme .filter-section{background:var(--glass-bg);border-color:var(--glass-border);box-shadow:var(--glass-shadow)}.filter-section:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:var(--gradient-primary);border-radius:28px 28px 0 0;animation:gradientShift 6s ease-in-out infinite}@keyframes gradientShift{0%,to{background:var(--gradient-primary)}25%{background:var(--gradient-secondary)}50%{background:var(--gradient-tertiary)}75%{background:var(--gradient-warm)}}.filter-section:hover{transform:translateY(-2px);box-shadow:0 16px 64px var(--shadow-medium),0 8px 32px #3b82f61a}.search-results-banner{display:flex;align-items:center;gap:1rem;padding:1.25rem 1.75rem;background:var(--gradient-primary);color:#fff;font-size:var(--font-sm);font-weight:600;border-radius:28px 28px 0 0;position:relative;overflow:hidden}.search-results-banner:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);animation:shimmer 3s infinite}@keyframes shimmer{0%{left:-100%}to{left:100%}}.search-results-banner svg{flex-shrink:0;filter:drop-shadow(0 2px 4px rgba(0,0,0,.2))}.results-count{font-weight:800;font-size:var(--font-md);background:#ffffff40;padding:.375rem .875rem;border-radius:16px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.2);box-shadow:inset 0 1px #ffffff4d}.results-text{flex:1;font-weight:500;text-shadow:0 1px 2px rgba(0,0,0,.2)}.clear-search-results{background:#fff3;border:1px solid rgba(255,255,255,.3);border-radius:12px;padding:.625rem;color:#fff;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);display:flex;align-items:center;justify-content:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 2px 8px #0000001a}.clear-search-results:hover{background:#ffffff4d;transform:scale(1.05);box-shadow:0 4px 12px #0003}.category-filter-container{position:relative;padding:2rem;background:linear-gradient(145deg,#ffffff1a,#ffffff0d)}:root .category-filter-container{background:linear-gradient(145deg,#f8fafccc,#ffffffe6)}.dark-theme .category-filter-container{background:linear-gradient(145deg,#ffffff0d,#ffffff05)}.category-filter-scroll-hint{display:none;align-items:center;justify-content:center;gap:.75rem;margin-bottom:1.5rem;padding:1rem 1.5rem;background:var(--gradient-primary);border:1px solid rgba(59,130,246,.3);border-radius:20px;font-size:var(--font-xs);font-weight:700;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.2);animation:fadeInBounce .6s ease-out;position:relative;overflow:hidden;box-shadow:0 4px 20px #3b82f640}.category-filter-scroll-hint:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);animation:shimmer 2s infinite}.category-filter-scroll-hint svg{color:#ffffffe6;animation:pulse 2s ease-in-out infinite}.category-filter{display:flex;justify-content:center;flex-wrap:wrap;gap:1rem;position:relative;z-index:2;overflow-x:auto;-webkit-overflow-scrolling:touch;scroll-snap-type:x mandatory;scrollbar-width:none;-ms-overflow-style:none;padding:.75rem 0}.category-filter::-webkit-scrollbar{display:none}@media (max-width: 768px){.filter-section{position:sticky;top:140px;z-index:90;margin:0 -1rem var(--space-xl) -1rem;border-radius:0 0 24px 24px;box-shadow:0 4px 20px #0000001f,0 1px 3px #00000014}.category-filter-container{padding:1rem}.category-filter-scroll-hint{display:flex}.category-filter{flex-wrap:nowrap;justify-content:flex-start;gap:.5rem;padding:.75rem 0;scroll-padding:1rem}.category-filter:before,.category-filter:after{content:"";flex-shrink:0;width:.5rem}}.filter-btn{display:flex;align-items:center;gap:.75rem;padding:1rem 1.5rem;border:none;border-radius:24px;background:var(--bg-card);color:var(--text-primary);font-weight:600;cursor:pointer;transition:all .4s cubic-bezier(.23,1,.32,1);-webkit-backdrop-filter:blur(20px) saturate(180%);backdrop-filter:blur(20px) saturate(180%);border:2px solid var(--border-color);position:relative;overflow:hidden;font-size:var(--font-sm);min-width:max-content;touch-action:manipulation;-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none;box-shadow:0 4px 20px var(--shadow-light),inset 0 1px #ffffff1a,0 1px 3px var(--shadow-light);scroll-snap-align:start;transform-origin:center}:root .filter-btn{background:#fffffff2;border-color:#3b82f626;box-shadow:0 4px 20px #00000014,inset 0 1px #fffc,0 1px 3px #0000001a}.dark-theme .filter-btn{background:var(--glass-bg);border-color:var(--glass-border);box-shadow:var(--glass-shadow)}.filter-btn:before{content:"";position:absolute;inset:0;background:var(--gradient-primary);opacity:0;transition:opacity .4s ease;z-index:-1}.filter-btn:after{content:"";position:absolute;top:50%;left:50%;width:0;height:0;background:radial-gradient(circle,rgba(59,130,246,.2) 0%,transparent 70%);transform:translate(-50%,-50%);transition:all .6s cubic-bezier(.23,1,.32,1);z-index:1}.filter-icon{font-size:1.2em;flex-shrink:0;filter:drop-shadow(0 1px 2px rgba(0,0,0,.05));transition:all .3s ease;z-index:2;position:relative}.filter-text{font-weight:700;letter-spacing:.02em;text-shadow:0 1px 2px rgba(0,0,0,.02);z-index:2;position:relative;transition:all .3s ease}.filter-count{display:flex;align-items:center;justify-content:center;background:var(--accent-primary);border-radius:16px;padding:.375rem .75rem;font-size:var(--font-xs);font-weight:800;min-width:28px;color:#fff;transition:all .4s cubic-bezier(.23,1,.32,1);border:1px solid rgba(255,255,255,.2);box-shadow:0 2px 8px #3b82f640,inset 0 1px #ffffff4d;z-index:2;position:relative}.filter-btn:hover{transform:translateY(-4px) scale(1.03);box-shadow:0 12px 40px var(--shadow-medium),0 8px 24px #3b82f633,inset 0 1px #ffffff4d;border-color:#3b82f666}:root .filter-btn:hover{background:#fff;box-shadow:0 12px 40px #00000026,0 8px 24px #3b82f633,inset 0 1px #ffffffe6}.dark-theme .filter-btn:hover{background:var(--bg-header);box-shadow:0 12px 40px var(--shadow-medium),0 8px 24px #667eea33,inset 0 1px #ffffff4d}.filter-btn:hover:before{opacity:.08}.filter-btn:hover:after{width:120px;height:120px}.filter-btn:hover .filter-icon{transform:scale(1.1) rotate(5deg);filter:drop-shadow(0 2px 4px rgba(0,0,0,.1))}.filter-btn:hover .filter-count{background:var(--gradient-secondary);transform:scale(1.1) rotate(-2deg);box-shadow:0 4px 16px #3b82f64d,inset 0 1px #fff6}.filter-btn.active{background:var(--gradient-primary);color:#fff;border-color:var(--accent-primary);font-weight:800;transform:scale(1.05);box-shadow:0 16px 48px var(--shadow-heavy),0 8px 24px #667eea66,inset 0 2px 4px #ffffff4d,0 0 0 4px #667eea33;text-shadow:0 1px 2px rgba(0,0,0,.3);position:relative}.filter-btn.active:before{opacity:1}.filter-btn.active:after{content:"";position:absolute;inset:-3px;background:var(--gradient-warm);border-radius:27px;z-index:-2;animation:borderGlow 2s ease-in-out infinite alternate}@keyframes borderGlow{0%{opacity:.5;transform:scale(1)}to{opacity:.8;transform:scale(1.02)}}.filter-btn.active .filter-icon{transform:scale(1.15) rotate(-3deg);filter:drop-shadow(0 2px 4px rgba(0,0,0,.3));animation:iconBounce .6s ease-out}@keyframes iconBounce{0%{transform:scale(1.15) rotate(-3deg)}50%{transform:scale(1.25) rotate(3deg)}to{transform:scale(1.15) rotate(-3deg)}}.filter-btn.active .filter-text{text-shadow:0 1px 3px rgba(0,0,0,.3)}.filter-btn.active .filter-count{background:#ffffff4d;color:#fff;border-color:#fff6;transform:scale(1.1);box-shadow:0 4px 16px #0000004d,inset 0 1px #ffffff80;animation:countPulse .8s ease-out}@keyframes countPulse{0%{transform:scale(1.1)}50%{transform:scale(1.2)}to{transform:scale(1.1)}}.filter-btn:active{transform:scale(.95);transition-duration:.1s}.filter-btn:focus-visible{outline:3px solid var(--accent-primary);outline-offset:4px;box-shadow:0 8px 32px var(--shadow-medium),0 0 0 4px #667eea4d}@media (max-width: 768px){.filter-section{position:sticky;top:140px;z-index:90;margin:0 -1rem var(--space-xl) -1rem;border-radius:0 0 28px 28px;box-shadow:var(--glass-shadow),0 8px 32px #667eea26}.category-filter-container{padding:1.5rem}.category-filter-scroll-hint{display:flex}.category-filter{flex-wrap:nowrap;justify-content:flex-start;gap:.75rem;padding:1rem 0;scroll-padding:1rem}.category-filter:before,.category-filter:after{content:"";flex-shrink:0;width:.75rem}.filter-btn{padding:.875rem 1.25rem;min-width:140px}}@media (max-width: 480px){.filter-btn{padding:.75rem 1rem;font-size:var(--font-xs);gap:.5rem;min-width:120px}.filter-icon{font-size:1.1em}.filter-count{padding:.25rem .6rem;font-size:.7rem;min-width:24px}}@keyframes fadeInScale{0%{opacity:0;transform:scale(.9) translateY(-10px)}to{opacity:1;transform:scale(1) translateY(0)}}@keyframes bounce{0%,20%,50%,80%,to{transform:translate(0)}40%{transform:translate(-3px)}60%{transform:translate(3px)}}.search-container{max-width:600px;margin:0 auto 2rem;display:none}.search-bar{position:relative;display:flex;align-items:center}.search-input{width:100%;padding:1rem 1.5rem;font-size:1rem;border:2px solid var(--border-color);border-radius:50px;background:var(--bg-card);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);color:var(--text-primary);outline:none;transition:all .3s ease}.search-input::placeholder{color:var(--text-muted)}.search-input:focus{border-color:var(--accent-primary);background:var(--bg-card);transform:scale(1.02);box-shadow:0 4px 20px var(--shadow-light)}.clear-search{position:absolute;right:1rem;background:none;border:none;color:#ffffffb3;font-size:1.5rem;cursor:pointer;padding:.25rem;border-radius:50%;transition:all .2s ease;width:30px;height:30px;display:flex;align-items:center;justify-content:center}.clear-search:hover{background:#fff3;color:#fff}.search-results{text-align:center;color:#fffc;font-size:.9rem;margin-top:.5rem;font-style:italic}.category-sections{max-width:1600px;margin:0 auto;position:relative;z-index:2}.category-section{margin-bottom:6rem;scroll-margin-top:120px;animation:slideInUp .8s ease-out;animation-fill-mode:both;scroll-snap-align:start;scroll-snap-stop:normal}.category-section:nth-child(1){animation-delay:.1s}.category-section:nth-child(2){animation-delay:.2s}.category-section:nth-child(3){animation-delay:.3s}.category-section:nth-child(4){animation-delay:.4s}.category-section:nth-child(5){animation-delay:.5s}.category-section:nth-child(6){animation-delay:.6s}.category-section:nth-child(7){animation-delay:.7s}.category-header{display:flex;align-items:center;justify-content:space-between;text-align:left;margin-bottom:3rem;padding:2rem;background:var(--bg-header);border-radius:20px;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid var(--border-color);position:relative;overflow:hidden;box-shadow:0 4px 12px var(--shadow-light);transition:all .3s ease}.category-header:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.1),transparent);transition:left .5s ease}.category-section:hover .category-header:before{left:100%}.category-title{display:flex;align-items:center;gap:15px;font-size:2.5rem;font-weight:800;margin:0;background:linear-gradient(135deg,var(--text-primary),var(--text-secondary),var(--accent-primary));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;text-shadow:0 0 20px var(--shadow-light);letter-spacing:-.02em;transition:all .3s ease}.category-icon{font-size:2.5rem;filter:drop-shadow(0 4px 8px var(--shadow-medium));transition:transform .3s ease}.category-section:hover .category-icon{transform:scale(1.05) rotate(2deg)}.category-description{font-size:1.2rem;color:var(--text-muted);margin-bottom:1rem;line-height:1.6;max-width:600px;margin-left:auto;margin-right:auto;transition:all .3s ease}.category-count{display:flex;flex-direction:column;align-items:center;gap:5px;padding:15px 25px;background:var(--border-color);border:2px solid var(--accent-secondary);border-radius:20px;-webkit-backdrop-filter:blur(15px);backdrop-filter:blur(15px);transition:all .3s ease}.category-section:hover .category-count{background:var(--accent-secondary);border-color:var(--accent-primary);transform:scale(1.05)}.count-number{font-size:2rem;font-weight:900;color:var(--text-primary);text-shadow:0 4px 12px var(--shadow-light);margin:0}.count-label{font-size:.8rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:1.5px;font-weight:700;margin:0}.category-photos{display:grid;grid-template-columns:repeat(auto-fill,minmax(min(280px,100%),1fr));gap:clamp(1rem,2.5vw,1.5rem);margin-top:2rem;container-type:inline-size}@keyframes cardAppear{0%{opacity:0;transform:translateY(20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.photo-card{position:relative;border-radius:16px;overflow:hidden;cursor:pointer;transition:all .4s cubic-bezier(.23,1,.32,1);background:var(--bg-card);box-shadow:var(--shadow-light);aspect-ratio:4/3;border:1px solid var(--border-color);max-height:220px;animation:cardAppear .6s ease-out;animation-fill-mode:both;-webkit-backdrop-filter:blur(20px) saturate(180%);backdrop-filter:blur(20px) saturate(180%);touch-action:manipulation;-webkit-tap-highlight-color:transparent;-webkit-touch-callout:none;-webkit-user-select:none;user-select:none}:root .photo-card{background:#ffffffe6;border-color:#3b82f61a;box-shadow:0 8px 32px #00000014,0 1px 3px #0000000d}.dark-theme .photo-card{background:var(--glass-bg);border-color:var(--glass-border);box-shadow:var(--glass-shadow)}.photo-card.loading{background:linear-gradient(90deg,var(--glass-bg) 25%,rgba(102,126,234,.1) 50%,var(--glass-bg) 75%);background-size:200% 100%;animation:loading 1.5s infinite}.photo-card:before{content:"";position:absolute;inset:0;background:var(--gradient-primary);opacity:0;transition:opacity .4s cubic-bezier(.23,1,.32,1);z-index:1;pointer-events:none;mix-blend-mode:overlay}.photo-card:hover:before{opacity:.15}.photo-card:hover{transform:translateY(-8px) scale(1.03);box-shadow:0 16px 40px var(--shadow-medium),0 8px 24px var(--shadow-light),0 4px 12px var(--shadow-light);border-color:var(--accent-primary)}:root .photo-card:hover{box-shadow:0 16px 40px #0000001f,0 8px 24px #3b82f626,0 4px 12px #00000014;border-color:#3b82f64d}.dark-theme .photo-card:hover{box-shadow:var(--glass-shadow),0 16px 40px #667eea33,0 8px 24px var(--shadow-medium);border-color:var(--accent-primary)}.photo-card:active{transform:scale(.98);transition-duration:.1s}.photo-card:focus-visible{outline:2px solid var(--accent-primary);outline-offset:2px}.photo-card img{width:100%;height:100%;object-fit:cover;transition:all .3s ease;filter:brightness(1) contrast(1) saturate(1)}.photo-card:hover img{transform:scale(1.05);filter:brightness(1.05) contrast(1.05) saturate(1.1)}.photo-frame{position:relative;width:100%;height:100%;overflow:hidden;border-radius:10px}.photo-gradient{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(to top,rgba(0,0,0,.7) 0%,rgba(0,0,0,.4) 40%,rgba(0,0,0,.1) 70%,transparent 100%);padding:20px;transform:translateY(100%);transition:all .3s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);z-index:2}.photo-card:hover .photo-gradient{transform:translateY(0)}.photo-content{color:#fff;text-align:center}.photo-content h3{margin:0 0 8px;font-size:1.1rem;font-weight:600;text-shadow:0 2px 8px rgba(0,0,0,.6);letter-spacing:-.02em}.photo-content p{margin:0;font-size:.9rem;opacity:.9;text-shadow:0 1px 4px rgba(0,0,0,.6);line-height:1.4}.photo-actions{position:absolute;top:12px;right:12px;background:#ffffffe6;padding:8px;border-radius:50%;opacity:0;transform:scale(.8) translate(10px,-10px);transition:all .3s ease;-webkit-backdrop-filter:blur(15px);backdrop-filter:blur(15px);box-shadow:0 4px 12px #0000001a,0 2px 6px #0000000d;z-index:3;cursor:pointer}.photo-card:hover .photo-actions{opacity:1;transform:scale(1) translate(0)}.photo-actions:hover{background:#fff;transform:scale(1.05) translate(0)}.photo-actions svg{width:18px;height:18px;color:#334155;transition:transform .2s ease}.photo-actions:hover svg{transform:scale(1.1)}.photo-card:hover .photo-overlay{transform:translateY(0)}.photo-card:focus{outline:3px solid rgba(255,255,255,.6);outline-offset:3px}.photo-card:focus .photo-overlay{transform:translateY(0)}.photo-overlay h3{margin:0 0 .8rem;font-size:1.5rem;font-weight:600;text-shadow:0 2px 4px rgba(0,0,0,.5);animation:slideUp .3s ease-out .1s both}.photo-description{margin:.8rem 0 0;font-size:.9rem;opacity:.9;line-height:1.4;text-shadow:0 1px 2px rgba(0,0,0,.5)}.no-results{grid-column:1 / -1;text-align:center;padding:4rem 2rem;color:#fffc}.no-results h3{font-size:2rem;margin-bottom:1rem;color:#fff}.no-results p{font-size:1.1rem;opacity:.8}.category-tag{background:linear-gradient(145deg,#ffffff40,#ffffff1a);padding:.5rem 1.2rem;border-radius:20px;font-size:.9rem;font-weight:500;-webkit-backdrop-filter:blur(15px);backdrop-filter:blur(15px);border:1px solid rgba(255,255,255,.2);display:inline-block;animation:slideUp .3s ease-out .2s both;box-shadow:0 4px 15px #0003}.category-tag.clickable{cursor:pointer;transition:all .3s ease;position:relative;overflow:hidden}.category-tag.clickable:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);transition:left .3s ease}.category-tag.clickable:hover:before{left:100%}.category-tag.clickable:hover{background:linear-gradient(145deg,#fff6,#ffffff40);border-color:#fff6;transform:scale(1.05);box-shadow:0 6px 20px #0000004d}.category-tag.clickable:focus{outline:2px solid rgba(255,255,255,.6);outline-offset:2px}.category-tag.clickable:active{transform:scale(.95)}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.lightbox{position:fixed;top:0;left:0;width:100%;height:100%;background:#f8fafcfa;display:flex;flex-direction:column;justify-content:center;align-items:center;z-index:1000;padding:2rem;animation:lightboxAppear .3s ease-out;overscroll-behavior:contain;-webkit-overflow-scrolling:touch}.dark-theme .lightbox{background:#000000fc}@supports (backdrop-filter: blur(10px)){.lightbox{background:#f8fafce6;-webkit-backdrop-filter:blur(10px) saturate(150%);backdrop-filter:blur(10px) saturate(150%)}.dark-theme .lightbox{background:#000000e6;-webkit-backdrop-filter:blur(10px) saturate(150%);backdrop-filter:blur(10px) saturate(150%)}}@keyframes lightboxAppear{0%{opacity:0;-webkit-backdrop-filter:blur(0px);backdrop-filter:blur(0px)}to{opacity:1;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}}.lightbox-content{position:relative;max-width:90vw;max-height:80vh;display:flex;flex-direction:column;align-items:center;gap:1.5rem;animation:zoomIn .3s ease-out}@keyframes zoomIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.lightbox-content img{width:100%;height:auto;max-height:75vh;object-fit:contain;display:block;border-radius:8px;box-shadow:0 8px 32px #0006}.close-btn{position:absolute;top:1rem;right:1rem;width:2.5rem;height:2.5rem;border:none;border-radius:50%;background:#334155cc;color:#fff;font-size:1.5rem;cursor:pointer;z-index:1001;display:flex;align-items:center;justify-content:center;transition:all .2s ease;font-weight:300}.close-btn:hover{background:#334155e6;transform:scale(1.1)}.dark-theme .close-btn{background:#0009;color:#fff}.dark-theme .close-btn:hover{background:#000c}.lightbox-info{text-align:center;color:var(--text-primary);max-width:600px}.lightbox-info h2{margin:0 0 .5rem;font-size:1.4rem;font-weight:600;color:var(--text-primary)}.lightbox-description{font-size:1rem;line-height:1.5;color:var(--text-secondary);margin:0}.scroll-progress{position:fixed;top:0;left:0;width:100%;height:3px;background:#94a3b833;z-index:1001;transition:opacity .3s ease}.scroll-progress-bar{height:100%;background:linear-gradient(90deg,var(--accent-primary),var(--accent-secondary));transition:width .1s ease-out;border-radius:0 2px 2px 0}.dark-theme .scroll-progress{background:#3341554d}.back-to-top{position:fixed;bottom:2rem;right:2rem;width:50px;height:50px;border:none;border-radius:50%;background:var(--accent-primary);color:#fff;cursor:pointer;z-index:999;display:flex;align-items:center;justify-content:center;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 4px 12px #00000026,0 2px 6px #0000001a;touch-action:manipulation;-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none}.back-to-top:hover{transform:translateY(-2px) scale(1.05);box-shadow:0 8px 20px #0003,0 4px 12px #00000026;background:var(--accent-secondary)}.back-to-top:active{transform:translateY(0) scale(.95);transition-duration:.1s}.back-to-top:focus-visible{outline:2px solid var(--accent-primary);outline-offset:3px}@media (max-width: 768px){.back-to-top{bottom:1rem;right:1rem;width:45px;height:45px}}@container (max-width: 600px){.category-photos{grid-template-columns:1fr 1fr;gap:1rem}}@container (max-width: 400px){.category-photos{grid-template-columns:1fr;gap:.8rem}}@media (max-width: 1440px){.photo-grid{grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:2rem}}@media (max-width: 1024px){.photo-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.5rem}.photo-album{padding:1.5rem}}@supports (container-type: inline-size){.category-section{container-type:inline-size}}@media (min-width: 1800px){.photo-grid{grid-template-columns:repeat(auto-fill,minmax(400px,1fr));gap:3rem}.category-sections{max-width:2000px;margin:0 auto}.album-header h1{font-size:4rem}}@media (min-width: 1440px) and (max-width: 1799px){.photo-grid{grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:2.5rem}}@media (max-width: 1200px){.photo-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:2rem}.category-sections{padding:0 1rem}}@media (max-width: 900px){.photo-grid{grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:1.5rem}.album-header h1{font-size:2.2rem}.category-description{font-size:1.1rem}}@media (max-width: 768px){.photo-album{padding:1rem;-webkit-overflow-scrolling:touch;overscroll-behavior-y:contain;scroll-snap-type:y proximity;min-height:100vh;min-height:-webkit-fill-available}.album-header{position:sticky;top:0;z-index:100;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);scroll-snap-align:start;padding:1.5rem 0;margin-bottom:1rem;border-radius:0 0 15px 15px;box-shadow:0 2px 15px #0000001a}.album-header h1{font-size:2rem;margin-bottom:0}.header-top{gap:1rem;margin-bottom:1rem;flex-direction:row;justify-content:space-between;align-items:center}.theme-toggle{width:50px;height:28px}.toggle-circle{width:18px;height:18px}.dark-theme .toggle-circle{left:calc(100% - 20px)}.category-section{margin-bottom:3rem;scroll-snap-align:start;scroll-margin-top:200px}.category-header{padding:1.5rem;margin-bottom:1.5rem;flex-direction:column;text-align:center;gap:1rem;border-radius:15px;background:var(--bg-card);border:1px solid var(--border-color);box-shadow:0 4px 15px #00000014}.category-title{font-size:1.8rem;justify-content:center}.category-description{font-size:1rem;line-height:1.6}.category-photos{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.5rem;-webkit-overflow-scrolling:touch;overscroll-behavior:contain}.photo-card{max-height:220px;touch-action:manipulation;border-radius:12px}.category-filter{gap:.8rem;overflow-x:auto;-webkit-overflow-scrolling:touch;scroll-snap-type:x mandatory;padding:0 1rem;margin:0 -1rem 2rem}.filter-btn{padding:.8rem 1.2rem;font-size:.9rem;min-width:110px;flex-shrink:0;scroll-snap-align:center;border-radius:25px}.lightbox{padding:1rem;overscroll-behavior:contain;-webkit-overflow-scrolling:touch}.lightbox-content{max-width:95vw;max-height:90vh;gap:1rem;touch-action:pan-x pan-y pinch-zoom}.lightbox-content img{max-height:70vh;touch-action:pan-x pan-y pinch-zoom}.lightbox-info h2{font-size:1.2rem}.lightbox-description{font-size:.9rem}.close-btn{width:2rem;height:2rem;font-size:1.2rem;top:.5rem;right:.5rem;touch-action:manipulation}.header-top{flex-direction:column;gap:var(--space-sm);align-items:stretch}.title-container{flex-direction:column;text-align:center;gap:var(--space-sm)}.title-decoration{flex-direction:row;gap:var(--space-sm)}.title-line{width:40px;height:2px}.album-header h1{font-size:clamp(1.75rem,4vw,2.5rem);text-align:center}.subtitle{text-align:center;font-size:var(--font-sm);margin:var(--space-xs) auto}.title-stats{justify-content:center;gap:var(--space-md)}.header-actions{flex-direction:column;gap:var(--space-sm);width:100%}.search-wrapper{min-width:100%;padding:.625rem 1rem}.search-input{font-size:var(--font-sm)}.theme-toggle{align-self:center;width:50px;height:28px}.filter-section{padding:var(--space-md);margin:0 -1rem var(--space-lg) -1rem;border-radius:0;position:sticky;top:180px;z-index:90}.filter-header{flex-direction:column;align-items:flex-start;gap:var(--space-sm)}.category-filter{flex-wrap:nowrap;justify-content:flex-start;overflow-x:auto;padding:var(--space-sm) 0;scroll-padding:var(--space-sm)}.filter-btn{flex-shrink:0;min-width:120px;padding:.75rem 1.25rem;scroll-snap-align:center}}@media (max-width: 640px){.title-container{gap:var(--space-sm)}.album-header h1{font-size:clamp(1.5rem,4vw,2rem)}.subtitle{font-size:var(--font-sm);max-width:100%}.title-stats{flex-direction:column;gap:var(--space-xs);align-items:center}.stat-item{align-items:center;text-align:center}.camera-icon{width:28px;height:28px;padding:.5rem}.header-top{gap:var(--space-sm);flex-direction:column;align-items:stretch}.header-actions{flex-direction:column;gap:var(--space-xs)}.search-wrapper{min-width:100%;padding:.5rem .875rem}.theme-toggle{align-self:center;width:45px;height:25px}.toggle-circle{width:15px;height:15px}.filter-section{padding:var(--space-sm);position:sticky;top:160px}.filter-title{font-size:var(--font-md)}.category-photos{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:.8rem}.photo-card{max-height:160px;border-radius:10px}.category-filter{gap:.4rem;padding:var(--space-xs) 0}.filter-btn{padding:.5rem .8rem;font-size:.8rem;min-width:80px;border-radius:20px}.filter-count{padding:.15rem .4rem;font-size:.7rem}.category-header{padding:.8rem;margin-bottom:1rem}.category-title{font-size:1.5rem}.category-count{padding:8px 16px}.count-number{font-size:1.5rem}.count-label{font-size:.7rem}}@media (max-width: 480px){.photo-album{padding:.5rem;min-height:100vh;min-height:-webkit-fill-available}.album-header{padding:1rem 0;margin-bottom:.5rem}.album-header h1{font-size:1.5rem}.header-top{gap:.5rem;padding:0 .5rem}.theme-toggle{width:40px;height:22px;padding:3px}.toggle-circle{width:14px;height:14px}.dark-theme .toggle-circle{left:calc(100% - 17px)}.category-section{margin-bottom:2rem;scroll-margin-top:120px}.category-header{padding:.6rem;margin-bottom:.8rem;border-radius:12px}.category-title{font-size:1.2rem;gap:6px}.category-icon{font-size:1rem}.category-description{font-size:.8rem;line-height:1.4}.category-count{padding:5px 10px}.count-number{font-size:1rem}.count-label{font-size:.55rem}.category-photos{grid-template-columns:1fr 1fr;gap:.6rem}.photo-card{max-height:140px;border-radius:8px}.photo-card:nth-child(2n):hover{transform:translateY(-5px) scale(1.01)}.category-filter{gap:.3rem;margin-bottom:1.5rem;padding:0 .3rem;margin:0 -.3rem 1.5rem}.filter-btn{padding:.4rem .6rem;font-size:.75rem;min-width:70px;border-radius:15px}.filter-count{padding:.1rem .3rem;font-size:.65rem;min-width:14px}.lightbox{padding:.5rem}.lightbox-content{gap:.8rem}.lightbox-content img{max-height:65vh;border-radius:6px}.lightbox-info h2{font-size:1.1rem}.lightbox-description{font-size:.85rem}.close-btn{width:1.8rem;height:1.8rem;font-size:1rem;top:.3rem;right:.3rem}.photo-card:active{transform:scale(.98)}.filter-btn:active{transform:scale(.95)}}@media (max-width: 360px){.photo-album{padding:.3rem}.album-header h1{font-size:1.3rem}.category-photos{grid-template-columns:1fr 1fr;gap:.5rem}.photo-card{max-height:120px;border-radius:6px}.category-filter{gap:.2rem}.filter-btn{padding:.3rem .5rem;font-size:.7rem;min-width:60px;border-radius:12px}.filter-count{padding:.05rem .25rem;font-size:.6rem}.category-header{padding:.4rem}.category-title,.lightbox-info h2{font-size:1rem}.lightbox-description{font-size:.8rem}}.photo-card{animation:fadeInUp .8s cubic-bezier(.175,.885,.32,1.275) both}@keyframes fadeInUp{0%{opacity:0;transform:translateY(50px) scale(.8)}to{opacity:1;transform:translateY(0) scale(1)}}.photo-card:nth-child(1){animation-delay:.1s}.photo-card:nth-child(2){animation-delay:.2s}.photo-card:nth-child(3){animation-delay:.3s}.photo-card:nth-child(4){animation-delay:.4s}.photo-card:nth-child(5){animation-delay:.5s}.photo-card:nth-child(6){animation-delay:.6s}.album-footer{margin-top:6rem;position:relative;margin-left:-30px;margin-right:-30px;margin-bottom:-40px}.footer-hero{background:linear-gradient(135deg,#8070e7d9,#030345e6);padding:5rem 2rem;text-align:center;position:relative;overflow:hidden;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-top:1px solid rgba(255,255,255,.1)}.footer-hero:before{content:"";position:absolute;inset:0;background:linear-gradient(45deg,transparent,rgba(255,255,255,.02),transparent),linear-gradient(-45deg,transparent,rgba(255,255,255,.02),transparent);background-size:100px 100px}.footer-hero-content{position:relative;z-index:2;max-width:800px;margin:0 auto}.footer-hero-content h2{font-size:3rem;color:#fff;margin-bottom:1.5rem;text-shadow:0 4px 8px rgba(0,0,0,.5);font-weight:700;background:linear-gradient(45deg,#fff,#f0f8ff,#fff);background-size:300% 300%;-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;animation:shimmer 4s ease-in-out infinite}.footer-hero-content p{font-size:1.3rem;color:#ffffffd9;margin-bottom:3rem;line-height:1.6;font-weight:300}.footer-stats{display:flex;justify-content:center;gap:4rem;flex-wrap:wrap}.stat-item{text-align:center;padding:2rem 1.5rem;background:linear-gradient(145deg,#cd1e1e1a,#ffffff0d);border-radius:20px;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.15);transition:all .4s ease;min-width:140px;position:relative;overflow:hidden}.stat-item:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.1),transparent);transition:left .6s ease}.stat-item:hover:before{left:100%}.stat-item:hover{transform:translateY(-8px) scale(1.05);box-shadow:0 15px 40px #8c1d1d4d;border-color:#ffffff4d}.stat-number{display:block;font-size:3rem;font-weight:800;color:#fff;text-shadow:0 2px 4px rgba(0,0,0,.3);margin-bottom:.5rem}.stat-label{display:block;font-size:1rem;color:#fffc;font-weight:500;text-transform:uppercase;letter-spacing:1px}.footer-content{background:linear-gradient(135deg,#02010ed9,#030345e6);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:3rem;padding:4rem 2rem;position:relative}.footer-content:before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 20% 30%,rgba(255,255,255,.02) 0%,transparent 50%),radial-gradient(circle at 80% 70%,rgba(255,255,255,.02) 0%,transparent 50%);opacity:.8}.footer-section{position:relative;z-index:2}@keyframes bounce{0%,20%,50%,80%,to{transform:translateY(0)}40%{transform:translateY(-10px)}60%{transform:translateY(-5px)}}.footer-section h4{color:#fff;font-size:1.3rem;margin-bottom:1.5rem;font-weight:600;position:relative}.footer-section h4:after{content:"";position:absolute;bottom:-5px;left:0;width:50px;height:3px;background:linear-gradient(90deg,#e60d0d99,#ffffff4d);border-radius:2px}.location-grid,.category-grid{display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.location-item,.category-item{display:flex;align-items:center;gap:.8rem;padding:1rem;background:linear-gradient(145deg,#ffffff14,#ffffff05);border-radius:15px;border:1px solid rgba(255,255,255,.1);transition:all .3s ease;cursor:pointer}.location-item:hover,.category-item:hover{background:linear-gradient(145deg,#ffffff26,#ffffff0d);transform:translate(5px);border-color:#fff3;box-shadow:0 5px 15px #0003}.location-item span:last-child,.category-item span:last-child{color:#ffffffe6;font-weight:500}.about-text{color:#fffc;line-height:1.7;margin-bottom:2rem;font-size:1rem}.social-links{display:flex;gap:1rem;flex-wrap:wrap}.social-item{display:flex;align-items:center;gap:.5rem;padding:.8rem 1.2rem;background:linear-gradient(145deg,#667eea33,#764ba233);border-radius:25px;border:1px solid rgba(255,255,255,.1);transition:all .3s ease;cursor:pointer}.social-item:hover{transform:translateY(-3px);box-shadow:0 8px 20px #667eea4d;border-color:#ffffff4d}.social-item span:first-child{font-size:1.1rem}.social-item span:last-child{color:#ffffffe6;font-weight:500;font-size:.9rem}.footer-bottom{background:linear-gradient(180deg,#0f0f1ef2,#05050ffa);margin-bottom:10px;border-top:1px solid rgba(255,255,255,.08)}.footer-wave{position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,#fff6,#fff9,#fffc,#fff9,#fff6);background-size:400% 100%;animation:wave 6s ease-in-out infinite}@keyframes wave{0%,to{background-position:0% 50%}50%{background-position:100% 50%}}.footer-bottom-content{padding:3rem 2rem;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:2rem;position:relative;z-index:2;max-width:1200px;margin:0 auto}.copyright{display:flex;flex-direction:column;gap:.8rem}.copyright-main{display:flex;align-items:center;gap:.8rem;color:#ffffffe6;font-weight:600;font-size:1.1rem}.separator{color:#fff6;font-weight:300}.copyright-sub{color:#ffffffb3;font-size:1rem;line-height:1.6}.heart,.coffee{color:#ffffffe6;font-weight:600;font-style:italic;filter:none}.footer-badges{display:flex;gap:1.5rem;flex-wrap:wrap}.badge{display:flex;align-items:center;gap:.8rem;padding:1rem 1.5rem;background:linear-gradient(145deg,#ffffff1f,#ffffff0f);border-radius:30px;border:1px solid rgba(255,255,255,.15);transition:all .4s ease;position:relative;overflow:hidden;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px)}.badge:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.1),transparent);transition:left .6s ease}.badge:hover:before{left:100%}.badge:hover{transform:translateY(-5px) scale(1.05);box-shadow:0 12px 30px #00000040;border-color:#ffffff4d;background:linear-gradient(145deg,#ffffff2e,#ffffff1a)}.badge span:last-child{color:#ffffffe6;font-size:.95rem;font-weight:600;position:relative;z-index:2}@media (max-width: 768px){.album-footer{margin:4rem -1rem -1rem}.footer-hero{padding:3rem 1.5rem;background:linear-gradient(135deg,#8070e7e6,#030345f2)}.footer-hero-content h2{font-size:2.2rem;margin-bottom:1rem}.footer-hero-content p{font-size:1.1rem;margin-bottom:2rem;line-height:1.6}.footer-stats{gap:1rem;flex-direction:row;justify-content:space-around;width:100%}.stat-item{min-width:90px;padding:1.2rem .8rem;flex:1;max-width:120px}.stat-number{font-size:2.2rem}.stat-label{font-size:.8rem}.footer-content{grid-template-columns:1fr;gap:2.5rem;padding:3rem 1.5rem}.footer-section{text-align:center}.footer-section h4{font-size:1.4rem;margin-bottom:1.5rem}.location-grid,.category-grid{grid-template-columns:repeat(2,1fr);gap:1rem}.location-item,.category-item{padding:1.2rem;text-align:center;border-radius:12px}.about-text{font-size:1rem;line-height:1.7;text-align:left;margin-bottom:2rem}.social-links{justify-content:center;gap:.8rem}.social-item{padding:1rem 1.5rem;font-size:.9rem}.footer-bottom-content{flex-direction:column;text-align:center;padding:2rem 1.5rem;gap:1.5rem}.copyright-main{flex-direction:column;gap:.5rem;font-size:1rem}.copyright-sub{font-size:.9rem}.footer-badges{justify-content:center;gap:1rem}}@media (max-width: 480px){.photo-album{padding:.5rem;min-height:100vh;min-height:-webkit-fill-available}.album-header{padding:1rem 0;margin-bottom:.5rem}.album-header h1{font-size:1.7rem}.header-top{gap:.5rem;padding:0 .5rem}.theme-toggle{width:45px;height:25px;padding:4px}.toggle-circle{width:15px;height:15px}.dark-theme .toggle-circle{left:calc(100% - 19px)}.category-section{margin-bottom:2rem;scroll-margin-top:150px}.category-header{padding:1rem;margin-bottom:1rem;border-radius:12px}.category-title{font-size:1.4rem;gap:8px}.category-icon{font-size:1.2rem}.category-description{font-size:.9rem;line-height:1.5}.category-count{padding:8px 12px}.count-number{font-size:1.4rem}.count-label{font-size:.7rem}.category-photos{grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1rem}.photo-card{max-height:180px;border-radius:10px}.category-filter{gap:.5rem;margin-bottom:1.5rem;padding:.8rem 1rem}.filter-btn{padding:.7rem 1rem;font-size:.8rem;min-width:85px;border-radius:20px}.filter-count{padding:.2rem .5rem;font-size:.7rem;min-width:16px}.lightbox{padding:.5rem}.lightbox-content{gap:.8rem;max-width:100vw}.lightbox-content img{max-height:65vh;border-radius:8px}.lightbox-info h2{font-size:1.1rem}.lightbox-description{font-size:.85rem}.close-btn{width:1.8rem;height:1.8rem;font-size:1rem;top:.3rem;right:.3rem}.footer-hero{padding:2rem 1rem}.footer-hero-content h2{font-size:1.8rem}.footer-hero-content p{font-size:1rem}.footer-stats{flex-direction:column;gap:1rem;width:100%}.stat-item{padding:1rem;min-width:auto;width:100%;max-width:none}.footer-content{padding:2rem 1rem;gap:2rem}.location-grid,.category-grid{grid-template-columns:1fr;gap:.8rem}.social-links{flex-direction:column;gap:.8rem}.social-item{padding:.8rem 1rem;width:100%;justify-content:center}.footer-badges{flex-direction:column;align-items:center;gap:.8rem}.back-to-top{bottom:1rem;right:1rem;width:45px;height:45px}}.photo-card.loading{background:linear-gradient(90deg,#951f1f1a 25%,#fff3,#ffffff1a 75%);background-size:200% 100%;animation:loading 1.5s infinite}@keyframes loading{0%{background-position:-200% 0}to{background-position:200% 0}}.photo-grid{transition:all .3s ease-in-out}.filter-btn.active{animation:pulse 2s infinite}@keyframes pulse{0%,to{box-shadow:0 6px 20px #00000026,inset 0 2px 4px #0000001a,0 0 #fff6}50%{box-shadow:0 6px 20px #00000026,inset 0 2px 4px #0000001a,0 0 0 8px #ffffff1a}}.photo-card:after{content:"";position:absolute;inset:0;border-radius:25px;padding:3px;background:linear-gradient(45deg,rgba(255,255,255,.3),transparent,rgba(255,255,255,.3));mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);-webkit-mask-composite:xor;mask-composite:xor;opacity:0;transition:opacity .3s ease}.photo-card:hover:after{opacity:1}@media (hover: none) and (pointer: coarse){.photo-card:hover{transform:none;box-shadow:0 4px 12px var(--shadow-light)}.photo-card:active{transform:scale(.98);transition-duration:.1s}.filter-btn:hover{transform:none;background:var(--bg-header)}.filter-btn:active{transform:scale(.95);transition-duration:.1s}.back-to-top:hover{transform:none}.back-to-top:active{transform:scale(.9);transition-duration:.1s}}@media (max-width: 768px){.category-filter:after{content:"← Scroll for more →";position:absolute;bottom:-25px;left:50%;transform:translate(-50%);font-size:.7rem;color:var(--text-muted);opacity:.7;pointer-events:none;animation:fadeInOut 3s ease-in-out infinite;z-index:1}.category-filter.scrolled:after{animation:fadeOut .5s ease-out forwards}.filter-btn{min-height:44px;min-width:44px}.category-filter{padding:15px 10px 40px}}@keyframes fadeInOut{0%,to{opacity:.3}50%{opacity:.7}}@keyframes fadeOut{0%{opacity:.7}to{opacity:0}}@media (max-width: 768px){*{-webkit-overflow-scrolling:touch}.photo-grid,.photo-card{will-change:transform}}
