@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600&display=swap";:root{--bg-primary: #ffffff;--bg-secondary: #f8f9fa;--text-primary: #1a1a1a;--text-secondary: #555;--text-muted: #888;--accent: #00ca88;--accent-dim: rgba(0, 202, 136, .12);--border: #e5e5e5;font-family:Inter,system-ui,-apple-system,sans-serif;line-height:1.6;font-weight:400;color-scheme:light;color:var(--text-primary);background-color:var(--bg-primary);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh}::selection{background:var(--accent);color:#fff}.layout{min-height:100vh;display:flex;flex-direction:column}.nav{display:flex;justify-content:space-between;align-items:center;padding:2rem 3rem;max-width:1200px;margin:0 auto;width:100%}.logo{font-size:1.1rem;font-weight:500;color:var(--text-primary);text-decoration:none;letter-spacing:-.02em}.logo:hover{color:var(--accent)}.nav-links{display:flex;gap:2.5rem}.nav-links a{color:var(--text-secondary);text-decoration:none;font-size:.9rem;font-weight:400;transition:color .2s ease}.nav-links a:hover,.nav-links a.active{color:var(--text-primary)}.main-content{flex:1;max-width:1200px;margin:0 auto;width:100%;padding:0 3rem}.footer{padding:3rem;text-align:center;color:var(--text-muted);font-size:.85rem}@media(max-width:640px){.nav{padding:1.5rem}.nav-links{gap:1.5rem}.main-content{padding:0 1.5rem}.footer{padding:2rem 1.5rem}}.home{min-height:calc(100vh - 200px);display:flex;align-items:center;position:relative;overflow:hidden}.noise-overlay{position:fixed;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:1000;opacity:.03;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)'/%3E%3C/svg%3E");background-repeat:repeat}.accent-line{position:absolute;top:20%;right:-5%;width:40%;height:60%;color:var(--accent);opacity:.15;z-index:0}.accent-line path{stroke-dasharray:500;stroke-dashoffset:500;animation:drawLine 3s ease forwards}@keyframes drawLine{to{stroke-dashoffset:0}}.home:before{content:"";position:absolute;top:10%;right:10%;width:1px;height:0;background:linear-gradient(to bottom,transparent,var(--accent),transparent);animation:growLine 1.5s ease .5s forwards;z-index:0}@keyframes growLine{to{height:200px}}.hero{padding:4rem 0;position:relative;z-index:1}.hero-greeting{color:var(--text-secondary);font-size:1.1rem;margin:0 0 .5rem;font-weight:400}.hero-name{font-size:clamp(3rem,10vw,5rem);font-weight:600;margin:0 0 1.5rem;letter-spacing:-.03em;line-height:1}.hero-tagline{font-size:1.25rem;color:var(--text-secondary);margin:0 0 .75rem;font-weight:400}.ironclad-link{color:var(--accent);text-decoration:none;transition:opacity .2s ease}.ironclad-link:hover{opacity:.8}.hero-sub{font-size:1rem;color:var(--text-muted);margin:0 0 2.5rem}.hero-links{display:flex;align-items:center;gap:.75rem}.hero-links a{color:var(--text-primary);text-decoration:none;font-size:.95rem;padding-bottom:2px;border-bottom:1px solid var(--border);transition:border-color .2s ease}.hero-links a:hover{border-color:var(--accent)}.divider{color:var(--text-muted)}@media(max-width:640px){.hero{padding:2rem 0}.hero-tagline{font-size:1.1rem}.hero-sub{font-size:.9rem}.accent-line{display:none}.home:before{display:none}}.about{padding:4rem 0;max-width:600px}.about h1{font-size:2rem;font-weight:600;margin:0 0 3rem;letter-spacing:-.02em}.about-content{display:flex;flex-direction:column;gap:2.5rem}.intro{font-size:1.25rem;line-height:1.7;color:var(--text-primary);margin:0}.pronunciation{color:var(--text-muted);font-size:1rem}.about-section h2{font-size:.85rem;font-weight:500;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);margin:0 0 1rem}.about-section p{font-size:1.05rem;line-height:1.7;color:var(--text-secondary);margin:0 0 .75rem}.about-section p:last-child{margin-bottom:0}.about-section a{color:var(--accent);text-decoration:none}.about-section a:hover{text-decoration:underline}.note{font-size:.95rem;color:var(--text-muted);font-style:italic}.contact-links{display:flex;gap:1.5rem}.contact-links a{display:flex;align-items:center;gap:.5rem;color:var(--text-primary);text-decoration:none;font-size:.95rem;padding-bottom:2px;border-bottom:1px solid var(--border);transition:border-color .2s ease,color .2s ease}.contact-links a:hover{border-color:var(--accent);color:var(--accent)}@media(max-width:640px){.about{padding:2rem 0}.intro{font-size:1.1rem}.about-section p{font-size:1rem}}.photography{padding:4rem 2rem}.photography-container{max-width:1400px;margin:0 auto}.photography h1{font-size:2rem;font-weight:600;margin-bottom:1rem;letter-spacing:-.02em}.photography-intro{font-size:1.1rem;color:var(--text-secondary);margin-bottom:2rem}.filter-bar{display:flex;gap:.25rem;margin-bottom:2.5rem;flex-wrap:wrap}.filter-btn{background:none;border:none;padding:.4rem .85rem;font-size:.9rem;color:var(--text-muted);cursor:pointer;border-radius:20px;transition:all .2s ease;font-family:inherit}.filter-btn:hover{color:var(--text-primary)}.filter-btn.active{color:var(--text-primary);background:var(--bg-secondary);font-weight:500}.photo-gallery{column-count:4;column-gap:1rem;column-fill:balance}.photo-item{break-inside:avoid;-webkit-column-break-inside:avoid;page-break-inside:avoid;margin-bottom:1rem;cursor:pointer;border-radius:8px;overflow:hidden;background:var(--bg-secondary);display:block;width:100%;transition:box-shadow .3s ease}.photo-item:hover{box-shadow:0 8px 24px #00000026}.lazy-image-container{position:relative;width:100%;display:block;line-height:0;background:var(--bg-secondary)}.photo-image{display:block;width:100%;height:auto!important;max-width:100%;object-fit:contain;-webkit-backface-visibility:hidden;backface-visibility:hidden}.photo-image.loading{opacity:0;transition:opacity .3s ease}.photo-image.loaded{opacity:1}.image-placeholder{position:absolute;inset:0;background:linear-gradient(90deg,var(--bg-secondary) 0%,var(--border) 50%,var(--bg-secondary) 100%);background-size:200% 100%;animation:shimmer 1.5s infinite}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.photo-info{padding:.75rem 1rem}.photo-title{color:var(--text-primary);font-size:.9rem;font-weight:500;margin-bottom:.25rem}.photo-category{color:var(--text-muted);font-size:.8rem}.photo-label{font-size:.7rem;color:var(--accent);background:var(--accent-dim);padding:.15rem .5rem;border-radius:12px}.no-photos{color:var(--text-muted);text-align:center;font-size:1.1rem;margin-top:2rem}.error-message{color:#dc2626}@media(max-width:1200px){.photo-gallery{column-count:3}}@media(max-width:768px){.photo-gallery{column-count:2;column-gap:.75rem}.photo-item{margin-bottom:.75rem}}@media(max-width:480px){.photography{padding:2rem 1rem}.filter-bar{gap:.15rem;margin-bottom:1.5rem;overflow-x:auto;flex-wrap:nowrap;-webkit-overflow-scrolling:touch;scrollbar-width:none}.filter-bar::-webkit-scrollbar{display:none}.filter-btn{font-size:.8rem;padding:.35rem .7rem;white-space:nowrap;flex-shrink:0}.photo-gallery{column-count:2;column-gap:.5rem}.photo-item{margin-bottom:.5rem;border-radius:6px}.photography h1{font-size:1.75rem}.photo-info{padding:.5rem .65rem}.photo-title{font-size:.75rem}.photo-category{font-size:.65rem}.photo-labels{gap:.25rem;margin-top:.35rem}.photo-label{font-size:.55rem;padding:.1rem .35rem}}.photo-modal-overlay{position:fixed;inset:0;background:#000000e6;display:flex;align-items:center;justify-content:center;z-index:1000;padding:2rem;animation:fadeIn .2s ease}.photo-modal{position:relative;max-width:1200px;max-height:90vh;width:100%;background:var(--bg-primary);border-radius:16px;overflow:hidden;animation:scaleIn .2s ease}.photo-modal-close{position:absolute;top:1rem;right:1rem;width:40px;height:40px;background:#00000080;border:none;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:10;transition:all .2s ease}.photo-modal-close svg{width:20px;height:20px;color:#fff}.photo-modal-close:hover{background:#000000b3;transform:scale(1.1)}.photo-modal-content{display:flex;max-height:90vh}.photo-modal-image{flex:1;min-width:0;background:#000;display:flex;align-items:center;justify-content:center}.photo-modal-image img{max-width:100%;max-height:90vh;object-fit:contain}.photo-modal-info{width:320px;padding:2rem;background:var(--bg-primary);overflow-y:auto;max-height:90vh}.photo-modal-info h2{font-size:1.5rem;font-weight:600;color:var(--text-primary);margin:0 0 .75rem;line-height:1.3}.photo-modal-category{display:inline-block;background:var(--accent-dim);color:var(--accent);padding:.35rem .85rem;border-radius:20px;font-size:.85rem;font-weight:500}.photo-modal-labels{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:1rem}.photo-modal-label{background:var(--bg-secondary);color:var(--text-secondary);padding:.3rem .7rem;border-radius:16px;font-size:.8rem;border:1px solid var(--border)}.photo-modal-metadata{margin-top:2rem;padding-top:1.5rem;border-top:1px solid var(--border)}.metadata-item{display:flex;align-items:flex-start;gap:.75rem;margin-bottom:1rem;color:var(--text-secondary);font-size:.9rem}.metadata-item svg{width:18px;height:18px;flex-shrink:0;color:var(--text-muted);margin-top:2px}.metadata-item span{line-height:1.4}.metadata-item.location a{color:var(--accent);text-decoration:none}.metadata-item.location a:hover{text-decoration:underline}.metadata-settings{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1rem}.metadata-settings span{background:var(--bg-secondary);color:var(--text-secondary);padding:.4rem .75rem;border-radius:6px;font-size:.8rem;font-family:SF Mono,Monaco,Inconsolata,Roboto Mono,monospace;border:1px solid var(--border)}@media(max-width:900px){.photo-modal-overlay{padding:0}.photo-modal{max-height:100vh;border-radius:0}.photo-modal-content{flex-direction:column;max-height:100vh}.photo-modal-image,.photo-modal-image img{max-height:50vh}.photo-modal-info{width:100%;max-height:50vh;padding:1.5rem}.photo-modal-info h2{font-size:1.25rem}.photo-modal-close{top:.75rem;right:.75rem;width:36px;height:36px}}.admin{padding:2rem;min-height:100vh;background:var(--bg-primary)}.admin-container{max-width:1200px;margin:0 auto}.admin-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;padding-bottom:1.5rem;border-bottom:1px solid var(--border)}.admin-brand{display:flex;align-items:center;gap:1rem}.admin h1{font-size:2rem;font-weight:700;margin:0;color:var(--text-primary)}.admin-badge{background:var(--accent);color:#fff;padding:.25rem .75rem;border-radius:20px;font-size:.75rem;font-weight:600;text-transform:uppercase}.logout-btn{display:flex;align-items:center;gap:.5rem;background:transparent;color:var(--text-muted);padding:.75rem 1.25rem;border:1px solid var(--border);border-radius:8px;cursor:pointer;transition:all .2s ease;font-size:.9rem}.logout-btn svg{width:18px;height:18px}.logout-btn:hover{border-color:#dc2626;color:#dc2626;background:#dc26260d}.admin-tabs{display:flex;gap:.5rem;margin-bottom:2rem;background:var(--bg-secondary);padding:.5rem;border-radius:12px}.tab{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;background:transparent;border:none;color:var(--text-muted);font-size:.95rem;font-weight:500;cursor:pointer;border-radius:8px;transition:all .2s ease}.tab svg{width:18px;height:18px}.tab:hover{color:var(--text-primary);background:var(--bg-primary)}.tab.active{color:#fff;background:var(--accent)}.tab-count{background:#fff3;padding:.15rem .5rem;border-radius:10px;font-size:.75rem}.message{display:flex;align-items:center;gap:.75rem;padding:1rem 1.25rem;border-radius:10px;margin-bottom:1.5rem;font-weight:500;animation:slideIn .3s ease}@keyframes slideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.message svg{width:20px;height:20px;flex-shrink:0}.message.success{background:#00ca881a;color:var(--accent);border:1px solid rgba(0,202,136,.3)}.message.error{background:#dc26261a;color:#dc2626;border:1px solid rgba(220,38,38,.3)}.message-close{margin-left:auto;background:none;border:none;color:inherit;font-size:1.25rem;cursor:pointer;opacity:.7}.message-close:hover{opacity:1}.dashboard-content,.upload-content,.manage-content{animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem;margin-bottom:2rem}.stat-card{background:var(--bg-secondary);border:1px solid var(--border);border-radius:12px;padding:1.5rem;display:flex;align-items:center;gap:1rem;transition:transform .2s ease}.stat-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000000d}.stat-card.primary{background:var(--accent-dim);border-color:#00ca884d}.stat-icon{width:50px;height:50px;background:var(--accent-dim);border-radius:12px;display:flex;align-items:center;justify-content:center}.stat-icon svg{width:24px;height:24px;color:var(--accent)}.stat-info{display:flex;flex-direction:column}.stat-value{font-size:2rem;font-weight:700;color:var(--text-primary);line-height:1}.stat-label{color:var(--text-muted);font-size:.9rem;margin-top:.25rem}.categories-breakdown{background:var(--bg-secondary);border:1px solid var(--border);border-radius:12px;padding:1.5rem;margin-bottom:2rem}.categories-breakdown h3,.recent-uploads h3{color:var(--text-primary);font-size:1.1rem;margin:0 0 1.25rem}.category-bars{display:flex;flex-direction:column;gap:1rem}.category-bar{display:flex;flex-direction:column;gap:.5rem}.category-info{display:flex;justify-content:space-between;font-size:.9rem;color:var(--text-secondary)}.category-count{color:var(--accent);font-weight:600}.bar-track{height:8px;background:var(--border);border-radius:4px;overflow:hidden}.bar-fill{height:100%;background:var(--accent);border-radius:4px;transition:width .5s ease}.recent-uploads{background:var(--bg-secondary);border:1px solid var(--border);border-radius:12px;padding:1.5rem}.recent-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:1rem}.recent-item{position:relative;aspect-ratio:1;border-radius:8px;overflow:hidden}.recent-item img{width:100%;height:100%;object-fit:cover;transition:transform .3s ease}.recent-item:hover img{transform:scale(1.1)}.recent-overlay{position:absolute;bottom:0;left:0;right:0;padding:.5rem;background:linear-gradient(transparent,#000000b3);opacity:0;transition:opacity .3s ease}.recent-item:hover .recent-overlay{opacity:1}.recent-overlay span{font-size:.75rem;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:block}.empty-state{text-align:center;padding:4rem 2rem;background:var(--bg-secondary);border:1px solid var(--border);border-radius:12px}.empty-state svg{width:80px;height:80px;color:var(--border);margin-bottom:1.5rem}.empty-state h3{color:var(--text-primary);font-size:1.25rem;margin:0 0 .5rem}.empty-state p{color:var(--text-muted);margin:0 0 1.5rem}.upload-form{background:var(--bg-secondary);border:1px solid var(--border);border-radius:12px;padding:2rem}.drop-zone{border:2px dashed var(--border);border-radius:12px;padding:3rem;text-align:center;background:var(--bg-primary);transition:all .3s ease;cursor:pointer;min-height:300px;display:flex;align-items:center;justify-content:center}.drop-zone:hover{border-color:var(--accent);background:var(--accent-dim)}.drop-zone.has-preview{border-style:solid;border-color:var(--accent)}.drop-zone-content{display:flex;flex-direction:column;align-items:center;gap:1rem}.upload-icon{width:64px;height:64px;color:var(--accent)}.drop-zone p{color:var(--text-muted);margin:0}.drop-zone-or{color:var(--text-muted);font-size:.9rem}.file-input{display:none}.file-input-label{background:var(--accent);color:#fff;padding:.75rem 2rem;border-radius:8px;cursor:pointer;font-weight:600;transition:all .2s ease;display:inline-block}.file-input-label:hover{transform:translateY(-2px);box-shadow:0 5px 20px #00ca884d}.preview-container{position:relative;width:100%;max-height:400px;display:flex;align-items:center;justify-content:center}.preview-image{max-width:100%;max-height:400px;border-radius:8px;object-fit:contain}.clear-preview{position:absolute;top:-10px;right:-10px;width:30px;height:30px;background:#dc2626;color:#fff;border:none;border-radius:50%;font-size:1.25rem;cursor:pointer;display:flex;align-items:center;justify-content:center}.clear-preview:hover{transform:scale(1.1)}.form-fields{margin-top:2rem}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem;margin-bottom:1.5rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{color:var(--text-secondary);font-weight:500;font-size:.9rem}.form-group .optional{color:var(--text-muted);font-weight:400}.form-group input,.form-group select{padding:.875rem 1rem;border-radius:8px;border:1px solid var(--border);background:var(--bg-primary);color:var(--text-primary);font-size:1rem;transition:border-color .3s ease}.form-group input:focus,.form-group select:focus{outline:none;border-color:var(--accent)}.form-group input::placeholder{color:var(--text-muted)}.category-input-container{display:flex;gap:.5rem}.category-input-container select,.category-input-container input{flex:1}.category-toggle-btn{padding:.875rem 1rem;background:var(--bg-secondary);color:var(--text-secondary);border:1px solid var(--border);border-radius:8px;font-weight:500;cursor:pointer;transition:all .2s ease;white-space:nowrap}.category-toggle-btn:hover{border-color:var(--accent);color:var(--accent)}.labels-input-container{display:flex;gap:.5rem}.labels-input-container input{flex:1}.add-label-btn{padding:.875rem 1.25rem;background:var(--accent);color:#fff;border:none;border-radius:8px;font-weight:500;cursor:pointer;transition:all .2s ease}.add-label-btn:hover{opacity:.9}.labels-list{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.75rem}.label-tag{display:inline-flex;align-items:center;gap:.35rem;background:var(--accent-dim);color:var(--accent);padding:.35rem .75rem;border-radius:20px;font-size:.85rem;font-weight:500}.label-tag button{background:none;border:none;color:inherit;cursor:pointer;font-size:1rem;line-height:1;opacity:.7}.label-tag button:hover{opacity:1}.form-actions{display:flex;gap:1rem;margin-top:1.5rem}.btn-primary{display:flex;align-items:center;justify-content:center;gap:.5rem;background:var(--accent);color:#fff;padding:1rem 2rem;border:none;border-radius:8px;font-weight:600;cursor:pointer;transition:all .2s ease;font-size:1rem}.btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 5px 20px #00ca884d}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.btn-secondary{padding:.875rem 1.5rem;background:transparent;border:1px solid var(--border);color:var(--text-secondary);border-radius:8px;font-weight:500;cursor:pointer}.btn-secondary:hover{border-color:var(--accent);color:var(--accent)}.btn-danger{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.25rem;background:#dc26261a;border:1px solid rgba(220,38,38,.3);color:#dc2626;border-radius:8px;font-weight:500;cursor:pointer}.btn-danger svg{width:16px;height:16px}.btn-danger:hover{background:#dc2626;border-color:#dc2626;color:#fff}.spinner.large{width:40px;height:40px;border-width:3px;border-color:#00ca884d;border-top-color:var(--accent)}.manage-toolbar{display:flex;align-items:center;gap:1rem;margin-bottom:1.5rem;padding:1rem;background:var(--bg-secondary);border:1px solid var(--border);border-radius:10px}.select-all{display:flex;align-items:center;gap:.5rem;color:var(--text-secondary);cursor:pointer;font-size:.9rem}.select-all input{width:18px;height:18px;cursor:pointer;accent-color:var(--accent)}.loading-state{display:flex;flex-direction:column;align-items:center;gap:1rem;padding:4rem}.loading-state p{color:var(--text-muted)}.photos-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:1.5rem}.photo-card{position:relative;background:var(--bg-secondary);border:2px solid var(--border);border-radius:12px;overflow:hidden;transition:all .2s ease}.photo-card:hover{border-color:var(--text-muted);box-shadow:0 4px 12px #0000000d}.photo-card.selected{border-color:var(--accent)}.photo-checkbox{position:absolute;top:.75rem;left:.75rem;z-index:10}.photo-checkbox input{width:20px;height:20px;cursor:pointer;accent-color:var(--accent)}.photo-card img{width:100%;aspect-ratio:4/3;object-fit:cover}.photo-card-info{padding:1rem}.photo-card-info h4{color:var(--text-primary);font-size:1rem;margin:0 0 .5rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.photo-category-tag{display:inline-block;background:var(--accent-dim);color:var(--accent);padding:.25rem .75rem;border-radius:20px;font-size:.75rem;font-weight:500}.photo-labels{display:flex;flex-wrap:wrap;gap:.35rem;margin-top:.5rem}.photo-label{font-size:.7rem;color:var(--text-muted);background:var(--bg-primary);border:1px solid var(--border);padding:.15rem .5rem;border-radius:12px}.photo-card-actions{position:absolute;top:.75rem;right:.75rem;opacity:0;transition:opacity .2s ease;display:flex;gap:.5rem}.photo-card:hover .photo-card-actions{opacity:1}.btn-edit{width:36px;height:36px;background:#0009;border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.btn-edit svg{width:16px;height:16px}.btn-edit:hover{background:var(--accent);transform:scale(1.1)}.btn-delete{width:36px;height:36px;background:#dc2626e6;border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center}.btn-delete svg{width:18px;height:18px}.btn-delete:hover{background:#dc2626;transform:scale(1.1)}.photo-meta-tag{display:inline-block;background:var(--bg-primary);color:var(--text-muted);padding:.2rem .6rem;border-radius:12px;font-size:.7rem;margin-left:.5rem;border:1px solid var(--border)}.drop-zone.has-files{border-style:solid;border-color:var(--accent);padding:1.5rem;min-height:auto}.drop-zone-hint{font-size:.85rem;color:var(--text-muted);margin-top:.5rem}.upload-previews{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:1rem;width:100%}.upload-preview-item{position:relative;background:var(--bg-primary);border:1px solid var(--border);border-radius:10px;overflow:hidden;transition:all .2s ease}.upload-preview-item.uploading{border-color:var(--accent)}.upload-preview-item.success{border-color:var(--accent);background:var(--accent-dim)}.upload-preview-item.error{border-color:#dc2626;background:#dc26260d}.upload-preview-item img{width:100%;aspect-ratio:4/3;object-fit:cover}.preview-info{padding:.75rem}.preview-info input{width:100%;padding:.5rem;border:1px solid var(--border);border-radius:6px;background:var(--bg-secondary);color:var(--text-primary);font-size:.85rem}.preview-info input:focus{outline:none;border-color:var(--accent)}.preview-info input:disabled{opacity:.7;cursor:not-allowed}.preview-metadata{display:flex;flex-wrap:wrap;gap:.35rem;margin-top:.5rem;font-size:.7rem;color:var(--text-muted)}.preview-metadata span{background:var(--bg-secondary);padding:.2rem .5rem;border-radius:4px}.status-icon{display:inline-flex;align-items:center;justify-content:center;margin-top:.5rem;font-size:1rem}.status-icon.success{color:var(--accent)}.status-icon.error{color:#dc2626;cursor:help}.remove-file{position:absolute;top:.5rem;right:.5rem;width:24px;height:24px;background:#dc2626e6;color:#fff;border:none;border-radius:50%;font-size:1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .2s ease}.upload-preview-item:hover .remove-file{opacity:1}.remove-file:hover{background:#dc2626;transform:scale(1.1)}.add-more-files{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5rem;padding:2rem;border:2px dashed var(--border);border-radius:10px;cursor:pointer;transition:all .2s ease;min-height:150px}.add-more-files:hover{border-color:var(--accent);background:var(--accent-dim)}.add-more-files svg{width:32px;height:32px;color:var(--text-muted)}.add-more-files span{font-size:.85rem;color:var(--text-muted)}.spinner.small{width:14px;height:14px;border-width:2px}.upload-progress{margin:1.5rem 0}.progress-bar{height:8px;background:var(--border);border-radius:4px;overflow:hidden}.progress-fill{height:100%;background:var(--accent);border-radius:4px;transition:width .3s ease}.progress-text{display:block;text-align:center;margin-top:.5rem;font-size:.85rem;color:var(--text-muted)}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease}.modal{background:var(--bg-primary);border:1px solid var(--border);border-radius:16px;padding:2rem;max-width:400px;width:90%;animation:scaleIn .2s ease}@keyframes scaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.modal h3{color:var(--text-primary);font-size:1.25rem;margin:0 0 1rem}.modal p{color:var(--text-secondary);margin:0 0 1.5rem;line-height:1.5}.modal-actions{display:flex;gap:1rem;justify-content:flex-end}.edit-modal{background:var(--bg-primary);border:1px solid var(--border);border-radius:16px;max-width:600px;width:90%;animation:scaleIn .2s ease;overflow:hidden}.edit-modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem 1.5rem 0}.edit-modal-header h3{color:var(--text-primary);font-size:1.25rem;margin:0}.modal-close-btn{background:none;border:none;color:var(--text-muted);cursor:pointer;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:8px;transition:all .2s ease}.modal-close-btn svg{width:20px;height:20px}.modal-close-btn:hover{background:var(--bg-secondary);color:var(--text-primary)}.edit-modal-body{padding:1.5rem}.edit-preview{margin-bottom:1.5rem;border-radius:10px;overflow:hidden}.edit-preview img{width:100%;max-height:250px;object-fit:cover;display:block}.edit-fields{display:flex;flex-direction:column;gap:1.25rem}.edit-modal-footer{display:flex;justify-content:flex-end;gap:.75rem;padding:1rem 1.5rem 1.5rem}@media(max-width:768px){.admin{padding:1rem}.admin-header{flex-direction:column;gap:1rem;align-items:flex-start}.admin h1{font-size:1.5rem}.admin-tabs{flex-wrap:wrap}.tab{padding:.6rem 1rem;font-size:.85rem}.stats-grid{grid-template-columns:1fr}.recent-grid{grid-template-columns:repeat(3,1fr)}.form-row{grid-template-columns:1fr}.photos-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:1rem}}.login{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem;position:relative;overflow:hidden;background:var(--bg-primary)}.aperture-container{position:fixed;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:100;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .3s ease}.aperture-container.aperture-open{opacity:1}.aperture{width:200vmax;height:200vmax;position:relative}.aperture-blade{position:absolute;width:50%;height:50%;background:var(--accent);top:50%;left:50%;transform-origin:0 0;transform:rotate(calc(var(--i) * 45deg)) translate(-100%);clip-path:polygon(100% 0,100% 100%,0 50%);transition:transform .8s cubic-bezier(.4,0,.2,1)}.aperture-container.aperture-open .aperture-blade{transform:rotate(calc(var(--i) * 45deg)) translate(0)}.login-container{width:100%;max-width:400px;position:relative;z-index:10;animation:slideUp .6s ease}.login-container.fade-out{animation:fadeOut .5s ease forwards}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeOut{to{opacity:0;transform:scale(.98)}}.login-brand{text-align:center;margin-bottom:2.5rem}.camera-icon{width:64px;height:64px;margin:0 auto 1.25rem;background:var(--accent);border-radius:16px;display:flex;align-items:center;justify-content:center;transition:transform .3s ease}.camera-icon:hover{transform:scale(1.05)}.camera-icon svg{width:32px;height:32px;color:#fff}.login h1{font-size:1.75rem;font-weight:600;margin-bottom:.5rem;color:var(--text-primary);letter-spacing:-.02em}.login-subtitle{color:var(--text-muted);font-size:.95rem}.login-form{background:var(--bg-primary);padding:2rem;border-radius:12px;border:1px solid var(--border)}.login-form .form-group{margin-bottom:1.25rem}.login-form .form-group:last-of-type{margin-bottom:1.75rem}.login-form label{display:block;color:var(--text-secondary);font-weight:500;margin-bottom:.5rem;font-size:.9rem}.input-wrapper{position:relative}.input-icon{position:absolute;left:1rem;top:50%;transform:translateY(-50%);width:18px;height:18px;color:var(--text-muted);transition:color .3s ease}.login-form input{width:100%;padding:.875rem 1rem .875rem 2.75rem;border-radius:8px;border:1px solid var(--border);background:var(--bg-primary);color:var(--text-primary);font-size:1rem;transition:all .2s ease}.login-form input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-dim)}.input-wrapper:focus-within .input-icon{color:var(--accent)}.login-form input::placeholder{color:var(--text-muted)}.login-form input:disabled{opacity:.6;background:var(--bg-secondary)}.login-btn{width:100%;background:var(--accent);color:#fff;padding:.875rem;border:none;border-radius:8px;font-weight:500;cursor:pointer;transition:all .2s ease;font-size:1rem;position:relative;overflow:hidden}.login-btn:hover:not(:disabled){opacity:.9;transform:translateY(-1px)}.login-btn:active:not(:disabled){transform:translateY(0)}.login-btn:disabled{cursor:not-allowed;opacity:.7}.btn-loading,.btn-success{display:flex;align-items:center;justify-content:center;gap:.5rem}.spinner{width:18px;height:18px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.btn-success svg{width:18px;height:18px;animation:checkmark .4s ease}@keyframes checkmark{0%{transform:scale(0)}to{transform:scale(1)}}.error-message{display:flex;align-items:center;gap:.5rem;background:#fef2f2;color:#dc2626;border:1px solid #fecaca;padding:.875rem 1rem;border-radius:8px;margin-bottom:1.25rem;font-size:.9rem;animation:shake .4s ease}.error-message svg{width:18px;height:18px;flex-shrink:0}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-4px)}75%{transform:translate(4px)}}.login-footer{text-align:center;margin-top:1.5rem;color:var(--text-muted);font-size:.85rem}@media(max-width:640px){.login-container{max-width:100%}.login h1{font-size:1.5rem}.login-form{padding:1.5rem;border:none;background:transparent}.camera-icon{width:56px;height:56px;border-radius:14px}.camera-icon svg{width:28px;height:28px}}#root{min-height:100vh}
