@import"https://fonts.googleapis.com/css2?family=DM+Serif+Display&family=Nunito:wght@300;400;500;600;700&display=swap";:root{--font-sans: "Nunito", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-serif: "DM Serif Display", Georgia, serif;--cream: #FDF8F3;--warm-white: #FAF6F1;--linen: #F5EDE4;--oatmeal: #EBE1D5;--parchment: #E0D4C6;--caramel: #C4956A;--caramel-light: #D9B38C;--caramel-deep: #A67B52;--amber: #D4A84B;--amber-glow: #E8C46A;--candlelight: #F5D98A;--sage: #9BAF93;--sage-muted: #A8BC9F;--sage-deep: #7A9470;--cocoa: #6B5344;--walnut: #5D4935;--espresso: #3D3028;--wool-cream: #F2E8DC;--wool-grey: #C9BFB4;--knit-beige: #D6C9B8;--text-primary: #3D3028;--text-secondary: #5D4935;--text-muted: #8A7A6B;--text-light: #FAF6F1;--bg-primary: var(--cream);--bg-warm: var(--warm-white);--bg-card: #FFFFFF;--border-color: var(--oatmeal);--border-soft: var(--linen);--shadow-soft: 0 2px 8px rgba(61, 48, 40, .06);--shadow-medium: 0 4px 16px rgba(61, 48, 40, .08);--shadow-warm: 0 4px 20px rgba(196, 149, 106, .15);--shadow-cozy: 0 6px 24px rgba(166, 120, 88, .18);--radius-sm: 8px;--radius-md: 12px;--radius-lg: 20px;--radius-xl: 28px;--radius-pill: 50px;--transition-fast: .15s ease;--transition-base: .25s ease;--transition-cozy: .35s cubic-bezier(.4, 0, .2, 1);font-family:var(--font-sans);line-height:1.75;font-weight:400;color:var(--text-primary);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}html{overflow-x:hidden;scroll-behavior:smooth}body{margin:0;min-width:320px;min-height:100vh;overflow-x:hidden;background:var(--bg-primary)}::selection{background:var(--caramel-light);color:var(--espresso)}::-webkit-scrollbar{width:10px}::-webkit-scrollbar-track{background:var(--linen)}::-webkit-scrollbar-thumb{background:var(--wool-grey);border-radius:5px}::-webkit-scrollbar-thumb:hover{background:var(--caramel-light)}.login-container{display:flex;justify-content:center;align-items:center;min-height:100vh;background:var(--bg-primary)}.login-card{background:var(--bg-card);padding:3rem;border-radius:var(--radius-xl);box-shadow:var(--shadow-warm);border:1px solid var(--border-soft);text-align:center;min-width:350px}.login-card h1{margin-bottom:2rem;color:var(--text-primary);font-family:var(--font-serif);font-size:1.8rem;font-weight:400}.password-input{width:100%;padding:.8rem 1rem;font-size:1rem;font-family:var(--font-sans);border:2px solid var(--oatmeal);border-radius:var(--radius-lg);margin-bottom:1rem;transition:all var(--transition-cozy);background:var(--bg-card);color:var(--text-primary)}.password-input:hover{border-color:var(--parchment);background:var(--warm-white)}.password-input:focus{outline:none;border-color:var(--caramel);background:var(--bg-card);box-shadow:0 0 0 4px #c4956a1f}.login-button{width:100%;padding:.8rem;font-size:1rem;font-family:var(--font-sans);font-weight:600;color:var(--text-light);background:linear-gradient(135deg,var(--caramel) 0%,var(--caramel-deep) 100%);border:none;border-radius:var(--radius-pill);cursor:pointer;transition:all var(--transition-cozy);box-shadow:var(--shadow-cozy)}.login-button:hover{background:linear-gradient(135deg,var(--caramel-light) 0%,var(--caramel) 100%);transform:translateY(-2px);box-shadow:0 8px 28px #c4956a4d}.error-message{color:#c0392b;margin:.5rem 0;font-size:.9rem}@media (max-width: 768px){.login-card{min-width:unset;width:90%;max-width:400px;padding:2rem 1.5rem}.login-card h1{font-size:1.5rem;margin-bottom:1.5rem}}.landing-page{min-height:calc(100vh - 52px);background:var(--bg-primary);overflow-x:hidden}.landing-hero{background:linear-gradient(180deg,var(--warm-white) 0%,var(--cream) 60%,var(--bg-primary) 100%);color:var(--text-primary);text-align:center;padding:3rem 2rem;position:relative;overflow:hidden}.landing-hero:before{content:"";position:absolute;top:0;left:0;right:0;height:5px;background:linear-gradient(90deg,var(--caramel),var(--amber),var(--candlelight),var(--amber),var(--caramel));border-radius:0 0 3px 3px}.landing-hero:after{content:"";position:absolute;top:-80px;left:50%;transform:translate(-50%);width:500px;height:250px;background:radial-gradient(ellipse,rgba(245,217,138,.12) 0%,transparent 70%);pointer-events:none}.landing-hero h1{font-family:var(--font-serif);font-size:2.5rem;font-weight:400;margin:0;position:relative;z-index:1}.landing-subtitle{font-size:1.2rem;opacity:.9;color:var(--text-secondary)}.landing-stats{display:flex;justify-content:center;gap:3rem;padding:2rem;background:var(--bg-card);border-bottom:1px solid var(--border-soft)}.stats-loading{display:flex;gap:3rem}.stat-skeleton{display:flex;flex-direction:column;align-items:center;gap:.5rem}.stat-skeleton-number{width:60px;height:2rem;background:linear-gradient(90deg,var(--oatmeal) 25%,var(--linen) 50%,var(--oatmeal) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:var(--radius-sm)}.stat-skeleton-label{width:80px;height:.9rem;background:linear-gradient(90deg,var(--oatmeal) 25%,var(--linen) 50%,var(--oatmeal) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:var(--radius-sm)}.stat-item{display:flex;flex-direction:column;align-items:center;gap:.25rem}.stat-number{font-family:var(--font-serif);font-size:2rem;font-weight:400;color:var(--caramel-deep)}.stat-label{font-size:.9rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.15em;font-weight:600}.landing-actions{display:flex;justify-content:center;gap:1rem;padding:2rem}.action-button{padding:1rem 2rem;font-size:1rem;font-family:var(--font-sans);font-weight:600;border:none;border-radius:var(--radius-pill);cursor:pointer;transition:all var(--transition-cozy)}.action-button.primary{background:linear-gradient(135deg,var(--caramel) 0%,var(--caramel-deep) 100%);color:var(--text-light);box-shadow:var(--shadow-cozy)}.action-button.primary:hover:not(:disabled){background:linear-gradient(135deg,var(--caramel-light) 0%,var(--caramel) 100%);transform:translateY(-2px);box-shadow:0 8px 28px #c4956a4d}.action-button.primary:disabled{opacity:.6;cursor:not-allowed}.action-button.secondary{background:var(--bg-card);color:var(--text-secondary);border:2px solid var(--oatmeal);box-shadow:var(--shadow-soft)}.action-button.secondary:hover{border-color:var(--caramel);color:var(--caramel-deep);background:#c4956a0d;transform:translateY(-2px)}.landing-years{padding:2rem;max-width:1200px;margin:0 auto}.landing-years h2{font-family:var(--font-serif);font-size:1.5rem;color:var(--text-primary);margin-bottom:1.5rem;text-align:center}.years-loading{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1.5rem}.year-card-skeleton{background:var(--bg-card);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-soft)}.year-card-skeleton-image{width:100%;height:140px;background:linear-gradient(90deg,var(--oatmeal) 25%,var(--linen) 50%,var(--oatmeal) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite}.year-card-skeleton-info{padding:1rem;display:flex;justify-content:space-between}.year-card-skeleton-year{width:50px;height:1.25rem;background:linear-gradient(90deg,var(--oatmeal) 25%,var(--linen) 50%,var(--oatmeal) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:var(--radius-sm)}.year-card-skeleton-count{width:70px;height:.85rem;background:linear-gradient(90deg,var(--oatmeal) 25%,var(--linen) 50%,var(--oatmeal) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:var(--radius-sm)}.years-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1.5rem}.year-card{background:var(--bg-card);border:1px solid var(--border-soft);border-radius:var(--radius-lg);overflow:hidden;cursor:pointer;transition:all var(--transition-cozy);box-shadow:var(--shadow-soft);text-align:left}.year-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-warm)}.year-card-image{width:100%;height:140px;overflow:hidden;background:var(--linen)}.year-card-image img{width:100%;height:100%;object-fit:cover}.year-card-placeholder{width:100%;height:100%;background:linear-gradient(135deg,var(--wool-cream) 0%,var(--linen) 100%)}.year-card-info{padding:1rem;display:flex;justify-content:space-between;align-items:center}.year-card-year{font-family:var(--font-serif);font-size:1.25rem;font-weight:400;color:var(--text-primary)}.year-card-count{font-size:.85rem;color:var(--text-muted)}@media (max-width: 768px){.stats-loading{gap:1.5rem;flex-wrap:wrap;justify-content:center}.years-loading{grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:1rem}.year-card-skeleton-image{height:100px}.year-card-skeleton-info{padding:.75rem}.landing-hero{padding:3rem 1.5rem}.landing-hero h1{font-size:1.8rem}.landing-subtitle{font-size:1rem}.landing-stats{gap:1.5rem;padding:1.5rem 1rem;flex-wrap:wrap}.stat-number{font-size:1.5rem}.stat-label{font-size:.75rem}.landing-actions{flex-direction:column;padding:1.5rem}.action-button{width:100%}.landing-years{padding:1.5rem}.years-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:1rem}.year-card-image{height:100px}.year-card-info{padding:.75rem}.year-card-year{font-size:1.1rem}.landing-page .photo-year-badge{top:.75rem;left:4rem;padding:.4rem .6rem;font-size:.85rem}}.landing-page .lightbox{background:#3d3028e0!important}.landing-page .image-wrapper img{transition:none}.landing-page .image-wrapper img.loaded{opacity:1}.landing-page .photo-year-badge{position:absolute;top:1rem;left:5rem;display:inline-block;width:auto;background:#5d4935e6;color:var(--text-light);padding:.5rem .75rem;border-radius:var(--radius-pill);font-size:.9rem;font-weight:600;z-index:5;pointer-events:none;white-space:nowrap;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.gallery-container{min-height:100vh;background:var(--bg-primary);overflow-x:hidden}.mobile-only{display:none}.desktop-only{display:flex}@media (max-width: 768px){.mobile-only{display:flex}.desktop-only{display:none!important}}.gallery-header{background:var(--walnut);color:var(--text-light);padding:2rem;text-align:center;border-bottom:2px solid var(--oatmeal)}.gallery-header h1{margin:0;font-family:var(--font-serif);font-size:2rem;font-weight:400}.gallery-header .photo-count{margin:.5rem 0 0;font-size:1rem;opacity:.9}.face-groups-btn{display:inline-flex;align-items:center;gap:.5rem;margin-top:1rem;padding:.6rem 1.2rem;font-size:.9rem;font-family:var(--font-sans);font-weight:600;background:linear-gradient(135deg,var(--amber) 0%,var(--amber-glow) 100%);color:var(--espresso);border:none;border-radius:var(--radius-pill);cursor:pointer;transition:all var(--transition-cozy)}.face-groups-btn:hover{background:linear-gradient(135deg,var(--amber-glow) 0%,var(--candlelight) 100%);transform:translateY(-1px)}.year-selector{display:flex;justify-content:center;gap:1rem;padding:2rem;background:var(--bg-card);box-shadow:var(--shadow-soft);flex-wrap:wrap}.year-selector-mobile{display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:1rem;background:var(--bg-card);box-shadow:var(--shadow-soft)}.year-dropdown-label{font-weight:600;color:var(--text-secondary);font-size:.9rem}.year-dropdown{width:100%;max-width:300px;padding:.75rem 2.5rem .75rem 1rem;font-size:1rem;font-family:var(--font-sans);border:2px solid var(--oatmeal);background:var(--bg-card);color:var(--text-primary);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-cozy);appearance:none;background-image:url("data:image/svg+xml,%3Csvg width='12' height='8' viewBox='0 0 12 8' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1.5L6 6.5L11 1.5' stroke='%238A7A6B' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .75rem center}.year-dropdown:focus{outline:none;border-color:var(--caramel);box-shadow:0 0 0 4px #c4956a1f}.year-button{padding:.8rem 1.5rem;font-size:1.1rem;font-family:var(--font-sans);font-weight:600;border:2px solid var(--oatmeal);background:var(--bg-card);color:var(--text-secondary);border-radius:var(--radius-pill);cursor:pointer;transition:all var(--transition-cozy)}.year-button:hover{background:var(--linen);border-color:var(--caramel-light);transform:translateY(-1px);box-shadow:var(--shadow-warm)}.year-button.active{background:linear-gradient(135deg,var(--caramel) 0%,var(--caramel-deep) 100%);color:var(--text-light);border-color:var(--caramel);box-shadow:var(--shadow-cozy)}.photo-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:1.5rem;padding:2rem;max-width:1400px;margin:0 auto}.photo-grid-container{max-width:1400px;margin:0 auto;min-height:400px}.photo-grid-virtualized{scrollbar-width:thin;scrollbar-color:var(--wool-grey) var(--linen)}.photo-grid-virtualized::-webkit-scrollbar{width:8px}.photo-grid-virtualized::-webkit-scrollbar-track{background:var(--linen)}.photo-grid-virtualized::-webkit-scrollbar-thumb{background-color:var(--wool-grey);border-radius:4px}.empty-gallery{display:flex;justify-content:center;align-items:center;min-height:300px;color:var(--text-muted);font-size:1.1rem}.photo-item{position:relative;aspect-ratio:1;overflow:hidden;border-radius:var(--radius-lg);cursor:pointer;transition:transform var(--transition-cozy),box-shadow var(--transition-cozy);background:var(--wool-cream);border:3px solid var(--bg-card);box-shadow:var(--shadow-soft)}.photo-item:hover{transform:translateY(-4px) scale(1.03);box-shadow:var(--shadow-warm);border-color:var(--oatmeal);z-index:1}.photo-item:hover .photo-overlay{opacity:1}.photo-item img{width:100%;height:100%;object-fit:cover;transition:opacity .3s ease;opacity:0}.photo-item img.loaded{opacity:1}.photo-item:before{content:"";position:absolute;inset:0;background:linear-gradient(90deg,var(--wool-cream) 25%,var(--linen) 50%,var(--wool-cream) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;z-index:0}.photo-item.loaded:before{display:none}.photo-overlay{position:absolute;bottom:0;left:0;right:0;padding:.5rem;background:linear-gradient(transparent,#3d3028b3);opacity:0;transition:opacity .3s ease}.photo-size{color:var(--text-light);font-size:.75rem;font-weight:500}.loading,.error{display:flex;flex-direction:column;justify-content:center;align-items:center;min-height:100vh;font-size:1.5rem;color:var(--text-muted);gap:1rem}.loading-spinner{width:48px;height:48px;border:4px solid var(--oatmeal);border-top-color:var(--caramel);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.skeleton-container{min-height:100vh;background:var(--bg-primary)}.skeleton-header{background:var(--walnut);padding:2rem;text-align:center;border-bottom:2px solid var(--oatmeal)}.skeleton-title{height:2rem;width:60%;max-width:400px;margin:0 auto .5rem;background:linear-gradient(90deg,#faf6f11a 25%,#faf6f14d,#faf6f11a 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:var(--radius-sm)}.skeleton-subtitle{height:1rem;width:100px;margin:0 auto;background:linear-gradient(90deg,#faf6f11a 25%,#faf6f14d,#faf6f11a 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:var(--radius-sm)}.skeleton-year-selector{display:flex;justify-content:center;gap:1rem;padding:2rem;background:var(--bg-card);box-shadow:var(--shadow-soft);flex-wrap:wrap}.skeleton-year-btn{width:100px;height:44px;background:linear-gradient(90deg,var(--oatmeal) 25%,var(--linen) 50%,var(--oatmeal) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:var(--radius-pill)}.skeleton-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:1.5rem;padding:2rem;max-width:1400px;margin:0 auto}.skeleton-photo{aspect-ratio:1;background:linear-gradient(90deg,var(--wool-cream) 25%,var(--linen) 50%,var(--wool-cream) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:var(--radius-lg);border:3px solid var(--bg-card);box-shadow:var(--shadow-soft)}@media (max-width: 768px){.skeleton-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:1rem;padding:1rem}.skeleton-year-selector{padding:1rem;gap:.5rem}.skeleton-year-btn{width:80px;height:38px}}.error{color:#c0392b}.retry-button{padding:.8rem 1.5rem;font-size:1rem;font-family:var(--font-sans);font-weight:600;background:linear-gradient(135deg,var(--caramel) 0%,var(--caramel-deep) 100%);color:var(--text-light);border:none;border-radius:var(--radius-pill);cursor:pointer;transition:all var(--transition-cozy)}.retry-button:hover{background:linear-gradient(135deg,var(--caramel-light) 0%,var(--caramel) 100%)}.lightbox{position:fixed;inset:0;background:#000;display:flex;justify-content:center;align-items:center;z-index:1000;cursor:default;pointer-events:auto;overflow:hidden;overscroll-behavior:none}.lightbox-content{position:relative;width:100vw;height:100vh;height:100dvh;cursor:default;isolation:isolate}.lightbox-header{position:absolute;top:1rem;right:1rem;display:flex;justify-content:flex-end;align-items:center;z-index:20}.photo-name-container,.photo-year-label,.photo-name{display:none}.lightbox-actions{display:flex;align-items:center;gap:.75rem}.download-button{display:flex;align-items:center;justify-content:center;gap:.4rem;padding:0;width:44px;height:44px;font-size:.9rem;font-weight:500;background:#5d4935cc;color:var(--text-light);border:none;border-radius:50%;cursor:pointer;transition:all var(--transition-cozy);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.download-button:hover:not(:disabled){background:#6b5344e6;transform:scale(1.05)}.download-button:disabled{opacity:.5;cursor:not-allowed}.download-button svg{flex-shrink:0;width:20px;height:20px}.tag-toggle-button svg,.show-tags-button svg,.show-detected-button svg{width:20px;height:20px}.download-spinner{display:inline-block;width:16px;height:16px;border:2px solid rgba(250,246,241,.3);border-top-color:var(--text-light);border-radius:50%;animation:spin .8s linear infinite}.download-button-mobile{display:flex;align-items:center;justify-content:center;padding:0;width:44px;height:44px;font-size:.85rem;font-weight:500;background:#5d4935cc;color:var(--text-light);border:none;border-radius:50%;cursor:pointer;transition:all var(--transition-cozy);margin:.5rem auto;flex-shrink:0;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.download-button-mobile:hover:not(:disabled){background:#6b5344e6;transform:scale(1.05)}.download-button-mobile:disabled{opacity:.5;cursor:not-allowed}.download-button-mobile svg{flex-shrink:0;width:20px;height:20px}.lightbox-toolbar{position:absolute;top:0;left:0;right:0;display:flex;align-items:center;justify-content:space-between;padding:.5rem .75rem;z-index:30;pointer-events:auto;background:linear-gradient(to bottom,rgba(0,0,0,.5) 0%,transparent 100%)}.lightbox-toolbar-left{display:flex;align-items:center;gap:.75rem}.lightbox-toolbar-right{display:flex;align-items:center;gap:.25rem}.close-button{background:transparent;border:none;color:#ffffffe6;cursor:pointer;padding:0;width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background .2s ease}.close-button:hover{background:#ffffff1a}.close-button svg{width:20px;height:20px}.lightbox-year-label{color:#ffffffe6;font-size:.95rem;font-weight:500}.lightbox-icon-btn{background:transparent;border:none;color:#ffffffe6;cursor:pointer;padding:0;width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background .2s ease}.lightbox-icon-btn:hover:not(:disabled){background:#ffffff1a}.lightbox-icon-btn:disabled{opacity:.4;cursor:not-allowed}.lightbox-icon-btn.active{background:#ffffff26}.lightbox-image-container{position:relative;display:flex;align-items:center;justify-content:center;background:#000;width:100%;height:100vh;height:100dvh;z-index:1;pointer-events:auto;touch-action:none}.lightbox-image-container img{max-width:95vw;max-height:90vh;max-height:90dvh;object-fit:contain;transition:opacity .15s ease;touch-action:none}.lightbox-image-container img.loading{opacity:0}.lightbox-image-container img.loaded{opacity:1}.lightbox-placeholder{position:absolute;max-width:95vw;max-height:90vh;max-height:90dvh;object-fit:contain;filter:blur(2px);opacity:1!important;z-index:0}.lightbox-loading{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);z-index:5}.nav-button{position:absolute;top:0;bottom:0;width:72px;background:transparent;border:none;color:#fff0;cursor:pointer;padding:0;display:flex;align-items:center;justify-content:center;z-index:10;transition:color .2s ease,background .2s ease}.nav-button svg{width:36px;height:36px;filter:drop-shadow(0 1px 3px rgba(0,0,0,.5));transition:transform .15s ease}.nav-button:hover{color:#ffffffe6;background:linear-gradient(to right,rgba(0,0,0,.15),transparent)}.nav-button.next:hover{background:linear-gradient(to left,rgba(0,0,0,.15),transparent)}.nav-button:hover svg{transform:scale(1.1)}.nav-button.prev{left:0}.nav-button.next{right:0}.lightbox-footer{position:absolute;bottom:0;left:0;right:0;padding:1rem 1.5rem;background:linear-gradient(to top,#3d3028cc,#3d302800);text-align:center;z-index:20;pointer-events:none}.photo-info{color:var(--text-light);font-size:.9rem;opacity:.8;font-weight:400}.reset-zoom-button{position:absolute;bottom:5rem;left:50%;transform:translate(-50%);z-index:25;background:#5d4935e6;color:var(--text-light);border:none;border-radius:var(--radius-pill);padding:.5rem 1rem;font-size:.85rem;font-family:var(--font-sans);font-weight:600;cursor:pointer;transition:all var(--transition-cozy);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);white-space:nowrap}.reset-zoom-button:hover{background:#6b5344f2;transform:translate(-50%) scale(1.05)}@media (max-width: 768px){.gallery-header{padding:1.5rem 1rem}.gallery-header h1{font-size:1.5rem}.year-selector{padding:1rem;gap:.5rem}.year-button{padding:.6rem 1rem;font-size:.9rem}.photo-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:1rem;padding:1rem}.lightbox-content{width:100vw;height:100vh;height:100dvh}.lightbox-header{top:.75rem;right:.75rem}.lightbox-image-container{width:100%;height:100vh;height:100dvh}.photo-name-container{max-width:40%;gap:.5rem}.photo-year-label{font-size:.75rem;padding:.25rem .5rem}.photo-name{font-size:.8rem}.photo-year-badge{font-size:.75rem;padding:.25rem .5rem;top:.35rem;right:.35rem}.close-button,.lightbox-icon-btn{width:36px;height:36px}.lightbox-image-container img,.image-wrapper{max-width:100vw;max-height:85vh;max-height:85dvh}.image-wrapper img{max-width:100%;max-height:100%}.nav-button{display:none}.lightbox-footer{padding:.75rem 1rem}.photo-year-badge{top:.75rem;right:.75rem;padding:.4rem .8rem;font-size:.85rem}}@media (min-width: 769px) and (max-width: 1024px){.photo-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr))}}.people-filter{display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:1.5rem 2rem;background:var(--warm-white);border-bottom:1px solid var(--border-soft)}.filter-label{font-weight:600;color:var(--text-primary);font-size:.9rem;text-align:center}.search-container{position:relative;width:100%;max-width:400px}.search-input{width:100%;padding:.6rem 2.5rem .6rem .75rem;font-size:.95rem;font-family:var(--font-sans);border:2px solid var(--oatmeal);border-radius:var(--radius-lg);outline:none;transition:all var(--transition-cozy);background:var(--bg-card);color:var(--text-primary)}.search-input:hover{border-color:var(--parchment)}.search-input:focus{border-color:var(--caramel);box-shadow:0 0 0 4px #c4956a1f}.clear-search-btn{position:absolute;right:.5rem;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--text-muted);font-size:1.5rem;cursor:pointer;padding:0;width:1.5rem;height:1.5rem;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all var(--transition-cozy)}.clear-search-btn:hover{background:var(--linen);color:var(--text-primary)}.autocomplete-dropdown{position:absolute;top:100%;left:0;right:0;background:var(--bg-card);border:1px solid var(--oatmeal);border-top:none;border-radius:0 0 var(--radius-lg) var(--radius-lg);box-shadow:var(--shadow-medium);max-height:300px;overflow-y:auto;z-index:1000;margin-top:-1px}.autocomplete-item{display:flex;align-items:center;justify-content:space-between;transition:background var(--transition-fast);border-bottom:1px solid var(--border-soft)}.autocomplete-item:last-child{border-bottom:none}.autocomplete-item:hover{background:var(--warm-white)}.autocomplete-name{flex:1;padding:.75rem;cursor:pointer;color:var(--text-primary)}.autocomplete-name:hover{color:var(--caramel-deep)}.rename-person-btn{background:transparent;border:none;color:var(--text-muted);cursor:pointer;font-size:1rem;padding:.5rem .75rem;border-radius:4px;transition:all var(--transition-cozy);flex-shrink:0}.rename-person-btn:hover{background:#c4956a1f;color:var(--caramel-deep)}.modal-overlay{position:fixed;inset:0;background:#3d302899;display:flex;align-items:center;justify-content:center;z-index:2000}.modal-content{background:var(--bg-card);border-radius:var(--radius-xl);padding:1.5rem;box-shadow:var(--shadow-warm)}.rename-modal{min-width:350px;max-width:90vw}.rename-modal h2{margin:0 0 .5rem;color:var(--text-primary);font-family:var(--font-serif);font-size:1.25rem;font-weight:400}.rename-modal p{margin:0 0 1.25rem;color:var(--text-muted);font-size:.9rem}.rename-modal .form-group{margin-bottom:1rem}.rename-modal .form-group label{display:block;margin-bottom:.4rem;font-weight:600;color:var(--text-primary);font-size:.9rem}.rename-modal .form-group input{width:100%;padding:.65rem;border:2px solid var(--oatmeal);border-radius:var(--radius-md);font-size:1rem;font-family:var(--font-sans);box-sizing:border-box;color:var(--text-primary);transition:all var(--transition-cozy)}.rename-modal .form-group input:disabled{background:var(--linen);color:var(--text-muted);cursor:not-allowed}.rename-modal .form-group input:focus{outline:none;border-color:var(--caramel);box-shadow:0 0 0 4px #c4956a1f}.rename-modal .modal-actions{display:flex;gap:.75rem;justify-content:flex-end;margin-top:1.5rem}.rename-modal .modal-actions button{padding:.65rem 1.25rem;border:none;border-radius:var(--radius-pill);font-size:.95rem;font-family:var(--font-sans);font-weight:600;cursor:pointer;transition:all var(--transition-cozy)}.rename-modal .modal-actions button[type=button]{background:var(--linen);color:var(--text-secondary)}.rename-modal .modal-actions button[type=button]:hover:not(:disabled){background:var(--oatmeal)}.rename-modal .modal-actions button[type=submit]{background:linear-gradient(135deg,var(--caramel) 0%,var(--caramel-deep) 100%);color:var(--text-light)}.rename-modal .modal-actions button[type=submit]:hover:not(:disabled){background:linear-gradient(135deg,var(--caramel-light) 0%,var(--caramel) 100%)}.rename-modal .modal-actions button:disabled{opacity:.5;cursor:not-allowed}.tag-toggle-button,.show-tags-button{display:flex;align-items:center;justify-content:center;gap:.4rem;padding:0;width:44px;height:44px;font-size:.85rem;font-weight:500;background:#5d4935cc;color:var(--text-light);border:none;border-radius:50%;cursor:pointer;transition:all var(--transition-cozy);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.tag-toggle-button:hover{background:#6b5344e6}.show-tags-button:hover{background:#6b5344e6;transform:scale(1.05)}.tag-toggle-button.active,.show-tags-button.active{background:#6b5344e6}.tag-toggle-button svg~*,.show-tags-button svg~*,.show-detected-button svg~*,.download-button svg~*{display:none}.image-wrapper{position:relative;display:flex;align-items:center;justify-content:center;max-width:95vw;max-height:90vh;max-height:90dvh}.image-wrapper img{display:block;max-width:100%;max-height:100%;width:auto;height:auto;object-fit:contain;opacity:0}.image-wrapper img.loading{opacity:0!important}.image-wrapper img.loaded{opacity:1!important}.image-wrapper img.tagging-cursor{cursor:crosshair}.tagging-overlay{position:absolute;inset:0;z-index:15;cursor:crosshair}.tag-marker{position:absolute;border:none;background:transparent;cursor:pointer;transition:all var(--transition-cozy)}.tag-marker:hover{background:transparent}.tag-marker.tagging-mode{border:2px solid rgba(250,246,241,.8);border-radius:4px;background:#9baf9333}.tag-name{position:absolute;bottom:0;left:50%;transform:translate(-50%) translateY(100%);background:#3d3028e0;color:var(--text-light);padding:.35rem .6rem;border-radius:var(--radius-sm);font-size:.8rem;white-space:nowrap;display:flex;align-items:center;gap:.25rem;pointer-events:auto;opacity:0;transition:opacity var(--transition-fast);margin-top:4px;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.tag-marker:hover .tag-name,.tag-marker.tagging-mode .tag-name{opacity:1}.tag-delete{background:none;border:none;color:#e88;font-size:1rem;cursor:pointer;padding:0 0 0 .25rem;line-height:1;opacity:0;transition:opacity var(--transition-cozy)}.tag-name:hover .tag-delete,.tag-marker.tagging-mode .tag-delete{opacity:.8}.tag-delete:hover{opacity:1!important}.tag-input-popup{position:absolute;transform:translate(-50%,-100%);background:var(--bg-card);border-radius:var(--radius-lg);box-shadow:var(--shadow-warm);padding:.75rem;z-index:100;min-width:200px;border:1px solid var(--border-soft)}.tag-input-popup:after{content:"";position:absolute;bottom:-8px;left:50%;transform:translate(-50%);border-left:8px solid transparent;border-right:8px solid transparent;border-top:8px solid var(--bg-card)}.tag-input-container{position:relative}.tag-input-popup input{width:100%;padding:.5rem;font-size:.9rem;font-family:var(--font-sans);border:2px solid var(--oatmeal);border-radius:var(--radius-sm);outline:none;box-sizing:border-box;color:var(--text-primary);transition:all var(--transition-cozy)}.tag-input-popup input:focus{border-color:var(--caramel);box-shadow:0 0 0 3px #c4956a1f}.tag-autocomplete-dropdown{position:absolute;top:100%;left:0;right:0;background:var(--bg-card);border:1px solid var(--oatmeal);border-top:none;border-radius:0 0 var(--radius-sm) var(--radius-sm);max-height:200px;overflow-y:auto;z-index:10;box-shadow:var(--shadow-medium)}.tag-autocomplete-item{display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--border-soft)}.tag-autocomplete-item:last-child{border-bottom:none}.tag-autocomplete-item:hover{background:var(--warm-white)}.tag-autocomplete-name{flex:1;padding:.5rem;cursor:pointer;font-size:.85rem;color:var(--text-primary)}.tag-autocomplete-name:hover{color:var(--caramel-deep)}.tag-autocomplete-item .rename-person-btn{padding:.35rem .5rem;font-size:.85rem}.tag-input-buttons{display:flex;gap:.5rem;margin-top:.5rem}.tag-input-buttons button{flex:1;padding:.4rem .75rem;font-size:.85rem;font-family:var(--font-sans);font-weight:600;border:none;border-radius:var(--radius-pill);cursor:pointer;transition:all var(--transition-cozy)}.tag-input-buttons button[type=submit]{background:linear-gradient(135deg,var(--caramel) 0%,var(--caramel-deep) 100%);color:var(--text-light)}.tag-input-buttons button[type=submit]:hover:not(:disabled){background:linear-gradient(135deg,var(--caramel-light) 0%,var(--caramel) 100%)}.tag-input-buttons button[type=submit]:disabled{background:var(--wool-grey);cursor:not-allowed}.tag-input-buttons button[type=button]{background:var(--linen);color:var(--text-secondary)}.tag-input-buttons button[type=button]:hover{background:var(--oatmeal)}.auto-detect-button{display:flex;align-items:center;gap:.4rem;padding:.5rem .8rem;font-size:.85rem;font-family:var(--font-sans);font-weight:600;background:linear-gradient(135deg,var(--amber) 0%,var(--amber-glow) 100%);color:var(--espresso);border:none;border-radius:var(--radius-pill);cursor:pointer;transition:all var(--transition-cozy)}.auto-detect-button:hover:not(:disabled){background:linear-gradient(135deg,var(--amber-glow) 0%,var(--candlelight) 100%);transform:translateY(-1px)}.auto-detect-button:disabled{opacity:.7;cursor:not-allowed}.auto-detect-button.detecting{background:linear-gradient(135deg,var(--amber-glow) 0%,var(--amber) 100%)}.detect-spinner{display:inline-block;width:14px;height:14px;border:2px solid rgba(250,246,241,.3);border-top-color:var(--text-light);border-radius:50%;animation:spin .8s linear infinite}.show-detected-button{display:flex;align-items:center;justify-content:center;gap:.4rem;padding:0;width:44px;height:44px;font-size:.85rem;font-weight:500;background:#5d4935cc;color:var(--text-light);border:none;border-radius:50%;cursor:pointer;transition:all var(--transition-cozy);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.show-detected-button:hover{background:#6b5344e6;transform:scale(1.05)}.show-detected-button.active{background:#6b5344e6}.show-detected-button span{display:none}.detected-face-marker{position:absolute;border:2px solid rgba(250,246,241,.6);border-radius:4px;background:transparent;cursor:pointer;transition:all var(--transition-cozy)}.detected-face-marker:hover{border-color:#faf6f1e6;background:#faf6f11a}.detected-face-marker.selected{border-color:var(--sage);background:#9baf9333}.detected-face-label{position:absolute;bottom:0;left:50%;transform:translate(-50%) translateY(100%);background:#3d3028e0;color:var(--text-light);padding:.3rem .5rem;border-radius:var(--radius-sm);font-size:.75rem;white-space:nowrap;margin-top:4px;opacity:0;transition:opacity var(--transition-fast)}.detected-face-marker:hover .detected-face-label{opacity:1}.detected-face-marker.selected .detected-face-label{opacity:1;background:#7a9470e6}.tag-input-popup.for-detected-face{border:2px solid var(--caramel)}.detected-face-hint{font-size:.75rem;color:var(--caramel);margin-bottom:.5rem;font-weight:600}@media (max-width: 768px){.people-filter{padding:.75rem 1rem}.filter-label{width:100%;margin-bottom:.25rem}.show-tags-button,.show-detected-button,.tag-toggle-button,.download-button{width:40px;height:40px}.lightbox-actions{gap:.5rem}.tag-input-popup{min-width:180px}}.photo-year-badge{position:absolute;top:1rem;right:1rem;background:#5d4935d9;color:var(--text-light);padding:.5rem 1rem;border-radius:var(--radius-pill);font-size:.9rem;font-weight:600;z-index:5;pointer-events:none;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.landing-page .lightbox{background:#000}*{margin:0;padding:0;box-sizing:border-box}.app{min-height:100vh}.main-nav{display:flex;justify-content:center;gap:0;background:var(--walnut);padding:0}.main-nav button{padding:1rem 2rem;font-size:1rem;font-family:var(--font-sans);font-weight:600;border:none;background:transparent;color:#faf6f1b3;cursor:pointer;transition:all var(--transition-cozy);border-bottom:3px solid transparent}.main-nav button:hover{color:var(--text-light);background:#faf6f114}.main-nav button.active{color:var(--text-light);background:#faf6f114;border-bottom-color:var(--candlelight)}.main-nav .logout-button{margin-left:auto;color:#faf6f180;font-size:.9rem}.main-nav .logout-button:hover{color:#faf6f1cc}@media (max-width: 768px){.main-nav button{padding:.75rem 1rem;font-size:.9rem}}
