@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/2c55a0e60120577a-s.2a48534a.woff2)format("woff2");unicode-range:U+460-52F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/9c72aa0f40e4eef8-s.18a48cbc.woff2)format("woff2");unicode-range:U+301,U+400-45F,U+490-491,U+4B0-4B1,U+2116}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/ad66f9afd8947f86-s.7a40eb73.woff2)format("woff2");unicode-range:U+1F??}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/5476f68d60460930-s.c995e352.woff2)format("woff2");unicode-range:U+370-377,U+37A-37F,U+384-38A,U+38C,U+38E-3A1,U+3A3-3FF}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/2bbe8d2671613f1f-s.76dcb0b2.woff2)format("woff2");unicode-range:U+102-103,U+110-111,U+128-129,U+168-169,U+1A0-1A1,U+1AF-1B0,U+300-301,U+303-304,U+308-309,U+323,U+329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/1bffadaabf893a1e-s.7cd81963.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/83afe278b6a6bb3c-s.p.3a6ba036.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Inter Fallback;src:local(Arial);ascent-override:90.44%;descent-override:22.52%;line-gap-override:0.0%;size-adjust:107.12%}.inter_5972bc34-module__OU16Qa__className{font-family:Inter,Inter Fallback;font-style:normal}
:root{--bg-primary:#0a0a0f;--bg-secondary:#12121a;--bg-card:#1a1a24;--bg-hover:#22222e;--text-primary:#fff;--text-secondary:#a0a0b0;--text-muted:#6a6a7a;--accent:#f97316;--accent-hover:#fb923c;--accent-glow:#f973164d;--success:#22c55e;--error:#ef4444;--warning:#eab308;--border:#ffffff14;--border-hover:#ffffff26;--gradient-accent:linear-gradient(135deg,#f97316 0%,#ec4899 100%);--gradient-bg:linear-gradient(180deg,#0a0a0f 0%,#12121a 100%);--space-xs:.25rem;--space-sm:.5rem;--space-md:1rem;--space-lg:1.5rem;--space-xl:2rem;--space-2xl:3rem;--radius-sm:.375rem;--radius-md:.75rem;--radius-lg:1rem;--radius-xl:1.5rem;--radius-full:9999px;--shadow-sm:0 1px 2px #0000004d;--shadow-md:0 4px 12px #0006;--shadow-lg:0 8px 24px #00000080;--shadow-glow:0 0 20px var(--accent-glow);--font-sans:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;--font-mono:"JetBrains Mono","Fira Code",monospace;--transition-fast:.15s ease;--transition-base:.25s ease;--transition-slow:.4s ease}*{box-sizing:border-box;margin:0;padding:0}html,body{height:100%}body{font-family:var(--font-sans);background:var(--bg-primary);color:var(--text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;line-height:1.6}a{color:var(--accent);transition:color var(--transition-fast);text-decoration:none}a:hover{color:var(--accent-hover)}.btn{justify-content:center;align-items:center;gap:var(--space-sm);padding:var(--space-sm)var(--space-lg);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-base);white-space:nowrap;border:none;font-size:.9375rem;font-weight:500;display:inline-flex}.btn-primary{background:var(--gradient-accent);color:#fff;box-shadow:var(--shadow-md)}.btn-primary:hover{box-shadow:var(--shadow-glow);transform:translateY(-2px)}.btn-secondary{background:var(--bg-card);color:var(--text-primary);border:1px solid var(--border)}.btn-secondary:hover{background:var(--bg-hover);border-color:var(--border-hover)}.btn-danger{background:var(--error);color:#fff}.btn-danger:hover{opacity:.9}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.input,.textarea,.select{width:100%;padding:var(--space-sm)var(--space-md);background:var(--bg-card);color:var(--text-primary);border:1px solid var(--border);border-radius:var(--radius-md);transition:all var(--transition-fast);font-family:inherit;font-size:1rem}.input:focus,.textarea:focus,.select:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow);outline:none}.input::placeholder,.textarea::placeholder{color:var(--text-muted)}.textarea{resize:vertical;min-height:100px}.label{margin-bottom:var(--space-xs);color:var(--text-secondary);font-size:.875rem;font-weight:500;display:block}.form-group{margin-bottom:var(--space-lg)}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-lg);transition:all var(--transition-base)}.card:hover{border-color:var(--border-hover);box-shadow:var(--shadow-md)}.container{width:100%;max-width:1200px;padding:0 var(--space-lg);margin:0 auto}.page{min-height:100vh;padding:var(--space-xl)0}.header{z-index:100;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid var(--border);padding:var(--space-md)0;background:#0a0a0fcc;position:sticky;top:0}.header-inner{justify-content:space-between;align-items:center;display:flex}.logo{background:var(--gradient-accent);color:#0000;-webkit-background-clip:text;background-clip:text;font-size:1.25rem;font-weight:700}.nav{align-items:center;gap:var(--space-md);display:flex}.nav-link{padding:var(--space-sm)var(--space-md);color:var(--text-secondary);border-radius:var(--radius-md);transition:all var(--transition-fast)}.nav-link:hover{color:var(--text-primary);background:var(--bg-hover)}.nav-link.active{color:var(--accent)}.photo-grid{gap:var(--space-lg);grid-template-columns:repeat(auto-fill,minmax(280px,1fr));display:grid}.photo-card{aspect-ratio:4/3;border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-base);position:relative;overflow:hidden}.photo-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-4px)}.photo-card img{object-fit:cover;width:100%;height:100%;transition:transform var(--transition-slow)}.photo-card:hover img{transform:scale(1.05)}.photo-card-overlay{padding:var(--space-lg);color:#fff;opacity:0;transition:opacity var(--transition-base);background:linear-gradient(#0000,#000c);position:absolute;bottom:0;left:0;right:0}.photo-card:hover .photo-card-overlay{opacity:1}.photo-card-date{color:var(--text-muted);margin-bottom:var(--space-xs);font-size:.75rem}.photo-card-location{font-size:.875rem;font-weight:500}.month-group{margin-bottom:var(--space-2xl)}.month-title{margin-bottom:var(--space-lg);align-items:center;gap:var(--space-md);font-size:1.5rem;font-weight:600;display:flex}.month-title:after{content:"";background:var(--border);flex:1;height:1px}.month-count{color:var(--text-muted);font-size:.875rem;font-weight:400}.upload-zone{border:2px dashed var(--border);border-radius:var(--radius-xl);padding:var(--space-2xl);text-align:center;transition:all var(--transition-base);cursor:pointer}.upload-zone:hover,.upload-zone.dragover{border-color:var(--accent);background:#f973160d}.upload-zone-icon{margin-bottom:var(--space-md);font-size:3rem}.upload-zone-text{color:var(--text-secondary);margin-bottom:var(--space-sm)}.upload-zone-hint{color:var(--text-muted);font-size:.875rem}.preview-grid{gap:var(--space-md);margin-top:var(--space-lg);grid-template-columns:repeat(auto-fill,minmax(150px,1fr));display:grid}.preview-item{aspect-ratio:1;border-radius:var(--radius-md);position:relative;overflow:hidden}.preview-item img{object-fit:cover;width:100%;height:100%}.preview-remove{top:var(--space-xs);right:var(--space-xs);color:#fff;border-radius:var(--radius-full);cursor:pointer;width:24px;height:24px;transition:background var(--transition-fast);background:#0009;border:none;justify-content:center;align-items:center;display:flex;position:absolute}.preview-remove:hover{background:var(--error)}.photo-detail{gap:var(--space-xl);grid-template-columns:1fr 400px;min-height:calc(100vh - 200px);display:grid}.photo-detail-image{border-radius:var(--radius-xl);background:var(--bg-secondary);position:relative;overflow:hidden}.photo-detail-image img{object-fit:contain;width:100%;height:100%}.photo-detail-sidebar{gap:var(--space-lg);flex-direction:column;display:flex}.tags{gap:var(--space-sm);flex-wrap:wrap;display:flex}.tag{padding:var(--space-xs)var(--space-sm);background:var(--bg-hover);color:var(--text-secondary);border-radius:var(--radius-full);align-items:center;font-size:.75rem;display:inline-flex}.tag-remove{margin-left:var(--space-xs);cursor:pointer;opacity:.6}.tag-remove:hover{opacity:1}.loading{padding:var(--space-2xl);justify-content:center;align-items:center;display:flex}.spinner{border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;width:40px;height:40px;animation:1s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.empty-state{text-align:center;padding:var(--space-2xl);color:var(--text-muted)}.empty-state-icon{margin-bottom:var(--space-lg);opacity:.5;font-size:4rem}.empty-state-text{margin-bottom:var(--space-md);font-size:1.125rem}.login-page{background:var(--gradient-bg);justify-content:center;align-items:center;min-height:100vh;display:flex}.login-card{width:100%;max-width:400px;padding:var(--space-xl)}.login-title{text-align:center;margin-bottom:var(--space-xs);background:var(--gradient-accent);color:#0000;-webkit-background-clip:text;background-clip:text;font-size:1.75rem;font-weight:700}.login-subtitle{text-align:center;color:var(--text-muted);margin-bottom:var(--space-xl)}.toast{bottom:var(--space-xl);right:var(--space-xl);padding:var(--space-md)var(--space-lg);background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);animation:.3s slideIn;position:fixed}.toast.success{border-color:var(--success)}.toast.error{border-color:var(--error)}@keyframes slideIn{0%{opacity:0;transform:translateY(100%)}to{opacity:1;transform:translateY(0)}}@media (max-width:768px){.container{padding:0 var(--space-md)}.photo-grid{gap:var(--space-md);grid-template-columns:repeat(auto-fill,minmax(160px,1fr))}.photo-detail{grid-template-columns:1fr}.header-inner{gap:var(--space-md);flex-wrap:wrap}.nav{justify-content:center;width:100%}}
