*{margin:0;padding:0;box-sizing:border-box}:root{--primary-color: #6366f1;--primary-hover: #4f46e5;--secondary-color: #f1f5f9;--text-primary: #1e293b;--text-secondary: #64748b;--border-color: #e2e8f0;--success-color: #10b981;--danger-color: #ef4444;--background: #f8fafc;--card-background: #ffffff;--shadow-sm: 0 1px 2px 0 rgb(0 0 0 / .05);--shadow-md: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1);--shadow-lg: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1);--radius-sm: .375rem;--radius-md: .5rem;--radius-lg: .75rem}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;background-color:var(--background);color:var(--text-primary);line-height:1.6}a{text-decoration:none;color:inherit}button{cursor:pointer;font-family:inherit}img{max-width:100%;height:auto}.app{min-height:100vh;display:flex;flex-direction:column}.container{max-width:1280px;margin:0 auto;padding:0 1rem;width:100%}.header{background:var(--card-background);border-bottom:1px solid var(--border-color);padding:1rem 0;position:sticky;top:0;z-index:100;box-shadow:var(--shadow-sm)}.header-content{display:flex;align-items:center;justify-content:space-between}.logo{font-size:1.5rem;font-weight:700;color:var(--primary-color);display:flex;align-items:center;gap:.5rem}.nav{display:flex;gap:.5rem}.nav-link{padding:.5rem 1rem;border-radius:var(--radius-md);font-weight:500;transition:all .2s;color:var(--text-secondary)}.nav-link:hover{background:var(--secondary-color);color:var(--text-primary)}.nav-link.active{background:var(--primary-color);color:#fff}.main{flex:1;padding:2rem 0}.page-header{margin-bottom:2rem}.page-title{font-size:1.875rem;font-weight:700;margin-bottom:.5rem}.page-subtitle{color:var(--text-secondary);font-size:1rem}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.625rem 1.25rem;border-radius:var(--radius-md);font-weight:500;font-size:.875rem;border:none;transition:all .2s}.btn-primary{background:var(--primary-color);color:#fff}.btn-primary:hover{background:var(--primary-hover)}.btn-secondary{background:var(--secondary-color);color:var(--text-primary)}.btn-secondary:hover{background:#e2e8f0}.btn-danger{background:var(--danger-color);color:#fff}.btn-danger:hover{background:#dc2626}.btn-outline{background:transparent;border:1px solid var(--border-color);color:var(--text-primary)}.btn-outline:hover{background:var(--secondary-color)}.btn-sm{padding:.375rem .75rem;font-size:.8125rem}.btn-lg{padding:.875rem 1.75rem;font-size:1rem}.btn:disabled{opacity:.5;cursor:not-allowed}.upload-area{border:2px dashed var(--border-color);border-radius:var(--radius-lg);padding:3rem;text-align:center;background:var(--card-background);cursor:pointer;transition:all .2s}.upload-area:hover,.upload-area.drag-over{border-color:var(--primary-color);background:#f0f0ff}.upload-area.uploading{pointer-events:none;opacity:.7}.upload-icon{font-size:3rem;margin-bottom:1rem;color:var(--text-secondary)}.upload-title{font-size:1.25rem;font-weight:600;margin-bottom:.5rem}.upload-text{color:var(--text-secondary);margin-bottom:1rem}.upload-input{display:none}.progress-bar{width:100%;height:.5rem;background:var(--secondary-color);border-radius:9999px;overflow:hidden;margin-top:1rem}.progress-bar-fill{height:100%;background:var(--primary-color);transition:width .3s}.photo-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem}.photo-card{position:relative;aspect-ratio:1;border-radius:var(--radius-lg);overflow:hidden;background:var(--secondary-color);box-shadow:var(--shadow-sm);transition:all .2s}.photo-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}.photo-card img{width:100%;height:100%;object-fit:cover}.photo-card-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(to top,rgba(0,0,0,.5),transparent);opacity:0;transition:opacity .2s;display:flex;align-items:flex-end;padding:1rem}.photo-card:hover .photo-card-overlay{opacity:1}.photo-card-actions{display:flex;gap:.5rem;width:100%}.photo-card-checkbox{position:absolute;top:.75rem;left:.75rem;width:1.5rem;height:1.5rem;border-radius:var(--radius-sm);border:2px solid white;background:#fffc;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.photo-card-checkbox.selected{background:var(--primary-color);border-color:var(--primary-color)}.photo-card-checkbox.selected:after{content:"✓";color:#fff;font-size:.875rem;font-weight:700}.gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem}.gallery-card{background:var(--card-background);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-md);transition:all .2s}.gallery-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}.gallery-card-cover{aspect-ratio:16/10;background:var(--secondary-color);display:grid;grid-template-columns:repeat(2,1fr);grid-template-rows:repeat(2,1fr);gap:2px;overflow:hidden}.gallery-card-cover img{width:100%;height:100%;object-fit:cover}.gallery-card-cover .placeholder{display:flex;align-items:center;justify-content:center;background:var(--secondary-color);color:var(--text-secondary);font-size:2rem}.gallery-card-content{padding:1.25rem}.gallery-card-title{font-size:1.125rem;font-weight:600;margin-bottom:.25rem}.gallery-card-meta{color:var(--text-secondary);font-size:.875rem;display:flex;gap:1rem}.gallery-card-actions{display:flex;gap:.5rem;margin-top:1rem;padding-top:1rem;border-top:1px solid var(--border-color)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.modal{background:var(--card-background);border-radius:var(--radius-lg);max-width:500px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-lg)}.modal-header{padding:1.25rem 1.5rem;border-bottom:1px solid var(--border-color);display:flex;align-items:center;justify-content:space-between}.modal-title{font-size:1.25rem;font-weight:600}.modal-close{background:none;border:none;font-size:1.5rem;color:var(--text-secondary);cursor:pointer;line-height:1}.modal-close:hover{color:var(--text-primary)}.modal-body{padding:1.5rem}.modal-footer{padding:1rem 1.5rem;border-top:1px solid var(--border-color);display:flex;justify-content:flex-end;gap:.75rem}.form-group{margin-bottom:1.25rem}.form-label{display:block;font-weight:500;margin-bottom:.5rem}.form-input,.form-textarea{width:100%;padding:.625rem .875rem;border:1px solid var(--border-color);border-radius:var(--radius-md);font-size:1rem;transition:border-color .2s}.form-input:focus,.form-textarea:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #6366f11a}.form-textarea{min-height:100px;resize:vertical}.lightbox-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000f2;display:flex;align-items:center;justify-content:center;z-index:2000}.lightbox-content{max-width:90vw;max-height:90vh}.lightbox-content img{max-width:100%;max-height:90vh;object-fit:contain}.lightbox-close{position:absolute;top:1rem;right:1rem;background:#ffffff1a;border:none;color:#fff;font-size:2rem;width:3rem;height:3rem;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center}.lightbox-close:hover{background:#fff3}.lightbox-nav{position:absolute;top:50%;transform:translateY(-50%);background:#ffffff1a;border:none;color:#fff;font-size:2rem;width:3rem;height:3rem;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center}.lightbox-nav:hover{background:#fff3}.lightbox-nav.prev{left:1rem}.lightbox-nav.next{right:1rem}.selection-bar{position:fixed;bottom:2rem;left:50%;transform:translate(-50%);background:var(--card-background);padding:1rem 1.5rem;border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);display:flex;align-items:center;gap:1rem;z-index:50}.selection-count{font-weight:500;color:var(--text-primary)}.empty-state{text-align:center;padding:4rem 2rem;color:var(--text-secondary)}.empty-state-icon{font-size:4rem;margin-bottom:1rem}.empty-state-title{font-size:1.25rem;font-weight:600;color:var(--text-primary);margin-bottom:.5rem}.empty-state-text{margin-bottom:1.5rem}.spinner{width:2rem;height:2rem;border:3px solid var(--secondary-color);border-top-color:var(--primary-color);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading-container{display:flex;align-items:center;justify-content:center;padding:4rem}.toast-container{position:fixed;bottom:2rem;right:2rem;z-index:3000;display:flex;flex-direction:column;gap:.5rem}.toast{padding:1rem 1.5rem;background:var(--card-background);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);display:flex;align-items:center;gap:.75rem;animation:slideIn .3s ease-out}@keyframes slideIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.toast.success{border-left:4px solid var(--success-color)}.toast.error{border-left:4px solid var(--danger-color)}@media (max-width: 768px){.header-content{flex-direction:column;gap:1rem}.nav{width:100%;justify-content:center}.page-title{font-size:1.5rem}.photo-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr))}.gallery-grid{grid-template-columns:1fr}.upload-area{padding:2rem}.selection-bar{left:1rem;right:1rem;transform:none;flex-wrap:wrap;justify-content:center}}
