*,*: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:280px;flex-shrink:0;background:#fff;border-right:1px solid #e2e8f0;display:flex;flex-direction:column;padding:1.5rem;overflow-y:auto}.sidebar-logo{display:flex;align-items:center;gap:.5rem;margin-bottom:2rem}.sidebar-brand{font-size:1rem;font-weight:700;color:#0f172a;letter-spacing:-.02em}.sidebar-section{margin-bottom:1.5rem}.sidebar-label{font-size:.6875rem;font-weight:600;text-transform:uppercase;letter-spacing:.07em;color:#94a3b8;margin-bottom:.25rem}.sidebar-value{font-size:.9375rem;font-weight:500;color:#0f172a;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:.5rem}.signer-item{display:flex;align-items:center;gap:.5rem}.signer-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}.dot-signed{background:#22c55e}.dot-declined{background:#ef4444}.dot-pending{background:#cbd5e1}.signer-name{font-size:.875rem;color:#334155;flex:1}.signer-status{font-size:.75rem;color:#94a3b8}.sidebar-footer{margin-top:auto;padding-top:1.5rem;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}
