*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%;font-family:-apple-system,BlinkMacSystemFont,Inter,Segoe UI,sans-serif;background:#f8fafc;color:#0f172a;-webkit-font-smoothing:antialiased}.layout{display:flex;height:100vh;overflow:hidden}.sidebar{width:300px;flex-shrink:0;background:#fff;border-right:1px solid #e8edf2;display:flex;flex-direction:column;padding:2rem 1.75rem;overflow-y:auto}.sidebar-header{margin-bottom:2rem;padding-bottom:1.5rem;border-bottom:1px solid #f1f5f9}.sidebar-header-label{font-size:.6875rem;font-weight:600;text-transform:uppercase;letter-spacing:.09em;color:#94a3b8;margin-bottom:.25rem}.sidebar-header-sub{font-size:.8125rem;color:#64748b;line-height:1.45}.sidebar-case{margin-bottom:1.75rem}.sidebar-case-title{font-size:1.0625rem;font-weight:600;color:#0f172a;line-height:1.35;letter-spacing:-.015em}.sidebar-case-desc{margin-top:.375rem;font-size:.8125rem;color:#94a3b8;line-height:1.5}.sidebar-divider{height:1px;background:#f1f5f9;margin-bottom:1.75rem}.sidebar-section{margin-bottom:1.5rem}.sidebar-label{font-size:.6875rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:#94a3b8;margin-bottom:.375rem}.sidebar-value{font-size:.9rem;font-weight:500;color:#1e293b;line-height:1.4}.sidebar-value--muted{font-weight:400;color:#64748b;font-size:.875rem}.signer-list{list-style:none;display:flex;flex-direction:column;gap:.625rem}.signer-item{display:flex;align-items:center;gap:.625rem}.signer-avatar{width:28px;height:28px;border-radius:50%;background:#f1f5f9;color:#475569;font-size:.6875rem;font-weight:600;display:flex;align-items:center;justify-content:center;flex-shrink:0}.signer-info{display:flex;flex-direction:column;gap:.1rem;flex:1;min-width:0}.signer-name{font-size:.875rem;color:#1e293b;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.signer-status-text{font-size:.75rem}.status-signed{color:#16a34a}.status-declined{color:#dc2626}.status-viewed{color:#2563eb}.status-pending{color:#94a3b8}.sidebar-footer{margin-top:auto;padding-top:1.25rem;border-top:1px solid #f1f5f9}.sidebar-footer-text{font-size:.75rem;color:#cbd5e1;line-height:1.6}.viewer{flex:1;display:flex;flex-direction:column;overflow:hidden;background:#f1f5f9}.pdf-frame{flex:1;width:100%;border:none;display:block}.no-doc{flex:1;display:flex;align-items:center;justify-content:center;color:#94a3b8;font-size:.9375rem}.action-bar{background:#fff;border-top:1px solid #e2e8f0;padding:1rem 1.5rem;display:flex;align-items:center;gap:1rem;flex-wrap:wrap}.action-hint{flex:1;font-size:.8125rem;color:#94a3b8;min-width:200px}.action-buttons{display:flex;gap:.75rem;align-items:center}.action-error{width:100%;font-size:.8125rem;color:#ef4444;margin-bottom:.25rem}.btn{display:inline-flex;align-items:center;gap:.4rem;padding:.5rem 1.25rem;border-radius:6px;font-size:.875rem;font-weight:500;cursor:pointer;border:none;transition:background .15s,opacity .15s;text-decoration:none;white-space:nowrap}.btn:disabled{opacity:.55;cursor:not-allowed}.btn-primary{background:#4f46e5;color:#fff}.btn-primary:hover:not(:disabled){background:#4338ca}.btn-danger{background:#ef4444;color:#fff}.btn-danger:hover:not(:disabled){background:#dc2626}.btn-ghost{background:transparent;color:#64748b;border:1px solid #e2e8f0}.btn-ghost:hover:not(:disabled){background:#f8fafc;color:#0f172a}.btn-outline{background:transparent;color:#4f46e5;border:1px solid #4f46e5}.btn-outline:hover{background:#eef2ff}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a73;display:flex;align-items:center;justify-content:center;z-index:50;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.modal{background:#fff;border-radius:10px;padding:2rem;width:420px;max-width:calc(100vw - 2rem);box-shadow:0 20px 60px #00000026}.modal-title{font-size:1.0625rem;font-weight:600;color:#0f172a;margin-bottom:.75rem}.modal-body{font-size:.9rem;color:#475569;line-height:1.6;margin-bottom:1.5rem}.modal-actions{display:flex;justify-content:flex-end;gap:.75rem}.state-page{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.75rem;padding:2rem;background:#f8fafc}.state-icon{width:52px;height:52px;border-radius:50%;display:flex;align-items:center;justify-content:center;margin-bottom:.5rem}.state-icon--success{background:#dcfce7;color:#16a34a}.state-icon--error{background:#fee2e2;color:#dc2626}.state-title{font-size:1.25rem;font-weight:600;color:#0f172a}.state-sub{font-size:.9375rem;color:#64748b;text-align:center;max-width:380px}.state-label{font-size:.9rem;color:#94a3b8}.state-footer{font-size:.75rem;color:#cbd5e1;margin-top:2rem}.spinner{width:32px;height:32px;border:3px solid #e2e8f0;border-top-color:#4f46e5;border-radius:50%;animation:spin .7s linear infinite}.spinner-sm{display:inline-block;width:14px;height:14px;border:2px solid rgba(255,255,255,.4);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@media (max-width: 700px){.layout{flex-direction:column;height:auto}.sidebar{width:100%;border-right:none;border-bottom:1px solid #e2e8f0}.viewer{height:calc(100vh - 300px);min-height:400px}.pdf-frame{min-height:400px}.action-bar{flex-direction:column;align-items:stretch}.action-buttons{justify-content:flex-end}}.state-note{font-size:.8125rem;color:#94a3b8;text-align:center;max-width:360px;margin-top:.25rem}
