*{box-sizing:border-box}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;margin:0}.App{min-height:100vh}.loading{color:#666;font-size:18px}.loading,.login-container{align-items:center;display:flex;justify-content:center;min-height:100vh}.login-container{background:linear-gradient(135deg,#667eea,#764ba2)}.login-box{background:#fff;border-radius:10px;box-shadow:0 10px 25px #0003;max-width:400px;padding:40px;width:100%}.login-box h1{color:#333;margin-bottom:30px;margin-top:0;text-align:center}.form-group{margin-bottom:20px}.form-group label{color:#555;font-weight:500;margin-bottom:5px}.form-group input,.form-group select{border:1px solid #ddd;border-radius:5px;box-sizing:border-box;font-size:14px;padding:10px;width:100%}.form-group input:focus,.form-group select:focus{border-color:#667eea;outline:none}.error{margin-bottom:15px}button[type=submit]{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:5px;color:#fff;cursor:pointer;font-size:16px;font-weight:600;padding:12px;transition:transform .2s;width:100%}button[type=submit]:hover:not(:disabled){transform:translateY(-2px)}button[type=submit]:disabled{cursor:not-allowed;opacity:.6}.hint{background-color:#f5f5f5;border-radius:5px;margin-top:20px;padding:15px;text-align:center}.hint p{color:#666;font-size:12px;margin:0}.album-manager-overlay{background:#00000080;bottom:0;display:flex;justify-content:flex-end;left:0;position:fixed;right:0;top:0;z-index:2000}.album-manager-panel{animation:slideIn .3s ease-out;background:#fff;box-shadow:-2px 0 10px #0003;height:100%;max-width:90%;overflow-y:auto;width:500px}.album-manager-header{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:flex;justify-content:space-between;padding:20px}.album-manager-header h2{font-size:24px;margin:0}.close-button{align-items:center;background:#fff3;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:30px;height:40px;justify-content:center;line-height:1;transition:background .3s;width:40px}.close-button:hover{background:#ffffff4d}.album-manager-content{padding:20px}.error-message{background:#ffebee;color:#d32f2f;margin:15px 20px;padding:12px}.create-album-section{border-bottom:2px solid #f0f0f0;margin-bottom:30px;padding-bottom:30px}.create-album-section h3{color:#333;margin-bottom:15px;margin-top:0}.create-album-section form{display:flex;flex-direction:column;gap:12px}.create-album-section input,.create-album-section textarea{border:1px solid #ddd;border-radius:5px;font-family:inherit;font-size:14px;padding:10px}.create-album-section textarea{min-height:60px;resize:vertical}.create-album-section button{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:5px;color:#fff;cursor:pointer;font-size:14px;font-weight:600;padding:12px;transition:transform .2s}.create-album-section button:hover:not(:disabled){transform:translateY(-2px)}.create-album-section button:disabled{cursor:not-allowed;opacity:.6}.albums-list-section h3{color:#333;margin-bottom:15px;margin-top:0}.albums-list{display:flex;flex-direction:column;gap:12px}.album-item{align-items:flex-start;background:#f9f9f9;border:1px solid #e0e0e0;border-radius:8px;display:flex;justify-content:space-between;padding:15px;transition:box-shadow .3s}.album-item:hover{box-shadow:0 2px 8px #0000001a}.album-item.default{background:linear-gradient(135deg,#f5f7fa,#e9ecef);border-color:#667eea}.album-info{flex:1 1}.album-info h4{align-items:center;color:#333;display:flex;font-size:16px;gap:8px;margin:0 0 5px}.default-badge{background:#667eea;border-radius:12px;color:#fff;font-size:10px;font-weight:600;padding:3px 8px;text-transform:uppercase}.album-info p{color:#666;font-size:13px;margin:0}.album-actions{display:flex;gap:8px}.album-actions button{background:#667eea;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:12px;padding:6px 12px;transition:background .3s}.album-actions button:hover{background:#5568d3}.album-actions button.delete-btn{background:#e74c3c}.album-actions button.delete-btn:hover{background:#c0392b}.album-edit-form{display:flex;flex-direction:column;gap:10px;width:100%}.album-edit-form input,.album-edit-form textarea{border:1px solid #ddd;border-radius:4px;font-family:inherit;font-size:14px;padding:8px}.album-edit-form textarea{min-height:50px;resize:vertical}.album-edit-actions{display:flex;gap:8px}.album-edit-actions button{border:none;border-radius:4px;cursor:pointer;flex:1 1;font-size:13px;font-weight:600;padding:8px}.album-edit-actions button:first-child{background:#27ae60;color:#fff}.album-edit-actions button:first-child:hover{background:#229954}.album-edit-actions button:last-child{background:#95a5a6;color:#fff}.album-edit-actions button:last-child:hover{background:#7f8c8d}@media (max-width:600px){.album-manager-panel{width:100%}}.user-management-container{padding:30px}.create-user-section{background:#f9f9f9;border:1px solid #e0e0e0;border-radius:8px;margin-bottom:40px;padding:25px}.create-user-section h3{color:#333;font-size:18px;margin-bottom:20px;margin-top:0}.create-user-section form{display:flex;flex-direction:column;gap:15px}.create-user-section input[type=password],.create-user-section input[type=text]{border:1px solid #ddd;border-radius:5px;font-size:14px;padding:12px}.create-user-section input:focus{border-color:#667eea;outline:none}.checkbox-label{align-items:center;cursor:pointer;display:flex;gap:10px;-webkit-user-select:none;user-select:none}.checkbox-label input[type=checkbox]{cursor:pointer;height:18px;width:18px}.checkbox-label span{color:#333;font-size:14px}.create-user-section button{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:5px;color:#fff;cursor:pointer;font-size:15px;font-weight:600;padding:12px 20px;transition:transform .2s}.create-user-section button:hover:not(:disabled){transform:translateY(-2px)}.create-user-section button:disabled{cursor:not-allowed;opacity:.6}.users-list-section{margin-top:30px}.users-list-section h3{color:#333;font-size:18px;margin-bottom:20px}.users-list{display:flex;flex-direction:column;gap:15px}.user-item{align-items:center;background:#fff;border:1px solid #e0e0e0;border-radius:8px;display:flex;justify-content:space-between;padding:20px;transition:box-shadow .3s}.user-item:hover{box-shadow:0 2px 8px #0000001a}.user-info h4{align-items:center;color:#333;display:flex;font-size:16px;gap:10px;margin:0 0 5px}.user-info p{color:#666;font-size:13px;margin:0}.user-email{color:#667eea;font-size:13px;margin:3px 0!important}.user-date{margin-top:5px!important}.superuser-badge{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:12px;color:#fff;display:inline-block;font-size:11px;font-weight:600;padding:3px 10px;text-transform:uppercase}.user-actions{display:flex;gap:10px}.user-actions button{border:none;border-radius:5px;cursor:pointer;font-size:14px;font-weight:600;padding:8px 16px;transition:all .2s}.user-actions button:first-child{background:#667eea;color:#fff}.user-actions button:first-child:hover{background:#5568d3}.user-actions button.delete-btn{background:#dc3545;color:#fff}.user-actions button.delete-btn:hover{background:#c82333}.user-edit-form{display:flex;flex-direction:column;gap:12px;width:100%}.user-edit-form input[type=password],.user-edit-form input[type=text]{border:1px solid #ddd;border-radius:5px;font-size:14px;padding:10px}.user-edit-form input:focus{border-color:#667eea;outline:none}.user-edit-actions{display:flex;gap:10px;margin-top:5px}.user-edit-actions button{border:none;border-radius:5px;cursor:pointer;flex:1 1;font-size:14px;font-weight:600;padding:10px;transition:all .2s}.user-edit-actions button:first-child{background:#667eea;color:#fff}.user-edit-actions button:first-child:hover{background:#5568d3}.user-edit-actions button:last-child{background:#e0e0e0;color:#333}.user-edit-actions button:last-child:hover{background:#d0d0d0}.error-message{padding:12px 20px}.tenant-preferences{max-width:800px;padding:20px}.tenant-preferences h2{color:#333;font-size:24px;margin-bottom:10px;margin-top:0}.preferences-description{color:#666;font-size:14px;margin-bottom:30px}.error-message{background:#f8d7da;border:1px solid #f5c6cb;border-radius:5px;color:#721c24}.error-message,.success-message{font-size:14px;margin-bottom:20px;padding:12px 16px}.success-message{background:#d4edda;border:1px solid #c3e6cb;border-radius:5px;color:#155724}.preferences-form{background:#fff}.form-section{background:#f9f9f9;border:1px solid #e0e0e0;border-radius:8px;margin-bottom:20px;padding:25px}.form-section h3{border-bottom:2px solid #667eea;color:#555;font-size:18px;margin-bottom:20px;margin-top:0;padding-bottom:10px}.form-group{margin-bottom:25px}.form-group label{color:#333;display:block;font-size:14px;font-weight:600;margin-bottom:8px}.label-hint{color:#666;display:block;font-size:12px;font-style:italic;font-weight:400;margin-top:4px}.form-group input[type=text]{border:1px solid #ddd;border-radius:5px;box-sizing:border-box;font-size:14px;padding:12px;transition:border-color .3s;width:100%}.form-group input[type=text]:focus{border-color:#667eea;box-shadow:0 0 0 2px #667eea1a;outline:none}.form-group input[type=text]:disabled{background:#f5f5f5;cursor:not-allowed;opacity:.6}.preview-section{border-top:1px solid #e0e0e0;margin-top:30px;padding-top:20px}.preview-section h4{color:#666;font-size:14px;font-weight:600;letter-spacing:.5px;margin-bottom:15px;margin-top:0;text-transform:uppercase}.gallery-preview{border:2px dashed #ddd;border-radius:8px;overflow:hidden}.preview-header{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:30px 40px;text-align:center}.preview-header h1{font-size:32px;font-weight:600;margin:0}.form-actions{display:flex;gap:15px;justify-content:flex-end;margin-top:25px}.save-button{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:5px;color:#fff;cursor:pointer;font-size:16px;font-weight:600;padding:12px 30px;transition:transform .2s,box-shadow .2s}.save-button:hover:not(:disabled){box-shadow:0 5px 15px #667eea4d;transform:translateY(-2px)}.save-button:disabled{cursor:not-allowed;opacity:.6;transform:none}@media (max-width:768px){.tenant-preferences{padding:15px}.form-section{padding:20px}.preview-header h1{font-size:24px}.form-actions{flex-direction:column}.save-button{width:100%}}.settings-overlay{background:#00000080;bottom:0;display:flex;justify-content:flex-end;left:0;position:fixed;right:0;top:0;z-index:2000}.settings-panel{animation:slideIn .3s ease-out;background:#fff;box-shadow:-2px 0 10px #0003;display:flex;flex-direction:column;height:100%;width:600px}@keyframes slideIn{0%{transform:translateX(100%)}to{transform:translateX(0)}}.settings-header{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-bottom:2px solid #e0e0e0;color:#fff;display:flex;justify-content:space-between;padding:20px 30px}.settings-header h2{font-size:24px;margin:0}.settings-close-btn{align-items:center;background:#fff3;border:1px solid #fff;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:30px;height:40px;justify-content:center;line-height:1;transition:background .3s;width:40px}.settings-close-btn:hover{background:#ffffff4d}.settings-tabs{background:#f5f5f5;border-bottom:2px solid #e0e0e0;display:flex}.settings-tab{background:#0000;border:none;border-bottom:3px solid #0000;color:#666;cursor:pointer;flex:1 1;font-size:16px;font-weight:600;padding:15px 20px;transition:all .3s}.settings-tab:hover{background:#667eea1a;color:#667eea}.settings-tab.active{background:#fff;border-bottom:3px solid #667eea;color:#667eea}.settings-content{flex:1 1;overflow-y:auto}@media (max-width:768px){.settings-panel{width:100%}}.photo-grid-container{background:#f5f5f5;min-height:100vh}.header{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);box-shadow:0 2px 10px #0000001a;color:#fff;display:flex;justify-content:space-between;padding:20px 40px}.header h1{font-size:24px;margin:0}.header-info{align-items:center;display:flex;gap:20px}.storage-usage{background:#ffffff26;border:1px solid #ffffff4d;border-radius:4px;font-size:13px;padding:6px 12px;white-space:nowrap}.hamburger-btn{background:#fff3;border:1px solid #fff;border-radius:5px;cursor:pointer;display:flex;flex-direction:column;gap:4px;padding:8px 12px;transition:background .3s}.hamburger-btn:hover{background:#ffffff4d}.hamburger-btn span{background:#fff;border-radius:2px;display:block;height:2px;width:20px}.logout-btn{background:#fff3;border:1px solid #fff;border-radius:5px;color:#fff;cursor:pointer;padding:8px 20px;transition:background .3s}.logout-btn:hover{background:#ffffff4d}.controls-section{align-items:center;background:#fff;display:flex;flex-wrap:wrap;gap:20px;justify-content:space-between;margin-bottom:20px;padding:20px 40px}.album-filter{align-items:center;display:flex;gap:10px}.album-filter label{color:#333;font-weight:600}.album-filter select{background:#fff;border:1px solid #ddd;border-radius:5px;cursor:pointer;font-size:14px;min-width:200px;padding:10px 15px}.album-filter select:focus{border-color:#667eea;outline:none}.upload-section{align-items:center;display:flex}.upload-btn{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:5px;color:#fff;cursor:pointer;display:inline-block;font-weight:600;padding:12px 30px;transition:transform .2s}.upload-btn:hover{transform:translateY(-2px)}.error{display:inline-block;margin-top:15px;padding:10px}.no-photos{color:#666;padding:60px 20px;text-align:center}.photo-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(4,1fr);margin:0 auto;max-width:1400px;padding:0 40px 40px}.photo-card{background:#fff;border-radius:10px;box-shadow:0 2px 8px #0000001a;cursor:pointer;overflow:hidden;transition:transform .3s,box-shadow .3s}.photo-card:hover{box-shadow:0 5px 20px #0003;transform:translateY(-5px)}.photo-card img{display:block;height:250px;object-fit:cover;width:100%}.photo-info{padding:15px}.photo-name{color:#333;font-weight:600;margin:0 0 5px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.photo-user{color:#666;font-size:12px;margin:0}.photo-album{color:#667eea;font-size:11px;font-weight:500;margin:5px 0 0}.pagination{align-items:center;display:flex;gap:20px;justify-content:center;padding:40px 20px}.pagination button{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:5px;color:#fff;cursor:pointer;font-weight:600;padding:10px 25px;transition:transform .2s}.pagination button:hover:not(:disabled){transform:translateY(-2px)}.pagination button:disabled{cursor:not-allowed;opacity:.5}.pagination span{color:#333;font-weight:600}@media (max-width:1200px){.photo-grid{grid-template-columns:repeat(3,1fr)}}@media (max-width:768px){.photo-grid{grid-template-columns:repeat(2,1fr)}.header{padding:15px 20px}.upload-section{padding:20px}}@media (max-width:480px){.photo-grid{grid-template-columns:1fr}}.upload-modal-overlay{align-items:center;background:#000000b3;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1500}.upload-modal{background:#fff;border-radius:10px;box-shadow:0 10px 40px #0000004d;max-width:500px;padding:30px;width:90%}.upload-modal h3{color:#333;font-size:22px;margin:0 0 20px}.selected-file-name{background:#f5f7fa;border-radius:5px;color:#555;font-size:14px;margin-bottom:20px;padding:12px;word-break:break-all}.upload-modal .form-group{margin-bottom:20px}.upload-modal .form-group label{color:#333;display:block;font-weight:600;margin-bottom:8px}.upload-modal .form-group select{background:#fff;border:1px solid #ddd;border-radius:5px;cursor:pointer;font-size:14px;padding:12px;width:100%}.upload-modal .form-group select:focus{border-color:#667eea;outline:none}.modal-actions{display:flex;gap:12px;margin-top:25px}.modal-actions button{border:none;border-radius:5px;cursor:pointer;flex:1 1;font-size:15px;font-weight:600;padding:12px;transition:transform .2s,opacity .2s}.modal-actions button:first-child{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.modal-actions button:first-child:hover:not(:disabled){transform:translateY(-2px)}.modal-actions button:last-child{background:#e0e0e0;color:#333}.modal-actions button:last-child:hover:not(:disabled){background:#d0d0d0}.modal-actions button:disabled{cursor:not-allowed;opacity:.6}.error{background-color:#ffebee;border-radius:5px;color:#d32f2f;font-size:14px;margin:15px 40px;padding:10px 20px}.photo-viewer-overlay{align-items:center;background:#000000e6;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:1000}.photo-viewer-container{background:#fff;border-radius:10px;display:flex;flex-direction:column;max-height:95%;max-width:95%;overflow:hidden;position:relative}.close-btn{align-items:center;background:#00000080;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:30px;height:40px;justify-content:center;line-height:1;position:absolute;right:10px;top:10px;transition:background .3s;width:40px;z-index:10}.close-btn:hover{background:#000000b3}.photo-viewer-content{display:flex;height:90vh;overflow:hidden}.photo-viewer-image{align-items:center;background:#000;display:flex;flex:1 1;justify-content:center;padding:20px}.photo-viewer-image img{max-height:100%;max-width:100%;object-fit:contain}.photo-viewer-metadata{background:#fff;border-left:1px solid #ddd;overflow-y:auto;padding:30px;width:400px}.photo-viewer-metadata h2{color:#333;font-size:24px;margin-bottom:20px;margin-top:0}.photo-viewer-metadata h3{border-bottom:2px solid #667eea;color:#555;font-size:18px;margin-bottom:15px;margin-top:30px;padding-bottom:10px}.album-selector-section{background:#f9f9f9;border:1px solid #e0e0e0;border-radius:8px;margin-top:20px;padding:20px}.album-selector-section h3{border-bottom:none;font-size:16px;margin-bottom:12px;margin-top:0;padding-bottom:0}.album-selector-controls{display:flex;flex-direction:column;gap:10px}.album-selector{background:#fff;border:1px solid #ddd;border-radius:5px;cursor:pointer;font-size:14px;padding:10px;transition:border-color .3s;width:100%}.album-selector:hover:not(:disabled){border-color:#667eea}.album-selector:focus{border-color:#667eea;box-shadow:0 0 0 2px #667eea1a;outline:none}.album-selector:disabled{cursor:not-allowed;opacity:.6}.saving-indicator{color:#667eea;font-size:13px;font-style:italic}.save-message{border-radius:4px;display:inline-block;font-size:13px;padding:8px 12px}.save-message.success{background:#d4edda;border:1px solid #c3e6cb;color:#155724}.save-message.error{background:#f8d7da;border:1px solid #f5c6cb;color:#721c24}.title-section{background:#f9f9f9;border:1px solid #e0e0e0;border-radius:8px;margin-top:20px;padding:20px}.title-section h3{border-bottom:none;font-size:16px;margin-bottom:12px;margin-top:0;padding-bottom:0}.title-controls{display:flex;flex-direction:column;gap:10px}.title-input{background:#fff;border:1px solid #ddd;border-radius:5px;font-size:14px;padding:10px;transition:border-color .3s;width:100%}.title-input:focus,.title-input:hover:not(:disabled){border-color:#667eea}.title-input:focus{box-shadow:0 0 0 2px #667eea1a;outline:none}.title-input:disabled{cursor:not-allowed;opacity:.6}.title-help-text{color:#666;font-size:12px;font-style:italic;margin:5px 0 0}.published-section{background:#f9f9f9;border:1px solid #e0e0e0;border-radius:8px;margin-top:20px;padding:20px}.published-section h3{border-bottom:none;font-size:16px;margin-bottom:12px;margin-top:0;padding-bottom:0}.published-controls{align-items:center;display:flex;gap:15px}.published-toggle{align-items:center;cursor:pointer;display:flex;gap:10px;-webkit-user-select:none;user-select:none}.published-toggle input[type=checkbox]{accent-color:#667eea;cursor:pointer;height:20px;width:20px}.published-toggle input[type=checkbox]:disabled{cursor:not-allowed;opacity:.6}.published-label{color:#333;font-size:14px;font-weight:600}.published-badge{background:linear-gradient(135deg,#28a745,#20c997);border-radius:12px;color:#fff;display:inline-block;font-size:12px;font-weight:600;padding:4px 12px;text-transform:uppercase}.metadata-table{border-collapse:collapse;margin-bottom:20px;width:100%}.metadata-table th{color:#666;font-weight:600;padding:10px 10px 10px 0;text-align:left;vertical-align:top;width:140px}.metadata-table td{color:#333;padding:10px 0;word-break:break-word}.metadata-table tr{border-bottom:1px solid #f0f0f0}.metadata-table tr:last-child{border-bottom:none}.stats-value{align-items:center;color:#333;display:flex;font-weight:600;gap:8px}.stats-icon{font-size:18px}.no-metadata{color:#999;font-style:italic;padding:20px 0}.json-value{font-family:Courier New,monospace;font-size:12px}.json-value pre{background:#f5f5f5;border-radius:4px;margin:0;max-height:200px;overflow-y:auto;padding:8px;white-space:pre-wrap;word-break:break-word}@media (max-width:1024px){.photo-viewer-content{flex-direction:column}.photo-viewer-image{height:60%}.photo-viewer-metadata{border-left:none;border-top:1px solid #ddd;height:40%;width:100%}}@media (max-width:768px){.photo-viewer-metadata{padding:20px}.photo-viewer-metadata h2{font-size:20px}.photo-viewer-metadata h3{font-size:16px}.metadata-table th{font-size:14px;width:120px}.metadata-table td{font-size:14px}}
/*# sourceMappingURL=main.ff5ca6ec.css.map*/