body{margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}h1,h2,h3,h4,h5,h6{margin:0}button{font-family:inherit}.register-container{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;flex-direction:column;justify-content:center;min-height:100vh;padding:20px}.register-card{animation:slideUp .4s ease-out;background:#fff;border-radius:12px;box-shadow:0 20px 60px #0000004d;max-width:480px;padding:40px;width:100%}.register-header{margin-bottom:30px;text-align:center}.register-header .logo{color:#667eea;font-size:32px;font-weight:700;margin-bottom:10px}.register-header h2{color:#333;font-size:24px;font-weight:600;margin-bottom:8px}.register-header p{color:#666;font-size:14px;line-height:1.5}.register-form{margin-bottom:20px}.btn-secondary{background:#fff;border:2px solid #667eea;border-radius:6px;color:#667eea;cursor:pointer;font-size:14px;font-weight:500;padding:10px 16px;transition:all .2s ease}.btn-secondary:hover{background:#667eea;color:#fff}.recovery-key-modal{text-align:center}.recovery-key-icon{font-size:48px;margin-bottom:16px}.recovery-key-modal h3{color:#333;font-size:22px;font-weight:600;margin-bottom:12px}.warning-text{background:#fff3cd;border:1px solid #ffc107;border-radius:8px;color:#856404;font-size:14px;line-height:1.6;margin-bottom:20px;padding:16px;text-align:left}.recovery-key-display{background:#f8f9fa;border:2px solid #e0e0e0;border-radius:8px;margin-bottom:20px;padding:16px;word-break:break-all}.recovery-key-display code{color:#333;font-family:Courier New,monospace;font-size:14px;line-height:1.6}.recovery-key-actions{display:flex;gap:12px;margin-bottom:20px}.recovery-key-actions button{flex:1 1}.recovery-key-confirm{background:#e3f2fd;border:1px solid #2196f3;border-radius:8px;margin-bottom:20px;padding:16px}.checkbox-label{align-items:center;color:#333;cursor:pointer;display:flex;font-size:14px;gap:12px}.checkbox-label input[type=checkbox]{cursor:pointer;height:20px;width:20px}.security-info{max-width:480px}@media (max-width:600px){.register-card{padding:24px}.register-header .logo{font-size:28px}.register-header h2{font-size:20px}.recovery-key-actions{flex-direction:column}}.login-container{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;flex-direction:column;justify-content:center;min-height:100vh;padding:20px}.login-card{animation:slideUp .4s ease-out;background:#fff;border-radius:12px;box-shadow:0 20px 60px #0000004d;max-width:420px;padding:40px;width:100%}.login-header{margin-bottom:30px;text-align:center}.login-header .logo{color:#667eea;font-size:32px;font-weight:700;margin-bottom:10px}.login-header h2{color:#333;font-size:24px;font-weight:600;margin-bottom:8px}.login-header p{color:#666;font-size:14px}.error-message{animation:shake .3s ease;background:#fee;border:1px solid #fcc;border-radius:6px;color:#c33;font-size:14px;margin-bottom:20px;padding:12px}@keyframes shake{0%,to{transform:translateX(0)}25%{transform:translateX(-10px)}75%{transform:translateX(10px)}}.form-group,.login-form{margin-bottom:20px}.form-group label{color:#333;font-size:14px;margin-bottom:6px}.form-group input{border:2px solid #e0e0e0;border-radius:8px;font-family:inherit;font-size:15px;padding:12px 16px;transition:all .2s ease;width:100%}.form-group input:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.form-group input:disabled{background:#f5f5f5;cursor:not-allowed}.form-group input::placeholder{color:#999}.password-input-wrapper{position:relative}.password-input-wrapper input{padding-right:45px}.toggle-password{background:none;border:none;cursor:pointer;font-size:18px;opacity:.6;padding:4px;position:absolute;right:12px;top:50%;transform:translateY(-50%);transition:opacity .2s ease}.toggle-password:hover{opacity:1}.form-options{margin-bottom:20px;text-align:right}.link-small{color:#667eea;font-size:13px;text-decoration:none;transition:color .2s ease}.link-small:hover{color:#5568d3;text-decoration:underline}.btn-primary{align-items:center;border:none;border-radius:8px;cursor:pointer;display:flex;font-size:16px;font-weight:600;gap:8px;justify-content:center;padding:14px;transition:all .3s ease;width:100%}.spinner{animation:spin .6s linear infinite;border:2px solid #ffffff4d;border-top-color:#fff;height:16px;width:16px}.divider{margin:24px 0;position:relative;text-align:center}.divider:before{background:#e0e0e0;content:"";height:1px;left:0;position:absolute;top:50%;width:100%}.divider span{background:#fff;color:#999;font-size:13px;padding:0 12px;position:relative}.google-signin{margin-bottom:20px}.google-signin>div{display:flex!important;justify-content:center!important;width:100%!important}.google-signin button{border-radius:8px!important;box-shadow:0 2px 8px #0000001a!important;font-size:15px!important;font-weight:500!important;height:48px!important;transition:all .2s ease!important;width:100%!important}.google-signin button:hover{box-shadow:0 4px 12px #00000026!important;transform:translateY(-1px)!important}.form-footer{border-top:1px solid #e0e0e0;margin-top:20px;padding-top:20px;text-align:center}.form-footer p{color:#666;font-size:14px}.link{color:#667eea;font-weight:500;text-decoration:none;transition:color .2s ease}.link:hover{color:#5568d3;text-decoration:underline}.security-info{margin-top:20px;max-width:420px;text-align:center}.security-info p{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border-radius:8px;color:#ffffffe6;font-size:13px;line-height:1.6;padding:16px}@media (max-width:600px){.login-card{padding:24px}.login-header .logo{font-size:28px}.login-header h2{font-size:20px}}.verify-email-page{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;justify-content:center;min-height:100vh;padding:20px}.verify-email-container{max-width:500px;width:100%}.verify-email-card{animation:slideUp .4s ease-out;background:#fff;border-radius:16px;box-shadow:0 20px 60px #0000004d;overflow:hidden}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.verify-email-header{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:40px 30px;text-align:center}.verify-email-header h1{font-size:32px;font-weight:700;margin:0 0 10px}.verify-email-header h2{font-size:20px;font-weight:400;margin:0;opacity:.9}.verify-email-content{padding:40px 30px}.verify-status{animation:fadeIn .5s ease-out;text-align:center}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.verify-status.verifying .loading-spinner{animation:spin 1s linear infinite;border:4px solid #f3f3f3;border-radius:50%;border-top-color:#667eea;height:60px;margin:0 auto 20px;width:60px}.verify-status.verifying p{color:#666;font-size:16px}.verify-status.success .success-icon{align-items:center;animation:scaleIn .5s ease-out;background:#4caf50;border-radius:50%;color:#fff;display:flex;font-size:48px;height:80px;justify-content:center;margin:0 auto 20px;width:80px}@keyframes scaleIn{0%{transform:scale(0)}to{transform:scale(1)}}.verify-status.success h3{color:#4caf50;font-size:24px;margin:0 0 15px}.verify-status.success p{color:#666;font-size:16px;line-height:1.5;margin:0 0 20px}.redirect-message{color:#999!important;font-size:14px!important;margin:10px 0 20px!important}.verify-status.error .error-icon{align-items:center;animation:scaleIn .5s ease-out;background:#f44336;border-radius:50%;color:#fff;display:flex;font-size:48px;height:80px;justify-content:center;margin:0 auto 20px;width:80px}.verify-status.error h3{color:#f44336;font-size:24px;margin:0 0 15px}.verify-status.error p{color:#666;font-size:16px;line-height:1.5;margin:0 0 30px}.resend-section{background:#f9f9f9;border-radius:12px;margin:30px 0;padding:25px}.resend-text{color:#666;font-size:14px;margin:0 0 15px;text-align:center}.resend-form{display:flex;flex-direction:column;gap:12px}.resend-form input{border:2px solid #e0e0e0;border-radius:8px;font-size:16px;padding:14px;transition:all .3s ease}.resend-form input:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.resend-form input:disabled{background:#f5f5f5;cursor:not-allowed}.resend-message{border-radius:6px;font-size:14px;margin:10px 0 0;padding:10px;text-align:center}.resend-message.success{background:#e8f5e9;color:#2e7d32}.resend-message.error{background:#ffebee;color:#c62828}.btn-primary,.btn-secondary{border:none;border-radius:8px;cursor:pointer;display:inline-block;font-size:16px;font-weight:600;margin-top:10px;padding:14px 28px;text-align:center;text-decoration:none;transition:all .3s ease}.btn-primary{background:linear-gradient(135deg,#667eea,#764ba2)}.btn-primary:hover:not(:disabled){box-shadow:0 8px 20px #667eea66;transform:translateY(-2px)}.btn-primary:disabled{cursor:not-allowed;opacity:.6;transform:none}.btn-secondary{background:#f5f5f5;color:#333}.btn-secondary:hover{background:#e0e0e0}.verify-email-footer{background:#f9f9f9;border-top:1px solid #e0e0e0;padding:20px 30px;text-align:center}.verify-email-footer p{color:#666;font-size:14px;margin:0}.verify-email-footer a{color:#667eea;font-weight:600;text-decoration:none}.verify-email-footer a:hover{text-decoration:underline}@media (max-width:600px){.verify-email-page{padding:10px}.verify-email-header{padding:30px 20px}.verify-email-header h1{font-size:28px}.verify-email-header h2{font-size:18px}.verify-email-content{padding:30px 20px}.verify-status.error .error-icon,.verify-status.success .success-icon{font-size:36px;height:60px;width:60px}.verify-status.error h3,.verify-status.success h3{font-size:20px}.resend-section{padding:20px}}.document-card{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;display:flex;flex-direction:column;gap:15px;padding:20px;position:relative;transition:all .3s}.document-card:hover{box-shadow:0 4px 16px #00000026;transform:translateY(-2px)}.document-icon{font-size:48px;padding:10px 0;text-align:center}.document-info{flex:1 1}.document-title{color:#333;font-size:18px;font-weight:600;margin:0 0 8px;word-break:break-word}.document-meta{align-items:center;display:flex;flex-wrap:wrap;gap:8px;margin-bottom:8px}.doc-type{color:#666;font-size:13px}.separator{color:#ccc}.file-size{color:#999;font-size:13px}.document-description{color:#666;font-size:14px;line-height:1.5;margin:8px 0}.document-footer{align-items:center;display:flex;flex-wrap:wrap;gap:10px;justify-content:space-between;margin-top:10px}.upload-date{color:#999;font-size:12px}.category-badge{background:#e3f2fd;border-radius:12px;color:#1976d2;font-size:12px;padding:4px 10px}.document-menu-container{position:absolute;right:15px;top:15px}.btn-menu{align-items:center;background:#0000000d;border:none;border-radius:50%;cursor:pointer;display:flex;font-size:20px;height:32px;justify-content:center;transition:all .2s;width:32px}.btn-menu:hover{background:#0000001a}.document-dropdown-menu{background:#fff;border-radius:8px;box-shadow:0 4px 12px #00000026;min-width:180px;overflow:hidden;position:absolute;right:0;top:40px;z-index:1000}.menu-item{align-items:center;background:#fff;border:none;color:#333;cursor:pointer;display:flex;font-size:14px;gap:12px;padding:12px 16px;text-align:left;transition:background .2s;width:100%}.menu-item:hover{background:#f5f5f5}.menu-item.danger{color:#d32f2f}.menu-item.danger:hover{background:#ffebee}.menu-icon{align-items:center;display:flex;font-size:16px;justify-content:center;width:20px}.menu-divider{background:#e0e0e0;height:1px;margin:4px 0}.document-actions{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px}.btn-action{border:none;border-radius:6px;cursor:pointer;flex:1 1;font-size:13px;font-weight:500;min-width:80px;padding:8px 12px;transition:all .2s}.btn-view{background:#e3f2fd;color:#1976d2}.btn-view:hover{background:#bbdefb}.btn-download{background:#f3e5f5;color:#7b1fa2}.btn-download:hover{background:#e1bee7}.btn-delete{background:#ffebee;color:#d32f2f}.btn-delete:hover{background:#ffcdd2}.small-modal{max-width:500px}.folder-list{display:flex;flex-direction:column;gap:8px;margin-top:15px;max-height:300px;overflow-y:auto}.folder-option{align-items:center;background:#fff;border:2px solid #e0e0e0;border-radius:8px;cursor:pointer;display:flex;gap:12px;padding:12px;text-align:left;transition:all .2s}.folder-option:hover:not(:disabled){background:#f0f8ff;border-color:#2196f3}.folder-option:disabled{cursor:not-allowed;opacity:.5}.current-badge{background:#4caf50;border-radius:10px;color:#fff;font-size:11px;margin-left:auto;padding:3px 8px}@media (max-width:768px){.document-actions{flex-direction:column}.btn-action{width:100%}}.document-viewer-overlay{align-items:center;background:#000c;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:1000}.document-viewer{background:#fff;border-radius:12px;box-shadow:0 10px 40px #0000004d;display:flex;flex-direction:column;max-height:90vh;max-width:1200px;width:90%}.viewer-header{align-items:center;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;padding:20px 24px}.viewer-title h2{color:#1f2937;font-size:20px;font-weight:600;margin:0}.viewer-meta{color:#6b7280;font-size:14px;margin:4px 0 0}.viewer-actions{display:flex;gap:8px}.btn-icon{background:#f3f4f6;border-radius:8px;font-size:18px;height:40px;transition:all .2s;width:40px}.btn-icon:hover{background:#e5e7eb;transform:scale(1.05)}.btn-close{background:#0000;color:#6b7280;font-size:24px;transition:color .2s}.btn-close:hover{color:#ef4444}.viewer-content{align-items:center;display:flex;flex:1 1;justify-content:center;overflow:auto;padding:24px}.preview-loading{padding:40px;text-align:center}.spinner{animation:spin 1s linear infinite;border:4px solid #f3f4f6;border-top-color:#3b82f6;margin:0 auto 16px}.preview-loading p{color:#6b7280;font-size:14px}.preview-error{padding:40px;text-align:center}.preview-error p{color:#ef4444;margin-bottom:20px}.preview-image,.preview-pdf,.preview-text,.preview-video{align-items:center;display:flex;justify-content:center;width:100%}.preview-image img{border-radius:8px;box-shadow:0 4px 12px #0000001a}.preview-unsupported{max-width:500px;padding:60px 40px;text-align:center}.unsupported-icon{font-size:64px;margin-bottom:20px}.preview-unsupported h3{color:#1f2937;font-size:20px;margin:0 0 8px}.preview-unsupported p{color:#6b7280;margin:0 0 20px}.file-info{background:#f9fafb;border-radius:8px;font-size:14px;line-height:1.6;margin:20px 0;padding:16px}.btn-download{background:#3b82f6;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:15px;font-weight:500;padding:12px 24px;transition:all .2s}.btn-download:hover{background:#2563eb;box-shadow:0 4px 12px #3b82f64d;transform:translateY(-1px)}@media (max-width:768px){.document-viewer{max-height:95vh;width:95%}.viewer-header{padding:16px}.viewer-title h2{font-size:18px}.viewer-meta{font-size:12px}.viewer-content{padding:16px}.preview-unsupported{padding:40px 20px}}.modal-overlay{align-items:center;background-color:#00000080;bottom:0;display:flex;justify-content:center;left:0;padding:var(--spacing-lg);position:fixed;right:0;top:0;z-index:1000}.modal-content{background-color:var(--bg-primary);border-radius:var(--border-radius-lg);box-shadow:var(--shadow-lg);max-height:90vh;max-width:600px;overflow-y:auto;width:100%}.modal-header{align-items:center;border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;padding:var(--spacing-lg) var(--spacing-xl)}.modal-header h2{color:var(--text-primary);font-size:24px}.btn-close{align-items:center;background:none;border:none;border-radius:50%;color:var(--text-secondary);cursor:pointer;display:flex;font-size:32px;height:40px;justify-content:center;transition:all .2s ease;width:40px}.btn-close:hover{background-color:var(--bg-tertiary);color:var(--text-primary)}.file-drop-zone,.modal-content form{padding:var(--spacing-xl)}.file-drop-zone{background-color:var(--bg-secondary);border:3px dashed var(--border-color);border-radius:var(--border-radius-lg);margin-bottom:var(--spacing-lg);text-align:center;transition:all .2s ease}.file-drop-zone.active{background-color:#2563eb0d;border-color:var(--primary-color)}.file-prompt{align-items:center;display:flex;flex-direction:column;gap:var(--spacing-sm)}.upload-icon{font-size:48px;opacity:.5}.file-prompt p{color:var(--text-secondary);margin:0}.or-text{color:var(--text-muted);font-size:14px;margin:var(--spacing-sm) 0}.btn-select-file{background-color:var(--primary-color);border-radius:var(--border-radius);color:#fff;cursor:pointer;font-weight:600;padding:10px 24px;transition:all .2s ease}.btn-select-file:hover{background-color:var(--primary-hover)}.file-hint{color:var(--text-muted);font-size:13px}.file-selected{align-items:center;background-color:var(--bg-primary);border-radius:var(--border-radius);display:flex;gap:var(--spacing-md);padding:var(--spacing-md)}.file-icon{font-size:32px}.file-info{flex:1 1;text-align:left}.file-name{color:var(--text-primary);font-weight:600;margin-bottom:4px}.file-size{font-size:14px}.btn-remove,.file-size{color:var(--text-secondary)}.btn-remove{align-items:center;background:none;border:none;border-radius:50%;cursor:pointer;display:flex;font-size:24px;height:32px;justify-content:center;transition:all .2s ease;width:32px}.btn-remove:hover{background-color:var(--danger-color);color:#fff}.upload-progress{margin:var(--spacing-lg) 0}.progress-bar{background-color:var(--bg-tertiary);border-radius:4px;height:8px;margin-bottom:var(--spacing-sm);overflow:hidden}.progress-fill{background:linear-gradient(90deg,var(--primary-color),var(--success-color));height:100%;transition:width .3s ease}.progress-text{color:var(--text-secondary);font-size:14px;font-weight:500;text-align:center}.modal-actions{border-top:1px solid var(--border-color);display:flex;gap:var(--spacing-md);margin-top:var(--spacing-xl);padding-top:var(--spacing-lg)}.modal-actions button{flex:1 1}@media (max-width:768px){.modal-content{max-height:95vh}.file-drop-zone,.modal-content form{padding:var(--spacing-lg)}}.upload-context{background:#e3f2fd;border-left:4px solid #2196f3;border-radius:8px;margin-bottom:15px;padding:12px 15px}.upload-context small{color:#666;display:block;font-size:11px;letter-spacing:.5px;margin-bottom:5px;text-transform:uppercase}.context-path{color:#1976d2;font-size:14px;font-weight:500}.folder-tree{background:#f8f9fa;border-right:1px solid #e0e0e0;height:100%;overflow-y:auto;padding:10px 0}.folder-loading{color:#666;padding:20px;text-align:center}.folder-item{margin:2px 0;position:relative}.folder-header{align-items:center;border-radius:4px;cursor:pointer;display:flex;gap:8px;margin:2px 5px;padding:8px 10px;position:relative;transition:background-color .2s}.folder-header:hover{background-color:#e3f2fd}.folder-header.selected{background-color:#2196f3;color:#fff}.folder-header.root{background-color:#fff;border-bottom:2px solid #e0e0e0;font-weight:600;margin-bottom:10px}.folder-header.root:hover{background-color:#f0f0f0}.folder-header.root.selected{background-color:#2196f3;color:#fff}.folder-toggle{align-items:center;background:none;border:none;color:inherit;cursor:pointer;display:flex;font-size:10px;height:16px;justify-content:center;padding:0;width:16px}.folder-toggle:hover{opacity:.7}.folder-icon{flex-shrink:0;font-size:18px}.folder-name{flex:1 1;font-size:14px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.folder-count{color:#666;font-size:12px;margin-left:auto}.folder-header.selected .folder-count{color:#fffc}.folder-menu-btn{background:none;border:none;border-radius:4px;color:#666;cursor:pointer;font-size:16px;opacity:0;padding:4px 6px;transition:opacity .2s}.folder-header:hover .folder-menu-btn{opacity:1}.folder-menu-btn:hover{background:#0000001a}.folder-header.selected .folder-menu-btn{color:#fff;opacity:1}.folder-context-menu{background:#fff;border-radius:8px;box-shadow:0 4px 12px #00000026;min-width:150px;overflow:hidden}.context-menu-item{align-items:center;background:#fff;border:none;color:#333;cursor:pointer;display:flex;font-size:14px;gap:10px;padding:10px 14px;text-align:left;transition:background .2s;width:100%}.context-menu-item:hover{background:#f5f5f5}.context-menu-item.danger{color:#d32f2f}.context-menu-item.danger:hover{background:#ffebee}.context-menu-divider{background:#e0e0e0;height:1px;margin:4px 0}.folder-children{margin-left:0}.btn-create-folder{background:#4caf50;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:14px;font-weight:500;margin:10px;padding:10px;transition:background-color .2s;width:calc(100% - 20px)}.btn-create-folder:hover{background:#45a049}.btn-create-folder:active{transform:scale(.98)}.create-folder-modal{max-width:90vw;width:500px}.parent-folder-info{background:#f0f8ff;border-left:3px solid #2196f3;border-radius:4px;margin-bottom:15px;padding:10px}.parent-folder-info small{color:#666;display:block;font-size:12px;margin-bottom:5px}.parent-folder-name{color:#2196f3;font-weight:500}.icon-picker{grid-gap:8px;display:grid;gap:8px;grid-template-columns:repeat(auto-fill,minmax(45px,1fr));margin-top:8px}.icon-option{align-items:center;background:#f5f5f5;border:2px solid #0000;border-radius:8px;cursor:pointer;display:flex;font-size:24px;justify-content:center;padding:10px;transition:all .2s}.icon-option:hover{background:#e8e8e8;transform:scale(1.05)}.icon-option.selected{background:#e3f2fd;border-color:#2196f3;transform:scale(1.1)}.icon-option:disabled{cursor:not-allowed;opacity:.5}.color-picker{display:flex;flex-wrap:wrap;gap:10px;margin-top:8px}.color-option{border:3px solid #0000;border-radius:50%;box-shadow:0 2px 4px #0000001a;cursor:pointer;height:40px;transition:all .2s;width:40px}.color-option:hover{box-shadow:0 4px 8px #0003;transform:scale(1.1)}.color-option.selected{border-color:#000;box-shadow:0 4px 12px #0000004d;transform:scale(1.15)}.color-option:disabled{cursor:not-allowed;opacity:.5}.folder-preview{align-items:center;background:#f8f9fa;border:2px dashed #ccc;border-radius:8px;display:flex;gap:10px;padding:15px}.preview-icon{font-size:32px}.preview-name{color:#333;font-size:16px;font-weight:500}.form-hint{color:#666;font-size:12px;font-style:italic;margin-top:5px}.notification-bell-container{cursor:pointer;margin-right:20px;position:relative}.notification-bell{align-items:center;background-color:initial;border-radius:50%;display:flex;height:40px;justify-content:center;position:relative;transition:all .3s ease;width:40px}.notification-bell:hover{background-color:#0000000d}.notification-bell.active{background-color:#4a90e21a}.bell-icon{color:#333;height:22px;transition:transform .3s ease;width:22px}.notification-bell:hover .bell-icon{animation:ring .5s ease;transform:rotate(15deg)}@keyframes ring{0%,to{transform:rotate(0deg)}25%{transform:rotate(15deg)}50%{transform:rotate(-15deg)}75%{transform:rotate(10deg)}}.notification-badge{animation:pulse 2s infinite;background-color:#ff4757;border-radius:10px;box-shadow:0 2px 4px #0003;color:#fff;font-size:10px;font-weight:700;line-height:1.2;min-width:18px;padding:2px 5px;position:absolute;right:2px;text-align:center;top:2px}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.9;transform:scale(1.1)}}.notification-panel{animation:slideDown .3s ease;background-color:#fff;border-radius:12px;box-shadow:0 8px 32px #00000026;display:flex;flex-direction:column;max-height:600px;overflow:hidden;position:absolute;right:0;top:50px;width:400px;z-index:1000}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.notification-panel-header{align-items:center;background-color:#f9fafb;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;padding:20px}.notification-panel-header h3{color:#1f2937;font-size:18px;font-weight:600;margin:0}.notification-panel-actions{display:flex;gap:10px}.btn-text{background:none;border:none;border-radius:4px;color:#4a90e2;cursor:pointer;font-size:13px;font-weight:500;padding:4px 8px;transition:all .2s ease}.btn-text:hover{background-color:#4a90e21a;color:#3b7bc4}.notification-panel-content{flex:1 1;max-height:500px;overflow-y:auto}.notification-loading{align-items:center;color:#6b7280;display:flex;flex-direction:column;justify-content:center;padding:60px 20px}.spinner{animation:spin .8s linear infinite;border:3px solid #e5e7eb;border-radius:50%;border-top-color:#4a90e2;height:40px;margin-bottom:16px;width:40px}.notification-loading p{font-size:14px;margin:0}.notification-empty{align-items:center;display:flex;flex-direction:column;justify-content:center;padding:60px 20px;text-align:center}.empty-icon{color:#d1d5db;height:64px;margin-bottom:16px;width:64px}.notification-empty p{color:#1f2937;font-size:16px;font-weight:600;margin:0}.notification-empty span{color:#6b7280;font-size:14px;margin-top:8px}.notification-list{display:flex;flex-direction:column}.notification-item{border-bottom:1px solid #e5e7eb;cursor:pointer;display:flex;gap:12px;padding:16px 20px;position:relative;transition:all .2s ease}.notification-item:hover{background-color:#f9fafb}.notification-item:last-child{border-bottom:none}.notification-item.unread{background-color:#eff6ff}.notification-item.unread:hover{background-color:#dbeafe}.unread-indicator{background-color:#4a90e2;border-radius:50%;height:6px;left:8px;position:absolute;top:50%;transform:translateY(-50%);width:6px}.notification-item.priority-critical .notification-icon{color:#ef4444}.notification-item.priority-high .notification-icon{color:#f59e0b}.notification-item.priority-medium .notification-icon{color:#3b82f6}.notification-item.priority-low .notification-icon{color:#6b7280}.notification-icon{align-items:center;background-color:#4a90e21a;border-radius:50%;display:flex;flex-shrink:0;height:40px;justify-content:center;width:40px}.notification-icon svg{height:20px;width:20px}.notification-content{flex:1 1;min-width:0}.notification-header{align-items:flex-start;display:flex;gap:8px;justify-content:space-between;margin-bottom:4px}.notification-title{color:#1f2937;font-size:14px;font-weight:600;line-height:1.4;margin:0}.notification-time{color:#6b7280;flex-shrink:0;font-size:12px;white-space:nowrap}.notification-body{color:#4b5563;font-size:13px;line-height:1.5;margin:0}.notification-reference{align-items:center;background-color:#4a90e20d;border-radius:6px;color:#4a90e2;display:flex;font-size:12px;gap:6px;margin-top:8px;padding:6px 10px}.notification-reference svg{height:14px;width:14px}.notification-actions{display:flex;flex-shrink:0;gap:4px;opacity:0;transition:opacity .2s ease}.notification-item:hover .notification-actions{opacity:1}.btn-icon{align-items:center;background-color:initial;border:none;border-radius:6px;color:#6b7280;cursor:pointer;display:flex;height:32px;justify-content:center;transition:all .2s ease;width:32px}.btn-icon:hover{background-color:#0000000d;color:#1f2937}.btn-icon.btn-delete:hover{background-color:#ef44441a;color:#ef4444}.btn-icon svg{height:16px;width:16px}.notification-panel-footer{background-color:#f9fafb;border-top:1px solid #e5e7eb;padding:12px 20px}.btn-view-all{background-color:#fff;border:1px solid #d1d5db;border-radius:8px;color:#4a90e2;cursor:pointer;font-size:14px;font-weight:500;padding:10px;transition:all .2s ease;width:100%}.btn-view-all:hover{background-color:#f3f4f6;border-color:#4a90e2}@media (max-width:480px){.notification-panel{max-height:80vh;right:16px;width:calc(100vw - 32px)}.notification-panel-header{padding:16px}.notification-panel-header h3{font-size:16px}.notification-item{padding:12px 16px}.notification-title{font-size:13px}.notification-body{font-size:12px}}.notification-panel-content::-webkit-scrollbar{width:6px}.notification-panel-content::-webkit-scrollbar-track{background:#f1f1f1}.notification-panel-content::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:3px}.notification-panel-content::-webkit-scrollbar-thumb:hover{background:#a8a8a8}.dashboard{background-color:#f5f5f5;display:flex;flex-direction:column;height:100vh}.dashboard-main{display:flex;flex:1 1;overflow:hidden}.dashboard-sidebar{background:#fff;border-right:1px solid #e0e0e0;flex-shrink:0;overflow-y:auto;width:280px}.dashboard-content{flex:1 1;overflow-y:auto;padding:20px}.breadcrumb{align-items:center;color:#666;display:flex;font-size:14px;gap:8px;margin-bottom:10px}.breadcrumb-item{color:#666}.breadcrumb-item.clickable{color:#2196f3;cursor:pointer}.breadcrumb-item.clickable:hover{text-decoration:underline}.breadcrumb-item.active{color:#333;font-weight:500}.breadcrumb-separator{color:#999}.navbar{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);box-shadow:0 2px 4px #0000001a;color:#fff;display:flex;justify-content:space-between;padding:15px 30px}.navbar-brand h1{font-size:24px;font-weight:600;margin:0}.navbar-actions{align-items:center;display:flex;gap:20px}.storage-indicator{display:flex;flex-direction:column;gap:4px}.storage-indicator small{font-size:12px;opacity:.9}.storage-bar{background:#ffffff4d;border-radius:3px;height:6px;overflow:hidden;width:150px}.storage-fill{background:#4caf50;height:100%;transition:width .3s ease}.user-badge{background:#fff3;border-radius:12px;font-size:12px;font-weight:600;padding:6px 12px}.btn-logout{background:#fff3;border:1px solid #ffffff4d;border-radius:6px;color:#fff;cursor:pointer;font-weight:500;padding:8px 16px;transition:all .2s}.btn-logout:hover{background:#ffffff4d}.error-banner{background:#fff3cd;border:1px solid #ffc107;border-radius:6px;color:#856404;margin-bottom:15px;padding:12px}.dashboard-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:20px}.header-left{flex:1 1}.header-left h2{color:#333;font-size:28px;margin:10px 0}.search-box{margin-top:10px}.search-box input{border:1px solid #ddd;border-radius:8px;font-size:14px;max-width:400px;padding:10px 15px;width:100%}.btn-upload{background:#2196f3;border:none;border-radius:8px;box-shadow:0 2px 4px #0000001a;color:#fff;cursor:pointer;font-size:14px;font-weight:600;padding:12px 24px;transition:all .2s}.btn-upload:hover{background:#1976d2;box-shadow:0 4px 8px #00000026;transform:translateY(-1px)}.categories-filter{display:flex;gap:10px;margin-bottom:20px;overflow-x:auto;padding-bottom:10px}.categories-filter button{background:#fff;border:2px solid #e0e0e0;border-radius:20px;cursor:pointer;font-size:14px;padding:10px 20px;transition:all .2s;white-space:nowrap}.categories-filter button:hover{background:#e3f2fd;border-color:#2196f3}.categories-filter button.active{background:#2196f3;border-color:#2196f3;color:#fff}.warning-banner{background:#fff3cd;border:1px solid #ffc107;border-radius:8px;color:#856404;margin-bottom:20px;padding:15px}.warning-banner code{background:#0000001a;border-radius:3px;font-family:monospace;padding:2px 6px}.documents-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));margin-top:20px}.empty-state{background:#fff;border:2px dashed #e0e0e0;border-radius:12px;grid-column:1/-1;padding:60px 20px;text-align:center}.empty-icon{font-size:64px;margin-bottom:20px;opacity:.5}.empty-state h3{color:#666;margin-bottom:10px}.empty-state p{color:#999;margin-bottom:20px}.loading-container{background:#f5f5f5;height:100vh}.loading-spinner{border:4px solid #f3f3f3;border-top-color:#2196f3;height:50px;width:50px}.loading-container p{color:#666;margin-top:20px}@media (max-width:768px){.dashboard-main{flex-direction:column}.dashboard-sidebar{border-bottom:1px solid #e0e0e0;border-right:none;max-height:200px;width:100%}.dashboard-header{flex-direction:column;gap:15px}.documents-grid{grid-template-columns:1fr}.categories-filter{flex-wrap:wrap}}*{box-sizing:border-box;margin:0;padding:0}:root{--primary-color:#2563eb;--primary-hover:#1d4ed8;--secondary-color:#64748b;--danger-color:#dc2626;--danger-hover:#b91c1c;--success-color:#16a34a;--warning-color:#ea580c;--bg-primary:#fff;--bg-secondary:#f8fafc;--bg-tertiary:#f1f5f9;--text-primary:#0f172a;--text-secondary:#475569;--text-muted:#94a3b8;--border-color:#e2e8f0;--border-radius:8px;--border-radius-lg:12px;--shadow-sm:0 1px 2px 0 #0000000d;--shadow:0 1px 3px 0 #0000001a,0 1px 2px -1px #0000001a;--shadow-md:0 4px 6px -1px #0000001a,0 2px 4px -2px #0000001a;--shadow-lg:0 10px 15px -3px #0000001a,0 4px 6px -4px #0000001a;--spacing-xs:4px;--spacing-sm:8px;--spacing-md:16px;--spacing-lg:24px;--spacing-xl:32px;--spacing-2xl:48px;--font-family:-apple-system,BlinkMacSystemFont,"Segoe UI","Roboto","Oxygen","Ubuntu","Cantarell","Fira Sans","Droid Sans","Helvetica Neue",sans-serif;--font-mono:"SF Mono","Monaco","Inconsolata","Fira Code","Droid Sans Mono","Source Code Pro",monospace}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f8fafc;background-color:var(--bg-secondary);color:#0f172a;color:var(--text-primary);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;font-family:var(--font-family);font-size:16px;line-height:1.5}code{background-color:#f1f5f9;background-color:var(--bg-tertiary);border-radius:4px;font-family:SF Mono,Monaco,Inconsolata,Fira Code,Droid Sans Mono,Source Code Pro,monospace;font-family:var(--font-mono);font-size:.875em;padding:2px 6px}.app,.loading-container{display:flex;flex-direction:column;min-height:100vh}.loading-container{align-items:center;gap:24px;gap:var(--spacing-lg);justify-content:center}.loading-spinner{animation:spin 1s linear infinite;border:4px solid #e2e8f0;border-top-color:#2563eb;border:4px solid var(--border-color);border-radius:50%;border-top-color:var(--primary-color);height:48px;width:48px}@keyframes spin{to{transform:rotate(1turn)}}.btn-danger,.btn-primary,.btn-secondary{align-items:center;border:none;border-radius:8px;border-radius:var(--border-radius);cursor:pointer;display:inline-flex;font-size:16px;font-weight:600;gap:8px;gap:var(--spacing-sm);padding:12px 24px;transition:all .2s ease}.btn-primary{background-color:#2563eb;background-color:var(--primary-color);color:#fff}.btn-primary:hover:not(:disabled){background-color:#1d4ed8;background-color:var(--primary-hover);box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -2px #0000001a;box-shadow:var(--shadow-md);transform:translateY(-1px)}.btn-secondary{background-color:#f1f5f9;background-color:var(--bg-tertiary);color:#0f172a;color:var(--text-primary)}.btn-secondary:hover:not(:disabled){background-color:#e2e8f0;background-color:var(--border-color)}.btn-danger{background-color:#dc2626;background-color:var(--danger-color);color:#fff}.btn-danger:hover:not(:disabled){background-color:#b91c1c;background-color:var(--danger-hover)}button:disabled{cursor:not-allowed;opacity:.6}.form-group{margin-bottom:24px;margin-bottom:var(--spacing-lg)}.form-group label{color:#0f172a;color:var(--text-primary);display:block;font-weight:500;margin-bottom:8px;margin-bottom:var(--spacing-sm)}.form-group input,.form-group select,.form-group textarea{border:2px solid #e2e8f0;border:2px solid var(--border-color);border-radius:8px;border-radius:var(--border-radius);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;font-family:var(--font-family);font-size:16px;padding:12px 16px;transition:border-color .2s ease;width:100%}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:#2563eb;border-color:var(--primary-color);outline:none}.form-group textarea{min-height:80px;resize:vertical}.form-hint{color:#94a3b8;color:var(--text-muted);display:block;font-size:14px;margin-top:4px;margin-top:var(--spacing-xs)}.form-group-inline{align-items:center;display:flex;gap:8px;gap:var(--spacing-sm);margin-bottom:16px;margin-bottom:var(--spacing-md)}.form-group-inline input[type=checkbox]{cursor:pointer;height:18px;width:18px}.form-group-inline label{cursor:pointer;margin:0}.error-message,.success-message,.warning-message{border-radius:8px;border-radius:var(--border-radius);font-weight:500;margin-bottom:24px;margin-bottom:var(--spacing-lg);padding:12px 16px}.error-message{background-color:#fee2e2;border:1px solid #fecaca;color:#991b1b}.success-message{background-color:#d1fae5;border:1px solid #a7f3d0;color:#065f46}.warning-message{background-color:#ffedd5;border:1px solid #fed7aa;color:#9a3412}.error-banner,.warning-banner{border-radius:8px;border-radius:var(--border-radius);margin-bottom:24px;margin-bottom:var(--spacing-lg);padding:16px;padding:var(--spacing-md)}.error-banner{background-color:#fee2e2;color:#991b1b}.warning-banner{background-color:#ffedd5;color:#9a3412}@media (max-width:768px){body{font-size:14px}.btn-danger,.btn-primary,.btn-secondary{font-size:14px;padding:10px 20px}}
/*# sourceMappingURL=main.adbd77c9.css.map*/