.modal-overlay{align-items:center;background-color:#00000080;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:1000}.modal-content{background:#fff;border-radius:12px;box-shadow:0 10px 40px #0003;max-height:90vh;max-width:700px;overflow-y:auto;width:100%}.signature-modal{max-width:800px}.modal-header{align-items:center;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;padding:20px 24px}.modal-header h2{color:#111827;font-size:24px;margin:0}.modal-close{background:none;border:none;color:#6b7280;cursor:pointer;font-size:24px;line-height:1;padding:4px 8px;transition:color .2s}.modal-close:hover{color:#111827}.modal-body{padding:24px}.modal-footer{border-top:1px solid #e5e7eb;display:flex;gap:12px;justify-content:flex-end;padding:16px 24px}.signature-warning{background:#fef3c7;border-left:4px solid #f59e0b;border-radius:4px;color:#92400e;font-weight:500;margin-bottom:24px;padding:16px}.signature-current{background:#f9fafb;border-radius:8px;margin-bottom:24px;padding:16px}.signature-current-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:12px}.signature-current p{color:#374151;margin:0}.btn-danger{background:#dc2626;border:none;border-radius:6px;color:#fff;cursor:pointer;font-weight:500;padding:10px 20px;transition:background .2s}.btn-danger:hover:not(:disabled){background:#b91c1c}.btn-danger:disabled{background:#fca5a5;cursor:not-allowed}.delete-confirm-overlay{align-items:center;background:#0009;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1100}.delete-confirm-box{background:#fff;border-radius:12px;box-shadow:0 20px 60px #0000004d;max-width:400px;padding:24px}.delete-confirm-box h3{color:#dc2626;font-size:20px;margin:0 0 12px}.delete-confirm-box p{color:#374151;line-height:1.5;margin:0 0 20px}.delete-confirm-actions{display:flex;gap:12px;justify-content:flex-end}.signature-tabs{border-bottom:2px solid #e5e7eb;display:flex;gap:8px;margin-bottom:24px}.signature-tabs button{background:none;border:none;border-bottom:3px solid #0000;color:#6b7280;cursor:pointer;flex:1 1;font-weight:500;margin-bottom:-2px;padding:12px 24px;transition:all .2s}.signature-tabs button:hover:not(:disabled){background:#f9fafb;color:#111827}.signature-tabs button.active{border-bottom-color:#2563eb;color:#2563eb}.signature-tabs button:disabled{cursor:not-allowed;opacity:.5}.signature-content{margin-top:24px}.signature-canvas-container{display:flex;flex-direction:column;gap:16px}.signature-canvas-wrapper{align-items:center;background:#f9fafb;border:2px dashed #d1d5db;border-radius:8px;display:flex;flex-direction:column;padding:16px;position:relative}.signature-canvas{background:#fff;border:1px solid #e5e7eb;border-radius:4px;cursor:crosshair;max-width:100%}.signature-canvas-hint{color:#6b7280;font-size:14px;margin-top:12px}.signature-canvas-actions{display:flex;gap:12px;justify-content:flex-end}.signature-upload-container{display:flex;flex-direction:column;gap:16px}.signature-upload-area{background:#f9fafb;border:2px dashed #d1d5db;border-radius:8px;cursor:pointer;padding:40px 24px;text-align:center;transition:all .2s}.signature-upload-area:hover{background:#eff6ff;border-color:#2563eb}.signature-upload-area.dragging{background:#dbeafe;border-color:#2563eb}.signature-upload-input{display:none}.signature-upload-label{cursor:pointer;display:block}.upload-icon{font-size:48px;margin-bottom:12px}.upload-text{color:#374151;font-size:16px;font-weight:500;margin:0 0 8px}.upload-hint{color:#6b7280;font-size:14px;margin:0}.signature-preview-container{align-items:center;display:flex;flex-direction:column;gap:16px}.signature-preview{background:#fff;border:2px solid #e5e7eb;border-radius:8px;display:flex;justify-content:center;max-width:100%;padding:16px}.signature-preview img{max-height:200px;max-width:100%;object-fit:contain}.signature-upload-tips{background:#eff6ff;border-left:4px solid #2563eb;border-radius:4px;padding:16px}.signature-upload-tips h4{color:#1e40af;font-size:14px;margin:0 0 8px}.signature-upload-tips ul{color:#1e40af;margin:0;padding-left:20px}.signature-upload-tips li{font-size:14px;margin:4px 0}.signature-upload-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:8px}.missing-signatures-modal{max-width:600px}.warning-message{background:#fef3c7;border-left:4px solid #f59e0b;border-radius:4px;color:#92400e;margin-bottom:20px;padding:12px}.missing-list{display:flex;flex-direction:column;gap:12px;margin:20px 0}.missing-item{align-items:center;background:#f9fafb;border-left:3px solid #dc2626;border-radius:8px;display:flex;gap:12px;padding:12px}.user-icon{flex-shrink:0;font-size:32px}.user-info{display:flex;flex:1 1;flex-direction:column;gap:4px}.user-info strong{color:#111827;font-size:16px}.user-role{color:#6b7280;font-size:14px}.user-email{color:#9ca3af;font-size:13px;font-style:italic}.info-box{background:#eff6ff;border-left:4px solid #2563eb;border-radius:4px;margin-top:20px;padding:16px}.info-box p{color:#1e40af;margin:0 0 8px}.info-box ul{color:#1e40af;margin:8px 0 0 20px;padding:0}.info-box li{font-size:14px;margin:4px 0}.signature-error{border:1px solid #fca5a5;border-radius:6px;font-size:14px;margin-top:12px}.signature-error,.signature-error-message{background:#fee2e2;color:#991b1b;padding:12px}.signature-error-message{border-left:4px solid #dc2626;border-radius:4px;margin-top:16px}.signature-loading{color:#2563eb;font-weight:500;padding:16px;text-align:center}.btn-primary{background:#2563eb;border:none;border-radius:6px;color:#fff;cursor:pointer;font-weight:500;padding:10px 20px;transition:background .2s}.btn-primary:hover:not(:disabled){background:#1d4ed8}.btn-primary:disabled{background:#93c5fd;cursor:not-allowed}.btn-secondary{background:#fff;border:1px solid #d1d5db;border-radius:6px;color:#374151;cursor:pointer;font-weight:500;padding:10px 20px;transition:all .2s}.btn-secondary:hover{background:#f9fafb;border-color:#9ca3af}.btn-small{font-size:14px;padding:6px 12px}@media (max-width:768px){.modal-content{border-radius:0;margin:0;max-height:100vh;max-width:100%}.signature-canvas{max-width:100%;width:100%!important}.signature-tabs button{font-size:14px;padding:10px 16px}.signature-canvas-actions,.signature-upload-actions{flex-direction:column}.signature-canvas-actions button,.signature-upload-actions button{width:100%}}
/*# sourceMappingURL=main.07ce70db.css.map*/