:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light;color:#213547;background-color:#fff;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}.container{margin:auto;padding:10px;display:flex;flex-direction:column;gap:20px;background-color:#f0f2ef;min-height:100vh;overflow-x:hidden}.header{text-align:center;padding:20px 10px;border-bottom:2px solid #e0e0e0;margin-bottom:10px;position:relative}.header-content{display:flex;justify-content:center;align-items:center;position:relative}.header h1{margin:0 0 8px;font-size:32px;color:#213547}.header p{margin:0;font-size:16px;color:#f38375}.upload-card{background:#fff;padding:24px;border-radius:15px;box-shadow:0 2px 8px #00000014;max-width:500px;margin:0 auto;transition:box-shadow .3s ease}.upload-card h2{margin:0 0 15px;font-size:20px;color:#213547}.storage-info{margin-bottom:15px;padding:10px;background:#f0f2ef80;border-radius:8px}.storage-bar{width:100%;height:8px;background:#e0e0e0;border-radius:10px;overflow:hidden;margin-bottom:5px}.storage-fill{height:100%;background:linear-gradient(90deg,#48bb78,#38a169);transition:width .3s ease}.storage-fill.full{background:linear-gradient(90deg,#f56565,#e53e3e)}.storage-text{text-align:center;font-size:12px;color:#213547}.storage-full{color:#e53e3e;font-weight:600}.upload-form{display:flex;flex-direction:column;gap:10px}.file-drop-zone{border:2px dashed #d0d0d0;border-radius:12px;padding:20px;cursor:pointer;transition:all .3s ease;background:#fafafa;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:0;min-height:200px}.file-drop-zone:hover{border-color:#667eea;background:#f5f7fb}.file-drop-zone.dragging{border-color:#667eea;background:#e8ecff;transform:scale(1.01)}.file-drop-zone.has-files{padding:12px;border-color:#667eea;border-style:solid;min-height:auto;align-items:stretch;justify-content:flex-start}.drop-zone-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:15px;padding:30px 20px;color:#666;width:100%;min-height:180px}.upload-icon-large{font-size:48px;opacity:.6}.drop-zone-text{display:flex;flex-direction:column;gap:5px;text-align:center}.drop-zone-text strong{font-size:16px;color:#213547}.drop-zone-text span{font-size:14px;color:#999}.files-list-compact{display:flex;flex-direction:column;gap:8px;width:100%}.file-item-compact{display:flex;align-items:center;gap:10px;padding:10px 12px;background:#fff;border-radius:8px;border:1px solid #e0e0e0;transition:all .2s;position:relative}.file-item-compact:hover{border-color:#667eea;box-shadow:0 2px 6px #667eea26}.file-icon-tiny{font-size:20px;flex-shrink:0}.file-info-inline{flex:1;display:flex;flex-direction:column;gap:2px;min-width:0}.file-name-inline{font-size:14px;font-weight:500;color:#213547;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.file-size-inline{font-size:12px;color:#666}.remove-file-btn-compact{width:24px;height:24px;border-radius:50%;border:none;background:#b00020;color:#fff;font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;flex-shrink:0;font-weight:700;padding:0;line-height:1}.remove-file-btn-compact:hover{background:#8b0019;transform:scale(1.1)}.add-more-area{margin-top:8px;padding:12px;border:2px dashed #d0d0d0;border-radius:8px;text-align:center;background:#fafafa;transition:all .2s}.add-more-area:hover{border-color:#667eea;background:#f5f7fb}.add-more-text{font-size:13px;color:#667eea;font-weight:500}.upload-form input[type=file]{padding:10px;border-radius:10px;border:1px solid #d0d0d0;font-size:15px;background:#fff;cursor:pointer;transition:border-color .2s}.upload-form input[type=file]:focus{outline:none;border-color:#667eea}.upload-form textarea{padding:10px 12px;border-radius:8px;border:none;font-size:14px;width:100%;max-width:100%;box-sizing:border-box;font-family:inherit;resize:vertical;transition:background .2s;min-height:45px;line-height:1.4;background:#f5f5f5}.upload-form textarea:focus{outline:none;background:#ebebeb}.private-checkbox-label{display:flex;align-items:center;gap:12px;padding:0;margin-top:12px;background:transparent;border:none;cursor:pointer;-webkit-user-select:none;user-select:none}.private-checkbox-label input[type=checkbox]{width:20px;height:20px;cursor:pointer;accent-color:#667eea;border-radius:4px}.private-checkbox-label span{font-size:14px;color:#666;font-weight:400}.private-checkbox-label:has(input:disabled){cursor:not-allowed;opacity:.6}.expiration-options{display:flex;gap:8px;flex-wrap:wrap}.expiration-btn{flex:1;min-width:70px;padding:8px 12px;border-radius:8px;border:2px solid #d0d0d0;background:#fff;color:#213547;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s}.expiration-btn:hover:not(:disabled):not(.active){border-color:#667eea;background:#f5f7fb;transform:translateY(-1px)}.expiration-btn.active{border-color:#667eea;background:#667eea;color:#fff;font-weight:600;box-shadow:0 2px 8px #667eea4d}.expiration-btn:disabled{cursor:not-allowed;opacity:.5}.upload-form button[type=submit]{padding:12px;margin-top:15px;background:#ef6351;color:#fff;font-size:16px;border-radius:10px;cursor:pointer;border:none;transition:background .2s,transform .2s}.upload-form button[type=submit]:hover{background:#ad3a2b;transform:translateY(-1px)}.upload-form button[type=submit]:active{transform:translateY(0)}.status{background:#dc3545;color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:600;cursor:pointer;transition:background .2s;margin:15px 0;padding:12px;background:#f8f9fa;background:#c82333;animation:fadeIn .3s ease}.progress-bar{width:100%;height:8px;background:#e0e0e0;border-radius:4px;overflow:hidden;margin-top:8px}.progress-fill{height:100%;background:linear-gradient(90deg,#667eea,#764ba2);transition:width .3s ease;border-radius:4px}.progress-text{display:flex;justify-content:space-between;align-items:center;font-size:14px;font-weight:600;color:#213547}.progress-text:after{content:attr(data-percentage);color:#667eea;font-weight:700}.success-message{display:flex;flex-direction:column;gap:10px;align-items:stretch}.success-message span{font-weight:600;color:#48bb78}.copy-link-btn,.view-link-btn{padding:10px 20px;border-radius:8px;border:none;cursor:pointer;font-size:14px;font-weight:600;transition:all .2s,box-shadow .2s;text-decoration:none;display:inline-block;text-align:center}.copy-link-btn{background:#667eea;color:#fff}.copy-link-btn:hover{background:#5568d3;transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.view-link-btn{background:#48bb78;color:#fff}.view-link-btn:hover{background:#38a169;transform:translateY(-2px);box-shadow:0 4px 12px #48bb7866}.link-copied-message{padding:8px 12px;background:#c6f6d5;color:#22543d;border:1px solid #9ae6b4;border-radius:8px;font-size:13px;font-weight:500;text-align:center;animation:fadeIn .3s ease-in}.gallery-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;flex-wrap:wrap;gap:15px}.view-controls{display:flex;gap:10px}.view-btn{padding:10px 20px;border-radius:8px;border:1px solid #d0d0d0;background:#f38375;cursor:pointer;font-size:14px;font-weight:500;transition:all .2s;color:#fff}.view-btn:hover{background:#c76b5e}.view-btn.active{background:#ef6351;border-color:#ef6351;transform:translateY(-1px);box-shadow:0 2px 8px #ef63514d}.user-badge-container{position:absolute;right:20px;top:20px}.user-badge{width:30px;height:30px;display:flex;align-items:center;justify-content:center;cursor:pointer}.user-icon{font-size:20px;-webkit-user-select:none;user-select:none;filter:grayscale(100%)}.user-dropdown{position:absolute;right:0;top:48px;min-width:180px;background:#fff;border:1px solid #e0e0e0;border-radius:10px;box-shadow:0 6px 18px #0000001f;z-index:100;overflow:hidden}.user-dropdown-item{display:block;width:100%;padding:12px 16px;text-align:left;border:none;background:none;cursor:pointer;font-size:14px;color:#213547;transition:background .2s;border-bottom:1px solid #f0f0f0;text-decoration:none}.user-dropdown-item:last-child{border-bottom:none}.user-dropdown-item:hover{background:#f5f7fb}.user-dropdown-item.user-info{font-weight:600;color:#f38375;cursor:default;background:#fafafa}.user-dropdown-item.user-info:hover{background:#fafafa}.user-dropdown-item.logout-item{color:#dc3545}.user-dropdown-item.logout-item:hover{background:#fff0f0}.modal{background:#fff;padding:30px;border-radius:15px;box-shadow:0 4px 12px #00000026;max-width:400px;text-align:center}.modal p{background:#fff;border-radius:12px;box-shadow:0 2px 6px #0000000f;padding:30px;max-width:500px;margin:40px auto;max-width:450px;text-align:left}.password-modal h3{margin:0 0 20px;font-size:22px;color:#213547;text-align:center}.password-modal form{display:flex;flex-direction:column;gap:10px}.password-modal label{font-weight:600;color:#333;font-size:14px;margin-top:8px}.password-modal .input{padding:10px;border-radius:8px;border:1px solid #ddd;font-size:14px}.form-error{color:#b00020;background:#b000200f;padding:8px 10px;border-radius:8px;margin-top:8px;font-size:13px}.form-success{color:#2e7d32;background:#2e7d321a;padding:8px 10px;border-radius:8px;margin-top:8px;font-size:13px;text-align:center}.modal-buttons{display:flex;gap:10px;justify-content:center;margin-top:15px}.button,.button-confirm,.button-cancel{padding:10px 20px;border-radius:8px;border:none;cursor:pointer;font-size:14px;font-weight:600;transition:background .2s,transform .2s}.button-confirm{background:#ef6351;color:#fff;flex:1;margin-top:0}.button-confirm:hover{background:#ad3a2b}.button-cancel{background:#999;color:#fff;flex:1}.button-cancel:hover{background:#777}.homeboy-img{display:block;margin:20px auto;border-radius:15px;box-shadow:0 2px 6px #00000012;max-width:100%;height:auto}.gallery-section{margin-top:20px}.gallery-section h2{font-size:24px;color:#213547;margin-bottom:20px;text-align:center}.file-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:20px;padding-bottom:30px}.file-card{background:#fff;border-radius:15px;box-shadow:0 2px 8px #00000014;overflow:hidden;transition:transform .2s,box-shadow .2s}.file-card:hover{transform:translateY(-2px);box-shadow:0 4px 16px #0000001f}.file-preview-link{text-decoration:none;display:block}.file-name-link{text-decoration:none;color:inherit}.file-name-link:hover .file-name{color:#667eea}.file-preview{width:100%;height:200px;background:#f5f5f5;display:flex;align-items:center;justify-content:center;overflow:hidden}.file-preview img{width:100%;height:100%;object-fit:cover}.file-icon{font-size:48px;text-align:center;color:#999}.file-info{padding:15px}.file-name{font-size:16px;font-weight:600;color:#213547;margin-bottom:4px;word-break:break-word;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;line-height:1.4;max-height:2.8em}.file-original-name{font-size:12px;color:#999;margin-bottom:8px;word-break:break-word}.file-description{font-size:14px;color:#666;margin-bottom:10px;font-style:italic}.file-meta{display:flex;justify-content:space-between;align-items:center;font-size:12px;color:#999;margin-bottom:8px;padding-bottom:8px;border-bottom:1px solid #eee}.file-user{display:flex;align-items:center;gap:4px}.file-expires{font-size:12px;color:#f59e0b;background:#f59e0b1a;padding:4px 8px;border-radius:6px;margin-bottom:10px;font-weight:500;display:flex;align-items:center;gap:4px}.file-actions{display:flex;gap:8px}.btn-download,.btn-delete{flex:1;padding:10px 12px;border-radius:8px;border:none;cursor:pointer;font-size:13px;font-weight:600;transition:all .2s;text-decoration:none;display:flex;align-items:center;justify-content:center;gap:4px}.btn-download{background:#667eea;color:#fff}.btn-download:hover{background:#5568d3;transform:translateY(-1px);box-shadow:0 2px 8px #667eea4d}.btn-delete{background:#b00020;color:#fff}.btn-delete:hover{background:#8b0019;transform:translateY(-1px);box-shadow:0 2px 8px #b000204d}@media(max-width:768px){.header{padding:15px 10px}.header h1{font-size:24px}.user-badge-container{right:10px;top:10px}.upload-card{padding:15px;max-width:90%}.file-list{grid-template-columns:1fr;gap:15px}.gallery-header{flex-direction:column;align-items:stretch}.view-controls{width:100%;justify-content:space-between;flex-wrap:wrap}.view-btn{flex:1 1 calc(50% - 5px);min-width:120px;padding:12px 15px;font-size:13px}.user-dropdown{right:0;left:auto;min-width:160px}}.selected-files-display{width:100%;display:flex;flex-direction:column;gap:10px}.files-count{font-size:15px;font-weight:600;color:#213547;display:flex;align-items:center;gap:5px;flex-wrap:wrap}.total-size{font-size:13px;color:#666;font-weight:400}.selected-files-list{display:flex;flex-direction:column;gap:8px;max-height:300px;overflow-y:auto;padding-right:5px}.selected-file-item{display:flex;align-items:center;gap:10px;padding:8px 10px;background:#f8f9fa;border-radius:8px;position:relative;transition:background .2s}.selected-file-item:hover{background:#e9ecef}.file-icon-small{font-size:20px;flex-shrink:0}.file-details-small{flex:1;overflow:hidden;min-width:0}.file-name-small{font-size:13px;font-weight:600;color:#213547;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.file-size-small{font-size:11px;color:#666}.remove-file-btn-small{width:20px;height:20px;border-radius:50%;border:none;background:#e53e3e;color:#fff;font-size:12px;cursor:pointer;transition:background .2s;display:flex;align-items:center;justify-content:center;flex-shrink:0}.remove-file-btn-small:hover{background:#c53030}.batch-icon{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:flex;align-items:center;justify-content:center;flex-direction:column;font-size:40px;padding:20px}.page{margin:auto;padding:10px;display:flex;flex-direction:column;gap:20px;background-color:#f0f2ef;min-height:100vh;overflow-x:hidden}.main-content{max-width:1200px;margin:0 auto;width:100%;padding:0 10px}.card{background:#fff;padding:24px;border-radius:15px;box-shadow:0 2px 8px #00000014}.bottom-actions{text-align:center;padding:20px 0}.footer-link{color:#06c;text-decoration:none;font-size:14px;font-weight:500}.footer-link:hover{text-decoration:underline}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.modal{background:#fff;padding:24px;border-radius:12px;max-width:500px;width:100%;box-shadow:0 4px 20px #00000026}.modal h3{margin:0 0 20px;font-size:20px;color:#333}.modal label{display:block;margin:12px 0 6px;font-weight:600;color:#333;font-size:14px}.modal .input{width:100%;padding:10px 12px;border:1px solid #ddd;border-radius:8px;font-size:14px;box-sizing:border-box}.modal .input:focus{outline:none;border-color:#06c}.modal-buttons{display:flex;gap:12px;margin-top:20px}.modal-buttons .button{flex:1;padding:10px 16px;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s}.button-confirm{background:#06c;color:#fff}.button-confirm:hover{background:#0052a3}.button-cancel{background:#e0e0e0;color:#333}.button-cancel:hover{background:#d0d0d0}.form-error{background:#ffe8e8;color:#c62828;padding:10px;border-radius:8px;margin:10px 0;font-size:14px}.backend-status-banner{position:fixed;top:0;left:0;right:0;background:linear-gradient(135deg,#f093fb,#f5576c);color:#fff;padding:16px 20px;box-shadow:0 4px 12px #00000026;z-index:9999;animation:slideDown .3s ease-out}@keyframes slideDown{0%{transform:translateY(-100%);opacity:0}to{transform:translateY(0);opacity:1}}.backend-status-content{max-width:1200px;margin:0 auto;display:flex;align-items:center;gap:16px}.backend-status-icon{font-size:28px;animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.backend-status-text{flex:1;display:flex;flex-direction:column;gap:4px}.backend-status-text strong{font-size:16px;font-weight:600}.backend-status-subtext{font-size:13px;opacity:.9}.backend-status-retry{background:#fff3;border:1px solid rgba(255,255,255,.4);color:#fff;padding:8px 16px;border-radius:6px;cursor:pointer;font-weight:600;font-size:14px;transition:all .2s ease}.backend-status-retry:hover{background:#ffffff4d;transform:translateY(-1px)}.backend-status-retry:active{transform:translateY(0)}@media(max-width:600px){.backend-status-content{flex-direction:column;text-align:center;gap:12px}.backend-status-text{align-items:center}}.login-page{display:flex;align-items:center;justify-content:center;min-height:100vh;background:linear-gradient(135deg,#f38375,#f0f2ef);padding:20px}.login-container{width:100%;max-width:400px}.login-card{background:#fff;border-radius:15px;box-shadow:0 10px 40px #0003;padding:40px}.login-card h1{margin:0 0 8px;font-size:28px;color:#213547;text-align:center}.login-subtitle{margin:0 0 30px;font-size:14px;color:#666;text-align:center}.login-form{display:flex;flex-direction:column;gap:16px}.form-group{display:flex;flex-direction:column;gap:6px}.form-group label{font-weight:600;color:#333;font-size:14px}.login-input{padding:12px;border:1px solid #d0d0d0;border-radius:8px;font-size:15px;transition:border-color .2s,box-shadow .2s}.login-input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.login-error{color:#b00020;background:#b000200f;padding:10px 12px;border-radius:8px;font-size:13px;margin-top:4px}.login-button{padding:12px;background:linear-gradient(135deg,#ef6351,#f38375);color:#fff;font-size:16px;font-weight:600;border:none;border-radius:8px;cursor:pointer;transition:transform .2s,box-shadow .2s;margin-top:8px}.login-button:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0331ff66}.login-button:active{transform:translateY(0)}.login-toggle{margin:20px 0 0;text-align:center;font-size:14px;color:#666}.toggle-button{background:none;border:none;color:#548c2f;cursor:pointer;font-weight:600;text-decoration:none;transition:color .2s;padding:0;font-size:14px}.toggle-button:hover{color:#104911}.file-detail-container{padding:2rem;max-width:1200px;margin:0 auto;min-height:100vh;background:#f0f2ef}.file-detail-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.back-link{color:#ef6351;text-decoration:none;font-weight:600;font-size:16px;transition:color .2s,transform .2s;display:inline-block}.back-link:hover{color:#ad3a2b;transform:translate(-2px)}.private-badge{background:#b00020;color:#fff;padding:6px 12px;border-radius:20px;font-size:14px;font-weight:600}.file-detail-card{background:#fff;border-radius:15px;box-shadow:0 2px 8px #00000014;overflow:hidden;display:grid;grid-template-columns:1fr 1.3fr;gap:0;min-height:500px}.file-detail-preview{background:#f8f9fa;padding:2rem;display:flex;flex-direction:column;align-items:center;justify-content:center;border-right:1px solid #e9ecef;min-height:500px}.file-detail-preview img{max-width:100%;max-height:500px;object-fit:contain;border-radius:10px;box-shadow:0 2px 8px #0000001a;margin-bottom:1rem}.file-icon-large{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem}.file-icon-large .icon{font-size:6rem;margin-bottom:1rem;color:#999}.file-icon-large .extension{font-size:1.5rem;font-weight:600;color:#495057;background:#e9ecef;padding:.5rem 1.5rem;border-radius:8px}.preview-filename{font-size:1rem;font-weight:500;color:#212529;margin-bottom:.5rem;text-align:center;word-break:break-word;max-width:100%}.preview-filesize{font-size:.875rem;color:#6c757d;margin-bottom:1.5rem}.btn-download-preview{background:#667eea;color:#fff;padding:.75rem 1.5rem;border-radius:8px;text-decoration:none;font-weight:600;transition:all .2s;box-shadow:0 2px 4px #0000001a;display:inline-flex;align-items:center;gap:8px}.btn-download-preview:hover{background:#5568d3;transform:translateY(-2px);box-shadow:0 4px 8px #667eea66}.file-detail-info{padding:2rem;display:flex;flex-direction:column;gap:1.5rem;flex:1;min-height:0}.file-actions-detail{margin-top:auto}.batch-header-compact{display:flex;align-items:center;gap:1rem;padding-bottom:1.5rem;border-bottom:2px solid #e9ecef}.batch-icon-compact{font-size:3rem;width:70px;height:70px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:12px;flex-shrink:0}.file-title{font-size:1.75rem;margin:0;color:#213547}.batch-description{margin:.5rem 0 0;color:#666;font-size:.95rem}.file-metadata{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.metadata-item{display:flex;flex-direction:column;gap:.25rem}.metadata-item .label{font-size:.875rem;color:#666;font-weight:600}.metadata-item .value{font-size:1rem;color:#213547;font-weight:500}.expiration-warning{grid-column:1 / -1;background:#f59e0b1a;padding:12px;border-radius:8px}.expiration-warning .label{color:#f59e0b}.expires-value{color:#f59e0b;font-weight:600}.batch-files-section-compact{border-top:2px solid #e9ecef;padding-top:1.5rem}.batch-files-section-compact h3{font-size:1.1rem;margin:0 0 1rem;color:#213547;font-weight:600;display:flex;align-items:center;gap:8px}.batch-files-section-compact h3:before{content:"📂";font-size:1.2rem}.batch-files-list-compact{max-height:350px;overflow-y:auto;display:flex;flex-direction:column;gap:.5rem;padding-right:.5rem}.batch-files-list-compact::-webkit-scrollbar{width:8px}.batch-files-list-compact::-webkit-scrollbar-track{background:#f1f1f1;border-radius:4px}.batch-files-list-compact::-webkit-scrollbar-thumb{background:#888;border-radius:4px}.batch-files-list-compact::-webkit-scrollbar-thumb:hover{background:#555}.batch-file-item-compact{display:flex;align-items:center;gap:.75rem;padding:.75rem;background:#f8f9fa;border:2px solid transparent;border-radius:8px;cursor:pointer;transition:all .2s}.batch-file-item-compact:hover{background:#e9ecef;border-color:#dee2e6;transform:translate(2px)}.batch-file-item-compact.active{background:#667eea14;border-color:#667eea;box-shadow:0 2px 4px #667eea33}.file-icon-compact{font-size:1.5rem;flex-shrink:0}.file-info-compact{flex:1;display:flex;flex-direction:column;gap:.25rem;min-width:0}.file-name-compact{font-size:.9rem;font-weight:500;color:#213547;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.file-size-compact{font-size:.8rem;color:#666}.file-actions-detail{display:flex;flex-direction:column;gap:.75rem;padding-top:1.5rem;border-top:2px solid #e9ecef}.btn-copy-link,.btn-delete-large,.btn-download-large{padding:.75rem 1.5rem;border:none;border-radius:10px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s;text-align:center;display:flex;align-items:center;justify-content:center;gap:8px}.btn-download-large{background:#667eea;color:#fff;text-decoration:none}.btn-download-large:hover{background:#5568d3;transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.btn-copy-link{background:#48bb78;color:#fff}.btn-copy-link:hover{background:#38a169;transform:translateY(-2px);box-shadow:0 4px 12px #48bb7866}.btn-delete-large{background:#b00020;color:#fff}.btn-delete-large:hover{background:#8b0019;transform:translateY(-2px);box-shadow:0 4px 12px #b0002066}.copy-status-message{padding:10px 16px;border-radius:8px;font-size:14px;text-align:center;font-weight:500;background:#c6f6d5;color:#22543d;border:1px solid #9ae6b4;animation:fadeIn .3s ease-in}.status-message{padding:12px 16px;border-radius:8px;font-size:14px;text-align:center;font-weight:500}.status-message.success{background:#c6f6d5;color:#22543d;border:1px solid #9ae6b4}.status-message.error{background:#b000200f;color:#b00020;border:1px solid rgba(176,0,32,.2)}.file-description-section{background:#f8f9fa;padding:20px;border-radius:10px;border-left:4px solid #F38375}.file-description-section h3{margin:0 0 10px;font-size:16px;color:#f38375;font-weight:600}.file-description-section p{margin:0;font-size:16px;color:#444;line-height:1.6;white-space:pre-wrap}.loading,.error-message{text-align:center;padding:60px 20px;color:#666}.error-message h2{color:#b00020;margin-bottom:20px}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.modal{background:#fff;padding:2rem;border-radius:12px;max-width:400px;box-shadow:0 8px 16px #0003}.modal p{margin:0 0 1.5rem;font-size:1.1rem;color:#212529}.modal-buttons{display:flex;gap:1rem;justify-content:flex-end}.button{padding:.75rem 1.5rem;border:none;border-radius:8px;font-size:1rem;font-weight:500;cursor:pointer;transition:all .2s}.button-confirm{background:#b00020;color:#fff}.button-confirm:hover{background:#8b0019}.button-cancel{background:#6c757d;color:#fff}.button-cancel:hover{background:#5a6268}@keyframes fadeIn{0%{opacity:0;transform:translateY(-5px)}to{opacity:1;transform:translateY(0)}}.pdf-preview-container{width:100%;display:flex;flex-direction:column;align-items:center;gap:1.5rem}.btn-open-pdf{background:#dc3545;color:#fff;padding:.75rem 1.5rem;border-radius:8px;text-decoration:none;font-weight:600;font-size:1rem;transition:all .2s;box-shadow:0 2px 4px #0000001a;display:inline-flex;align-items:center;gap:8px}.btn-open-pdf:hover{background:#c82333;transform:translateY(-2px);box-shadow:0 4px 8px #dc354566}.media-preview{width:100%;display:flex;flex-direction:column;align-items:center;gap:1.5rem}.audio-player{width:100%;max-width:500px;margin-top:1rem}.video-player{width:100%;max-width:100%;max-height:500px;border-radius:10px;box-shadow:0 2px 8px #0000001a}.text-preview-container{width:100%;display:flex;flex-direction:column;align-items:center;gap:1rem;max-height:600px;overflow:hidden}.loading-text{font-size:.9rem;color:#666;font-style:italic}.text-preview-content{width:100%;max-height:400px;overflow:auto;background:#f8f9fa;border:1px solid #dee2e6;border-radius:8px;padding:1rem;font-family:Monaco,Menlo,Ubuntu Mono,Consolas,source-code-pro,monospace;font-size:.85rem;line-height:1.5;color:#212529;white-space:pre-wrap;word-wrap:break-word}.text-preview-content::-webkit-scrollbar{width:8px;height:8px}.text-preview-content::-webkit-scrollbar-track{background:#e9ecef;border-radius:4px}.text-preview-content::-webkit-scrollbar-thumb{background:#888;border-radius:4px}.text-preview-content::-webkit-scrollbar-thumb:hover{background:#555}.preview-truncated{margin-top:1rem;padding:.5rem 1rem;background:#fff3cd;color:#856404;border-radius:4px;font-style:italic;text-align:center}@media(max-width:992px){.file-detail-card{grid-template-columns:1fr}.file-detail-preview{border-right:none;border-bottom:1px solid #e9ecef;min-height:300px}.file-metadata{grid-template-columns:1fr}.file-detail-info{padding:1.5rem}.file-title{font-size:1.5rem}.video-player,.text-preview-content{max-height:300px}}.file-click-area{flex:1;display:flex;align-items:center;gap:.75rem;cursor:pointer}.btn-download-tiny{background:#667eea;color:#fff;padding:.4rem .6rem;border-radius:6px;text-decoration:none;font-size:.9rem;transition:all .2s;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0}.btn-download-tiny:hover{background:#5568d3;transform:scale(1.1)}.btn-download-all{background:#667eea;color:#fff;padding:.75rem 1.5rem;border:none;border-radius:10px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s;text-align:center;display:flex;align-items:center;justify-content:center;gap:8px}.btn-download-all:hover{background:#5568d3;transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.file-card{background:#fff;border-radius:14px;box-shadow:0 2px 10px #00000012;display:flex;flex-direction:column;align-items:stretch;padding:12px 12px 10px;margin:6px;min-width:250px;max-width:250px;width:250px;transition:box-shadow .18s,transform .18s,border .18s;position:relative;cursor:pointer;flex:0 1 250px}.file-card.clickable:hover{box-shadow:0 6px 24px #007bff29;transform:translateY(-1px) scale(1.015);border:1.5px solid #007bff33}.file-preview{display:flex;justify-content:center;align-items:center;margin-bottom:8px;min-height:180px;height:180px;width:100%;background:#f4f8ff;border-radius:8px;overflow:hidden}.file-image{width:100%;height:100%;object-fit:cover;border-radius:0;box-shadow:none;display:block}.file-icon{font-size:2.2em;color:#007bff}.batch-badge{position:absolute;top:8px;left:8px;background:#007bff;color:#fff;font-size:.85em;font-weight:700;padding:3px 10px;border-radius:8px;z-index:2;box-shadow:0 2px 8px #007bff1a}.file-info{margin-bottom:6px}.file-title{font-size:1em;font-weight:600;margin-bottom:2px;color:#222;text-overflow:ellipsis;overflow:hidden;white-space:nowrap}.file-meta{display:flex;flex-wrap:wrap;gap:6px;font-size:.92em;color:#555;margin-bottom:3px}.file-desc{font-size:.95em;color:#444;margin-bottom:3px;word-break:break-word}.file-actions{display:flex;gap:8px;justify-content:flex-end}.download-btn,.remove-btn{background:#f8f9fa;border:none;border-radius:5px;padding:5px 12px;font-size:.98em;cursor:pointer;transition:background .18s,color .18s;flex:1 1 0;min-width:0}.download-btn:hover{background:#007bff;color:#fff}.remove-btn{background:#ffeaea;color:#d00}.remove-btn:hover{background:#d00;color:#fff}@media(max-width:600px){.file-card{min-width:90vw;max-width:98vw;margin:10px auto}.file-preview{min-height:140px;height:140px}}.file-grid{display:flex;flex-wrap:wrap;gap:18px;margin-top:12px;margin-bottom:12px;align-items:flex-start}.gallery-section{padding:10px 0 0}.gallery-header{display:flex;flex-direction:column;align-items:flex-start;margin-bottom:10px}.view-controls{display:flex;gap:10px;margin-top:8px}.view-btn{background:#f8f9fa;border:1.5px solid #007bff33;border-radius:6px;padding:7px 16px;font-size:1em;cursor:pointer;color:#007bff;transition:background .2s,color .2s,border .2s}.view-btn.active,.view-btn:hover{background:#007bff;color:#fff;border:1.5px solid #007bff}.admin-card{max-width:1200px}.users-list{margin-top:20px;display:flex;flex-direction:column;gap:16px}.user-item{border:1px solid #e0e0e0;border-radius:12px;overflow:hidden;background:#fff;transition:box-shadow .2s ease}.user-item:hover{box-shadow:0 2px 8px #0000001a}.user-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;cursor:pointer;-webkit-user-select:none;user-select:none;background:#fafafa;transition:background .2s ease}.user-header:hover{background:#f5f5f5}.user-info{display:flex;align-items:center;gap:12px}.user-info h3{margin:0;font-size:18px;font-weight:600;color:#333}.user-id{font-size:12px;color:#999;background:#e8e8e8;padding:4px 8px;border-radius:6px}.admin-badge{font-size:12px;color:#fff;background:#9c27b0;padding:4px 8px;border-radius:6px;font-weight:600}.user-stats-summary{display:flex;gap:8px;flex-wrap:wrap}.stat-badge{padding:6px 12px;border-radius:8px;font-size:13px;font-weight:500;background:#e8f4f8;color:#06c}.stat-badge.expense{background:#ffe8e8;color:#c62828}.stat-badge.income{background:#e8f8e8;color:#2e7d32}.stat-badge.storage{background:#e8f0ff;color:#1565c0}.stat-badge.warning{background:#fff3cd;color:#856404}.expand-icon{font-size:14px;color:#999;transition:transform .2s ease}.user-details{padding:20px;background:#fff;border-top:1px solid #e0e0e0;animation:slideDown .2s ease}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.user-actions{display:flex;gap:12px;margin-bottom:20px;flex-wrap:wrap}.button-reset{background:#06c}.button-reset:hover{background:#0052a3}.button-storage{background:#1976d2}.button-storage:hover{background:#1565c0}.button-delete{background:#d32f2f}.button-delete:hover:not(:disabled){background:#b71c1c}.button-delete:disabled{background:#ccc;cursor:not-allowed;opacity:.6}.button-grant-admin{background:#9c27b0}.button-grant-admin:hover{background:#7b1fa2}.button-revoke-admin{background:#ff9800}.button-revoke-admin:hover{background:#f57c00}.user-details h4{margin:0 0 12px;font-size:16px;font-weight:600;color:#333}.no-data{color:#999;font-style:italic;margin:0}.storage-details{margin-top:20px;padding:16px;background:#f9f9f9;border-radius:8px}.storage-info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:12px;margin-top:12px}.storage-info-item{display:flex;justify-content:space-between;padding:8px 12px;background:#fff;border-radius:6px;border:1px solid #e0e0e0}.storage-info-item .label{color:#666;font-size:14px}.storage-info-item .value{color:#333;font-weight:600;font-size:14px}.storage-bar{width:100%;height:8px;background:#e0e0e0;border-radius:4px;overflow:hidden;margin-top:16px}.storage-bar-fill{height:100%;background:#4caf50;transition:width .3s ease,background .3s ease}.storage-bar-fill.warning{background:#ff9800}.transactions-table-wrapper{overflow-x:auto;border-radius:8px;border:1px solid #e0e0e0}.transactions-table{width:100%;border-collapse:collapse;font-size:14px}.transactions-table thead{background:#f5f5f5}.transactions-table th{text-align:left;padding:10px 12px;font-weight:600;color:#666;border-bottom:2px solid #e0e0e0}.transactions-table td{padding:10px 12px;border-bottom:1px solid #f0f0f0;color:#333}.transactions-table td:nth-child(3){max-width:200px;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;line-height:1.4;word-break:break-word}.transactions-table tbody tr:last-child td{border-bottom:none}.transactions-table tbody tr.income-row{background:#f1f8f4}.transactions-table tbody tr:hover{background:#fafafa}.transactions-table tbody tr.income-row:hover{background:#e8f4ed}.type-badge{padding:4px 8px;border-radius:6px;font-size:12px;font-weight:500;text-transform:capitalize}.type-badge.expense{background:#ffe8e8;color:#c62828}.type-badge.income{background:#e8f8e8;color:#2e7d32}.form-success{background:#e8f8e8;color:#2e7d32;padding:10px;border-radius:8px;margin:10px 0;font-weight:500}@media(max-width:768px){.user-header{flex-direction:column;align-items:flex-start;gap:12px}.user-stats-summary{width:100%}.expand-icon{position:absolute;top:16px;right:20px}.user-actions{flex-direction:column}.user-actions button{width:100%}.storage-info-grid{grid-template-columns:1fr}.transactions-table{font-size:12px}.transactions-table th,.transactions-table td{padding:8px}}
