*{margin:0;padding:0;box-sizing:border-box}:root{--primary: #2563eb;--primary-hover: #1d4ed8;--success: #16a34a;--danger: #dc2626;--warning: #f59e0b;--gray-50: #f9fafb;--gray-100: #f3f4f6;--gray-200: #e5e7eb;--gray-300: #d1d5db;--gray-400: #9ca3af;--gray-500: #6b7280;--gray-600: #4b5563;--gray-700: #374151;--gray-800: #1f2937;--gray-900: #111827;--radius: 8px;--shadow: 0 1px 3px rgba(0, 0, 0, .1), 0 1px 2px rgba(0, 0, 0, .06);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -2px rgba(0, 0, 0, .05)}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;background:var(--gray-50);color:var(--gray-900);line-height:1.6;min-height:100vh}#root,.layout{min-height:100vh;display:flex;flex-direction:column}.app-header{background:#fff;border-bottom:1px solid var(--gray-200);position:sticky;top:0;z-index:100}.container{max-width:1200px;margin:0 auto;padding:2rem;width:100%}.card{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow);padding:1.5rem}h1,h2,h3,h4{font-weight:600;margin-bottom:1rem}h1{font-size:1.875rem}h2{font-size:1.5rem}h3{font-size:1.25rem}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.625rem 1.25rem;font-size:.875rem;font-weight:500;border-radius:var(--radius);border:none;cursor:pointer;transition:all .15s ease}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover:not(:disabled){background:var(--primary-hover)}.btn-success{background:var(--success);color:#fff}.btn-success:hover:not(:disabled){background:#15803d}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover:not(:disabled){background:#b91c1c}.btn-outline{background:transparent;border:1px solid var(--gray-300);color:var(--gray-700)}.btn-outline:hover:not(:disabled){background:var(--gray-100)}.btn-icon{padding:.5rem;width:2.5rem;height:2.5rem}.btn-lg{padding:.875rem 1.75rem;font-size:1rem}.form-group{margin-bottom:1rem}.form-label{display:block;font-size:.875rem;font-weight:500;color:var(--gray-700);margin-bottom:.375rem}.form-input,.form-select{width:100%;padding:.625rem .875rem;font-size:.875rem;border:1px solid var(--gray-300);border-radius:var(--radius);transition:border-color .15s ease,box-shadow .15s ease}.form-input:focus,.form-select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #2563eb1a}.form-input::placeholder{color:var(--gray-400)}.file-upload{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.75rem;border:2px dashed var(--gray-300);border-radius:var(--radius);padding:2.5rem 2rem;text-align:center;cursor:pointer;transition:all .2s ease;background:var(--gray-50);min-height:160px}.file-upload:hover{border-color:var(--primary);background:#fff;box-shadow:0 0 0 4px #2563eb1a}.file-upload.has-file{border-color:var(--success);border-style:solid;background:#f0fdf4}.file-upload.has-file:hover{box-shadow:0 0 0 4px #16a34a1a}.file-upload input[type=file]{display:none}.file-upload .upload-icon{width:3.5rem;height:3.5rem;display:flex;align-items:center;justify-content:center;border-radius:50%;background:#fff;box-shadow:var(--shadow)}.file-upload .upload-text{display:flex;flex-direction:column;gap:.25rem}.file-upload .upload-text strong{font-size:1rem;color:var(--gray-800)}.file-upload .upload-text p{margin:0;font-size:.875rem;color:var(--gray-500)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.modal{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow-lg);max-width:600px;width:100%;max-height:90vh;overflow-y:auto}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.5rem;border-bottom:1px solid var(--gray-200)}.modal-body{padding:1.5rem}.modal-footer{display:flex;justify-content:flex-end;gap:.75rem;padding:1rem 1.5rem;border-top:1px solid var(--gray-200)}.signature-canvas-container{border:2px solid var(--gray-300);border-radius:var(--radius);background:#fff;touch-action:none}.signature-canvas-container canvas{display:block;width:100%;height:200px}.table-container{overflow-x:auto}table{width:100%;border-collapse:collapse}th,td{padding:.75rem 1rem;text-align:start;border-bottom:1px solid var(--gray-200)}th{font-weight:600;background:var(--gray-50)}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.gap-1{gap:.25rem}.gap-2{gap:.5rem}.gap-3{gap:.75rem}.gap-4{gap:1rem}.mt-2{margin-top:.5rem}.mt-4{margin-top:1rem}.mb-2{margin-bottom:.5rem}.mb-4{margin-bottom:1rem}.text-sm{font-size:.875rem}.text-gray{color:var(--gray-500)}.text-success{color:var(--success)}.text-danger{color:var(--danger)}.text-center{text-align:center}.w-full{width:100%}.grid{display:grid}.grid-cols-2{grid-template-columns:repeat(2,1fr)}@media (max-width: 640px){.grid-cols-2{grid-template-columns:1fr}}.link-item{display:flex;align-items:center;justify-content:space-between;padding:.75rem;border:1px solid var(--gray-200);border-radius:var(--radius);margin-bottom:.5rem}.link-item:last-child{margin-bottom:0}.badge{display:inline-flex;align-items:center;padding:.25rem .625rem;font-size:.75rem;font-weight:500;border-radius:9999px;background:var(--gray-100);color:var(--gray-700)}.badge-success{background:#dcfce7;color:#166534}.spinner{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.page-header{display:flex;align-items:center;gap:1rem;margin-bottom:1.5rem}.signature-protected{position:relative;display:inline-block;max-width:150px;max-height:60px;border:1px solid var(--gray-200);border-radius:var(--radius);background:#fff;overflow:hidden;user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;-webkit-touch-callout:none}.signature-protected canvas{display:block;max-width:150px;max-height:60px}.signature-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:transparent;cursor:default;z-index:10}.signature-protected,.signature-protected *{-webkit-touch-callout:none;-webkit-user-select:none;-khtml-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.password-requirements{margin-top:.5rem;padding:.75rem;background:var(--gray-50);border-radius:var(--radius);font-size:.75rem}.password-requirements ul{list-style:none;padding:0;margin:0}.password-requirements li{display:flex;align-items:center;gap:.5rem;padding:.125rem 0;color:var(--gray-500)}.password-requirements li.valid{color:var(--success)}.password-requirements li.invalid{color:var(--gray-400)}.form-preview{border:1px solid var(--gray-200);border-radius:var(--radius);overflow:hidden;background:var(--gray-100);max-height:400px}.form-preview img,.form-preview iframe{width:100%;height:400px;display:block;object-fit:contain}.empty-state{text-align:center;padding:3rem 2rem;color:var(--gray-500)}.empty-state svg{width:3rem;height:3rem;margin-bottom:1rem;opacity:.5}.legal-content{line-height:1.7;color:var(--gray-700)}.legal-content h1{font-size:1.5rem;margin-top:0;margin-bottom:1rem;padding-bottom:.5rem;border-bottom:2px solid var(--primary)}.legal-content h2{font-size:1.25rem;margin-top:1.5rem;margin-bottom:.75rem;color:var(--gray-800)}.legal-content h3{font-size:1.1rem;margin-top:1.25rem;margin-bottom:.5rem;color:var(--gray-700)}.legal-content p{margin-bottom:.75rem}.legal-content li{margin-bottom:.5rem;margin-inline-start:1.5rem;list-style-type:disc}.legal-content strong{color:var(--gray-800)}.legal-acceptance{display:flex;align-items:flex-start;gap:.75rem;padding:1rem;background:var(--gray-50);border-radius:var(--radius);border:1px solid var(--gray-200)}.legal-acceptance input[type=checkbox]{margin-top:.25rem;width:1.25rem;height:1.25rem;cursor:pointer;flex-shrink:0}.legal-acceptance label{font-size:.875rem;color:var(--gray-700);cursor:pointer;line-height:1.5}.legal-acceptance a,.legal-acceptance button.link-btn{color:var(--primary);text-decoration:underline;cursor:pointer;background:none;border:none;padding:0;font:inherit}.legal-acceptance a:hover,.legal-acceptance button.link-btn:hover{color:var(--primary-hover)}
