body,html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#1e293b;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;height:100%;margin:0;padding:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.activity-preview-enter{animation:slideIn .3s ease-out}.notification-badge{align-items:center;animation:pulse 2s infinite;background:#2b3540;border-radius:50%;box-shadow:0 2px 8px #2b354066;color:#fff;display:flex;font-size:12px;font-weight:700;height:24px;justify-content:center;min-width:24px;position:relative;transition:all .2s ease;width:24px}.notification-badge:hover{box-shadow:0 4px 16px #2b354099;transform:scale(1.1)}.notification-panel{max-height:80vh;max-width:400px;overflow-y:auto;position:fixed;right:20px;top:20px;z-index:1000}.notification-item{animation:slideIn .2s ease-out;background:#fff;border:1px solid #e2e8f0;border-radius:12px;margin-bottom:12px;opacity:1;padding:16px;transform:translateX(0);transition:all .6s cubic-bezier(.4,0,.2,1)}.notification-item.fade-out{animation:fadeOut 1s cubic-bezier(.4,0,.2,1) forwards}@keyframes slideIn{0%{opacity:0;transform:translateX(100%)}to{opacity:1;transform:translateX(0)}}@keyframes fadeOut{0%{opacity:1;transform:translateX(0)}to{opacity:0;transform:translateX(100%)}}.notification-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:8px}.notification-title{color:#1e293b;font-size:14px;font-weight:600}.notification-close{background:#0000;border:none;color:#64748b;cursor:pointer;font-size:18px;margin-left:8px;padding:0}.notification-close:hover{color:#475569}.notification-body{color:#475569;font-size:13px;margin-bottom:8px}.notification-footer{align-items:center;display:flex;justify-content:space-between}.notification-footer,.notification-timestamp{color:#94a3b8;font-size:11px}.notification-action{background:#2b3540;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:11px;font-weight:500;padding:4px 12px;transition:background-color .2s ease}.notification-action:hover{background:#1e293b}.dashboard-panel{position:relative}.dashboard-panel.has-notifications{border-left:4px solid #ef4444}.notification-count{position:absolute;right:16px;top:16px;z-index:10}.profile-modal-overlay{align-items:center;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:1000}.profile-modal-content{background:#fff;border-radius:16px;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;max-height:90vh;max-width:500px;overflow-y:auto;width:100%}.profile-modal-header{align-items:center;border-bottom:1px solid #e2e8f0;display:flex;justify-content:space-between;margin-bottom:24px;padding:24px 24px 0}.profile-modal-header h2{color:#1e293b;font-size:20px;font-weight:600;margin:0}.close-button{transition:all .2s ease}.close-button:hover{background:#f1f5f9;color:#475569}.profile-modal-body{padding:0 24px 24px}.profile-picture-section{margin-bottom:32px;text-align:center}.profile-picture-container{display:inline-block;margin-bottom:16px;position:relative}.profile-picture{border:4px solid #e2e8f0;border-radius:50%;height:120px;object-fit:cover;transition:all .2s ease;width:120px}.profile-picture-container:hover .profile-picture{border-color:#3b82f6}.profile-picture-overlay{bottom:0;display:flex;gap:8px;left:50%;opacity:0;position:absolute;transform:translateX(-50%);transition:opacity .2s ease}.profile-picture-container:hover .profile-picture-overlay{opacity:1}.remove-btn,.upload-btn{border:none;border-radius:6px;cursor:pointer;font-size:12px;font-weight:500;padding:6px 12px;transition:all .2s ease;white-space:nowrap}.upload-btn{background:#3b82f6;color:#fff}.upload-btn:hover:not(:disabled){background:#2563eb}.remove-btn{background:#ef4444;color:#fff}.remove-btn:hover:not(:disabled){background:#dc2626}.remove-btn:disabled,.upload-btn:disabled{cursor:not-allowed;opacity:.6}.upload-hint{color:#64748b;font-size:14px;margin:0}.form-group{margin-bottom:20px}.form-group label{color:#374151;display:block;font-size:14px;font-weight:500;margin-bottom:8px}.form-input{border:2px solid #e2e8f0;border-radius:8px;box-sizing:border-box;font-size:14px;padding:12px 16px;transition:all .2s ease}.form-input:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.form-input.disabled{background:#f8fafc;color:#64748b;cursor:not-allowed}.field-hint{color:#6b7280;display:block;font-size:12px;font-style:italic;margin-top:6px}.error-message,.success-message{border-radius:8px;font-size:14px;font-weight:500;margin-bottom:20px;padding:12px 16px}.error-message{background:#fef2f2}.success-message{background:#f0fdf4;border:1px solid #bbf7d0;color:#16a34a}.profile-modal-actions{border-top:1px solid #e2e8f0;display:flex;gap:12px;justify-content:flex-end;margin-top:32px;padding-top:20px}.btn-primary,.btn-secondary{border:none;border-radius:8px;cursor:pointer;font-size:14px;font-weight:500;min-width:100px;padding:12px 24px;transition:all .2s ease}.btn-secondary{background:#fff;border:2px solid #e2e8f0}.btn-secondary:hover:not(:disabled){background:#f8fafc;border-color:#cbd5e1}.btn-secondary:disabled{cursor:not-allowed;opacity:.6}.loading-state{padding:40px 20px;text-align:center}.spinner{border:4px solid #e2e8f0;height:40px;margin:0 auto 16px;width:40px}.loading-state p{color:#64748b;font-size:14px;margin:0}@media (max-width:640px){.profile-modal-content{margin:20px;max-height:calc(100vh - 40px)}.profile-modal-body,.profile-modal-header{padding-left:20px;padding-right:20px}.profile-modal-actions{flex-direction:column}.btn-primary,.btn-secondary{width:100%}}.notification-settings{padding:0}.settings-section{margin-bottom:24px}.settings-info-banner{align-items:flex-start;background-color:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;color:#475569;display:flex;font-size:13px;gap:12px;line-height:1.5;margin-bottom:16px;padding:12px 16px}.settings-info-banner svg{color:#64748b;margin-top:2px}.settings-section h3{color:#1e293b;font-size:16px;font-weight:600;margin-bottom:16px}.setting-item{align-items:center;background:#f8fafc;border-radius:8px;display:flex;justify-content:space-between;margin-bottom:12px;padding:12px 16px;transition:background-color .2s ease}.setting-item:hover{background:#f1f5f9}.setting-info{flex:1 1;margin-right:16px}.setting-info label{color:#334155;display:block;font-size:14px;font-weight:500;margin-bottom:2px}.setting-info p{color:#64748b;font-size:13px;margin:0}.setting-control{align-items:center;display:flex;gap:8px}input[type=checkbox]{border:2px solid #cbd5e1;border-radius:4px;cursor:pointer;height:18px;transition:all .2s ease;width:18px}input[type=checkbox]:checked{background-color:#2b3540;border-color:#2b3540}.permission-button{background-color:#3b82f6;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:13px;font-weight:500;padding:6px 12px;transition:background-color .2s}.permission-button:hover{background-color:#2563eb}.status-text{color:#64748b;font-size:13px}.settings-actions{border-top:1px solid #e2e8f0;display:flex;justify-content:flex-end;margin-top:24px;padding-top:16px}.save-button{background-color:#2b3540;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:14px;font-weight:500;min-width:100px;padding:8px 20px;transition:all .2s ease}.save-button:hover:not(:disabled){background-color:#1e293b;transform:translateY(-1px)}.save-button:disabled{cursor:not-allowed;opacity:.6}.notification-settings-loading{color:#64748b;font-size:14px;padding:32px;text-align:center}:root{--g-arrow-color:#1f2937;--g-bar-color:#fff;--g-bar-border:#fff;--g-tick-color-thick:#ededed;--g-tick-color:#f3f3f3;--g-actions-background:#f3f3f3;--g-border-color:#ebeff2;--g-text-muted:#7c7c7c;--g-text-light:#fff;--g-text-dark:#171717;--g-progress-color:#dbdbdb;--g-handle-color:#37352f;--g-weekend-label-color:#dcdce4;--g-expected-progress:#c4c4e9;--g-header-background:#fff;--g-row-color:#fdfdfd;--g-row-border-color:#c7c7c7;--g-today-highlight:#37352f;--g-popup-actions:#ebeff2;--g-weekend-highlight-color:#f7f7f7}.gantt-container{border-radius:8px;font-size:12px;height:var(--gv-grid-height);line-height:14.5px;overflow:auto;position:relative;width:100%}.gantt-container .popup-wrapper{background:#fff;border-radius:5px;box-shadow:0 10px 24px -3px #0003;left:0;padding:10px;position:absolute;top:0;width:max-content;z-index:1000}.gantt-container .popup-wrapper .title{color:#171717;color:var(--g-text-dark);font-size:.85rem;font-weight:650;line-height:15px;margin-bottom:2px}.gantt-container .popup-wrapper .subtitle{color:#171717;color:var(--g-text-dark);font-size:.8rem;margin-bottom:5px}.gantt-container .popup-wrapper .details{color:#7c7c7c;color:var(--g-text-muted);font-size:.7rem}.gantt-container .popup-wrapper .actions{margin-left:3px;margin-top:10px}.gantt-container .popup-wrapper .action-btn{background-color:#ebeff2;background-color:var(--g-popup-actions);border:none;border-right:1px solid #fff;border-right:1px solid var(--g-text-light);padding:5px 8px}.gantt-container .popup-wrapper .action-btn:hover{background-color:brightness(97%)}.gantt-container .popup-wrapper .action-btn:first-child{border-bottom-left-radius:4px;border-top-left-radius:4px}.gantt-container .popup-wrapper .action-btn:last-child{border-bottom-right-radius:4px;border-right:none;border-top-right-radius:4px}.gantt-container .grid-header{background-color:#fff;background-color:var(--g-header-background);border-bottom:1px solid #c7c7c7;border-bottom:1px solid var(--g-row-border-color);height:calc(var(--gv-lower-header-height) + var(--gv-upper-header-height) + 10px);left:0;position:sticky;top:0;z-index:1000}.gantt-container .lower-text,.gantt-container .upper-text{text-anchor:middle}.gantt-container .upper-header{height:var(--gv-upper-header-height)}.gantt-container .lower-header{height:var(--gv-lower-header-height)}.gantt-container .lower-text{align-content:center;color:#7c7c7c;color:var(--g-text-muted);font-size:12px;height:calc(var(--gv-lower-header-height)*.8);margin:0 calc(var(--gv-column-width)*.1);position:absolute;text-align:center;width:calc(var(--gv-column-width)*.8)}.gantt-container .upper-text{color:#171717;color:var(--g-text-dark);font-size:14px;font-weight:500;height:calc(var(--gv-lower-header-height)*.66);position:absolute;width:fit-content}.gantt-container .current-upper{background:#fff;left:0!important;padding-left:17px;position:sticky}.gantt-container .side-header{background:#fff;background:var(--g-header-background);display:flex;float:right;font-weight:400;line-height:20px;margin-left:auto;padding-right:10px;padding-top:10px;position:sticky;right:0;top:0;width:max-content;z-index:1000}.gantt-container .side-header *{background-color:#f3f3f3;background-color:var(--g-actions-background);border:none;border-radius:.5rem;box-sizing:initial;color:#171717;color:var(--g-text-dark);font-size:14px;font-weight:420;letter-spacing:.02em;margin-right:5px;padding:5px 8px;text-align:-webkit-center;transition-duration:.15s;transition-property:background-color;transition-timing-function:cubic-bezier(.4,0,.2,1)}.gantt-container .side-header :last-child{margin-right:0}.gantt-container .side-header :hover{filter:brightness(97.5%)}.gantt-container .side-header select{padding-right:1.25rem;width:50px}.gantt-container .date-range-highlight{background-color:#dbdbdb;background-color:var(--g-progress-color);border-radius:12px;height:calc(var(--gv-lower-header-height) - 6px);position:absolute;top:calc(var(--gv-upper-header-height) + 5px)}.gantt-container .current-highlight{background:#37352f;background:var(--g-today-highlight);position:absolute;width:1px;z-index:999}.gantt-container .current-ball-highlight{background:#37352f;background:var(--g-today-highlight);border-radius:50%;position:absolute;z-index:1001}.gantt-container .current-date-highlight{background:#37352f;background:var(--g-today-highlight);border-radius:5px;color:#fff;color:var(--g-text-light)}.gantt-container .holiday-label{background:--g-weekend-label-color;border-radius:5px;left:0;opacity:0;padding:2px 5px;position:absolute;top:0;z-index:1000}.gantt-container .holiday-label.show{opacity:1}.gantt-container .extras{left:0;position:sticky}.gantt-container .extras .adjust{background-color:#000000b3;border:none;border-radius:3px;color:#fff;left:8px;padding:8px;position:absolute;top:calc(var(--gv-grid-height) - 60px)}.gantt-container .hide{display:none}.gantt{position:absolute;user-select:none;-webkit-user-select:none}.gantt .grid-background{fill:none}.gantt .grid-row{fill:#fdfdfd;fill:var(--g-row-color)}.gantt .row-line{stroke:#ebeff2;stroke:var(--g-border-color)}.gantt .tick{stroke:#f3f3f3;stroke:var(--g-tick-color);stroke-width:.4}.gantt .tick.thick{stroke:#ededed;stroke:var(--g-tick-color-thick);stroke-width:.7}.gantt .arrow{fill:none;stroke:#1f2937;stroke:var(--g-arrow-color);stroke-width:1.5}.gantt .bar-wrapper .bar{fill:#fff;fill:var(--g-bar-color);stroke:#fff;stroke:var(--g-bar-border);stroke-width:0;transition:stroke-width .3s ease}.gantt .bar-progress{fill:#dbdbdb;fill:var(--g-progress-color);border-radius:4px}.gantt .bar-expected-progress{fill:#c4c4e9;fill:var(--g-expected-progress)}.gantt .bar-invalid{fill:#0000;stroke:#fff;stroke:var(--g-bar-border);stroke-width:1;stroke-dasharray:5}:is(.gantt .bar-invalid)~.bar-label{fill:#fff;fill:var(--g-text-light)}.gantt .bar-label{fill:#171717;fill:var(--g-text-dark);dominant-baseline:central;font-family:Helvetica;font-size:13px;font-weight:400}.gantt .bar-label.big{fill:#171717;fill:var(--g-text-dark);text-anchor:start}.gantt .handle{fill:#37352f;fill:var(--g-handle-color);opacity:0;transition:opacity .3s ease}.gantt .handle.active,.gantt .handle.visible{cursor:ew-resize;opacity:1}.gantt .handle.progress{fill:#7c7c7c;fill:var(--g-text-muted)}.gantt .bar-wrapper{cursor:pointer}.gantt .bar-wrapper .bar{border-radius:3px;outline:1px solid #c7c7c7;outline:1px solid var(--g-row-border-color)}.gantt .bar-wrapper:hover .bar{transition:transform .3s ease}.gantt .bar-wrapper:hover .date-range-highlight{display:block}.pdf-viewer-modal{align-items:center;background:#000000bf;bottom:0;display:flex;justify-content:center;left:0;padding:1rem;position:fixed;right:0;top:0;z-index:1000}.pdf-viewer-content{background:#fff;border-radius:.75rem;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;display:flex;flex-direction:column;height:100%;max-height:95vh;max-width:95vw;overflow:hidden;width:100%}.pdf-viewer-header{align-items:flex-start;background:#f9fafb;border-bottom:1px solid #e5e7eb;display:flex;flex-shrink:0;justify-content:flex-start;padding:1.5rem}.pdf-viewer-title h2{color:#111827;font-size:1.5rem;font-weight:600;line-height:1.2;margin:0 0 .5rem}.pdf-viewer-title p{color:#6b7280;font-size:.875rem;margin:0}.pdf-viewer-body{background:#f8fafc;flex:1 1;overflow:hidden;position:relative}.pdf-loading{color:#6b7280;left:50%;position:absolute;text-align:center;top:50%;transform:translate(-50%,-50%)}.pdf-spinner{animation:spin 1s linear infinite;border:2px solid #e5e7eb;border-radius:50%;border-top-color:#3b82f6;height:2rem;margin:0 auto 1rem;width:2rem}.pdf-error{color:#ef4444;left:50%;max-width:300px;position:absolute;text-align:center;top:50%;transform:translate(-50%,-50%)}.pdf-fallback-btn{background:#3b82f6;border:none;border-radius:.375rem;color:#fff;cursor:pointer;font-size:.875rem;margin-top:1rem;padding:.5rem 1rem;transition:background-color .2s}.pdf-fallback-btn:hover{background:#2563eb}.pdf-iframe{background:#fff;border:none;height:100%;width:100%}.pdf-viewer-footer{align-items:center;background:#f9fafb;border-top:1px solid #e5e7eb;display:flex;flex-shrink:0;justify-content:space-between;padding:1rem 1.5rem}.pdf-external-btn{background:#3b82f6;border:none;border-radius:.375rem;color:#fff;cursor:pointer;font-size:.875rem;font-weight:500;padding:.5rem 1rem;transition:background-color .2s}.pdf-external-btn:hover{background:#2563eb}.pdf-close-btn{background:#6b7280;border:none;border-radius:.375rem;color:#fff;cursor:pointer;font-size:.875rem;font-weight:500;padding:.5rem 1rem;transition:background-color .2s}.pdf-close-btn:hover{background:#4b5563}@media (max-width:768px){.pdf-viewer-modal{padding:.5rem}.pdf-viewer-content{max-height:100vh;max-width:100vw}.pdf-viewer-header{padding:1rem}.pdf-viewer-title h2{font-size:1.25rem}.pdf-viewer-footer{flex-direction:column;gap:.5rem;padding:.75rem 1rem}.pdf-close-btn,.pdf-external-btn{width:100%}}@media (max-width:480px){.pdf-viewer-header{align-items:flex-start;flex-direction:column;gap:1rem}}.react-rnd{box-shadow:none!important;outline:none!important}.signing-setup-modal{align-items:center;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;overflow:visible;position:fixed;right:0;top:0;z-index:1000}.signing-setup-content{background:#fff;border-radius:12px;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;max-height:90vh;max-width:1200px;overflow:hidden;width:95%}.signing-setup-header{align-items:center;background:#f8fafc;border-bottom:1px solid #e2e8f0;display:flex;justify-content:space-between;padding:24px 32px}.header-content h2{color:#1e293b;font-size:20px;margin:0}.header-content p{color:#64748b;font-size:14px;margin:4px 0 0}.close-button{border-radius:4px;color:#64748b;font-size:24px;padding:4px}.close-button:hover{color:#1e293b}.signing-setup-body{display:flex;flex-direction:column;max-height:calc(90vh - 80px);overflow:hidden;padding:0}.signing-mode-selection{background:#f8fafc;border-bottom:1px solid #e2e8f0;overflow:visible;padding:20px 32px;position:relative;z-index:10001}.signing-mode-selection h3{color:#1e293b;font-size:16px;font-weight:600;margin:0 0 16px}.mode-options{display:flex;gap:16px}.mode-option{background:#fff;border:2px solid #e2e8f0;border-radius:8px;cursor:pointer;flex:1 1;padding:16px;transition:all .2s ease}.mode-option:hover{background:#f0f9ff;border-color:#3b82f6}.mode-option.selected{background:#eff6ff;border-color:#3b82f6}.mode-option input[type=radio]{display:none}.mode-content h4{color:#1e293b;font-size:14px;font-weight:600;margin:0 0 4px}.mode-content p{color:#64748b;font-size:12px;margin:0}.mode-header{align-items:center;display:flex;gap:8px;margin-bottom:4px}.mode-header h4{color:#1e293b;font-size:14px;font-weight:600;margin:0}.info-tooltip{display:inline-block;position:relative}.info-icon{align-items:center;background:#e2e8f0;border-radius:50%;color:#64748b;cursor:help;display:inline-flex;font-size:10px;font-weight:600;height:16px;justify-content:center;transition:all .2s ease;width:16px}.info-icon:hover{background:#3b82f6;color:#fff}.tooltip-content{background:#1e293b;border-radius:6px;box-shadow:0 4px 6px -1px #0000001a;color:#fff;font-size:11px;line-height:1.4;min-width:200px;opacity:0;padding:12px;top:125%;transition:all .2s ease;visibility:hidden;white-space:nowrap;white-space:normal;z-index:10000}.tooltip-content,.tooltip-content:after{left:50%;position:absolute;transform:translateX(-50%)}.tooltip-content:after{border:5px solid;border-color:#0000 #0000 #1e293b;bottom:100%;content:""}.info-tooltip:hover .tooltip-content{opacity:1;visibility:visible}.setup-layout{display:flex;flex:1 1;min-height:0}.pdf-panel{border-right:1px solid #e2e8f0;display:flex;flex:1 1;flex-direction:column}.pdf-header{background:#f8fafc;border-bottom:1px solid #e2e8f0;padding:16px 24px}.pdf-header h3{color:#1e293b;font-size:16px;font-weight:600;margin:0 0 4px}.pdf-header p{color:#64748b;font-size:14px;margin:0}.pdf-container{flex:1 1;overflow:auto;padding:24px}.pdf-viewer{background:#f8fafc;border:2px dashed #cbd5e1;border-radius:8px;cursor:crosshair;min-height:400px;padding:20px;position:relative;transition:border-color .2s}.pdf-viewer:hover{border-color:#3b82f6}.pdf-placeholder{align-items:center;background:#f8fafc;border:2px dashed #cbd5e1;border-radius:8px;color:#64748b;height:400px}.pdf-page-wrapper,.pdf-placeholder{display:flex;justify-content:center}.pdf-page-wrapper{margin-bottom:20px;overflow:visible;position:relative}.page-overlay{background:#0000;bottom:0;left:0;overflow:visible;position:absolute;right:0;top:0;transition:background-color .2s ease;z-index:10}.page-overlay:hover{background:#3b82f60d}.page-overlay:hover:before{border:1px dashed #3b82f64d;bottom:0;content:"";left:0;pointer-events:none;position:absolute;right:0;top:0}.pdf-scroll{flex-direction:column;overflow:visible}.pdf-controls,.pdf-scroll{align-items:center;display:flex}.pdf-controls{gap:8px;margin-top:8px}.zoom-btn{align-items:center;background:#f3f4f6;border:1px solid #d1d5db;border-radius:4px;color:#374151;cursor:pointer;display:flex;font-size:16px;font-weight:500;height:32px;justify-content:center;transition:all .2s;width:32px}.zoom-btn:hover{background:#e5e7eb;border-color:#9ca3af}.zoom-label{color:#6b7280;font-size:14px;min-width:50px;text-align:center}.zoom-reset{background:#3b82f6;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:12px;padding:6px 12px;transition:background-color .2s}.zoom-reset:hover{background:#2563eb}.placed-field-rnd{background:#3b82f61a;border:2px solid #3b82f6!important;border-radius:4px;box-sizing:border-box;cursor:move;overflow:hidden;position:relative;transition:all .2s ease;z-index:20}.placed-field-rnd>div{border:none!important;box-shadow:none!important;outline:none!important}.custom-resize-handle,.placed-field-rnd .react-resizable-handle{background:#0000;opacity:0;z-index:30}.signing-field-element .react-resizable-handle,.signing-field-element .react-resizable-handle-se,div[class*=react-resizable-handle]{background:#3b82f6!important;border:2px solid #fff!important;border-radius:50%!important;bottom:-8px!important;box-shadow:0 2px 6px #3b82f666!important;cursor:se-resize!important;height:16px!important;opacity:1!important;position:absolute!important;right:-8px!important;transition:all .2s ease!important;width:16px!important;z-index:100!important}.signing-field-element:hover .react-resizable-handle,.signing-field-element:hover .react-resizable-handle-se{opacity:1!important;transform:scale(1.1)!important}.signing-field-element .react-resizable-handle-se:active,.signing-field-element .react-resizable-handle:active{box-shadow:0 3px 8px #3b82f699!important;transform:scale(1.2)!important}.signing-field-element{outline:none!important;position:absolute!important;z-index:20}.signing-field-element:hover{z-index:25}.signing-field-element:hover .custom-resize-handle{opacity:1!important;transform:scale(1)}.custom-resize-handle:hover{box-shadow:0 3px 8px #3b82f699!important;transform:scale(1.1)!important}.custom-resize-handle:active{transform:scale(1.2)!important}.signing-field-element:focus{outline:none!important}.placed-field-rnd:hover{background:#3b82f633;border-color:#2563eb!important;box-shadow:0 4px 8px #3b82f64d}.placed-field-rnd:active{border-color:#1d4ed8!important;box-shadow:0 6px 12px #3b82f666;transform:scale(1.02)}.placed-field-content{align-items:center;background:#ffffffe6;border-radius:2px;box-sizing:border-box;color:#1e40af;display:flex;font-size:12px;font-weight:500;height:100%;justify-content:center;line-height:1.2;overflow:hidden;padding:2px 6px;text-align:center;text-overflow:ellipsis;white-space:nowrap;width:100%}.controls-panel{background:#f8fafc;overflow-y:auto;padding:24px;width:350px}.field-types-section,.fields-section,.recipients-section,.roles-section{margin-bottom:24px}.field-types-section h3,.fields-section h3,.recipients-section h3,.roles-section h3{color:#1e293b;font-size:16px;font-weight:600;margin:0 0 12px}.recipients-list{gap:8px}.roles-section{margin-bottom:24px}.roles-list{display:flex;flex-direction:column;gap:8px}.role-item{align-items:center;background:#fff;border:1px solid #e2e8f0;border-radius:8px;cursor:pointer;display:flex;gap:12px;padding:14px;transition:all .2s}.role-item:hover{background:#f8fafc;border-color:#cbd5e1}.role-item.selected{background:#eff6ff;border-color:#3b82f6;border-left:4px solid #3b82f6!important}.role-name{color:#1e293b;font-size:14px;font-weight:500}.role-count{background:#f1f5f9;border-radius:4px;color:#64748b;font-size:12px;padding:2px 6px}.recipient-item{align-items:center;background:#fff;border:1px solid #e2e8f0;border-radius:8px;cursor:pointer;display:flex;gap:12px;padding:14px;transition:all .2s}.recipient-item:hover{background:#f0f9ff;border-color:#3b82f6}.recipient-item.selected{background:#eff6ff;border-color:#3b82f6}.recipient-name{color:#1e293b;font-size:14px;font-weight:600;margin:0}.recipient-email,.recipient-phone{color:#64748b;font-size:12px;margin:0}.pm-badge{background:#fef3c7;border-radius:4px;color:#92400e;flex-shrink:0;font-size:10px;font-weight:500;padding:2px 6px;white-space:nowrap}.field-types-grid{grid-gap:8px;display:grid;gap:8px;grid-template-columns:1fr 1fr}.field-type-btn{align-items:center;background:#fff;border:1px solid #e2e8f0;border-radius:6px;cursor:pointer;display:flex;flex-direction:column;gap:4px;padding:12px;transition:all .2s}.field-type-btn:hover{background:#f0f9ff;border-color:#3b82f6}.field-type-btn.selected{background:#eff6ff;border-color:#3b82f6}.field-icon{font-size:20px}.field-label{color:#374151;font-size:12px;font-weight:500}.fields-list{display:flex;flex-direction:column;gap:8px;max-height:200px;overflow-y:auto}.field-item{background:#fff;border:1px solid #e2e8f0;border-radius:6px;justify-content:space-between;padding:8px 12px}.field-info,.field-item{align-items:center;display:flex;gap:8px}.field-info{flex:1 1}.field-name{color:#1e293b;font-size:14px;font-weight:500}.field-type{background:#f1f5f9;border-radius:4px;color:#64748b;font-size:12px;padding:2px 6px}.delete-field-btn{align-items:center;background:#fee2e2;border:none;border-radius:4px;color:#dc2626;cursor:pointer;display:flex;font-size:16px;font-weight:700;height:24px;justify-content:center;transition:background-color .2s;width:24px}.delete-field-btn:hover{background:#fecaca}.no-fields{background:#f8fafc;border:1px dashed #cbd5e1;border-radius:6px;color:#64748b;font-size:14px;padding:20px;text-align:center}.error-message{background:#fee2e2;border:1px solid #fecaca;border-radius:6px;color:#dc2626;font-size:14px;margin-bottom:24px;padding:12px}.modal-actions{background:#fff;border-top:1px solid #e2e8f0;flex-shrink:0;gap:12px;padding:20px 24px}.btn-secondary{border:1px solid #d1d5db;border-radius:6px;color:#64748b;flex:1 1;font-size:14px;font-weight:500;padding:10px 16px}.btn-secondary:hover{background:#f1f5f9;border-color:#94a3b8}.btn-primary{border-radius:6px;flex:1 1;font-size:14px;font-weight:500;padding:10px 16px}.btn-primary:hover:not(:disabled){background:#1e293b}.btn-primary:disabled{cursor:not-allowed;opacity:.6}@media (max-width:1024px){.setup-layout{flex-direction:column;height:auto}.pdf-panel{border-bottom:1px solid #e2e8f0;border-right:none}.controls-panel{max-height:400px;width:100%}.field-types-grid{grid-template-columns:repeat(3,1fr)}}@media (max-width:768px){.signing-setup-content{max-height:95vh;width:98%}.signing-setup-header{padding:16px 20px}.controls-panel,.pdf-container{padding:16px}.field-types-grid{grid-template-columns:1fr 1fr}}.signing-progress-modal{align-items:center;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.signing-progress-content{background:#fff;border-radius:.75rem;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;display:flex;flex-direction:column;max-height:90vh;max-width:800px;overflow:hidden;width:90%}.signing-progress-header{align-items:flex-start;background:#f9fafb;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;padding:1.5rem}.header-content h2{color:#111827;font-size:1.5rem;font-weight:600;margin:0 0 .5rem}.header-content p{color:#6b7280;font-size:.875rem;margin:0 0 .25rem}.header-content small{color:#9ca3af;font-size:.75rem}.close-button{background:none;border:none;border-radius:.25rem;color:#6b7280;cursor:pointer;font-size:1.5rem;padding:.25rem;transition:color .2s}.close-button:hover{color:#374151}.signing-progress-body{flex:1 1;overflow-y:auto;padding:1.5rem}.loading-state{align-items:center;color:#6b7280;display:flex;flex-direction:column;justify-content:center;padding:3rem}.spinner{animation:spin 1s linear infinite;border:2px solid #e5e7eb;border-radius:50%;border-top-color:#3b82f6;height:2rem;margin-bottom:1rem;width:2rem}.error-state{color:#ef4444;padding:2rem;text-align:center}.retry-btn{background:#ef4444;border:none;border-radius:.375rem;color:#fff;cursor:pointer;font-size:.875rem;margin-top:1rem;padding:.5rem 1rem}.retry-btn:hover{background:#dc2626}.overall-progress{background:#f8fafc;border:1px solid #e2e8f0;border-radius:.5rem;margin-bottom:2rem;padding:1.5rem}.progress-header{margin-bottom:1rem}.progress-header h3{color:#1e293b;font-size:1.125rem;font-weight:600;margin:0}.progress-text{font-size:.875rem;font-weight:500}.progress-bar{background:#e2e8f0;border-radius:.375rem;height:.75rem;margin-bottom:.5rem}.progress-fill{background:linear-gradient(90deg,#10b981,#059669)}.progress-percentage{color:#059669;font-size:.875rem;font-weight:600;text-align:center}.recipients-section h3{color:#1e293b;font-size:1.125rem;font-weight:600;margin:0 0 1rem}.recipients-list{display:flex;flex-direction:column;gap:1rem}.recipient-card{background:#fff;border:1px solid #e5e7eb;border-radius:.5rem;padding:1rem;transition:box-shadow .2s}.recipient-card:hover{box-shadow:0 4px 6px -1px #0000001a}.recipient-header{justify-content:space-between;margin-bottom:1rem}.recipient-header,.recipient-info{align-items:flex-start;display:flex}.recipient-info{flex:1 1;gap:.75rem}.recipient-avatar{background:#fff;border:3px solid #e2e8f0;border-radius:8px;box-shadow:0 2px 8px #00000014;flex-shrink:0;height:80px;object-fit:cover;transition:all .2s ease;width:80px}.recipient-avatar:hover{border-color:#2b3540;box-shadow:0 4px 16px #2b354026}.recipient-details{display:flex;flex-direction:column;gap:.25rem}.recipient-details strong{color:#111827;font-size:.875rem}.recipient-email,.recipient-phone{color:#6b7280;font-size:.75rem}.recipient-role{background:#d1fae5;border-radius:.25rem;color:#059669;display:inline-block;font-size:.75rem;font-weight:500;padding:.125rem .375rem}.recipient-status{flex-shrink:0}.status-badge{border-radius:.25rem;color:#fff;font-size:.75rem;font-weight:500;padding:.25rem .5rem}.recipient-timeline{border-top:1px solid #f3f4f6;display:flex;flex-direction:column;gap:.5rem;padding-top:.75rem}.timeline-item{align-items:center;display:flex;font-size:.75rem;justify-content:space-between}.timeline-item.completed{color:#059669}.timeline-item.declined{color:#dc2626}.timeline-label{color:#6b7280;font-weight:500}.timeline-value{color:#374151}.signing-progress-actions{background:#f9fafb;border-top:1px solid #e5e7eb;display:flex;gap:.75rem;justify-content:flex-end;padding:1.5rem}.refresh-btn{background:#3b82f6;border:none;border-radius:.375rem;color:#fff;cursor:pointer;font-size:.875rem;font-weight:500;padding:.5rem 1rem;transition:background-color .2s}.refresh-btn:hover{background:#2563eb}.close-btn{background:#6b7280;border:none;border-radius:.375rem;color:#fff;cursor:pointer;font-size:.875rem;font-weight:500;padding:.5rem 1rem;transition:background-color .2s}.close-btn:hover{background:#4b5563}@media (max-width:640px){.signing-progress-content{margin:1rem;width:95%}.recipient-header{flex-direction:column;gap:.75rem}.recipient-status{align-self:flex-start}.timeline-item{align-items:flex-start;flex-direction:column;gap:.25rem}}.document-landing{background-color:#f1f5f9;min-height:100vh;padding:40px}.document-header{align-items:flex-start;justify-content:space-between;margin-bottom:32px}.document-title{color:#1e293b;font-size:24px;font-weight:600;margin-bottom:24px}.project-info{color:#475569;font-size:16px;margin-bottom:16px}.upload-button{align-items:center;background:#2b3540;border:none;border-radius:.5rem;color:#fff;cursor:pointer;display:flex;font-size:.875rem;font-weight:500;gap:.5rem;padding:.75rem 1.5rem;transition:background-color .2s}.upload-button:hover{background:#1e293b}.upload-button.disabled{background:#cbd5e1;color:#64748b;cursor:not-allowed;opacity:.6}.upload-button.disabled:hover{background:#cbd5e1}.header-actions{display:flex;gap:.75rem}.closed-project-notice{background:#fef3c7;border:1px solid #f59e0b;border-radius:8px;margin-bottom:24px;padding:16px;text-align:center}.closed-project-text{color:#92400e;font-size:14px;font-weight:500;margin:0}.documents-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));margin-bottom:2rem}.document-card{background:#fff;border:1px solid #e2e8f0;border-radius:.5rem;box-shadow:0 1px 3px #0000001a;display:flex;flex-direction:column;padding:1rem;transition:box-shadow .2s}.document-card:hover{box-shadow:0 4px 6px #0000001a}.document-header{align-items:center;display:flex;gap:.5rem;margin-bottom:.5rem}.document-icon{font-size:1.5rem}.document-name{color:#1e293b;font-size:1rem;font-weight:500;line-height:1.4;margin:0;word-break:break-word}.document-filename{color:#64748b;font-size:.875rem;line-height:1.3;margin-bottom:1rem;word-break:break-word}.document-tags{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:.75rem}.document-status{align-items:center;border-radius:.25rem;display:flex;font-size:.75rem;font-weight:500;gap:.25rem;padding:.25rem .5rem;white-space:nowrap}.status-draft{background:#fef3c7;color:#92400e}.status-sent{background:#dbeafe;color:#1e40af}.status-completed{background:#dcfce7;color:#166534}.status-declined{background:#fee2e2;color:#991b1b}.recipient-count{background:#f3f4f6;color:#374151}.recipient-count,.user-included{border-radius:.25rem;font-size:.75rem;font-weight:500;padding:.25rem .5rem;white-space:nowrap}.user-included{background:#fef3c7;color:#92400e}.template-warning{align-items:center;background:#fef2f2;border-radius:.25rem;color:#dc2626;display:flex;font-size:.75rem;font-weight:500;gap:.25rem;padding:.25rem .5rem;white-space:nowrap}.warning-dot{background-color:#dc2626}.pulse-indicator,.warning-dot{border-radius:50%;height:6px;width:6px}.pulse-indicator{animation:pulse 2s infinite;background-color:#10b981}.progress-container{margin-bottom:.75rem}.progress-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:.25rem}.progress-percentage,.progress-text{color:#64748b;font-size:.75rem}.progress-bar{background-color:#e2e8f0;border-radius:2px;height:4px;overflow:hidden;width:100%}.progress-fill{background-color:#3b82f6;height:100%;transition:width .3s ease}.document-actions{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:center;margin-top:.75rem}.action-button{border:none;border-radius:.25rem;cursor:pointer;flex-shrink:0;font-size:.875rem;font-weight:500;min-width:fit-content;padding:.5rem 1rem;transition:all .2s ease;white-space:nowrap}.action-button.view-pdf{background:none;border:1px solid #2b3540;color:#2b3540}.action-button.view-pdf:hover{background:#2b3540;color:#fff}.action-button.archive{background:#f59e0b;color:#fff}.action-button.archive:hover{background:#d97706}.btn-primary{background:#2b3540;border:none;border-radius:.25rem;color:#fff;cursor:pointer;font-size:.875rem;padding:.5rem 1rem;transition:background-color .2s}.btn-primary:hover{background:#1e293b}.btn-secondary{background:none;border:1px solid #2b3540;border-radius:.25rem;color:#2b3540;cursor:pointer;font-size:.875rem;padding:.5rem 1rem;transition:all .2s}.btn-secondary:hover{background:#2b3540;color:#fff}.modal-overlay{align-items:center;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.modal-content{background:#fff;border-radius:.5rem;max-height:80vh;max-width:500px;overflow:auto;padding:2rem;width:90%}.modal-title{color:#1e293b;font-size:1.25rem;font-weight:600;margin-bottom:1.5rem}.form-group{margin-bottom:1rem}.form-label{color:#374151;display:block;font-weight:500;margin-bottom:.5rem}.form-input{border:1px solid #d1d5db;border-radius:.25rem;font-size:.875rem;padding:.5rem;width:100%}.form-input:focus{border-color:#2b3540;box-shadow:0 0 0 3px #2b35401a;outline:none}.form-file{background:#fff;border:1px solid #d1d5db;border-radius:.25rem;font-size:.875rem;padding:.5rem;width:100%}.checkbox-group{display:flex;flex-direction:column;gap:.5rem}.checkbox-item{align-items:center;color:#374151;display:flex;font-size:.875rem;gap:.5rem}.checkbox-item input[type=checkbox]{accent-color:#2b3540;height:16px;width:16px}.modal-actions{display:flex;gap:1rem;justify-content:flex-end;margin-top:1.5rem}.btn-cancel{background:none;border:1px solid #d1d5db;border-radius:.25rem;color:#64748b;cursor:pointer;font-size:.875rem;padding:.5rem 1rem;transition:all .2s}.btn-cancel:hover{background:#f1f5f9;border-color:#94a3b8}.btn-upload{background:#2b3540;border:none;border-radius:.25rem;color:#fff;cursor:pointer;font-size:.875rem;opacity:1;padding:.5rem 1rem;transition:all .2s}.btn-upload:disabled{cursor:not-allowed;opacity:.6}.btn-upload:not(:disabled):hover{background:#1e293b}.signing-modal{max-width:800px;width:90%}.signing-preview{background:#f8fafc;border:1px solid #e2e8f0;border-radius:.5rem;margin-bottom:1rem;padding:1rem}.signing-info{color:#64748b;font-size:.875rem;margin-bottom:1rem}@media (max-width:768px){.document-landing{padding:20px}.document-header{flex-direction:column;gap:1rem}.documents-grid{gap:.75rem;grid-template-columns:1fr}.document-card{padding:.75rem}.document-actions{flex-direction:column;gap:.5rem}.action-button{justify-content:center;width:100%}.document-tags{gap:.25rem}.modal-content{padding:1.5rem}.modal-actions{flex-direction:column}}@media (max-width:480px){.document-landing{padding:16px}.documents-grid{gap:.5rem;grid-template-columns:1fr}.document-card{padding:.75rem}.document-name{font-size:.9rem}.document-filename{font-size:.8rem}.document-tags{align-items:flex-start;flex-direction:column;gap:.25rem}.action-button{font-size:.8rem;padding:.4rem .8rem}}.loading{font-size:.875rem;padding:2rem}.empty-state,.loading{color:#64748b;text-align:center}.empty-state{padding:3rem}.empty-state-icon{font-size:3rem;margin-bottom:1rem;opacity:.5}.empty-state-text{font-size:1.125rem;font-weight:500;margin-bottom:.5rem}.empty-state-subtext{color:#94a3b8;font-size:.875rem}@keyframes pulse{0%{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.2)}to{opacity:1;transform:scale(1)}}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}
/*# sourceMappingURL=main.f906ea10.css.map*/