body{margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.login-container{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;justify-content:center;min-height:100vh}.login-box{background:#fff;border-radius:8px;box-shadow:0 4px 6px #0000001a;max-width:400px;padding:2rem;width:100%}.login-box h1{color:#333;font-size:1.5rem;margin-top:0;text-align:center}.form-group{margin-bottom:1rem}.form-group label{color:#555;display:block;font-weight:500;margin-bottom:.5rem}.password-input-wrapper{position:relative;width:100%}.form-group input{border:1px solid #ddd;border-radius:4px;box-sizing:border-box;font-size:1rem;padding:.75rem;width:100%}.password-input-wrapper input{padding-right:3rem}.password-toggle{align-items:center;background:#0000;border:none;color:#666;cursor:pointer;display:flex;justify-content:center;padding:.5rem;position:absolute;right:.5rem;top:50%;transform:translateY(-50%);width:auto}.password-toggle:hover{background:#0000;color:#667eea}.password-toggle svg{display:block}.form-group input:focus{border-color:#667eea;outline:none}button{background:#667eea;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:1rem;font-weight:500;padding:.75rem;width:100%}button:hover:not(:disabled){background:#5568d3}button:disabled{cursor:not-allowed;opacity:.6}.error{background:#fee;border-radius:4px;color:#c33;font-size:.9rem;margin-bottom:1rem;padding:.75rem}.modal-backdrop{align-items:center;background:#000000e6;bottom:0;display:flex;justify-content:center;left:0;padding:1rem;position:fixed;right:0;top:0;z-index:1000}.modal-content{background:#1a1a2e;border-radius:12px;color:#fff;max-height:95vh;max-width:700px;overflow-y:auto;position:relative;width:100%}.close-button{align-items:center;background:#fff3;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:1.5rem;height:2rem;justify-content:center;line-height:1;position:absolute;right:.5rem;top:.5rem;width:2rem;z-index:10}.close-button:hover:not(:disabled){background:#ffffff4d}.modal-body{display:flex;flex-direction:column}.modal-header{align-items:center;background:#16213e;display:flex;justify-content:space-between;padding:.6rem 1rem}.modal-title{color:#fff;font-size:1rem;font-weight:600;margin:0}.image-counter{background:#0006;border-radius:10px;color:#8892a6;font-size:.75rem;font-weight:500;margin-right:2rem;padding:.25rem .5rem}.image-preview-container{align-items:center;background:#0f0f1a;display:flex;position:relative}.image-nav-arrow{align-items:center;background:#3498dbcc;border:none;color:#fff;cursor:pointer;display:flex;flex-shrink:0;font-size:2rem;height:4rem;justify-content:center;transition:background .2s,transform .2s;width:2.5rem}.image-nav-arrow:hover:not(:disabled){background:#3498db}.image-nav-arrow.disabled,.image-nav-arrow:disabled{background:#64646480;cursor:not-allowed;opacity:.3}.image-nav-prev{border-radius:0 8px 8px 0}.image-nav-next{border-radius:8px 0 0 8px}.image-preview{align-items:center;display:flex;flex:1 1;justify-content:center;min-height:200px;padding:.5rem}.image-preview img{border-radius:4px;box-shadow:0 4px 20px #0006;height:auto;max-height:50vh;max-width:100%}.action-buttons-row{justify-content:center;padding:.5rem 1rem}.action-buttons-row,.image-info-bar{align-items:center;background:#16213e;border-top:1px solid #2a3a5a;display:flex;gap:.5rem}.image-info-bar{justify-content:space-between;padding:.4rem 1rem}.info-left{flex:1 1;min-width:0}.info-filename{color:#fff;display:block;font-size:.8rem;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.action-btn{align-items:center;border:none;border-radius:50%;box-shadow:0 2px 6px #0000004d;cursor:pointer;display:flex;font-size:1.1rem;height:2.5rem;justify-content:center;transition:transform .15s,background .15s;width:2.5rem}.action-btn:hover:not(:disabled){transform:scale(1.1)}.action-btn:disabled{cursor:not-allowed;opacity:.5}.action-btn.approve{background:#2ecc71;color:#fff}.action-btn.approve:hover:not(:disabled){background:#27ae60}.action-btn.reject{background:#6c757d;color:#fff}.action-btn.reject:hover:not(:disabled){background:#5a6268}.action-btn.delete{background:#e74c3c;color:#fff}.action-btn.delete:hover:not(:disabled){background:#c0392b}.action-btn.undelete{background:#3498db;border-radius:6px;color:#fff;font-size:.85rem;font-weight:500;padding:.5rem 1rem;width:auto}.action-btn.undelete:hover:not(:disabled){background:#2980b9}.info-right{align-items:center;display:flex;flex-shrink:0;gap:.75rem}.info-dimensions,.info-filesize{color:#8892a6;font-size:.8rem}.info-filesize{background:#0000004d;border-radius:4px;padding:.15rem .4rem}.controls-row{align-items:center;background:#1a1a2e;border-top:1px solid #2a3a5a;display:flex;justify-content:space-between;padding:.6rem 1rem}.group-buttons{display:flex;gap:.3rem}.group-btn{align-items:center;background:var(--group-color);border:2px solid #0000;border-radius:5px;color:#fff;color:var(--group-text-color,#fff);cursor:pointer;display:flex;font-size:.8rem;font-weight:700;height:1.8rem;justify-content:center;text-shadow:0 1px 2px #0000001a;transition:all .15s ease;width:1.8rem}.group-btn:hover:not(:disabled){box-shadow:0 2px 6px #0000004d;transform:scale(1.1)}.group-btn.selected{border-color:#fff;box-shadow:0 0 0 2px #ffffff4d;transform:scale(1.1)}.group-btn:disabled{cursor:not-allowed;opacity:.5}.rating-stars{display:flex;gap:.1rem}.star-btn{background:none;border:none;cursor:pointer;font-size:1.3rem;line-height:1;padding:.1rem;transition:transform .15s}.star-btn.filled{color:#f1c40f}.star-btn.empty{color:#4a4a5a}.star-btn:hover:not(:disabled){color:#f1c40f;transform:scale(1.2)}.star-btn.hover-preview{color:#f1c40f}.star-btn:disabled{cursor:not-allowed;opacity:.5}.keywords-section{background:#1a1a2e;border-top:1px solid #2a3a5a;padding:.6rem 1rem}.keywords-header{align-items:center;display:flex;justify-content:center;margin-bottom:.4rem}.keywords-label{color:#fff;font-size:.85rem;font-weight:700;text-align:center}.keywords-list{align-items:center;display:flex;flex-wrap:wrap;gap:.15rem;line-height:1.6;margin-bottom:.5rem;min-height:1.25rem}.keyword-item{color:#b8c2d0;font-size:.8rem}.keyword-delete-btn,.keyword-item{align-items:center;display:inline-flex}.keyword-delete-btn{background:#e74c3ccc;border:none;border-radius:50%;color:#fff;cursor:pointer;font-size:.6rem;height:14px;justify-content:center;line-height:1;margin-left:.2rem;padding:0;text-align:center;transition:background .15s;vertical-align:middle;width:14px}.keyword-delete-btn:hover:not(:disabled){background:#e74c3c}.keyword-delete-btn:disabled{cursor:not-allowed;opacity:.5}.keyword-comma{color:#6c7a8a;margin-right:.25rem}.no-keywords{color:#6c7a8a;font-size:.75rem;font-style:italic}.keyword-input-row{display:flex;gap:.4rem}.keyword-input{background:#16213e;border:1px solid #2a3a5a;border-radius:4px;color:#fff;flex:1 1;font-size:.8rem;padding:.4rem .6rem}.keyword-input:focus{border-color:#3498db;outline:none}.keyword-input::placeholder{color:#6c7a8a}.keyword-add-btn{background:#3498db;border:none;border-radius:4px;color:#fff;cursor:pointer;flex-shrink:0;font-size:.75rem;font-weight:500;padding:.25rem .5rem;width:100px}.keyword-add-btn:hover:not(:disabled){background:#2980b9}.keyword-add-btn:disabled{cursor:not-allowed;opacity:.5}.ai-generate-btn{background:#9b59b6;border:none;border-radius:4px;color:#fff;cursor:pointer;flex-shrink:0;font-size:.75rem;font-weight:500;padding:.25rem .6rem;transition:all .15s ease;width:200px}.ai-generate-btn:hover:not(:disabled){background:#8e44ad}.ai-generate-btn:disabled{cursor:not-allowed;opacity:.5}.description-section{background:#1a1a2e;border-top:1px solid #2a3a5a;padding:.6rem 1rem}.description-label{align-items:center;color:#8892a6;display:flex;font-size:.75rem;gap:.4rem;margin-bottom:.3rem}.description-label:after{background:#9b59b6;border-radius:2px;color:#fff;content:"AI";font-size:.6rem;font-weight:600;padding:.1rem .25rem}.description-text{background:#0003;border-left:2px solid #9b59b6;border-radius:4px;color:#b8c2d0;font-size:.8rem;font-style:italic;line-height:1.4;margin:0;padding:.5rem}.description-placeholder{color:#6c7a8a;font-size:.75rem;font-style:italic;margin:0}.keyboard-hints{background:#0f0f1a;border-radius:0 0 12px 12px;color:#6c7a8a;display:flex;flex-wrap:wrap;font-size:.65rem;gap:.5rem;justify-content:center;padding:.5rem 1rem}.keyboard-hints span{background:#ffffff0d;border-radius:3px;padding:.15rem .35rem}@media (max-width:600px){.modal-content{border-radius:0;max-height:100vh}.image-nav-arrow{font-size:1.5rem;height:3rem;width:2rem}.image-info-bar{align-items:stretch;flex-direction:column;gap:.5rem}.action-buttons-row{justify-content:center}.info-left{text-align:center}.info-right{justify-content:center}.controls-row{flex-direction:column;gap:.5rem}.group-buttons,.rating-stars{justify-content:center}.keyboard-hints{display:none}}.transfer-banner{animation:slideDown .3s ease-out;background:#2563eb;box-shadow:0 2px 8px #0003;color:#fff;left:0;padding:12px 20px;position:fixed;right:0;top:0;z-index:1000}.transfer-banner.complete{background:#16a34a}.transfer-banner.error{background:#dc2626}.transfer-banner-content{display:flex;flex-direction:column;gap:8px;margin:0 auto;max-width:1200px}.transfer-banner-text{align-items:center;display:flex;gap:16px;justify-content:space-between}.transfer-status{font-size:14px;font-weight:500}.transfer-filename{font-family:monospace;font-size:13px;max-width:300px;opacity:.9;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.transfer-progress-bar{background:#ffffff4d;border-radius:2px;height:4px;overflow:hidden}.transfer-progress-fill{background:#fff;border-radius:2px;height:100%;transition:width .2s ease-out}.transfer-dismiss-btn{background:#0000;border:none;color:#fff;cursor:pointer;font-size:24px;opacity:.8;padding:4px 8px;position:absolute;right:16px;top:50%;transform:translateY(-50%);transition:opacity .2s}.transfer-dismiss-btn:hover{opacity:1}.project-modal-backdrop{align-items:center;background:#000000e6;bottom:0;display:flex;justify-content:center;left:0;padding:1rem;position:fixed;right:0;top:0;z-index:1000}.project-modal-content{background:#1a1a2e;border-radius:12px;color:#fff;max-height:90vh;max-width:500px;overflow-y:auto;padding:1rem;position:relative;width:100%}.project-modal-close{align-items:center;background:linear-gradient(135deg,#fff3,#ffffff1a);border:none;border-radius:50%;box-shadow:0 2px 8px #0003;color:#fff;cursor:pointer;display:flex;font-size:1.5rem;height:2.25rem;justify-content:center;line-height:1;position:absolute;right:1rem;top:1rem;transition:all .2s cubic-bezier(.4,0,.2,1);width:2.25rem}.project-modal-close:hover:not(:disabled){background:linear-gradient(135deg,#e74c3ccc,#c0392bcc);box-shadow:0 4px 12px #e74c3c66;transform:rotate(90deg) scale(1.1)}.project-modal-content h2{color:#fff;font-size:1.25rem;margin:0 0 .75rem;text-align:center}.project-form{display:flex;flex-direction:column;gap:.5rem}.project-form label{color:#8892a6;font-size:.85rem;margin-bottom:-.25rem}.project-form input,.project-form select{background:#16213e;border:1px solid #2a3a5a;border-radius:6px;color:#fff;font-size:.9rem;padding:.5rem}.project-form input:focus,.project-form select:focus{border-color:#3498db;box-shadow:0 0 0 2px #3498db33;outline:none}.project-form input::placeholder{color:#6c7a8a}.project-select-row{flex-direction:column}.project-select-row,.select-with-button{display:flex;gap:.5rem}.select-with-button .project-select{flex:1 1}.add-project-btn{background:linear-gradient(135deg,#2ecc71,#27ae60);border:none;border-radius:8px;box-shadow:0 4px 15px #2ecc7166;color:#fff;cursor:pointer;font-size:.9rem;font-weight:600;letter-spacing:.5px;padding:.75rem 0;text-align:center;text-shadow:0 2px 4px #0000004d;text-transform:uppercase;transition:all .2s cubic-bezier(.4,0,.2,1);white-space:nowrap;width:100px}.add-project-btn:hover:not(:disabled){background:linear-gradient(135deg,#3ddc84,#2ecc71);box-shadow:0 6px 20px #2ecc7180;transform:translateY(-2px)}.add-project-btn:active:not(:disabled){box-shadow:0 2px 10px #2ecc7166;transform:translateY(0)}.add-project-btn:disabled{box-shadow:none;cursor:not-allowed;opacity:.5}.project-btn{border:none;border-radius:10px;cursor:pointer;font-size:1rem;font-weight:700;letter-spacing:.5px;margin-top:.5rem;padding:.875rem;text-transform:uppercase;transition:all .2s cubic-bezier(.4,0,.2,1)}.project-btn.primary{background:linear-gradient(135deg,#3498db,#2980b9);box-shadow:0 4px 15px #3498db66;color:#fff;text-shadow:0 2px 4px #0000004d}.project-btn.primary:hover:not(:disabled){background:linear-gradient(135deg,#5dade2,#3498db);box-shadow:0 8px 25px #3498db80;transform:translateY(-3px)}.project-btn.primary:active:not(:disabled){box-shadow:0 4px 15px #3498db66;transform:translateY(-1px)}.project-btn:disabled{box-shadow:none;cursor:not-allowed;opacity:.5}.no-projects-section{align-items:center;display:flex;flex-direction:column;gap:1rem;padding:2rem}.no-projects-message{color:#8892a6;margin:0;text-align:center}.project-details{margin-top:.5rem}.project-details-divider{background:#2a3a5a;height:1px;margin-bottom:.5rem}.project-info-row{align-items:center;display:flex;justify-content:space-between;margin-top:.25rem}.project-info-row .project-date{color:#6c7a8a;font-size:.8rem;text-align:left}.project-info-row .project-count{color:#3498db;font-size:.8rem;text-align:right}.project-select{font-size:.9rem}.project-actions{flex-direction:column}.project-actions,.zip-buttons-row{display:flex;gap:.5rem}.generate-zip-btn{background:linear-gradient(135deg,#3498db,#2980b9);border:none;border-radius:8px;box-shadow:0 4px 12px #3498db59;color:#fff;cursor:pointer;flex:1 1;font-size:.85rem;font-weight:600;letter-spacing:.5px;padding:.7rem 1rem;text-align:center;text-shadow:0 2px 4px #0000004d;text-transform:uppercase;transition:all .2s cubic-bezier(.4,0,.2,1)}.generate-zip-btn:hover:not(:disabled){background:linear-gradient(135deg,#5dade2,#3498db);box-shadow:0 6px 18px #3498db73;transform:translateY(-2px)}.generate-zip-btn:active:not(:disabled){box-shadow:0 2px 8px #3498db59;transform:translateY(0)}.generate-zip-btn:disabled{box-shadow:none;cursor:not-allowed;opacity:.5}.delete-all-zips-btn{background:linear-gradient(135deg,#e74c3c,#c0392b);border:none;border-radius:8px;box-shadow:0 4px 12px #e74c3c59;color:#fff;cursor:pointer;flex:1 1;font-size:.85rem;font-weight:600;letter-spacing:.5px;padding:.7rem 1rem;text-align:center;text-shadow:0 2px 4px #0000004d;text-transform:uppercase;transition:all .2s cubic-bezier(.4,0,.2,1)}.delete-all-zips-btn:hover:not(:disabled){background:linear-gradient(135deg,#ec7063,#e74c3c);box-shadow:0 6px 18px #e74c3c73;transform:translateY(-2px)}.delete-all-zips-btn:active:not(:disabled){box-shadow:0 2px 8px #e74c3c59;transform:translateY(0)}.delete-all-zips-btn:disabled{box-shadow:none;cursor:not-allowed;opacity:.5}.zip-files-list{margin-top:.5rem}.zip-files-label{color:#8892a6;display:block;font-size:.75rem;margin-bottom:.25rem}.zip-file-item{align-items:center;display:flex;flex-direction:row;gap:.25rem;margin-bottom:.25rem;padding:.35rem 10px .35rem .35rem}.zip-file-info{display:flex;flex:1 1;flex-direction:column;gap:.25rem}.zip-file-link{background:none;border:none;color:#3498db;cursor:pointer;font:inherit;font-size:.8rem;padding:0;text-align:left;text-decoration:none;transition:color .15s ease}.zip-file-link:hover:not(:disabled){color:#5dade2;text-decoration:underline}.zip-file-link:disabled{color:#8892a6;cursor:not-allowed}.zip-file-meta{color:#6c7a8a;font-size:.75rem;text-align:right}.delete-zip-btn{background:linear-gradient(135deg,#e74c3c,#c0392b);border:none;border-radius:6px;box-shadow:0 3px 10px #e74c3c4d;color:#fff;cursor:pointer;font-size:.8rem;font-weight:600;letter-spacing:.3px;padding:.5rem .75rem;text-align:center;text-shadow:0 2px 4px #0000004d;text-transform:uppercase;transition:all .2s cubic-bezier(.4,0,.2,1);width:100px}.delete-zip-btn:hover:not(:disabled){background:linear-gradient(135deg,#ec7063,#e74c3c);box-shadow:0 4px 14px #e74c3c66;transform:translateY(-1px)}.delete-zip-btn:active:not(:disabled){box-shadow:0 2px 6px #e74c3c4d;transform:translateY(0)}.delete-zip-btn:disabled{box-shadow:none;cursor:not-allowed;opacity:.5}.zip-action-container{display:flex;flex-direction:column;gap:.5rem}.generate-zip-btn.failed{animation:pulse-error 2s infinite;background:linear-gradient(135deg,#e74c3c,#c0392b);box-shadow:0 4px 12px #e74c3c59}.generate-zip-btn.failed:hover:not(:disabled){background:linear-gradient(135deg,#ec7063,#e74c3c);box-shadow:0 6px 18px #e74c3c73}@keyframes pulse-error{0%,to{box-shadow:0 4px 12px #e74c3c59}50%{box-shadow:0 4px 20px #e74c3c99}}.zip-error-messages{background:#e74c3c1a;border:1px solid #e74c3c4d;border-radius:6px;margin-top:.25rem;padding:.75rem}.zip-error-message{color:#e74c3c;font-size:.75rem;line-height:1.4;margin-bottom:.25rem;word-break:break-word}.zip-error-message:last-child{margin-bottom:0}.add-images-section{border-top:1px solid #2a3a5a;margin-top:.5rem;padding-top:.5rem}.criteria-header{align-items:center;display:flex;justify-content:center;margin-bottom:.5rem}.criteria-label{color:#8892a6;font-size:.85rem;text-align:center}.criteria-row{align-items:center;display:flex;gap:.5rem}.criteria-divider{background:#2a3a5a;height:60px;margin:0 .25rem;width:1px}.add-images-btn{background:linear-gradient(135deg,#9b59b6,#8e44ad);border:none;border-radius:10px;box-shadow:0 4px 15px #9b59b666;color:#fff;cursor:pointer;font-size:.8rem;font-weight:700;height:60px;letter-spacing:.5px;line-height:1.3;padding:.5rem;text-align:center;text-shadow:0 2px 4px #0000004d;text-transform:uppercase;transition:all .2s cubic-bezier(.4,0,.2,1);width:150px}.add-images-btn:hover:not(:disabled){background:linear-gradient(135deg,#af7ac5,#9b59b6);box-shadow:0 6px 20px #9b59b680;transform:translateY(-2px) scale(1.02)}.add-images-btn:active:not(:disabled){box-shadow:0 2px 10px #9b59b666;transform:translateY(0) scale(1)}.add-images-btn:disabled{box-shadow:none;cursor:not-allowed;opacity:.5}.image-filter-buttons{display:flex;flex:1 1;flex-direction:column;gap:.25rem}.filter-buttons-row{gap:.25rem}.filter-btn,.filter-buttons-row{display:flex;justify-content:center}.filter-btn{align-items:center;border:2px solid #0000;border-radius:6px;box-shadow:0 2px 8px #0000004d;color:#fff;cursor:pointer;font-size:.75rem;font-weight:700;height:32px;min-width:32px;padding:0 10px;text-shadow:0 1px 3px #0006;transition:all .2s cubic-bezier(.4,0,.2,1)}.filter-btn:hover:not(:disabled){border-color:#fff9;box-shadow:0 4px 12px #0006;transform:scale(1.1) translateY(-2px)}.filter-btn.active{border-color:#fff;box-shadow:0 0 12px #fff9,0 4px 12px #0000004d;transform:scale(1.05)}.filter-btn:disabled{box-shadow:none;cursor:not-allowed;opacity:.5}.filter-btn.filter-all{background:linear-gradient(135deg,#555,#333);flex:1 1}.dialog-btn{border-radius:10px;font-weight:700;letter-spacing:.5px;padding:.85rem;text-transform:uppercase;transition:all .2s cubic-bezier(.4,0,.2,1)}.dialog-btn.cancel{background:linear-gradient(135deg,#3a4a6a,#2a3a5a);box-shadow:0 3px 10px #0003;color:#a8b2c6;text-shadow:0 1px 3px #0000004d}.dialog-btn.cancel:hover:not(:disabled){background:linear-gradient(135deg,#4a5a7a,#3a4a6a);box-shadow:0 5px 15px #0000004d;transform:translateY(-2px)}.dialog-btn.cancel:active:not(:disabled){box-shadow:0 2px 6px #0003;transform:translateY(0)}.dialog-btn.create{background:linear-gradient(135deg,#2ecc71,#27ae60);box-shadow:0 4px 15px #2ecc7166;text-shadow:0 2px 4px #0000004d}.dialog-btn.create:hover:not(:disabled){background:linear-gradient(135deg,#3ddc84,#2ecc71);box-shadow:0 6px 20px #2ecc7180;transform:translateY(-2px)}.dialog-btn.create:active:not(:disabled){box-shadow:0 2px 10px #2ecc7166;transform:translateY(0)}.dialog-btn:disabled{box-shadow:none}.delete-project-section{margin-top:1rem}.delete-project-divider{background:#2a3a5a;height:1px;margin-bottom:.5rem}.delete-project-btn{background:linear-gradient(135deg,#c0392b,#962d22);border:none;border-radius:8px;box-shadow:0 4px 12px #c0392b59;color:#fff;cursor:pointer;font-size:.85rem;font-weight:600;letter-spacing:.5px;padding:.75rem 1rem;text-align:center;text-shadow:0 2px 4px #0000004d;text-transform:uppercase;transition:all .2s cubic-bezier(.4,0,.2,1);width:100%}.delete-project-btn:hover:not(:disabled){background:linear-gradient(135deg,#e74c3c,#c0392b);box-shadow:0 6px 18px #c0392b73;transform:translateY(-2px)}.delete-project-btn:active:not(:disabled){box-shadow:0 2px 8px #c0392b59;transform:translateY(0)}.delete-project-btn:disabled{box-shadow:none;cursor:not-allowed;opacity:.5}@media (max-width:500px){.project-modal-content{border-radius:0;margin:0;max-height:100vh;padding:1.5rem}.select-with-button{flex-direction:column}.add-project-btn{width:100%}}.zip-progress-banner{display:flex;flex-direction:column;gap:2px;left:0;position:fixed;right:0;top:0;z-index:1001}.zip-progress-item{align-items:center;animation:slideDown .3s ease-out;background:#7c3aed;box-shadow:0 2px 8px #0003;color:#fff;display:flex;gap:12px;padding:10px 20px}@keyframes slideDown{0%{opacity:0;transform:translateY(-100%)}to{opacity:1;transform:translateY(0)}}.zip-progress-item.complete{background:#16a34a}.zip-progress-item.failed{background:#dc2626}.zip-progress-icon{align-items:center;display:flex;height:24px;justify-content:center;width:24px}.zip-spinner{animation:spin 1s linear infinite;border:2px solid #ffffff4d;border-radius:50%;border-top-color:#fff;height:20px;width:20px}.zip-check,.zip-error{font-size:18px;font-weight:700}.zip-progress-text{display:flex;flex-direction:column;gap:2px}.zip-progress-title{font-size:14px;font-weight:500}.zip-progress-time{font-size:12px;opacity:.8}.zip-progress-error{font-size:12px;max-width:500px;opacity:.9;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.notification-banner{animation:notificationSlideDown .3s ease-out;background:#2563eb;box-shadow:0 2px 8px #0003;color:#fff;left:0;padding:12px 20px;position:fixed;right:0;top:0;z-index:1001}@keyframes notificationSlideDown{0%{opacity:0;transform:translateY(-100%)}to{opacity:1;transform:translateY(0)}}.notification-banner.success{background:#16a34a}.notification-banner.error{background:#dc2626}.notification-banner.info{background:#2563eb}.notification-banner-content{align-items:center;display:flex;gap:16px;justify-content:space-between;margin:0 auto;max-width:1200px}.notification-message{font-size:14px;font-weight:500}.notification-dismiss-btn{background:#0000;border:none;color:#fff;cursor:pointer;font-size:24px;line-height:1;opacity:.8;padding:4px 8px;transition:opacity .2s}.notification-dismiss-btn:hover{opacity:1}.gallery-container{background:#0f0f1a;display:flex;min-height:100vh}.sidebar{background:#1a1a2e;display:flex;flex-direction:column;height:100vh;min-width:200px;position:-webkit-sticky;position:sticky;top:0;width:200px;z-index:100}.sidebar-top{display:flex;flex:1 1;flex-direction:column;gap:.5rem;overflow-y:auto;padding:.5rem}.sidebar-bottom{border-top:1px solid #2a3a5a;padding:.5rem}.sidebar-title{color:#fff;font-size:1.1rem;margin:0;padding-bottom:.25rem;text-align:center}.sidebar-section{display:flex;flex-direction:column;gap:.25rem}.sidebar-label{color:#8892a6;font-size:.7rem;letter-spacing:.5px;text-align:center;text-transform:uppercase}.sidebar-select{background:#16213e;border:1px solid #2a3a5a;border-radius:4px;color:#fff;cursor:pointer;font-size:.8rem;padding:.35rem;width:100%}.sidebar-select:hover{border-color:#3498db}.sidebar-select:focus{border-color:#3498db;box-shadow:0 0 0 2px #3498db33;outline:none}.sidebar-divider{background:#2a3a5a;height:1px;margin:.25rem 0}.sidebar-divider.double-margin{margin:.5rem 0}.sidebar-button{border:none;border-radius:4px;cursor:pointer;font-size:.8rem;font-weight:500;padding:.35rem;transition:background .2s;width:100%}.sidebar-button.primary{background:#27ae60;color:#fff}.sidebar-button.primary:hover:not(:disabled){background:#219a52}.sidebar-button.primary:disabled{cursor:not-allowed;opacity:.5}.sidebar-button.secondary{background:#3498db;color:#fff;margin-top:.5rem}.sidebar-button.secondary:hover{background:#2980b9}.group-boxes-row{display:flex;gap:2px;justify-content:center;margin-bottom:2px}.group-boxes-row:last-child{margin-bottom:0}.group-box{align-items:center;border:2px solid #0000;border-radius:3px;color:#fff;cursor:pointer;display:flex;font-size:.6rem;font-weight:600;height:24px;justify-content:center;min-width:24px;padding:0 4px;transition:all .15s}.group-box:hover{transform:scale(1.05)}.group-box.active{border-color:#fff;box-shadow:0 0 8px #ffffff80}.group-box.group-all{background:#444;flex:1 1}.group-box.group-ungrouped{background:#666;flex:1 1}.image-count-container{align-items:center;background:#3498db1a;border-radius:6px;display:flex;flex-direction:column;margin-bottom:.25rem;padding:.4rem}.image-count-label{color:#8892a6;font-size:.7rem;letter-spacing:.5px;text-transform:uppercase}.image-count-number{color:#3498db;font-size:1.5rem;font-weight:600}.logout-button{background:#e74c3c;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:.85rem;font-weight:500;padding:.5rem;transition:background .2s;width:100%}.logout-button:hover{background:#c0392b}.gallery-main{flex:1 1;min-width:0}.empty-state,.error-message,.loading{color:#8892a6;font-size:1.2rem;padding:4rem;text-align:center}.error-message{color:#e74c3c}.gallery-sections{padding:1rem 2rem}.date-section{margin-bottom:2rem}.date-section:last-child{margin-bottom:0}.date-section-header{align-items:center;display:flex;gap:1rem;margin-bottom:1rem;padding:0 .5rem}.date-section-line{background:linear-gradient(90deg,#3a4a6a,#0000);flex:1 1;height:1px}.date-section-title{color:#a8b8d8;font-size:.95rem;font-weight:500;text-shadow:0 1px 2px #00000080;white-space:nowrap}.date-section-count{color:#6a7a9a;font-size:.85rem;font-weight:400;margin-left:.5rem}.date-section-actions{align-items:center;display:flex;gap:.75rem}.date-colors{display:flex;gap:.25rem}.date-color-btn{border:2px solid #ffffff4d;border-radius:4px;color:#000000b3;cursor:pointer;font-size:.7rem;font-weight:600;height:22px;text-shadow:0 1px 1px #ffffff4d;transition:transform .15s,border-color .15s;width:22px}.date-color-btn:hover{border-color:#fff9;transform:scale(1.15)}.date-action-buttons{display:flex;gap:.25rem}.gallery-grid{column-count:4;column-gap:1.25rem;padding:2rem}.date-section .gallery-grid{padding:0}@media (max-width:1400px){.gallery-grid{column-count:3}}@media (max-width:1000px){.gallery-grid{column-count:2}}.gallery-item{background:#1a1a2e;border-radius:10px;box-shadow:0 2px 8px #0000004d;break-inside:avoid;cursor:pointer;margin-bottom:1.25rem;overflow:hidden;page-break-inside:avoid;transition:transform .2s,box-shadow .2s}.gallery-item:hover{box-shadow:0 8px 24px #0006;transform:translateY(-4px)}.gallery-item.processing{opacity:.5;pointer-events:none}.thumbnail-container{overflow:hidden;position:relative}.thumbnail{display:block;height:100%;image-rendering:-webkit-optimize-contrast;image-rendering:crisp-edges;object-fit:cover;width:100%}.gallery-item.deleted{opacity:.7}.gallery-item.deleted .thumbnail{filter:grayscale(50%)}.move-status-indicator{align-items:center;background:#000c;border-radius:8px;display:flex;flex-direction:column;gap:.5rem;left:50%;padding:.75rem 1rem;position:absolute;top:50%;transform:translate(-50%,-50%);z-index:8}.move-status-indicator .spinner{animation:spin 1s linear infinite;border:3px solid #ffffff4d;border-radius:50%;border-top-color:#3498db;height:24px;width:24px}@keyframes spin{to{transform:rotate(1turn)}}.move-status-indicator .status-text{color:#fff;font-size:.75rem;font-weight:500}.move-status-indicator.error{background:#e74c3ce6}.move-status-indicator.error .status-text{color:#fff}.image-info{background:#16213e;padding:.5rem}.info-row-1{align-items:center;display:flex;gap:.5rem;justify-content:space-between;margin-bottom:.4rem}.thumb-filename{color:#fff;flex:1 1;font-size:.75rem;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.thumb-size-info{color:#8892a6;flex-shrink:0;font-size:.7rem;white-space:nowrap}.info-row-project{margin-bottom:.4rem;text-align:center}.thumb-project-name{color:#4fc3f7;font-size:.7rem;font-style:italic}.info-row-2{align-items:center;display:flex;gap:.3rem;justify-content:space-between}.thumb-colors{display:flex;gap:.2rem}.color-btn{align-items:center;border:2px solid #0000;border-radius:4px;color:#fff;cursor:pointer;display:flex;font-size:.65rem;font-weight:700;height:1.4rem;justify-content:center;text-shadow:0 1px 2px #0006;transition:transform .15s,border-color .15s;width:1.4rem}.color-btn:hover{border-color:#ffffff80;transform:scale(1.15)}.color-btn.selected{border-color:#fff;box-shadow:0 0 0 1px #ffffff4d;transform:scale(1.1)}.thumb-actions{display:flex;gap:.25rem}.action-btn-mini{align-items:center;border:none;border-radius:50%;cursor:pointer;display:flex;font-size:.75rem;height:1.6rem;justify-content:center;transition:transform .15s,background .15s;width:1.6rem}.action-btn-mini:hover{transform:scale(1.2)}.action-btn-mini.approve{background:#2ecc71;color:#fff}.action-btn-mini.approve:hover{background:#27ae60}.action-btn-mini.reject{background:#6c757d;color:#fff}.action-btn-mini.reject:hover{background:#5a6268}.action-btn-mini.delete{background:#e74c3c;color:#fff}.action-btn-mini.delete:hover{background:#c0392b}.thumb-rating{display:flex;font-size:.7rem;gap:0;letter-spacing:-1px}.thumb-rating .star{color:#f1c40f}.thumb-rating .star.empty{color:#4a4a5a}.thumb-star-btn{background:none;border:none;cursor:pointer;font-size:.75rem;line-height:1;margin:0;padding:0;transition:transform .1s}.thumb-star-btn.filled{color:#f1c40f}.thumb-star-btn.empty{color:#4a4a5a}.thumb-star-btn:hover{transform:scale(1.2)}.thumb-star-btn.hover-preview{color:#f1c40f}.undelete-btn{background:#3498db;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:.75rem;font-weight:500;padding:.4rem .6rem;transition:background .2s;width:100%}.undelete-btn:hover{background:#2980b9}@media (max-width:768px){.gallery-header{align-items:flex-start;flex-direction:column}.header-controls{flex-wrap:wrap}.filter-select{min-width:100px}}@media (max-width:600px){.gallery-grid{column-count:2;column-gap:.75rem;padding:1rem}.gallery-item{margin-bottom:.75rem}.image-info{padding:.4rem}.thumb-filename{font-size:.65rem}.thumb-size-info{font-size:.6rem}.color-btn{font-size:.55rem;height:1.2rem;width:1.2rem}.action-btn-mini{font-size:.65rem;height:1.4rem;width:1.4rem}.thumb-rating{font-size:.6rem}}.sidebar-project-buttons{display:flex;gap:.5rem;margin-top:.5rem}.sidebar-project-buttons .sidebar-button{flex:1 1;margin-top:0}.sidebar-zip-list{display:flex;flex-direction:column;gap:.25rem;margin-top:.75rem}.sidebar-zip-link{background:none;border:none;color:#3498db;cursor:pointer;font:inherit;font-size:.8rem;overflow:hidden;padding:.4rem 0;text-align:left;text-decoration:none;text-overflow:ellipsis;transition:color .15s ease;white-space:nowrap}.sidebar-zip-link:hover:not(:disabled){color:#5dade2;text-decoration:underline}.sidebar-zip-link:disabled{color:#8892a6;cursor:not-allowed}.add-dialog-backdrop{align-items:center;background:#000000b3;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1100}.add-dialog{background:#1a1a2e;border-radius:12px;box-shadow:0 10px 40px #00000080;max-width:400px;padding:1.5rem;width:90%}.add-dialog h3{color:#fff;font-size:1.25rem;margin:0 0 1rem;text-align:center}.add-dialog input{background:#16213e;border:1px solid #2a3a5a;border-radius:8px;box-sizing:border-box;color:#fff;font-size:1rem;padding:.75rem;width:100%}.add-dialog input:focus{border-color:#3498db;box-shadow:0 0 0 2px #3498db33;outline:none}.add-dialog input::placeholder{color:#6c7a8a}.add-dialog-buttons{display:flex;gap:.75rem;margin-top:1rem}.dialog-btn{border:none;border-radius:8px;cursor:pointer;flex:1 1;font-size:.9rem;font-weight:600;padding:.75rem;transition:all .15s ease}.dialog-btn.cancel{background:#2a3a5a;color:#8892a6}.dialog-btn.cancel:hover:not(:disabled){background:#3a4a6a;color:#fff}.dialog-btn.create{background:#2ecc71;color:#fff}.dialog-btn.create:hover:not(:disabled){background:#27ae60}.dialog-btn:disabled{cursor:not-allowed;opacity:.5}.add-to-project-section{margin-top:.5rem}.projects-buttons-row{display:flex;gap:.25rem}.add-project-inline-btn{background:#2ecc71;border:none;border-radius:3px;color:#fff;cursor:pointer;flex:1 1;font-size:.7rem;font-weight:600;padding:.3rem 0;text-align:center;transition:all .15s ease}.add-project-inline-btn:hover{background:#27ae60}.manage-projects-btn{background:#3498db;border:none;border-radius:3px;color:#fff;cursor:pointer;flex:1 1;font-size:.7rem;font-weight:600;padding:.3rem 0;text-align:center;transition:all .15s ease}.manage-projects-btn:hover{background:#2980b9}*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}.App{min-height:100vh}
/*# sourceMappingURL=main.48ac8342.css.map*/