*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--amber-50:#fefce8;--amber-100:#fef3c7;--amber-200:#fde68a;--amber-300:#fcd34d;--amber-400:#d4a017;--amber-500:#b8860b;--amber-600:#92400e;--amber-700:#78350f;--indigo-900:#0c0a09;--indigo-800:#1c1917;--indigo-700:#292524;--indigo-600:#44403c;--cream-50:#fafaf9;--cream-100:#f5f5f4;--cream-200:#e7e5e4;--cream-300:#d6d3d1;--charcoal-900:#1c1917;--charcoal-800:#292524;--charcoal-700:#44403c;--charcoal-600:#57534e;--charcoal-500:#78716c;--charcoal-400:#a8a29e;--charcoal-300:#d6d3d1;--charcoal-200:#e7e5e4;--charcoal-100:#f5f5f4;--coral:#a78bfa;--coral-light:#c4b5fd;--sage:wheat;--sage-light:#fdf4e7;--success:#059669;--warning:#b45309;--error:#dc2626;--info:#0284c7;--font-display:"Playfair Display",Georgia,serif;--font-friendly:"Nunito","Inter",-apple-system,sans-serif;--font-body:"Inter",-apple-system,BlinkMacSystemFont,sans-serif;--font-mono:"JetBrains Mono",monospace;--purple-50:#f5f3ff;--purple-100:#ede9fe;--purple-200:#ddd6fe;--purple-300:#c4b5fd;--purple-400:#a78bfa;--purple-500:#8b5cf6;--purple-600:#7c3aed;--purple-700:#6d28d9;--purple-800:#5b21b6;--purple-900:#1e1b4b;--surface-page:#f5f4ff;--surface-card:#fff;--surface-subtle:#f0eeff;--text-on-light:#1e1b4b;--text-on-light-muted:#6b6b8a;--border-light:#7c3aed1a;--text-xs:.75rem;--text-sm:.875rem;--text-base:1rem;--text-lg:1.125rem;--text-xl:1.25rem;--text-2xl:1.5rem;--text-3xl:1.875rem;--text-4xl:2.25rem;--text-5xl:3rem;--text-6xl:3.75rem;--space-1:.25rem;--space-2:.5rem;--space-3:.75rem;--space-4:1rem;--space-5:1.25rem;--space-6:1.5rem;--space-8:2rem;--space-10:2.5rem;--space-12:3rem;--space-16:4rem;--space-20:5rem;--radius-sm:.375rem;--radius-md:.5rem;--radius-lg:.75rem;--radius-xl:1rem;--radius-2xl:1.5rem;--radius-full:9999px;--shadow-sm:0 1px 2px #0000000d;--shadow-md:0 4px 6px -1px #00000012,0 2px 4px -2px #0000000d;--shadow-lg:0 10px 15px -3px #00000014,0 4px 6px -4px #0000000a;--shadow-xl:0 20px 25px -5px #0000001a,0 8px 10px -6px #0000000d;--shadow-glow:0 0 20px #d4a01726;--shadow-photo:0 4px 20px #0000004d;--ease-out:cubic-bezier(.33,1,.68,1);--ease-spring:cubic-bezier(.34,1.56,.64,1);--duration-fast:.15s;--duration-normal:.25s;--duration-slow:.4s;--z-dropdown:10;--z-sticky:20;--z-modal-backdrop:40;--z-modal:50;--z-lightbox:60;--z-toast:70}html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:16px}body{font-family:var(--font-body);color:#e5e5e5;background:#0a0a0a;min-height:100vh;line-height:1.6}.font-display{font-family:var(--font-display)}.font-body{font-family:var(--font-body)}h1,h2,h3,h4,h5,h6{font-family:var(--font-display);color:#fafafa;font-weight:600;line-height:1.2}h1{font-size:var(--text-4xl)}h2{font-size:var(--text-3xl)}h3{font-size:var(--text-2xl)}h4{font-size:var(--text-xl)}p{color:#ffffff80;line-height:1.7}a{color:var(--amber-400);transition:color var(--duration-fast)var(--ease-out);text-decoration:none}a:hover{color:var(--amber-500)}.btn{justify-content:center;align-items:center;gap:var(--space-2);padding:var(--space-3)var(--space-6);font-family:var(--font-body);font-size:var(--text-sm);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--duration-normal)var(--ease-out);white-space:nowrap;border:none;font-weight:600;line-height:1;display:inline-flex}.btn:active{transform:scale(.97)}.btn-primary{background:linear-gradient(135deg,var(--amber-400),var(--amber-500));color:#fff;box-shadow:0 2px 8px #d4a0174d}.btn-primary:hover{background:linear-gradient(135deg,var(--amber-300),var(--amber-400));transform:translateY(-1px);box-shadow:0 4px 16px #d4a01766}.btn-secondary{color:#ffffffb3;background:#ffffff0d;border:1.5px solid #ffffff1a}.btn-secondary:hover{color:var(--amber-400);background:#d4a01714;border-color:#d4a01766}.btn-ghost{color:#ffffff80;padding:var(--space-2)var(--space-3);background:0 0}.btn-ghost:hover{color:#ffffffd9;background:#ffffff0f}.btn-lg{padding:var(--space-4)var(--space-8);font-size:var(--text-base);border-radius:var(--radius-xl)}.btn-icon{border-radius:var(--radius-full);width:40px;height:40px;padding:0}.btn-sm{padding:var(--space-2)var(--space-3);font-size:var(--text-xs);border-radius:var(--radius-md)}.card{-webkit-backdrop-filter:blur(12px);border-radius:var(--radius-xl);padding:var(--space-6);transition:all var(--duration-normal)var(--ease-out);background:#ffffff08;border:1px solid #ffffff0d}.card:hover{border-color:#d4a0171f;box-shadow:0 16px 48px -12px #00000080}.card-flat{background:#ffffff05;border:none}.input-group{gap:var(--space-2);flex-direction:column;display:flex}.input-group label{font-size:var(--text-sm);color:#fff9;font-weight:500}.input{padding:var(--space-3)var(--space-4);font-family:var(--font-body);font-size:var(--text-base);border-radius:var(--radius-lg);color:#e5e5e5;transition:all var(--duration-fast)var(--ease-out);background:#ffffff0d;border:1.5px solid #ffffff1a;outline:none}.input:focus{border-color:#d4a01780;box-shadow:0 0 0 3px #d4a0171a}.input::placeholder{color:#ffffff4d}.badge{padding:var(--space-1)var(--space-3);font-size:var(--text-xs);border-radius:var(--radius-full);letter-spacing:.02em;align-items:center;font-weight:600;display:inline-flex}.badge-amber{color:var(--amber-400);background:#d4a0171f;border:1px solid #d4a01726}.badge-sage{color:var(--sage);background:#f5deb31a;border:1px solid #f5deb326}.badge-coral{color:var(--coral);background:#a78bfa1a;border:1px solid #a78bfa26}.stat-card{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-radius:var(--radius-xl);padding:var(--space-5)var(--space-6);gap:var(--space-1);background:#ffffff08;border:1px solid #ffffff0d;flex-direction:column;display:flex}.stat-card .stat-value{font-family:var(--font-display);font-size:var(--text-3xl);color:#fafafa;font-weight:700}.stat-card .stat-label{font-size:var(--text-sm);color:#ffffff59}.theme-dark{--bg-primary:var(--indigo-900);--bg-secondary:var(--indigo-800);--bg-tertiary:var(--charcoal-800);--text-primary:#e7e5e4;--text-secondary:var(--charcoal-300);--text-muted:var(--charcoal-500);--border-color:#ffffff14;background:var(--bg-primary);color:var(--text-primary)}.theme-dark .card{background:var(--bg-secondary);border-color:var(--border-color)}.photo-grid{columns:3;column-gap:var(--space-3);padding:var(--space-3)}.photo-grid .photo-item{break-inside:avoid;margin-bottom:var(--space-3);border-radius:var(--radius-lg);cursor:pointer;transition:transform var(--duration-normal)var(--ease-spring);position:relative;overflow:hidden}.photo-grid .photo-item:hover{transform:scale(1.02)}.photo-grid .photo-item img{object-fit:cover;width:100%;height:auto;display:block}.photo-item .photo-overlay{opacity:0;transition:opacity var(--duration-normal)var(--ease-out);padding:var(--space-3);justify-content:flex-end;align-items:flex-end;gap:var(--space-2);background:linear-gradient(#0000 50%,#00000080 100%);display:flex;position:absolute;inset:0}.photo-item:hover .photo-overlay{opacity:1}.photo-overlay .overlay-icon{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:var(--radius-full);color:#fff;width:32px;height:32px;font-size:var(--text-sm);cursor:pointer;transition:all var(--duration-fast)var(--ease-out);background:#ffffff26;border:none;justify-content:center;align-items:center;display:flex}.photo-overlay .overlay-icon:hover{background:#ffffff4d;transform:scale(1.1)}.lightbox{z-index:var(--z-lightbox);opacity:0;visibility:hidden;transition:all var(--duration-slow)var(--ease-out);background:#000000f2;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.lightbox.active{opacity:1;visibility:visible}.lightbox img{object-fit:contain;border-radius:var(--radius-md);max-width:90vw;max-height:85vh;box-shadow:var(--shadow-photo)}.lightbox-close{top:var(--space-6);right:var(--space-6);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:var(--radius-full);color:#fff;width:44px;height:44px;font-size:var(--text-xl);cursor:pointer;transition:all var(--duration-fast)var(--ease-out);background:#ffffff1a;border:none;justify-content:center;align-items:center;display:flex;position:absolute}.lightbox-close:hover{background:#fff3}.lightbox-actions{bottom:var(--space-8);gap:var(--space-4);padding:var(--space-3)var(--space-6);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border-radius:var(--radius-full);background:#ffffff14;border:1px solid #ffffff0f;display:flex;position:absolute;left:50%;transform:translate(-50%)}.lightbox-actions button{color:#fff9;font-size:var(--text-lg);cursor:pointer;padding:var(--space-2);border-radius:var(--radius-full);transition:all var(--duration-fast)var(--ease-out);align-items:center;gap:var(--space-2);background:0 0;border:none;display:flex}.lightbox-actions button:hover{color:#fff;background:#ffffff1a}.lightbox-actions button .action-label{font-size:var(--text-xs);font-family:var(--font-body);font-weight:500}.watermarked{position:relative}.watermarked:after{content:var(--watermark-text,"SchoolMemories");font-family:var(--font-display);font-size:var(--text-2xl);color:#ffffff40;pointer-events:none;letter-spacing:.15em;text-transform:uppercase;justify-content:center;align-items:center;font-weight:700;display:flex;position:absolute;inset:0;transform:rotate(-30deg)}.upload-zone{border-radius:var(--radius-2xl);padding:var(--space-16)var(--space-8);text-align:center;cursor:pointer;transition:all var(--duration-normal)var(--ease-out);background:#ffffff05;border:2px dashed #ffffff1a}.upload-zone:hover,.upload-zone.dragover{box-shadow:var(--shadow-glow);background:#d4a0170d;border-color:#d4a01766}.upload-zone .upload-icon{font-size:var(--text-5xl);margin-bottom:var(--space-4);opacity:.6}.upload-zone .upload-text{font-size:var(--text-lg);color:#fff9;margin-bottom:var(--space-2)}.upload-zone .upload-hint{font-size:var(--text-sm);color:#ffffff4d}.progress-bar{border-radius:var(--radius-full);background:#ffffff0f;width:100%;height:6px;overflow:hidden}.progress-bar .progress-fill{background:linear-gradient(90deg,var(--amber-400),var(--amber-300));border-radius:var(--radius-full);height:100%;transition:width var(--duration-normal)var(--ease-out)}.premium-banner{background:linear-gradient(135deg,var(--indigo-800),var(--charcoal-800));border-radius:var(--radius-2xl);padding:var(--space-8);text-align:center;color:var(--cream-100);border:1px solid #d4a01726;position:relative;overflow:hidden}.premium-banner:before{content:"";pointer-events:none;background:radial-gradient(circle,#d4a0170d 0%,#0000 60%);width:200%;height:200%;position:absolute;top:-50%;left:-50%}.premium-banner h3{color:var(--amber-300);margin-bottom:var(--space-3)}.premium-banner p{color:var(--charcoal-300);max-width:400px;margin:0 auto var(--space-6)}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@keyframes pulse-soft{0%,to{opacity:1}50%{opacity:.7}}.animate-fade-in{animation:fadeIn var(--duration-slow)var(--ease-out)both}.animate-fade-in-up{animation:fadeInUp var(--duration-slow)var(--ease-out)both}.animate-scale-in{animation:scaleIn var(--duration-normal)var(--ease-spring)both}.stagger-children>:first-child{animation-delay:0s}.stagger-children>:nth-child(2){animation-delay:50ms}.stagger-children>:nth-child(3){animation-delay:.1s}.stagger-children>:nth-child(4){animation-delay:.15s}.stagger-children>:nth-child(5){animation-delay:.2s}.stagger-children>:nth-child(6){animation-delay:.25s}.stagger-children>:nth-child(7){animation-delay:.3s}.stagger-children>:nth-child(8){animation-delay:.35s}.stagger-children>:nth-child(9){animation-delay:.4s}.stagger-children>:nth-child(10){animation-delay:.45s}.skeleton{border-radius:var(--radius-md);background:linear-gradient(90deg,#ffffff08 25%,#ffffff0f 50%,#ffffff08 75%) 0 0/200% 100%;animation:1.5s infinite shimmer}@media (max-width:768px){.photo-grid{columns:2;column-gap:var(--space-2);padding:var(--space-2)}.photo-grid .photo-item{margin-bottom:var(--space-2)}h1{font-size:var(--text-3xl)}h2{font-size:var(--text-2xl)}.lightbox-actions{bottom:var(--space-4);gap:var(--space-3);padding:var(--space-2)var(--space-4)}}@media (max-width:480px){.photo-grid{columns:2}}.theme-dark::-webkit-scrollbar{width:6px}.theme-dark::-webkit-scrollbar-track{background:0 0}.theme-dark::-webkit-scrollbar-thumb{border-radius:var(--radius-full);background:#ffffff1a}.theme-dark::-webkit-scrollbar-thumb:hover{background:#fff3}.sr-only{clip:rect(0,0,0,0);border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.container{width:100%;max-width:1200px;padding:0 var(--space-6);margin:0 auto}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-2{gap:var(--space-2)}.gap-3{gap:var(--space-3)}.gap-4{gap:var(--space-4)}.gap-6{gap:var(--space-6)}.gap-8{gap:var(--space-8)}.text-center{text-align:center}.w-full{width:100%}@keyframes modalFadeIn{0%{opacity:0}to{opacity:1}}@keyframes modalSlideUp{0%{opacity:0;transform:translateY(12px)scale(.97)}to{opacity:1;transform:translateY(0)scale(1)}}
/*# sourceMappingURL=538110a8cf786a93.css.map*/