/* InkSeal — fintech-SaaS design system v2.
   Sidebar nav, refined neutrals, soft layered depth, Lucide icons, motion.
   Inter (incl. 800 for display numbers), JetBrains Mono for IDs/hashes.
   Wax-seal amber as the brand accent. */

:root{
  --bg:#f4f5f8;
  --bg-grad:radial-gradient(1200px 600px at 100% -5%, #eef1f7 0%, #f4f5f8 45%);
  --sidebar:#ffffff;
  --card:#ffffff;
  --ink:#15171d;
  --ink-soft:#33373f;
  --muted:#697086;
  --faint:#9aa1b1;
  --line:#e9ebf1;
  --line-soft:#f2f4f8;
  --accent:#b45309;
  --accent-2:#d97916;
  --accent-grad:linear-gradient(135deg,#c2682a,#b45309);
  --accent-soft:#fbeede;
  --pos:#0e9f6e; --pos-soft:#e4f6ef;
  --info:#3b6fd4; --info-soft:#e9eefb;
  --pend:#697086; --pend-soft:#eef0f4;
  --violet:#7c5cff; --violet-soft:#efeaff;
  --danger:#c0392b; --danger-soft:#fdecea;
  --r:16px; --r-sm:11px; --r-xs:8px;
  --sh-sm:0 1px 2px rgba(20,24,40,.05);
  --sh:0 2px 4px rgba(20,24,40,.05), 0 1px 2px rgba(20,24,40,.04);
  --sh-md:0 6px 16px rgba(20,24,40,.08), 0 2px 4px rgba(20,24,40,.05);
  --sh-lg:0 16px 40px rgba(20,24,40,.13);
  --font:'Inter',system-ui,-apple-system,sans-serif;
  --mono:'JetBrains Mono',ui-monospace,'SF Mono',Menlo,monospace;
  --sidebar-w:256px;
  /* dark "vault" sidebar */
  --side-bg:linear-gradient(180deg,#181b23 0%,#121419 100%);
  --side-fg:#e8eaf0;
  --side-muted:#8b93a4;
  --side-faint:#5f6675;
  --side-hover:rgba(255,255,255,.06);
  --side-active:rgba(180,83,9,.18);
  --side-line:rgba(255,255,255,.08);
}
*{box-sizing:border-box}
html,body{margin:0}
body{font:14.5px/1.55 var(--font);background:var(--bg);background-image:var(--bg-grad);
  background-attachment:fixed;color:var(--ink);-webkit-font-smoothing:antialiased}
a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}
svg[data-lucide]{width:18px;height:18px}

/* ---- motion ---- */
@keyframes fadeup{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}
@keyframes pop{from{opacity:0;transform:scale(.96)}to{opacity:1;transform:none}}
[data-anim]{animation:fadeup .5s cubic-bezier(.16,1,.3,1) both}
[data-anim="pop"]{animation:pop .45s cubic-bezier(.16,1,.3,1) both}

/* ---- app shell ---- */
.app-shell{display:flex;min-height:100vh}
.sidebar{width:var(--sidebar-w);flex:0 0 var(--sidebar-w);background:var(--side-bg);
  border-right:1px solid var(--side-line);display:flex;flex-direction:column;position:sticky;top:0;height:100vh}
.side-brand{display:flex;align-items:center;gap:11px;padding:22px 20px 20px;font-weight:800;
  font-size:18px;letter-spacing:-.03em;color:#fff}
.seal-mark{width:30px;height:30px;border-radius:9px;background:var(--accent-grad);display:grid;place-items:center;
  color:#fff;box-shadow:0 2px 10px rgba(180,83,9,.45),inset 0 0 0 1px rgba(255,255,255,.25)}
.seal-mark svg{width:16px;height:16px}
.side-label{padding:10px 22px 6px;font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--side-faint);font-weight:700}
.side-nav{padding:4px 12px;display:flex;flex-direction:column;gap:2px;flex:1}
.nav-item{display:flex;align-items:center;gap:11px;padding:10px 12px;border-radius:var(--r-sm);
  color:var(--side-muted);font-weight:500;font-size:14px;transition:background .15s,color .15s;position:relative}
.nav-item:hover{background:var(--side-hover);color:#fff;text-decoration:none}
.nav-item.active{background:var(--side-active);color:#fff;font-weight:600}
.nav-item.active::before{content:"";position:absolute;left:-12px;top:9px;bottom:9px;width:3px;
  border-radius:0 3px 3px 0;background:var(--accent-2)}
.nav-item.active svg{color:var(--accent-2)}
.nav-item svg{width:18px;height:18px;flex:0 0 18px;color:var(--side-faint)}
.nav-item:hover svg{color:#fff}
.side-foot{padding:12px;border-top:1px solid var(--side-line)}
.acct-menu{position:relative}
.op-chip{display:flex;align-items:center;gap:10px;padding:8px;border-radius:var(--r-sm);width:100%;
  border:1px solid transparent;background:none;cursor:pointer;font:inherit;text-align:left;transition:background .15s}
.op-chip:hover{background:var(--side-hover)}
.op-avatar{width:34px;height:34px;border-radius:50%;background:var(--accent-grad);color:#fff;display:grid;
  place-items:center;font-weight:700;font-size:13px;flex:0 0 34px;box-shadow:inset 0 0 0 1px rgba(255,255,255,.2)}
.op-meta{min-width:0;flex:1}
.op-name{font-size:13px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:#fff}
.op-tz{font-size:11px;color:var(--side-faint);display:flex;align-items:center;gap:5px}
.op-tz::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--pos)}
.op-chev{width:15px;height:15px;color:var(--side-faint);flex:0 0 15px;transition:transform .15s}
.acct-menu.open .op-chev{transform:rotate(180deg)}
.acct-pop{position:absolute;left:0;right:0;bottom:calc(100% + 8px);background:#fff;border:1px solid var(--line);
  border-radius:var(--r-sm);box-shadow:var(--sh-lg);padding:6px;display:none}
.acct-menu.open .acct-pop{display:block;animation:pop .16s ease both}
.acct-item{display:flex;align-items:center;gap:10px;padding:9px 11px;border-radius:var(--r-xs);
  font-size:13.5px;color:var(--ink);font-weight:500}
.acct-item:hover{background:var(--line-soft);text-decoration:none}
.acct-item.active{background:var(--accent-soft);color:var(--accent)}
.acct-item svg{width:16px;height:16px;color:var(--muted)}
.acct-item.danger{color:var(--danger)}.acct-item.danger svg{color:var(--danger)}
.acct-sep{height:1px;background:var(--line);margin:5px 4px}

/* ---- signature capture (Type/Draw/Image + color) ---- */
.sigtabs{display:inline-flex;background:var(--line-soft);border-radius:var(--r-sm);padding:3px;gap:2px;margin-bottom:12px}
.sigtab{border:0;background:none;font:inherit;font-size:13px;font-weight:600;color:var(--muted);
  padding:6px 16px;border-radius:8px;cursor:pointer}
.sigtab.active{background:#fff;color:var(--ink);box-shadow:var(--sh-sm)}
.sigcolors{display:flex;align-items:center;gap:8px;margin-bottom:12px}
.swatch{width:24px;height:24px;border-radius:50%;border:2px solid #fff;box-shadow:0 0 0 1px var(--line);cursor:pointer}
.swatch.active{box-shadow:0 0 0 2px var(--ink)}
/* ---- needs attention ---- */
.attn-card{padding:0;margin-bottom:24px;overflow:hidden;border-color:#f0d9b8}
.attn-head{display:flex;align-items:center;gap:8px;font-weight:700;font-size:14px;color:#92500a;
  padding:13px 18px;background:#fdf4e7;border-bottom:1px solid #f0d9b8}
.attn-head svg{width:16px;height:16px}
.attn-n{margin-left:auto;background:#b45309;color:#fff;border-radius:99px;font-size:11px;padding:1px 8px;font-weight:700}
.attn-list{display:flex;flex-direction:column}
.attn-item{display:flex;align-items:center;gap:11px;padding:11px 18px;border-bottom:1px solid var(--line-soft);
  color:var(--ink);text-decoration:none;transition:background .12s}
.attn-item:last-child{border-bottom:0}
.attn-item:hover{background:var(--line-soft);text-decoration:none}
.attn-dot{width:8px;height:8px;border-radius:99px;flex:0 0 8px;background:var(--muted)}
.attn-dot.warn{background:#d97916}.attn-dot.error{background:#dc2626}
.attn-t{font-weight:600;flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.attn-r{font-size:12.5px;color:var(--muted)}
.attn-r.warn{color:#b45309}.attn-r.error{color:#b91c1c}
.attn-item svg{width:15px;height:15px;color:var(--faint)}

/* ---- detail drawer ---- */
.dwr-scrim{position:fixed;inset:0;background:rgba(10,12,16,.34);opacity:0;pointer-events:none;
  transition:opacity .22s;z-index:150}
.dwr-scrim.show{opacity:1;pointer-events:auto}
.dwr{position:fixed;top:0;right:0;height:100vh;width:420px;max-width:92vw;background:var(--bg,#f7f8fa);
  box-shadow:-12px 0 40px rgba(10,12,16,.18);transform:translateX(100%);transition:transform .26s cubic-bezier(.4,0,.2,1);
  z-index:160;overflow-y:auto}
.dwr.open{transform:none}
.dwr-body{padding:0 0 30px}
.dwr-loading{padding:40px;text-align:center;color:var(--muted)}
.dwr-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;padding:22px 22px 16px;
  background:#fff;border-bottom:1px solid var(--line);position:sticky;top:0;z-index:2}
.dwr-eyebrow{font-size:11px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--accent)}
.dwr-title{font-size:18px;font-weight:750;letter-spacing:-.01em;margin:3px 0 2px}
.dwr-close{background:none;border:0;font-size:24px;line-height:1;color:var(--muted);cursor:pointer;padding:0 2px}
.dwr-close:hover{color:var(--ink)}
.dwr-actions{display:flex;gap:8px;flex-wrap:wrap;padding:14px 22px;background:#fff;border-bottom:1px solid var(--line)}
.dwr-sec{padding:16px 22px;border-bottom:1px solid var(--line-soft)}
.dwr-sec-h{font-size:11px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);margin-bottom:11px}
.dwr-rcp{display:flex;align-items:center;gap:10px;padding:7px 0}
.dwr-rcp-av{width:30px;height:30px;border-radius:99px;background:var(--accent-soft);color:var(--accent);
  display:grid;place-items:center;font-weight:700;font-size:13px;flex:0 0 30px}
.dwr-rcp-main{flex:1;display:flex;flex-direction:column;line-height:1.25;font-size:13px;min-width:0}
.dwr-rcp-main .faint{font-size:11.5px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.dwr-evt{display:flex;gap:10px;padding:6px 0}
.dwr-evt-dot{width:7px;height:7px;border-radius:99px;background:var(--accent);margin-top:6px;flex:0 0 7px}
.dwr-evt-t{font-size:13px;font-weight:600}
@media(max-width:520px){.dwr{width:100vw}}

/* ---- command palette ---- */
.cmdk{position:fixed;inset:0;z-index:300;display:none}
.cmdk.open{display:block}
.cmdk-scrim{position:absolute;inset:0;background:rgba(10,12,16,.4);backdrop-filter:blur(2px)}
.cmdk-box{position:relative;max-width:560px;margin:12vh auto 0;background:#fff;border-radius:16px;
  box-shadow:var(--sh-lg);overflow:hidden;animation:pop .14s ease both}
.cmdk-in{display:flex;align-items:center;gap:10px;padding:15px 18px;border-bottom:1px solid var(--line)}
.cmdk-in svg{width:18px;height:18px;color:var(--muted)}
.cmdk-in input{flex:1;border:0;outline:0;font:inherit;font-size:16px;color:var(--ink);background:none}
.cmdk-list{max-height:50vh;overflow-y:auto;padding:6px}
.cmdk-h{font-size:10.5px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--faint);padding:9px 12px 4px}
.cmdk-row{display:flex;align-items:center;gap:11px;padding:10px 12px;border-radius:9px;cursor:pointer}
.cmdk-row svg{width:16px;height:16px;color:var(--muted);flex:0 0 16px}
.cmdk-row.sel{background:var(--accent-soft)}
.cmdk-row.sel svg{color:var(--accent)}
.cmdk-label{flex:1;font-size:14px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.cmdk-sub{font-size:11px;color:var(--muted);text-transform:capitalize;background:var(--line-soft);padding:2px 8px;border-radius:99px}
.cmdk-empty{padding:26px;text-align:center;color:var(--muted);font-size:14px}
.cmdk-foot{display:flex;gap:16px;padding:10px 16px;border-top:1px solid var(--line);background:var(--line-soft);font-size:11.5px;color:var(--muted)}
.cmdk-foot kbd{background:#fff;border:1px solid var(--line);border-radius:5px;padding:1px 6px;font-family:var(--mono);font-size:10.5px;margin-right:3px}

/* ---- skeletons + bulk + saved views ---- */
.skel{background:linear-gradient(90deg,var(--line-soft) 25%,var(--line) 37%,var(--line-soft) 63%);
  background-size:400% 100%;animation:shimmer 1.3s ease infinite;border-radius:7px}
@keyframes shimmer{0%{background-position:100% 0}100%{background-position:-100% 0}}
.skel-row{height:14px;margin:10px 0}
.views{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:14px}
.view-chip{display:inline-flex;align-items:center;gap:6px;font:inherit;font-size:12.5px;font-weight:600;
  padding:6px 12px;border-radius:99px;border:1px solid var(--line);background:#fff;color:var(--ink-soft);cursor:pointer;transition:all .12s}
.view-chip:hover{border-color:var(--accent);color:var(--accent)}
.view-chip.active{background:var(--ink);color:#fff;border-color:var(--ink)}
.view-chip svg{width:14px;height:14px}
.bulkbar{display:none;align-items:center;gap:10px;background:var(--ink);color:#fff;border-radius:12px;
  padding:10px 14px;margin-bottom:14px;font-size:13.5px;box-shadow:var(--sh-md)}
.bulkbar.show{display:flex}
.bulkbar .bb-n{font-weight:700}
.bulkbar .bb-act{margin-left:auto;display:flex;gap:8px}
.bulkbar .bb-btn{background:rgba(255,255,255,.12);border:0;color:#fff;border-radius:8px;padding:6px 12px;
  font:inherit;font-size:12.5px;font-weight:600;cursor:pointer;display:inline-flex;align-items:center;gap:6px}
.bulkbar .bb-btn:hover{background:rgba(255,255,255,.2)}
.bulkbar .bb-btn.danger:hover{background:#b91c1c}
.bulkbar .bb-btn svg{width:14px;height:14px}
.chk-cell{width:34px;text-align:center}
.row-chk{width:16px;height:16px;cursor:pointer;accent-color:var(--accent)}
tr.kb-cur td{background:var(--accent-soft)!important;box-shadow:inset 3px 0 0 var(--accent)}

/* ---- command palette ---- end */
.toasts{position:fixed;right:20px;bottom:20px;z-index:200;display:flex;flex-direction:column;gap:10px;max-width:380px}
.toast{display:flex;align-items:flex-start;gap:10px;background:var(--ink);color:#fff;border-radius:12px;
  padding:13px 14px;box-shadow:var(--sh-lg);opacity:0;transform:translateY(10px) scale(.98);
  transition:opacity .25s,transform .25s;font-size:13.5px;line-height:1.45}
.toast.show{opacity:1;transform:none}
.toast svg{width:17px;height:17px;flex:0 0 17px;margin-top:1px;color:#fff}
.toast.success svg{color:#34d399}.toast.error svg{color:#f87171}
.toast-msg{flex:1}
.toast-x{background:none;border:0;color:rgba(255,255,255,.6);font-size:18px;line-height:1;cursor:pointer;padding:0 2px}
.toast-x:hover{color:#fff}

/* ---- dashboard KPIs ---- */
.sig-typed{font-family:'Dancing Script',cursive;font-size:40px;color:#111418;padding:14px;border:1px dashed var(--faint);
  border-radius:12px;min-height:70px;display:flex;align-items:center;margin-top:8px;background:#fff}

/* DocuSign-style status buckets */
.buckets{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-bottom:24px}
.bucket{position:relative;text-align:left;background:var(--card,#fff);border:1px solid var(--line);
  border-radius:var(--r);padding:18px 18px 16px;box-shadow:var(--sh);cursor:pointer;font:inherit;
  transition:transform .1s ease,box-shadow .15s,border-color .15s}
.bucket:hover{box-shadow:var(--sh-md);transform:translateY(-2px)}
.bucket:focus-visible{outline:2px solid var(--accent);outline-offset:2px}
.bk-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}
.bk-ico{width:36px;height:36px;border-radius:10px;display:grid;place-items:center}
.bk-ico svg{width:18px;height:18px}
.bk-n{font-size:32px;font-weight:750;letter-spacing:-.02em;color:var(--ink);line-height:1;font-variant-numeric:tabular-nums}
.bk-l{font-size:15px;font-weight:700;color:var(--ink)}
.bk-sub{font-size:12px;color:var(--muted);margin-top:3px;line-height:1.35}
.bk-go{position:absolute;top:18px;right:18px;display:none}
.b-action .bk-ico{background:#fbeede;color:#b45309}
.b-action{border-top:3px solid #d97916}
.b-wait .bk-ico{background:#e9eefb;color:#3b6fd4}
.b-done .bk-ico{background:#e4f6ef;color:#0e9f6e}
@media(max-width:820px){.buckets{grid-template-columns:1fr}}
.pill.action{background:#fbeede;color:#b45309}
.rowact{font-weight:600}
.flash-card{animation:flashcard 1.2s ease}
@keyframes flashcard{0%,100%{box-shadow:var(--sh)}30%{box-shadow:0 0 0 3px var(--accent-soft),0 0 0 1px var(--accent)}}

.kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:24px}
.kpi{background:var(--card,#fff);border:1px solid var(--line);border-radius:var(--r);padding:18px 18px 16px;box-shadow:var(--sh)}
.kpi-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}
.kpi-ico{width:34px;height:34px;border-radius:10px;display:grid;place-items:center}
.kpi-ico svg{width:17px;height:17px}
.kpi-ico.ink{background:#eef0f3;color:#15171d}.kpi-ico.amber{background:#fbeede;color:#b45309}
.kpi-ico.green{background:#e4f6ef;color:#0e9f6e}.kpi-ico.blue{background:#e7eefb;color:#2563c9}
.kpi-trend{font-size:11px;font-weight:600;color:var(--muted);background:var(--line-soft);padding:3px 8px;border-radius:20px}
.kpi-n{font-size:30px;font-weight:750;letter-spacing:-.02em;color:var(--ink);line-height:1}
.kpi-l{font-size:12.5px;color:var(--muted);margin-top:5px}
@media(max-width:900px){.kpis{grid-template-columns:repeat(2,1fr)}}

/* ---- card head: tabs + search ---- */
.card-head{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 16px;
  border-bottom:1px solid var(--line);flex-wrap:wrap}
.seg{display:inline-flex;background:var(--line-soft);border-radius:10px;padding:3px;gap:2px}
.seg-btn{border:0;background:transparent;font:inherit;font-size:13px;font-weight:600;color:var(--muted);
  padding:6px 12px;border-radius:8px;cursor:pointer;display:inline-flex;align-items:center;gap:6px;transition:all .12s}
.seg-btn:hover{color:var(--ink)}
.seg-btn.active{background:#fff;color:var(--ink);box-shadow:var(--sh)}
.seg-c{font-size:11px;background:var(--line);color:var(--muted);border-radius:20px;padding:1px 7px;font-weight:700}
.seg-btn.active .seg-c{background:var(--accent-soft);color:var(--accent)}
.search{display:flex;align-items:center;gap:8px;background:var(--line-soft);border:1px solid var(--line);
  border-radius:10px;padding:7px 12px;min-width:230px}
.search svg{width:15px;height:15px;color:var(--faint);flex:0 0 15px}
.search input{border:0;background:transparent;font:inherit;font-size:13.5px;width:100%;outline:none;color:var(--ink)}

/* ---- recipient progress ---- */
.prog{display:flex;align-items:center;gap:9px}
.prog-bar{width:74px;height:6px;border-radius:20px;background:var(--line);overflow:hidden}
.prog-bar span{display:block;height:100%;background:var(--accent);border-radius:20px}
.prog-t{font-size:12px;color:var(--muted);white-space:nowrap}

/* ---- upload dropzone ---- */
.dropzone{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;
  border:1.5px dashed var(--line);border-radius:var(--r-sm);padding:30px 20px;cursor:pointer;
  background:var(--line-soft);transition:all .15s;text-align:center}
.dropzone:hover,.dropzone.over{border-color:var(--accent);background:var(--accent-soft)}
.dropzone svg{width:26px;height:26px;color:var(--accent)}
.dz-main{font-size:14px;font-weight:600;color:var(--ink)}.dz-main span{color:var(--accent);text-decoration:underline}
.dz-sub{font-size:12px;color:var(--muted)}

textarea{font:inherit;font-size:13.5px;line-height:1.5;resize:vertical;min-height:90px}
.tokens{display:flex;flex-wrap:wrap;gap:6px;margin:4px 0 16px}
.tokens code{font-family:var(--mono);font-size:11.5px;background:var(--line-soft);border:1px solid var(--line);
  padding:3px 8px;border-radius:6px;color:var(--ink-soft)}
.grouphdr2{font-size:12px;font-weight:700;letter-spacing:.02em;color:var(--ink);margin:6px 0 10px;
  padding-top:12px;border-top:1px solid var(--line)}
.prev{background:var(--line-soft);border:1px solid var(--line);border-radius:var(--r-sm);padding:14px;margin-top:6px}
.prev-h{font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--faint);font-weight:700;margin-bottom:8px}
.prev-row{font-size:13px;margin-bottom:8px}.prev-row span{color:var(--muted);margin-right:6px}
.prev-body{font-size:13.5px;white-space:pre-wrap;line-height:1.55;background:#fff;border:1px solid var(--line);
  border-radius:8px;padding:12px;color:var(--ink-soft)}
.emodal{position:fixed;inset:0;background:rgba(16,24,40,.45);display:none;place-items:center;z-index:80;padding:20px}
.emodal.open{display:grid}
.esheet{background:#fff;border-radius:var(--r);max-width:560px;width:100%;box-shadow:var(--sh-lg);overflow:hidden}
.esheet-h{padding:16px 20px;border-bottom:1px solid var(--line);font-weight:700;display:flex;justify-content:space-between;align-items:center}
.esheet-b{padding:18px 20px}
.emeta{font-size:13px;margin-bottom:6px}.emeta span{color:var(--muted);display:inline-block;width:62px}
.ebody{white-space:pre-wrap;font-size:14px;line-height:1.55;background:var(--line-soft);border:1px solid var(--line);
  border-radius:10px;padding:14px;margin-top:10px}

.main{flex:1;min-width:0;display:flex;flex-direction:column}
.wrap{width:100%;max-width:1100px;margin:0 auto;padding:38px 40px}
.wrap-wide{max-width:1280px}

/* ---- page header ---- */
.page-top{display:flex;justify-content:space-between;align-items:flex-end;gap:18px;margin-bottom:28px;flex-wrap:wrap}
.eyebrow{font-size:11px;letter-spacing:.13em;text-transform:uppercase;color:var(--faint);font-weight:700}
.page-title{font-size:28px;font-weight:800;letter-spacing:-.035em;margin:4px 0 0}
.page-sub{color:var(--muted);font-size:14px;margin-top:6px}

/* ---- cards ---- */
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--sh)}
.card-pad{padding:24px}
.card h3{font-size:15px;font-weight:700;letter-spacing:-.02em;margin:0 0 16px}

/* ---- stat cards ---- */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:26px}
.stat{position:relative;background:var(--card);border:1px solid var(--line);border-radius:var(--r);
  padding:20px;box-shadow:var(--sh);overflow:hidden;transition:transform .18s cubic-bezier(.16,1,.3,1),box-shadow .18s}
.stat:hover{transform:translateY(-3px);box-shadow:var(--sh-md)}
.stat::after{content:"";position:absolute;inset:0 0 auto 0;height:3px;opacity:.9}
.stat.all::after{background:var(--ink)}.stat.draft::after{background:var(--pend)}
.stat.sent::after{background:var(--info)}.stat.done::after{background:var(--pos)}
.stat .ico{width:38px;height:38px;border-radius:11px;display:grid;place-items:center;margin-bottom:16px}
.stat .ico svg{width:19px;height:19px}
.stat .n{font-size:30px;font-weight:800;letter-spacing:-.03em;line-height:1;font-variant-numeric:tabular-nums}
.stat .l{font-size:13px;color:var(--muted);margin-top:6px;font-weight:500}
.stat.all .ico{background:var(--ink);color:#fff}
.stat.draft .ico{background:var(--pend-soft);color:var(--pend)}
.stat.sent .ico{background:var(--info-soft);color:var(--info)}
.stat.done .ico{background:var(--pos-soft);color:var(--pos)}

/* ---- buttons ---- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:7px;font:inherit;font-weight:600;
  font-size:13.5px;line-height:1;letter-spacing:-.01em;padding:0 16px;height:38px;border-radius:10px;
  border:1px solid transparent;cursor:pointer;background:var(--ink);color:#fff;white-space:nowrap;
  transition:transform .08s ease,box-shadow .15s,background .15s,filter .15s;box-shadow:var(--sh-sm)}
.btn:hover{background:#000;text-decoration:none;box-shadow:var(--sh)}
.btn:active{transform:translateY(1px)}
.btn:focus-visible{outline:2px solid var(--accent);outline-offset:2px}
.btn svg{width:15px;height:15px;flex:0 0 15px}
.btn-seal{background:var(--accent-grad);box-shadow:0 1px 2px rgba(180,83,9,.25),inset 0 1px 0 rgba(255,255,255,.18)}
.btn-seal:hover{filter:brightness(1.04);box-shadow:0 4px 14px rgba(180,83,9,.3),inset 0 1px 0 rgba(255,255,255,.18)}
.btn-ghost{background:#fff;color:var(--ink);border-color:var(--line);box-shadow:var(--sh-sm)}
.btn-ghost:hover{background:var(--line-soft);border-color:var(--line)}
.btn.danger-btn{color:var(--danger);border-color:var(--danger-soft)}
.btn.danger-btn:hover{background:var(--danger-soft);border-color:var(--danger)}
.btn.danger-btn svg{color:var(--danger)}
.btn-sm{height:32px;padding:0 12px;font-size:13px;border-radius:9px;gap:6px}
.btn-sm svg{width:14px;height:14px;flex:0 0 14px}

/* ---- inputs ---- */
input,select,textarea{font:inherit;font-size:14px;padding:10px 12px;border:1px solid var(--line);border-radius:var(--r-sm);
  background:#fff;color:var(--ink);width:100%;transition:border-color .15s,box-shadow .15s}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}
input::placeholder{color:var(--faint)}
label{font-size:13px}
.field{margin-bottom:14px}
.field>span{display:block;font-weight:600;font-size:12.5px;margin-bottom:6px;color:var(--ink-soft)}
.row{display:flex;gap:12px}.row>*{flex:1}
.check{display:flex;align-items:center;gap:7px;font-size:13px}.check input{width:auto}

/* ---- tables ---- */
table{width:100%;border-collapse:collapse}
th{text-align:left;font-size:11px;letter-spacing:.05em;text-transform:uppercase;color:var(--faint);
  font-weight:700;padding:13px 18px;border-bottom:1px solid var(--line);background:var(--line-soft)}
td{padding:16px 18px;border-bottom:1px solid var(--line);font-size:14px;vertical-align:middle}
tr:last-child td{border-bottom:0}
tbody tr{transition:background .12s}tbody tr:hover{background:var(--line-soft)}

/* ---- status pills ---- */
.pill{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:600;padding:4px 11px;border-radius:20px}
.pill::before{content:"";width:6px;height:6px;border-radius:50%;background:currentColor}
.pill.draft{background:var(--pend-soft);color:var(--pend)}
.pill.sent{background:var(--info-soft);color:var(--info)}
.pill.completed{background:var(--pos-soft);color:var(--pos)}
.pill.expired,.pill.voided{background:var(--danger-soft);color:var(--danger)}

/* ---- actions dropdown ---- */
.menu{position:relative;display:inline-block}
.menu-list{position:absolute;right:0;top:calc(100% + 6px);background:#fff;border:1px solid var(--line);
  border-radius:var(--r-sm);box-shadow:var(--sh-lg);padding:6px;min-width:230px;z-index:40;display:none}
.menu.open .menu-list{display:block;animation:pop .16s ease both}
.menu-item{display:flex;align-items:center;gap:10px;width:100%;text-align:left;padding:9px 11px;
  border:0;background:none;border-radius:var(--r-xs);font:inherit;font-size:13.5px;color:var(--ink);cursor:pointer}
.menu-item:hover{background:var(--line-soft);text-decoration:none;color:var(--ink)}
.menu-item svg{width:16px;height:16px;color:var(--muted)}
.menu-item.danger{color:var(--danger)}.menu-item.danger svg{color:var(--danger)}
.menu-sep{height:1px;background:var(--line);margin:6px 4px}
.menu-form{margin:0}
.ec-form{padding:8px 11px}
.ec-label{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:600;color:var(--ink);margin-bottom:7px}
.ec-label svg{width:15px;height:15px;color:var(--muted)}
.ec-row{display:flex;gap:6px}
.ec-row input{flex:1;font-size:13px;padding:6px 8px}
.ec-hint{font-size:11px;color:var(--muted);margin-top:5px}

/* send options popover */
.send-pop{width:260px;padding:14px}
.send-pop .sp-h{font-size:11px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:var(--muted);margin-bottom:10px}
.send-pop .sp-row{display:flex;flex-direction:column;gap:4px;margin-bottom:10px;font-size:12.5px;font-weight:600;color:var(--ink)}
.send-pop .sp-row select,.send-pop .sp-row input{width:100%}

/* clean field palette (drafting) */
.palette{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;
  background:var(--line-soft);border:1px solid var(--line);border-radius:12px;padding:10px 12px;margin-bottom:12px}
.pal-left{display:flex;align-items:center;gap:8px}
.pal-label{font-size:12px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.04em}
.pal-signer{width:auto;min-width:130px}
.pal-fields{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.btn.icon-only{padding:0 9px}
.btn.icon-only svg{margin:0}
.hintbar{font-size:12px;color:var(--muted);margin-bottom:12px}

.mono{font-family:var(--mono);font-size:12.5px}
.docid{font-family:var(--mono);font-size:12px;background:var(--ink);color:#e7eaf0;padding:4px 10px;border-radius:7px;letter-spacing:.02em}

/* ---- audit hash-chain ---- */
.chainwrap{position:relative}
.chain-event{position:relative;padding:0 0 16px 26px}
.chain-event::before{content:"";position:absolute;left:6px;top:4px;width:9px;height:9px;border-radius:50%;
  background:var(--accent);box-shadow:0 0 0 3px var(--accent-soft);z-index:1}
.chain-event::after{content:"";position:absolute;left:10px;top:12px;bottom:-4px;width:1.5px;background:var(--line)}
.chain-event:last-child::after{display:none}
.chain-event .ev{font-size:13px;font-weight:600}
.chain-event .meta{font-size:11.5px;color:var(--muted);margin-top:1px}
.chain-event .h{font-family:var(--mono);font-size:10px;color:var(--faint);word-break:break-all;margin-top:3px}
.verdict{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:600;padding:4px 10px;border-radius:20px}
.verdict.ok{background:var(--pos-soft);color:var(--pos)}
.verdict.bad{background:var(--danger-soft);color:var(--danger)}

.grid-2{display:grid;grid-template-columns:1fr 360px;gap:24px;align-items:start}
.muted{color:var(--muted)}.faint{color:var(--faint)}
.flash{background:var(--accent-soft);border:1px solid #f0d9bf;color:#7a3c08;padding:12px 15px;
  border-radius:var(--r-sm);font-size:13.5px;margin-bottom:18px}
.empty{color:var(--faint);text-align:center;padding:36px;font-size:14px}
hr{border:0;border-top:1px solid var(--line);margin:16px 0}

@media(max-width:920px){
  .app-shell{flex-direction:column}
  .sidebar{width:100%;height:auto;position:static;flex-direction:row;align-items:center;border-right:0;border-bottom:1px solid var(--line)}
  .side-brand{padding:14px 16px}.side-nav{flex-direction:row;flex:1;padding:8px}.side-label,.side-foot{display:none}
  .grid-2{grid-template-columns:1fr}.stats{grid-template-columns:repeat(2,1fr)}
  .wrap{padding:22px 18px}
}
@media(prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important}}

/* ===== Shared brand footer (matches verify page) ===== */
.foot{display:flex;align-items:center;justify-content:center;gap:7px;font-size:11px;color:var(--faint);margin-top:24px;text-align:center}
.foot svg{width:12px;height:12px;flex:none}
.madeby{font-size:12.5px;color:var(--muted);margin-top:16px;font-weight:550;letter-spacing:.01em;display:flex;align-items:center;justify-content:center;gap:6px}
.heart{color:#e0554c;font-size:13px;display:inline-block;transform-origin:center;animation:beat 2.4s ease-in-out infinite}
.inkbrand{display:inline-flex;align-items:center;gap:6px}
.inkbrand .glyph{width:18px;height:18px;border-radius:6px;display:grid;place-items:center;color:#fff;background:linear-gradient(135deg,#d98a2b,var(--accent));box-shadow:0 4px 11px -4px rgba(180,83,9,.55);animation:glyphFloat 4.5s ease-in-out infinite}
.inkbrand .glyph svg{width:11px;height:11px}
.inkbrand .wm{font-family:'Dancing Script',cursive;font-weight:600;font-size:15px;letter-spacing:-.005em;color:var(--ink)}
.inkbrand .wm .sl{color:var(--accent);background:linear-gradient(100deg,currentColor 0,currentColor 40%,#fff0cf 50%,currentColor 60%,currentColor 100%);background-size:240% 100%;-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;animation:sheen 5s ease-in-out infinite}
@supports not ((-webkit-background-clip:text) or (background-clip:text)){.inkbrand .wm .sl{-webkit-text-fill-color:currentColor}}
body.dark .inkbrand .wm .sl{color:#e2933a}
@keyframes beat{0%,30%,100%{transform:scale(1)}10%{transform:scale(1.22)}20%{transform:scale(1.06)}}
@keyframes glyphFloat{0%,100%{transform:translateY(0);box-shadow:0 4px 11px -4px rgba(180,83,9,.55)}50%{transform:translateY(-1.5px);box-shadow:0 9px 16px -5px rgba(180,83,9,.72)}}
@keyframes sheen{0%{background-position:120% 0}50%{background-position:-20% 0}100%{background-position:120% 0}}

/* company-name footer: wider shimmer for long text */
.inkbrand .wm .sl{background-size:300% 100%}
