.dashboard{margin:0 auto;max-width:900px}.stats-row{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(4,1fr);margin-bottom:1.5rem}.stat-card{background:#f9fafb;border-radius:10px;padding:16px}.stat-num{font-size:24px;font-weight:600;margin-bottom:2px}.stat-num.blue{color:#2563eb}.stat-num.amber{color:#d97706}.stat-num.green{color:#059669}.stat-num.purple{color:#7c3aed}.stat-lbl{color:#6b7280;font-size:12px}.dash-tabs{border-bottom:1px solid #e5e7eb;display:flex;gap:4px;margin-bottom:1.25rem}.dash-tab{background:none;border:none;border-bottom:2px solid #0000;color:#6b7280;cursor:pointer;font-family:inherit;font-size:13px;margin-bottom:-1px;padding:8px 16px}.dash-tab.active{border-bottom-color:#2563eb;color:#2563eb;font-weight:500}.notif-badge{align-items:center;background:#dc2626;border-radius:50%;color:#fff;display:inline-flex;font-size:10px;height:18px;justify-content:center;margin-left:4px;width:18px}.search-filter-row{display:flex;flex-direction:column;gap:8px;margin-bottom:1rem}.search-input{background:#f9fafb;border:1px solid #e5e7eb}.search-input:focus{background:#fff}.filters{display:flex;flex-wrap:wrap;gap:6px}.filter-btn{background:#fff;border:1px solid #e5e7eb;border-radius:20px;color:#6b7280;cursor:pointer;font-family:inherit;font-size:12px;padding:5px 12px}.filter-btn.active{background:#2563eb;border-color:#2563eb;color:#fff}.doc-list{display:flex;flex-direction:column;gap:8px}.doc-row{align-items:center;background:#fff;border:1px solid #e5e7eb;border-radius:10px;display:flex;gap:12px;padding:13px 16px;transition:border-color .15s}.doc-row:hover{border-color:#93c5fd}.doc-row.doc-row-new{background:#f0fdf4;border-color:#059669}.doc-icon{align-items:center;border-radius:8px;display:flex;flex-shrink:0;font-size:16px;height:36px;justify-content:center;width:36px}.doc-icon.pdf{background:#fef2f2}.doc-icon.word{background:#eff6ff}.doc-meta{flex:1 1;min-width:0}.doc-title{font-size:13px;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.doc-sub{color:#9ca3af;font-size:11px;margin-top:2px}.status-pill{border-radius:20px;flex-shrink:0;font-size:11px;font-weight:500;padding:3px 10px;white-space:nowrap}.sp-pending{background:#fef3c7;color:#92400e}.sp-signed{background:#d1fae5;color:#065f46}.sp-awaiting{background:#e0e7ff;color:#3730a3}.sp-new{background:#dcfce7;color:#14532d}.sp-cancelled{background:#f3f4f6;color:#6b7280}.doc-actions{display:flex;flex-shrink:0;gap:6px}.btn-sm{background:none;border:1px solid #e5e7eb;border-radius:5px;color:#2563eb;cursor:pointer;font-family:inherit;font-size:12px;padding:4px 10px;white-space:nowrap}.btn-sm:hover{background:#eff6ff}.btn-sm.resend{border-color:#fde68a;color:#d97706}.btn-sm.resend:hover{background:#fef3c7}.btn-sm.resend.sent{border-color:#6ee7b7;color:#059669;pointer-events:none}.loading-text{font-size:14px;padding:2rem}.empty-state,.loading-text{color:#9ca3af;text-align:center}.empty-state{padding:3rem}.empty-icon{font-size:40px;margin-bottom:8px}.notifs-panel{display:flex;flex-direction:column;gap:8px}.mark-all-read{background:none;border:none;color:#2563eb;cursor:pointer;font-family:inherit;font-size:13px;margin-bottom:8px;text-align:left}.notif-item{align-items:flex-start;background:#fff;border:1px solid #e5e7eb;border-radius:10px;display:flex;gap:12px;padding:12px 14px}.notif-item.unread{background:#eff6ff;border-color:#93c5fd}.notif-icon{align-items:center;border-radius:50%;display:flex;flex-shrink:0;font-size:14px;height:30px;justify-content:center;width:30px}.notif-icon.ok{background:#d1fae5}.notif-icon.out{background:#e0e7ff}.notif-body{flex:1 1}.notif-title{font-size:13px;font-weight:500;margin-bottom:2px}.notif-sub{color:#6b7280;font-size:12px}.notif-time{color:#9ca3af;font-size:11px;white-space:nowrap}.send-document{margin:0 auto;max-width:680px}.steps-bar{margin-bottom:2rem}.step,.steps-bar{align-items:center;display:flex}.step{flex:1 1;gap:8px}.step-circle{align-items:center;background:#e5e7eb;border-radius:50%;color:#6b7280;display:flex;flex-shrink:0;font-size:12px;font-weight:600;height:28px;justify-content:center;width:28px}.step.active .step-circle{background:#2563eb;color:#fff}.step.done .step-circle{background:#059669;color:#fff}.step-label{color:#6b7280;font-size:13px}.step.active .step-label{color:#2563eb;font-weight:500}.step-line{background:#e5e7eb;flex:1 1;height:1px;margin:0 8px}.step-content{background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:24px}.upload-zone{border:2px dashed #d1d5db;border-radius:10px;cursor:pointer;padding:2.5rem;text-align:center;transition:all .2s}.upload-zone:hover{background:#eff6ff;border-color:#2563eb}.upload-zone.filled{background:#f0fdf4;border-color:#059669}.upload-icon{font-size:32px;margin-bottom:8px}.upload-filename{color:#111827;font-size:14px;font-weight:500}.upload-size{color:#6b7280;font-size:12px}.upload-text{color:#374151;font-size:14px;font-weight:500}.upload-sub{color:#9ca3af;font-size:12px;margin-top:4px}.field-group{margin-bottom:1rem}.field-label{color:#6b7280;display:block;font-size:12px;font-weight:500;letter-spacing:.5px;margin-bottom:6px;text-transform:uppercase}.field-input{background:#fff;border:1px solid #d1d5db;border-radius:8px;color:#111827;font-family:inherit;font-size:14px;padding:9px 12px;width:100%}.field-input:focus{border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a;outline:none}.options-row{gap:16px;margin-bottom:1rem}.options-row,.watermark-toggle{align-items:center;display:flex}.watermark-toggle{cursor:pointer;font-size:13px;gap:8px;padding-top:20px}.btn-primary{background:#2563eb;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:14px;font-weight:500;margin-top:8px;padding:11px 20px;width:100%}.btn-primary:hover{background:#1d4ed8}.btn-primary:disabled{background:#d1d5db;cursor:not-allowed}.btn-secondary{background:#fff;border:1px solid #d1d5db;border-radius:8px;color:#374151;cursor:pointer;font-size:14px;padding:10px 20px}.btn-secondary:hover{background:#f9fafb}.step-actions{display:flex;gap:12px;margin-top:1rem}.step-desc{color:#6b7280;font-size:13px;margin-bottom:1rem}.user-picker{margin-top:4px}.search-wrap{margin-bottom:8px}.search-icon{color:#9ca3af;height:15px;width:15px}.search-input{border:1px solid #d1d5db;border-radius:8px;font-family:inherit;font-size:14px;padding:9px 12px 9px 34px}.search-input:focus{border-color:#2563eb}.search-spinner{color:#6b7280;position:absolute;right:10px;top:50%;transform:translateY(-50%)}.search-results{border:1px solid #e5e7eb;border-radius:8px;margin-bottom:8px;overflow:hidden}.result-item{align-items:center;background:#fff;border:none;cursor:pointer;display:flex;gap:10px;padding:10px 12px;text-align:left;width:100%}.result-item:hover{background:#f9fafb}.result-av{align-items:center;border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-size:12px;font-weight:500;height:32px;justify-content:center;width:32px}.result-name{color:#111827;font-size:13px;font-weight:500}.result-sub{color:#6b7280;font-size:12px}.result-add{color:#2563eb;font-size:18px;margin-left:auto}.signers-list{background:#f9fafb;border-radius:8px;padding:12px}.signers-list-label{color:#9ca3af;font-size:11px;letter-spacing:.5px;margin-bottom:8px;text-transform:uppercase}.signer-row{align-items:center;background:#fff;border:1px solid #e5e7eb;border-radius:6px;display:flex;gap:10px;margin-bottom:6px;padding:8px}.drag-handle{color:#d1d5db;cursor:grab;font-size:14px}.signer-order{background:#2563eb;height:20px;width:20px}.signer-av,.signer-order{align-items:center;border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-size:11px;font-weight:500;justify-content:center}.signer-av{height:28px;width:28px}.signer-info{flex:1 1}.signer-name{font-size:13px;font-weight:500}.signer-email{color:#6b7280;font-size:11px}.name-toggle{align-items:center;color:#6b7280;cursor:pointer;display:flex;font-size:12px;gap:4px}.remove-signer{background:none;border:none;color:#9ca3af;cursor:pointer;font-size:18px;line-height:1}.field-positioner{margin-top:8px}.positioner-hint{color:#6b7280;font-size:12px;margin-bottom:8px}.doc-preview-wrap{background:#f8fafc;border:1px solid #e5e7eb;border-radius:8px;cursor:crosshair;overflow:hidden;position:relative;-webkit-user-select:none;user-select:none}.doc-sim{background:#fff;min-height:200px;padding:20px}.doc-sim-line{background:#e5e7eb;border-radius:2px;height:8px;margin-bottom:10px}.doc-sim-line.title{background:#d1d5db;height:13px;width:55%}.doc-sim-line.med{width:72%}.doc-sim-line.short{width:38%}.field-box{align-items:center;border:2px dashed;border-radius:5px;cursor:move;display:flex;font-size:11px;font-weight:500;justify-content:center;padding:4px 8px;position:absolute}.sig-box{height:42px;width:160px}.name-box{height:24px;width:140px}.field-label-order{align-items:center;border-radius:50%;color:#fff;display:flex;font-size:10px;height:16px;justify-content:center;position:absolute;right:-8px;top:-8px;width:16px}.positioner-legend{display:flex;flex-wrap:wrap;gap:12px;margin-top:6px}.legend-item{align-items:center;color:#374151;display:flex;font-size:12px;gap:6px}.legend-dot{border-radius:50%;height:8px;width:8px}.legend-badge{background:#e0e7ff;border-radius:10px;color:#3730a3;font-size:10px;padding:1px 6px}.summary-card{background:#f9fafb;border:1px solid #e5e7eb;border-radius:10px;margin-bottom:1rem;padding:16px}.summary-row{border-bottom:1px solid #f3f4f6;display:flex;font-size:13px;justify-content:space-between;padding:6px 0}.summary-row:last-child{border-bottom:none}.summary-label{color:#6b7280}.summary-value{color:#111827;font-weight:500}.signers-summary{margin-bottom:1rem}.signer-summary-row{align-items:center;border-bottom:1px solid #f3f4f6;display:flex;font-size:13px;gap:10px;padding:8px 0}.signer-order-badge{align-items:center;background:#2563eb;border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-size:11px;font-weight:500;height:20px;justify-content:center;width:20px}.signer-email-muted{color:#9ca3af;font-size:12px}.badge-name{background:#e0e7ff;border-radius:10px;color:#3730a3;font-size:10px;padding:1px 6px}.error-banner{background:#fef2f2;border:1px solid #fca5a5;border-radius:8px;color:#dc2626;font-size:13px;margin-top:8px;padding:10px 14px}.admin-panel{max-width:1000px}.admin-header{margin-bottom:1.5rem}.admin-title{align-items:center;display:flex;gap:10px;margin-bottom:4px}.admin-title h1{font-size:20px;font-weight:500;margin:0}.admin-badge{background:#fef3c7;border:1px solid #fde68a;border-radius:20px;color:#92400e;font-size:11px;font-weight:500;padding:3px 10px}.admin-subtitle{color:var(--color-text-secondary);font-size:13px;margin:0}.admin-tabs{border-bottom:.5px solid var(--color-border-tertiary);display:flex;gap:4px;margin-bottom:1.5rem}.admin-tab{align-items:center;background:none;border:none;border-bottom:2px solid #0000;color:var(--color-text-secondary);cursor:pointer;display:flex;font-family:var(--font-sans);font-size:13px;gap:6px;margin-bottom:-.5px;padding:8px 16px;transition:all .15s}.admin-tab.active{border-bottom-color:#2563eb;color:#2563eb;font-weight:500}.admin-tab:hover:not(.active){color:var(--color-text-primary)}.admin-loading{color:var(--color-text-secondary);font-size:14px;padding:2rem;text-align:center}.admin-content{min-height:400px}.admin-stats-grid{grid-gap:10px;display:grid;gap:10px;grid-template-columns:repeat(4,1fr);margin-bottom:1.5rem}.admin-stat-card{background:var(--color-background-secondary);border-radius:var(--border-radius-md);padding:14px 16px}.ast-num{font-size:24px;font-weight:500;margin-bottom:2px}.ast-num.blue{color:#2563eb}.ast-num.green{color:#059669}.ast-num.amber{color:#d97706}.ast-num.purple{color:#7c3aed}.ast-lbl{font-size:12px}.admin-section-title,.ast-lbl{color:var(--color-text-secondary)}.admin-section-title{font-size:13px;font-weight:500;letter-spacing:.5px;margin-bottom:12px;text-transform:uppercase}.progress-rows{display:flex;flex-direction:column;gap:10px;margin-bottom:1.5rem}.prog-row{align-items:center;display:flex;gap:12px}.prog-label{color:var(--color-text-secondary);flex-shrink:0;font-size:13px;width:160px}.prog-bar-wrap{background:var(--color-background-secondary);border-radius:4px;flex:1 1;height:8px;overflow:hidden}.prog-bar{border-radius:4px;height:100%;transition:width .5s}.prog-bar.green{background:#059669}.prog-bar.amber{background:#d97706}.prog-bar.purple{background:#7c3aed}.prog-pct{font-size:13px;font-weight:500;min-width:40px;text-align:right}.admin-info-cards{display:flex;gap:10px}.admin-info-card{background:var(--color-background-secondary);border-radius:var(--border-radius-md);flex:1 1;padding:12px 14px}.aic-label{color:var(--color-text-secondary);font-size:11px;margin-bottom:4px}.aic-val{font-size:18px;font-weight:500}.config-groups{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:1.5rem}.config-group-btn{align-items:center;background:none;border:.5px solid var(--color-border-tertiary);border-radius:20px;color:var(--color-text-secondary);cursor:pointer;display:flex;font-family:var(--font-sans);font-size:13px;gap:6px;padding:6px 14px;transition:all .15s}.config-group-btn.active{background:#2563eb;border-color:#2563eb;color:#fff}.config-group-btn:hover:not(.active){background:var(--color-background-secondary)}.future-badge{background:#fef3c7;border-radius:10px;color:#92400e;font-size:10px;padding:1px 6px}.ca-notice{background:#eff6ff;border:.5px solid #bfdbfe;border-radius:var(--border-radius-md);color:#1e40af;font-size:13px;line-height:1.6;margin-bottom:1.5rem;padding:14px 16px}.config-fields{display:flex;flex-direction:column;gap:12px;padding-bottom:80px}.config-field{background:var(--color-background-primary);border:.5px solid var(--color-border-tertiary);border-radius:var(--border-radius-md);padding:14px 16px;transition:border-color .15s}.config-field.modified{background:#eff6ff;border-color:#2563eb}.cf-header{align-items:center;display:flex;gap:8px;margin-bottom:4px}.cf-label{font-size:13px;font-weight:500}.cf-sensitive{color:#d97706;font-size:11px}.cf-modified{color:#2563eb;font-size:11px;margin-left:auto}.cf-desc{color:var(--color-text-secondary);font-size:12px;margin-bottom:8px}.cf-input{background:var(--color-background-primary);border:.5px solid var(--color-border-tertiary);border-radius:var(--border-radius-md);color:var(--color-text-primary);font-family:var(--font-sans);font-size:14px;padding:8px 12px;width:100%}.cf-input:focus{border-color:#3b82f6;outline:none}.cf-key{color:var(--color-text-tertiary);font-family:var(--font-mono);font-size:11px;margin-top:6px}.cf-sensitive-note{background:var(--color-background-secondary);border-radius:6px;color:var(--color-text-secondary);font-size:12px;margin-top:4px;padding:8px 12px}.cf-sensitive-note code{font-family:var(--font-mono);font-size:11px}.cf-toggle{align-items:center;cursor:pointer;display:flex;font-size:13px;gap:10px}.cf-toggle input{display:none}.toggle-track{background:var(--color-border-secondary);border-radius:11px;flex-shrink:0;height:22px;position:relative;transition:background .2s;width:38px}.cf-toggle input:checked+.toggle-track{background:#2563eb}.toggle-thumb{background:#fff;border-radius:50%;height:16px;left:3px;position:absolute;top:3px;transition:left .2s;width:16px}.cf-toggle input:checked~.toggle-track .toggle-thumb{left:19px}.save-bar{align-items:center;background:#1e3a8a;bottom:0;color:#fff;display:flex;font-size:14px;justify-content:space-between;left:0;padding:14px 32px;position:fixed;right:0;z-index:100}.save-bar.saved{background:#065f46}.btn-primary-sm{background:#2563eb;border:none;border-radius:6px;color:#fff;cursor:pointer;font-family:var(--font-sans);font-size:13px;padding:7px 16px}.btn-primary-sm:disabled{cursor:not-allowed;opacity:.6}.btn-secondary-sm{background:#ffffff26;border:1px solid #ffffff4d;border-radius:6px;color:#fff;cursor:pointer;font-family:var(--font-sans);font-size:13px;padding:7px 16px}.users-toolbar{gap:12px;margin-bottom:10px}.guests-toggle,.users-toolbar{align-items:center;display:flex}.guests-toggle{cursor:pointer;font-size:13px;gap:6px;white-space:nowrap}.guests-notice,.guests-toggle{color:var(--color-text-secondary)}.guests-notice{background:var(--color-background-secondary);border-radius:6px;font-size:12px;margin-bottom:1rem;padding:8px 12px}.users-table-wrap{overflow-x:auto}.users-table{border-collapse:collapse;font-size:13px;width:100%}.users-table th{color:var(--color-text-secondary);font-size:11px;font-weight:500;letter-spacing:.5px;padding:8px 12px;text-align:left;text-transform:uppercase}.users-table td,.users-table th{border-bottom:.5px solid var(--color-border-tertiary)}.users-table td{padding:10px 12px}.users-table tr:hover td{background:var(--color-background-secondary)}.row-blocked td{background:#fff5f5;opacity:.6}.user-cell{gap:10px}.user-av-sm,.user-cell{align-items:center;display:flex}.user-av-sm{border-radius:50%;color:#fff;flex-shrink:0;font-size:11px;font-weight:500;height:30px;justify-content:center;width:30px}.user-cell-name{font-size:13px;font-weight:500}.dept-badge,.user-cell-email{color:var(--color-text-secondary);font-size:11px}.dept-badge{background:var(--color-background-secondary);border-radius:10px;padding:2px 8px}.num-cell{font-weight:500;text-align:center}.green-num{color:#059669}.amber-num{color:#d97706}.status-active{color:#059669;font-size:12px}.status-blocked{cursor:help}.btn-sm-red,.status-blocked{color:#dc2626;font-size:12px}.btn-sm-red{background:none;border:.5px solid #fca5a5;border-radius:5px;cursor:pointer;font-family:var(--font-sans);padding:4px 10px}.btn-sm-red:hover{background:#fef2f2}.btn-sm-green{background:none;border:.5px solid #6ee7b7;border-radius:5px;color:#059669;cursor:pointer;font-family:var(--font-sans);font-size:12px;padding:4px 10px}.btn-sm-green:hover{background:#f0fdf4}.empty-table{color:var(--color-text-secondary);font-size:14px;padding:2rem;text-align:center}.logs-filters{align-items:center;display:flex;flex-wrap:wrap;gap:8px;margin-bottom:1rem}.log-filter-input,.log-filter-select{background:var(--color-background-primary);border:.5px solid var(--color-border-tertiary);border-radius:var(--border-radius-md);color:var(--color-text-primary);font-family:var(--font-sans);font-size:13px;padding:7px 10px}.log-filter-input:focus,.log-filter-select:focus{border-color:#3b82f6;outline:none}.logs-count{color:var(--color-text-secondary);font-size:12px;margin-bottom:8px}.logs-list{display:flex;flex-direction:column;gap:4px}.log-row{align-items:center;background:var(--color-background-primary);border:.5px solid var(--color-border-tertiary);border-radius:var(--border-radius-md);display:flex;font-size:12px;gap:12px;padding:9px 12px}.log-row:hover{background:var(--color-background-secondary)}.log-action-badge{border-radius:10px;flex-shrink:0;font-size:11px;font-weight:500;padding:2px 10px;white-space:nowrap}.log-meta{align-items:center;display:flex;flex:1 1;flex-wrap:wrap;gap:10px;min-width:0}.log-user{color:var(--color-text-primary);font-weight:500}.log-doc{color:var(--color-text-secondary);max-width:180px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.log-details{color:var(--color-text-tertiary);font-size:11px}.log-right{align-items:flex-end;display:flex;flex-direction:column;flex-shrink:0;gap:2px}.log-ip{color:var(--color-text-tertiary);font-family:var(--font-mono);font-size:11px}.log-time{color:var(--color-text-secondary);font-size:11px}.pagination{align-items:center;display:flex;font-size:13px;gap:12px;justify-content:center;margin-top:1rem}.pagination .btn-secondary-sm{background:var(--color-background-secondary);border:.5px solid var(--color-border-tertiary);color:var(--color-text-primary)}.search-wrap{flex:1 1;position:relative}.search-icon{color:var(--color-text-secondary);height:14px;left:10px;position:absolute;top:50%;transform:translateY(-50%);width:14px}.search-input{background:var(--color-background-secondary);border:.5px solid var(--color-border-tertiary);border-radius:var(--border-radius-md);color:var(--color-text-primary);font-family:var(--font-sans);font-size:13px;padding:8px 12px 8px 32px;width:100%}.search-input:focus{background:var(--color-background-primary);border-color:#3b82f6;outline:none}.sign-page{background:#f4f4f5;display:flex;flex-direction:column;min-height:100vh}.sign-header{align-items:center;background:#1e3a8a;display:flex;gap:12px;padding:14px 24px}.sign-logo{color:#fff;font-size:16px;font-weight:700}.sign-header-sub{color:#93c5fd;font-size:11px;letter-spacing:.5px}.sign-card{background:#fff;border:1px solid #e5e7eb;border-radius:12px;margin:24px auto;max-width:520px;padding:28px;width:100%}.doc-info-box{background:#eff6ff;border:1px solid #bfdbfe;border-radius:8px;margin-bottom:1rem;padding:14px}.doc-info-label{color:#1d4ed8;font-size:11px;letter-spacing:.5px;margin-bottom:4px;text-transform:uppercase}.doc-info-title{color:#1e3a8a;font-size:15px;font-weight:600;margin-bottom:2px}.doc-info-from{color:#2563eb;font-size:12px}.doc-message{background:#f9fafb;border-left:3px solid #2563eb;border-radius:0 6px 6px 0;color:#374151;font-size:13px;font-style:italic;padding:10px 14px}.doc-message,.review-info{margin-bottom:1rem}.review-row{border-bottom:1px solid #f3f4f6;display:flex;font-size:13px;justify-content:space-between;padding:7px 0}.review-label{color:#6b7280}.review-val{font-weight:500}.view-doc-btn{border:1px solid #e5e7eb;border-radius:8px;color:#2563eb;display:block;font-size:13px;margin-bottom:1rem;padding:10px;text-align:center;text-decoration:none}.view-doc-btn:hover{background:#eff6ff}.legal-notice{background:#f9fafb;border-radius:6px;color:#9ca3af;font-size:12px;line-height:1.5;margin-bottom:1rem;padding:10px 12px}.btn-primary.full-width{width:100%}.canvas-section{margin-bottom:1rem}.canvas-label{color:#6b7280;font-size:12px;font-weight:500;letter-spacing:.5px;margin-bottom:6px;text-transform:uppercase}.canvas-wrap{background:#fff;border:1px solid #e5e7eb;border-radius:8px;margin-bottom:6px;overflow:hidden}#signCanvas{cursor:crosshair;display:block;height:120px;touch-action:none;width:100%}.canvas-hint{color:#9ca3af;font-size:11px;margin-bottom:8px;text-align:center}.canvas-actions{display:flex;gap:8px}.btn-back,.btn-secondary{background:#fff;border:1px solid #e5e7eb;border-radius:6px;cursor:pointer;flex:1 1;font-family:inherit;font-size:13px;padding:8px}.sign-meta{color:#9ca3af;font-size:11px;margin-bottom:12px;text-align:center}.confirm-btn{background:#2563eb;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:14px;font-weight:500;padding:12px;width:100%}.confirm-btn:disabled{background:#d1d5db;cursor:not-allowed}.loading-spinner{animation:spin 1s linear infinite;font-size:28px;margin-bottom:8px;text-align:center}@keyframes spin{to{transform:rotate(1turn)}}.done-icon,.error-icon{font-size:40px;margin-bottom:12px;text-align:center}.done-card h2,.error-card h2{font-size:18px;font-weight:600;margin-bottom:8px}.done-card p,.error-card p{color:#6b7280;font-size:14px;margin-bottom:1rem}.download-btn{background:#059669;border-radius:8px;color:#fff;display:block;font-size:14px;font-weight:500;margin-bottom:12px;padding:12px;text-align:center;text-decoration:none}.done-meta{color:#9ca3af;font-size:12px;text-align:center}*{box-sizing:border-box;margin:0;padding:0}body{font-family:system-ui,sans-serif}.login-page{align-items:center;background:#f4f4f5;display:flex;justify-content:center;min-height:100vh}.login-card{background:#fff;border:1px solid #e4e4e7;border-radius:12px;max-width:400px;padding:40px;text-align:center;width:100%}.login-logo{align-items:center;display:flex;gap:12px;justify-content:center;margin-bottom:24px}.login-logo-icon{font-size:32px}.login-logo-name{color:#1e3a8a;font-size:22px;font-weight:700}.login-logo-sub{color:#6b7280;font-size:11px;letter-spacing:.5px}.login-title{color:#111827;font-size:20px;font-weight:600;margin-bottom:8px}.login-desc{color:#6b7280;font-size:14px;margin-bottom:28px}.login-btn{align-items:center;background:#2563eb;border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:15px;font-weight:500;gap:10px;justify-content:center;padding:12px 20px;width:100%}.login-btn:hover{background:#1d4ed8}.app-layout{display:flex;flex-direction:column;min-height:100vh}.topbar{background:#fff;border-bottom:1px solid #e4e4e7;justify-content:space-between;padding:12px 24px}.topbar,.topbar-logo{align-items:center;display:flex}.topbar-logo{cursor:pointer;gap:10px}.logo-icon{font-size:20px}.logo-name{color:#1e3a8a;font-size:15px;font-weight:600}.logo-sub{color:#6b7280;font-size:10px}.topbar-nav{display:flex;gap:4px}.nav-btn{background:none;border:none;border-radius:6px;color:#6b7280;cursor:pointer;font-size:13px;padding:7px 14px}.nav-btn.active{background:#eff6ff;color:#2563eb;font-weight:500}.nav-btn.nav-admin{color:#d97706}.nav-btn.nav-admin.active{background:#fef3c7;color:#92400e}.topbar-user{gap:8px}.topbar-user,.user-av{align-items:center;display:flex}.user-av{background:#1d4ed8;border-radius:50%;color:#fff;font-size:12px;font-weight:500;height:32px;justify-content:center;width:32px}.user-name{font-size:13px;font-weight:500}.user-email{color:#6b7280;font-size:11px}.user-role{color:#d97706;font-size:11px}.logout-btn{background:none;border:1px solid #e4e4e7;border-radius:6px;color:#6b7280;cursor:pointer;font-size:12px;padding:4px 8px}.main-content{flex:1 1;margin:0 auto;max-width:960px;padding:24px;width:100%}.success-banner{align-items:center;background:#d1fae5;border:1px solid #6ee7b7;border-radius:8px;color:#065f46;display:flex;font-size:13px;justify-content:space-between;margin-bottom:16px;padding:10px 16px}.success-banner button{background:none;border:none;color:#065f46;cursor:pointer;font-size:16px}
/*# sourceMappingURL=main.f30c2d4f.css.map*/