:root{
  --green-deep:#1B2A1D; --green-forest:#2C3F2D; --green-moss:#3F5742;
  --gold-brass:#B08D57; --gold-warm:#C9A961; --gold-soft:#D4B97A; --gold-label:#80632E;
  --sand-light:#F4EDDD; --sand-mid:#E8DCC4; --sand-warm:#DDD0B3;
  --cream:#FAF6EB; --ink:#1A1F1A; --ink-soft:#3A3F3A; --muted:#6B655A;
  --line:#E6DCC6; --card:#FFFFFF; --bg:#FAF6EB;
  --ok:#2C5530; --ok-bg:#E7F0E4; --warn:#8A6D1F; --warn-bg:#FBF0D6; --err:#9B2C2C; --err-bg:#FBE7E5;
  --serif:'Cormorant Garamond',Georgia,'Times New Roman',serif;
  --sans:'Manrope',system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;
  --radius:14px; --radius-sm:9px;
  --shadow:0 1px 2px rgba(26,31,26,.05),0 10px 30px rgba(26,31,26,.06);
}
*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{margin:0;font-family:var(--sans);background:var(--bg);color:var(--ink);line-height:1.6;-webkit-font-smoothing:antialiased}
h1,h2,h3{font-family:var(--serif);font-weight:500;line-height:1.12;letter-spacing:-.01em;margin:0 0 .35em}
h1{font-size:clamp(28px,4vw,38px)}
h2{font-size:22px}
h3{font-size:18px}
a{color:var(--gold-label);text-decoration:none}
a:hover{text-decoration:underline}
p{margin:0 0 14px}
.lead{font-size:17px;color:var(--ink-soft)}
.muted{color:var(--muted);font-size:14px}
.eyebrow{font-family:var(--sans);font-size:11.5px;letter-spacing:.24em;text-transform:uppercase;font-weight:700;color:var(--gold-label);display:block;margin-bottom:10px}

/* chrome */
.topbar{display:flex;justify-content:space-between;align-items:center;gap:16px;
  padding:16px clamp(20px,5vw,40px);background:var(--green-deep);color:var(--sand-light);position:sticky;top:0;z-index:10}
.topbar .brand{font-family:var(--serif);font-size:21px;letter-spacing:.2em;color:var(--gold-warm);font-weight:500}
.topbar .tag{font-size:12px;letter-spacing:.06em;color:var(--sand-warm)}
.wrap{max-width:780px;margin:0 auto;padding:24px 18px 80px;padding:clamp(24px,5vw,48px) clamp(18px,5vw,28px) 80px}
.foot{max-width:780px;margin:0 auto;padding:24px 18px;padding:24px clamp(18px,5vw,28px);color:var(--muted);font-size:12.5px;border-top:1px solid var(--line)}

/* cards */
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:24px;margin:18px 0;box-shadow:var(--shadow)}
.card>h2{display:flex;align-items:baseline;gap:10px}
.card .num{font-family:var(--sans);font-size:13px;font-weight:700;color:#fff;background:var(--green-moss);width:24px;height:24px;border-radius:50%;display:inline-grid;place-items:center;flex:0 0 auto}
.page-head{margin-bottom:8px}

/* stepper */
.stepper{display:flex;gap:6px;margin:6px 0 22px;flex-wrap:wrap}
.step{display:flex;align-items:center;gap:9px;flex:1 1 0;min-width:140px;padding:10px 12px;border:1px solid var(--line);border-radius:var(--radius-sm);background:#fff}
.step .dot{width:24px;height:24px;border-radius:50%;display:grid;place-items:center;font-size:12px;font-weight:700;background:var(--sand-mid);color:var(--ink-soft);flex:0 0 auto}
.step .lbl{font-size:13px;font-weight:600;color:var(--ink-soft)}
.step.active{border-color:var(--gold-warm);background:#fffdf6}
.step.active .dot{background:var(--gold-warm);color:#3a2c10}
.step.done .dot{background:var(--ok);color:#fff}
.step.done .lbl{color:var(--ink)}

/* forms */
.fieldgroup{margin:0 0 8px}
.fieldgroup+.fieldgroup{margin-top:22px;padding-top:20px;border-top:1px solid var(--line)}
.field{margin:0 0 15px}
.field label{display:block;font-weight:600;font-size:13.5px;margin-bottom:6px;color:var(--ink)}
.field input,.field select{width:100%;padding:11px 12px;border:1px solid var(--sand-warm);border-radius:var(--radius-sm);font-size:15px;font-family:var(--sans);background:#fff;color:var(--ink)}
.field input:focus,.field select:focus{outline:none;border-color:var(--gold-warm);box-shadow:0 0 0 3px rgba(201,169,97,.25)}
.field.has-error input,.field.has-error select{border-color:var(--err)}
.field .help{margin:5px 0 0;color:var(--muted);font-size:12.5px}
.field .error,.error{color:var(--err);font-size:12.5px;margin:5px 0 0}
.req{color:var(--gold-label)}
.actions,.btn-row{display:flex;gap:10px;margin-top:18px;flex-wrap:wrap;align-items:center}

/* buttons */
.btn,button{font-family:var(--sans);font-size:15px;font-weight:600;cursor:pointer;border-radius:var(--radius-sm);
  padding:11px 20px;border:1px solid transparent;background:var(--green-deep);color:var(--sand-light);text-decoration:none;display:inline-block;transition:filter .15s ease,background .15s ease}
.btn:hover,button:hover{filter:brightness(1.08);text-decoration:none}
.btn.secondary,button.secondary{background:#fff;color:var(--ink);border-color:var(--sand-warm)}
.btn.secondary:hover,button.secondary:hover{background:var(--sand-light);filter:none}
.btn.ghost,button.ghost{background:transparent;color:var(--gold-label);border-color:transparent;padding:6px 8px}
button.link{background:none;border:0;color:var(--gold-label);padding:0;font-size:13px;font-weight:600;text-decoration:underline}
button.link:hover{filter:none;color:var(--green-forest)}
button.link-danger{background:none;border:0;color:var(--err);padding:0;font-size:13px;font-weight:600;text-decoration:underline;cursor:pointer}
button.link-danger:hover{filter:none;color:#8a2a1e}

/* status pills + badges */
.status{font-size:11.5px;font-weight:700;letter-spacing:.02em;padding:3px 11px;border-radius:20px;background:var(--sand-mid);color:var(--ink-soft);text-transform:capitalize;white-space:nowrap}
.status-invited,.status-in_progress,.status-pending,.status-submitted,.status-draft{background:var(--warn-bg);color:var(--warn)}
.status-approved,.status-issued,.status-signed,.status-complete{background:var(--ok-bg);color:var(--ok)}
.status-returned,.status-rejected,.status-failed,.status-revoked,.status-cancelled,.status-blocked,.status-voided{background:var(--err-bg);color:var(--err)}
button.danger,.btn.danger{background:var(--err-bg);color:var(--err);border:1px solid #e3b9b3}
button.danger:hover,.btn.danger:hover{background:#f7dcd8}
.badge{font-size:11px;font-weight:700;padding:2px 9px;border-radius:20px;background:var(--sand-light);color:var(--gold-label);border:1px solid var(--sand-warm)}
.badge.ocr{background:#fff7e3;border-color:var(--gold-soft)}

/* banners */
/* Note/callout boxes — editorial, on-theme: sand card with a gold left accent. */
.banner{background:var(--sand-light);border:1px solid var(--sand-warm);border-left:4px solid var(--gold-warm);border-radius:var(--radius-sm);padding:13px 16px 13px 18px;font-size:14px;color:var(--ink-soft);box-shadow:var(--shadow)}
.banner.info{background:var(--ok-bg);border-color:#cdd9cd;border-left-color:var(--green-moss)}
.banner.warn{background:var(--warn-bg);border-left-color:var(--gold-warm)}

/* document checklist */
.doclist{list-style:none;padding:0;margin:0}
.doclist>li{padding:14px 0;border-bottom:1px solid var(--line)}
.doclist>li:last-child{border-bottom:0}
.docitem-head{display:flex;justify-content:space-between;gap:10px;align-items:center;flex-wrap:wrap;margin-bottom:8px}
.docitem-label{font-weight:600;font-size:14.5px}
.upload{display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.upload input[type=file]{font-size:13px;max-width:100%}
.ok-text{color:var(--ok);font-weight:600;font-size:13px}
.todo-text{color:var(--gold-label);font-weight:600;font-size:13px}
.fname{font-size:12px;color:var(--muted)}

/* lists / tables */
.files{list-style:none;padding:0;margin:0}
.files li{padding:10px 0;border-bottom:1px solid var(--line)}
.files li:last-child{border-bottom:0}
table{width:100%;border-collapse:collapse}
.kv th,.kv td{text-align:left;padding:9px 8px;border-bottom:1px solid var(--line);vertical-align:top;font-size:14px}
.kv th{width:42%;font-weight:600;color:var(--ink-soft)}
.list th,.list td{text-align:left;padding:11px 10px;border-bottom:1px solid var(--line);font-size:14px}
.list th{font-size:11.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);font-weight:700}
.list tr:hover td{background:var(--sand-light)}
/* wide tables scroll horizontally on narrow screens instead of breaking layout */
@media (max-width:560px){
  .list,.cfg{display:block;overflow-x:auto;-webkit-overflow-scrolling:touch}
  .list thead,.cfg thead{white-space:nowrap}
}
/* visible, on-brand keyboard focus for all interactive elements */
a:focus-visible,button:focus-visible,.btn:focus-visible,input:focus-visible,select:focus-visible{
  outline:2px solid var(--gold-warm);outline-offset:2px}

/* intake-config editor table */
.cfg th.mid,.cfg td.mid{text-align:center;width:74px}
.cfg td input[type=text]{width:100%;padding:8px 10px;border:1px solid var(--sand-warm);border-radius:var(--radius-sm);font-size:13.5px;font-family:var(--sans)}
.cfg td input[type=text]:focus{outline:none;border-color:var(--gold-warm);box-shadow:0 0 0 3px rgba(201,169,97,.2)}
.cfg input[type=checkbox]{width:18px;height:18px;accent-color:var(--green-forest)}

/* list status filters */
.filters{display:flex;gap:8px;flex-wrap:wrap;margin:0 0 14px}
.filters .filter{display:inline-flex;align-items:center;gap:7px;font-size:13px;font-weight:600;color:var(--ink-soft);
  padding:6px 13px;border:1px solid var(--sand-warm);border-radius:20px;background:#fff;text-decoration:none}
.filters .filter:hover{background:var(--sand-light);text-decoration:none}
.filters .filter.on{background:var(--green-deep);color:var(--sand-light);border-color:var(--green-deep)}
.filters .filter-n{font-size:11px;font-weight:700;background:var(--sand-mid);color:var(--ink-soft);border-radius:20px;padding:0 7px;min-width:18px;text-align:center}
.filters .filter.on .filter-n{background:rgba(255,255,255,.18);color:#fff}

/* admin dashboard stats */
.stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(130px,1fr));gap:12px;margin:0 0 8px}
.stat{background:var(--card);border:1px solid var(--line);border-radius:var(--radius-sm);padding:14px 16px}
.stat-num{font-family:var(--serif);font-size:30px;line-height:1;color:var(--green-forest)}
.stat-label{font-size:12px;color:var(--muted);margin-top:6px;letter-spacing:.02em}

/* signer timeline */
.sigdoc{border:1px solid var(--line);border-radius:var(--radius-sm);padding:16px;margin:12px 0;background:#fff}
.sigdoc-head{display:flex;gap:10px;align-items:center;flex-wrap:wrap;margin-bottom:12px}
.sigdoc-head strong{font-size:15px}
.timeline{list-style:none;margin:0 0 6px;padding:0;position:relative}
.timeline>li{position:relative;padding:0 0 16px 30px}
.timeline>li:before{content:"";position:absolute;left:9px;top:20px;bottom:0;width:2px;background:var(--line)}
.timeline>li:last-child:before{display:none}
.tl-dot{position:absolute;left:0;top:2px;width:20px;height:20px;border-radius:50%;background:var(--sand-mid);border:2px solid #fff;box-shadow:0 0 0 1px var(--line)}
.tl-dot.done{background:var(--ok)}
.tl-dot.active{background:var(--gold-warm)}
.tl-main{display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.signer-role{font-size:10.5px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--gold-label)}
.sig-actions{font-size:13px;color:var(--muted);margin-top:3px}
.sig-actions a,.sig-actions .link{font-size:13px;margin-right:2px}
.addsigner{display:flex;gap:8px;flex-wrap:wrap;align-items:center;margin-top:12px;padding-top:12px;border-top:1px dashed var(--line)}
.addsigner input,.addsigner select{padding:8px 10px;border:1px solid var(--sand-warm);border-radius:var(--radius-sm);font-size:13.5px;font-family:var(--sans)}
.addsigner input[type=email]{min-width:200px}

/* signing wizard (guided Review → Sign → Done) */
.signwrap{max-width:540px;margin:0 auto;text-align:center;padding:6px 0 16px}
.signwrap h1{font-size:clamp(26px,4.4vw,36px);margin:18px 0 .3em}
.signwrap .lead{max-width:42ch;margin:0 auto 6px;color:var(--ink-soft)}
.signwrap .actions{justify-content:center;margin-top:22px}
.signwrap .card{text-align:left}
.signwrap .actions.actions-center{gap:6px;flex-direction:column;align-items:center}
.signwrap .card{border-radius:20px}
.signwrap .btn{padding:13px 30px;border-radius:999px;font-size:15.5px}
/* Big, side-by-side action buttons (e.g. Approve & sign / Decline). */
.btn.big,button.big{padding:15px 38px;font-size:16.5px;border-radius:999px;min-width:200px}
.actions-row{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;margin-top:24px}
.signsteps{list-style:none;display:flex;justify-content:center;margin:0 0 30px;padding:0}
.signsteps li{flex:1;max-width:120px;display:flex;flex-direction:column;align-items:center;gap:9px;position:relative}
.signsteps li::before{content:"";position:absolute;top:14px;right:50%;width:100%;height:2px;background:var(--line)}
.signsteps li:first-child::before{display:none}
.signsteps li.current::before,.signsteps li.done::before{background:var(--gold-soft)}
.signsteps .d{width:30px;height:30px;border-radius:50%;display:grid;place-items:center;font-size:13px;font-weight:700;
  background:#fff;border:2px solid var(--line);color:var(--muted);position:relative;z-index:1;transition:all .2s ease}
.signsteps .d svg{width:15px;height:15px}
.signsteps .t{font-size:12px;font-weight:600;color:var(--muted);letter-spacing:.02em}
.signsteps li.current .d{border-color:var(--gold-warm);background:var(--gold-warm);color:#3a2c10;box-shadow:0 0 0 4px rgba(201,169,97,.18)}
.signsteps li.current .t{color:var(--ink)}
.signsteps li.done .d{border-color:var(--ok);background:var(--ok);color:#fff}
.signsteps li.done .t{color:var(--ink-soft)}
.signsteps li.error .d{border-color:var(--err);background:var(--err);color:#fff}
.signsteps li.error .t{color:var(--err)}
.signhero{width:66px;height:66px;border-radius:50%;display:grid;place-items:center;margin:8px auto 2px}
.signhero svg{width:32px;height:32px;display:block}
.signhero.ok{background:var(--ok-bg);color:var(--ok)}
.signhero.warn{background:var(--warn-bg);color:var(--warn)}
.signhero.err{background:var(--err-bg);color:var(--err)}
.signtrust{display:inline-flex;align-items:center;gap:8px;margin-top:22px;font-size:12.5px;color:var(--muted)}
.signtrust svg{width:15px;height:15px;color:var(--gold-label);flex:0 0 auto}
.signdoc-card{margin:22px 0 4px;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);background:#fff}
.signdoc-card .docpreview{border:0;border-radius:0;margin:0;display:block;width:100%}
/* one-time-passcode entry (email/SMS signing) */
.otp-form{margin:18px auto 8px;max-width:320px}
.otp-input{width:100%;text-align:center;font-family:var(--mono,monospace);font-size:30px;font-weight:700;
  letter-spacing:.42em;padding:14px 10px;border:1px solid var(--sand-warm);border-radius:var(--radius-sm);background:#fff}
/* drawn-signature pad */
.draw-form{margin:18px auto 6px;max-width:480px}
.draw-pad{border:1px solid var(--sand-warm);border-radius:var(--radius-sm);background:#fff;box-shadow:var(--shadow);overflow:hidden}
.draw-canvas{display:block;width:100%;height:200px;border-radius:var(--radius-sm);touch-action:none;cursor:crosshair}
.draw-form .actions-row{justify-content:center}

/* document preview + qr + misc */
.docpreview{width:100%;height:58vh;min-height:360px;border:1px solid var(--line);border-radius:var(--radius-sm);margin:14px 0;background:#fff}
.qr{margin:14px 0;width:184px;height:184px;background:#fff;padding:8px;border:1px solid var(--line);border-radius:var(--radius-sm)}
.qr svg{width:100%;height:100%;display:block}
.admin-head{display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap}
.row{display:flex;gap:10px;flex-wrap:wrap;align-items:center}
.inline{display:inline}
.card.danger{border-color:#e3b9b3;background:#fdf6f5}
code{font-size:12.5px;background:var(--sand-light);padding:1px 6px;border-radius:5px}
code.break{word-break:break-all}
.success-ico{width:54px;height:54px;border-radius:50%;background:var(--ok-bg);color:var(--ok);display:grid;place-items:center;margin:0 0 14px}
.success-ico.warn{background:var(--warn-bg);color:var(--warn)}
.success-ico svg{width:28px;height:28px}
.card.narrow{max-width:420px}

/* release channels: header toggle + features panel */
.channelbar{display:flex;flex-wrap:wrap;align-items:center;gap:8px 14px;padding:8px 12px;margin:0 0 16px;border:1px solid var(--line);border-radius:var(--radius-sm);background:#fbf9f4;font-size:13px}
.channelbar.beta{background:var(--warn-bg);border-color:var(--gold-soft)}
.chan-label{font-weight:700;color:var(--ink-soft)}
.chan-toggle{display:inline-flex;border:1px solid var(--sand-warm);border-radius:999px;overflow:hidden}
.chan-toggle button{border:0;background:#fff;padding:5px 14px;font-size:13px;cursor:pointer;color:var(--ink-soft)}
.chan-toggle button.on{background:var(--green-deep);color:var(--sand-light);font-weight:700}
.chan-toggle button[disabled]{opacity:.45;cursor:not-allowed}
.chan-features{margin-left:auto;color:var(--green-deep);font-weight:600}
.beta-banner{flex-basis:100%;color:var(--warn);font-weight:700;font-size:12.5px}
.features{list-style:none;margin:0;padding:0}
.feature-row{display:flex;flex-wrap:wrap;gap:8px 12px;align-items:center;justify-content:space-between;padding:11px 0;border-top:1px solid var(--line)}
.feature-row:first-child{border-top:0}
.feature-row.greyed{opacity:.55}
.badge.live{background:var(--ok-bg);color:var(--ok)}
.badge.beta{background:var(--warn-bg);color:var(--warn)}
.badge.planned{background:var(--sand-light);color:var(--muted)}
.promolog{list-style:none;margin:0;padding:0;font-size:13.5px}
.promolog li{padding:5px 0;border-top:1px solid var(--line)}
.promolog li:first-child{border-top:0}

/* Hale name story */
.hale-story{border-left:3px solid var(--gold-warm)}
.hale-story p{margin:0 0 10px;line-height:1.55}
.hale-story em{font-style:italic;color:var(--green-deep)}

/* "drop it like it's hot" drag-and-drop zone */
.dropzone{display:block;border:2px dashed var(--sand-warm);border-radius:var(--radius-sm);background:#fbf9f4;margin:0 0 16px;transition:border-color .15s,background .15s}
.dropzone.dragover{border-color:var(--gold-warm);background:var(--warn-bg)}
.dropzone.uploading{opacity:.6;pointer-events:none}
.dropzone-inner{padding:20px 18px;text-align:center}
.dropzone-inner strong{display:block;font-size:16px;margin-bottom:4px}
.dropzone-inner input[type=file]{display:block;margin:12px auto 10px;max-width:100%}
.review-box{border:1px solid var(--gold-soft);background:var(--warn-bg);border-radius:var(--radius-sm);padding:12px 14px;margin:0 0 16px}
.review-box .doclist{margin:8px 0 0}
.review-box select{padding:8px 10px;border:1px solid var(--sand-warm);border-radius:var(--radius-sm);font-family:var(--sans);font-size:14px}

/* self-serve signing: account bar */
.sender-bar{display:flex;flex-wrap:wrap;gap:8px 16px;align-items:center;justify-content:space-between;
  padding:10px 14px;margin:0 0 18px;background:#eef3ee;border:1px solid #cdd9cd;border-radius:var(--radius-sm);font-size:13.5px}
.sender-bar-links{display:flex;gap:14px;align-items:center}
.linkbtn{background:none;border:0;padding:0;color:var(--green-deep);font:inherit;cursor:pointer;text-decoration:underline}

/* self-serve signing: compose + status */
.party-row{display:flex;gap:10px;margin:0 0 10px}
.party-row input{flex:1;min-width:0;padding:11px 12px;border:1px solid var(--sand-warm);border-radius:var(--radius-sm);font-size:15px;font-family:var(--sans);background:#fff;color:var(--ink)}
.party-row input:focus{outline:none;border-color:var(--gold-warm);box-shadow:0 0 0 3px rgba(201,169,97,.25)}
.signers{list-style:none;margin:0;padding:0}
.signer-row{display:flex;flex-wrap:wrap;align-items:center;gap:10px 14px;padding:14px 0;border-top:1px solid var(--line)}
.signer-row:first-child{border-top:0}
.signer-id{display:flex;align-items:center;gap:12px;flex:1;min-width:200px}
.signer-n{display:inline-flex;align-items:center;justify-content:center;width:26px;height:26px;border-radius:50%;background:var(--green-deep);color:var(--sand-light);font-size:13px;font-weight:700;flex:none}
.signer-link{flex-basis:100%;font-size:13px;color:var(--muted)}
.price{font-weight:700;color:var(--green-deep);white-space:nowrap}
/* status page: per-signer lifecycle trail (invited → delivered → opened → signing → signed) */
.trail{flex-basis:100%;list-style:none;display:flex;flex-wrap:wrap;gap:4px 0;margin:4px 0 0;padding:0;font-size:12px}
.trail li{display:inline-flex;align-items:center;gap:6px;color:var(--muted);white-space:nowrap}
.trail li+li::before{content:"";width:18px;height:2px;background:var(--line);margin:0 7px;border-radius:2px}
.trail .trail-dot{width:9px;height:9px;border-radius:50%;background:var(--sand-mid);box-shadow:0 0 0 1px var(--line);flex:none}
.trail li.done{color:var(--ok)}
.trail li.done .trail-dot{background:var(--ok);box-shadow:none}
.trail li.done+li::before{background:var(--ok-bg)}
.trail li.current{color:var(--gold-label);font-weight:700}
.trail li.current .trail-dot{background:var(--gold-warm);box-shadow:0 0 0 3px rgba(201,169,97,.25)}
@media(max-width:520px){.party-row{flex-direction:column;gap:8px}}
/* 390px mobile QC (R3 Stream C): on phone widths the signer rows must never force
   horizontal overflow — drop the fixed min-width and let long method pills wrap. */
@media(max-width:480px){
  .signer-id{min-width:0}
  .signer-row .status{white-space:normal;text-align:left}
}

/* UAE PASS verify prompt on the intake form */
.uaepass-prompt{display:flex;gap:12px;align-items:center;flex-wrap:wrap;justify-content:space-between;
  background:#eef3ee;border:1px solid #cdd9cd;border-radius:var(--radius-sm);padding:12px 14px;margin:0 0 18px;font-size:14px;color:var(--ink-soft)}
.uaepass-prompt span{flex:1;min-width:200px}

/* installed-app (PWA) chrome: respect the notch / safe areas in standalone mode */
.topbar{padding-top:max(16px,env(safe-area-inset-top));
  padding-left:max(clamp(20px,5vw,40px),env(safe-area-inset-left));
  padding-right:max(clamp(20px,5vw,40px),env(safe-area-inset-right))}
.foot{padding-bottom:max(24px,env(safe-area-inset-bottom))}
/* dismissible "install app" bar (PWA) */
.installbar{position:fixed;left:12px;right:12px;bottom:calc(12px + env(safe-area-inset-bottom));z-index:50;
  display:flex;align-items:center;gap:12px;background:var(--green-deep);color:var(--sand-light);
  padding:12px 14px;border-radius:14px;box-shadow:0 8px 28px rgba(26,31,26,.28);max-width:520px;margin:0 auto;font-size:14px}
.installbar span{flex:1}
.installbar-go{background:var(--gold-warm);color:#3a2c10;border:0;border-radius:999px;padding:8px 16px;font-weight:700;font-size:13.5px;cursor:pointer}
.installbar-x{background:transparent;border:0;color:var(--sand-warm);font-size:20px;line-height:1;cursor:pointer;padding:0 4px}
@media (display-mode:standalone){.installbar{display:none}}
/* --- Hâle send-for-signature wizard --- */
.wizard{border-radius:22px;padding:30px 30px 26px}
.wz-head{display:none}
.wizard.is-wizard .wz-head{display:flex;align-items:center;gap:14px;margin-bottom:20px}
.wz-stepn{font-size:12px;font-weight:700;letter-spacing:.04em;color:var(--gold-label);white-space:nowrap;text-transform:uppercase}
.wz-bar{flex:1;height:5px;background:var(--sand-mid);border-radius:999px;overflow:hidden}
.wz-bar i{display:block;height:100%;width:16%;background:var(--gold-warm);border-radius:999px;transition:width .25s ease}
.wizard.is-wizard .wz-step{display:none}
.wizard.is-wizard .wz-step.is-active{display:block;animation:wzIn .22s ease}
@keyframes wzIn{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}
.wz-eyebrow{font-size:12px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--gold-label);margin:0 0 6px}
.wz-step h2{font-size:26px;margin:0 0 6px}
.wz-step .field{margin:14px 0 4px}
.wz-step .field input{padding:14px 15px;font-size:16px;border-radius:12px}
.wz-step .dropzone{border-radius:16px}
.wz-invalid{border-color:var(--err) !important;box-shadow:0 0 0 3px rgba(155,44,44,.12) !important}
.wz-nav{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-top:24px}
.wz-spacer{flex:1}
.wz-backbtn{border-radius:999px;padding:13px 24px}
.wz-counts{display:flex;flex-wrap:wrap;gap:10px;align-items:center;margin:16px 0 4px}
.wz-counts button{width:58px;height:58px;border-radius:16px;border:1.5px solid var(--sand-warm);background:#fff;font-size:19px;font-weight:600;color:var(--ink);font-family:var(--serif)}
.wz-counts button.is-sel{background:var(--green-deep);color:var(--gold-warm);border-color:var(--green-deep)}
.wz-counts input[type=number]{width:88px;height:58px;border-radius:16px;border:1.5px solid var(--sand-warm);padding:0 14px;font-size:17px;font-family:var(--sans);margin-left:6px}
.wz-summary{list-style:none;margin:14px 0 4px;padding:0;border:1px solid var(--line);border-radius:14px;overflow:hidden}
.wz-summary li{display:flex;justify-content:space-between;gap:14px;padding:12px 16px;border-bottom:1px solid var(--line);background:#fff}
.wz-summary li:last-child{border-bottom:0}
.wz-summary li span{color:var(--gold-label);font-size:12.5px;font-weight:700;text-transform:uppercase;letter-spacing:.03em}
.wz-summary li strong{font-weight:600;text-align:right}
/* document source choice + template picker */
.wz-choices{display:flex;flex-direction:column;gap:12px;margin:18px 0 4px}
.wz-choice{display:flex;flex-direction:column;align-items:flex-start;gap:4px;text-align:left;padding:18px 20px;border-radius:16px;border:1.5px solid var(--sand-warm);background:#fff;cursor:pointer;font-family:var(--sans)}
.wz-choice strong{font-family:var(--serif);font-size:18px;color:var(--ink)}
.wz-choice span{color:var(--muted);font-size:14px}
.wz-choice.is-sel{border-color:var(--green-deep);box-shadow:0 0 0 3px rgba(27,42,29,.08)}
.wz-cats{display:flex;flex-wrap:wrap;gap:8px;margin:14px 0}
.wz-cat{padding:9px 16px;border-radius:999px;border:1.5px solid var(--sand-warm);background:#fff;font-size:14px;color:var(--ink);cursor:pointer;font-family:var(--sans)}
.wz-cat.is-sel{background:var(--green-deep);color:var(--gold-warm);border-color:var(--green-deep)}
.wz-tpl-list{display:flex;flex-direction:column;gap:10px;margin:6px 0 4px}
.wz-tpl{display:flex;flex-direction:column;align-items:flex-start;gap:3px;text-align:left;padding:14px 16px;border-radius:14px;border:1.5px solid var(--sand-warm);background:#fff;cursor:pointer;font-family:var(--sans)}
.wz-tpl strong{font-family:var(--serif);font-size:16.5px;color:var(--ink)}
.wz-tpl-cat{font-size:11px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--gold-label)}
.wz-tpl-sum{color:var(--muted);font-size:13.5px}
.wz-tpl-guidance{color:var(--muted);font-size:12.5px;font-style:italic;border-top:1px solid var(--sand-warm);margin-top:6px;padding-top:6px}
.wz-cat-intro{background:var(--cream-deep,#f5f0e8);border-radius:10px;padding:12px 14px;font-size:13.5px;color:var(--ink);line-height:1.55;margin-bottom:8px}
.wz-cat-intro[hidden]{display:none}
.wz-tpl.is-sel{border-color:var(--green-deep);box-shadow:0 0 0 3px rgba(27,42,29,.08)}
.wz-tpl-empty{color:var(--muted);padding:10px 0}
.wz-langs{display:flex;flex-wrap:wrap;gap:10px;margin:16px 0 6px}
.wz-lang{padding:12px 18px;border-radius:14px;border:1.5px solid var(--sand-warm);background:#fff;font-size:15px;color:var(--ink);cursor:pointer;font-family:var(--serif)}
.wz-lang.is-sel{background:var(--green-deep);color:var(--gold-warm);border-color:var(--green-deep)}
.wz-lang-tag{font-family:var(--sans);font-size:11px;font-weight:700;color:var(--gold-warm);margin-left:6px}
.wz-langnote{margin:10px 0 0}
.wz-fields{display:flex;flex-direction:column;gap:4px;margin:8px 0}
.wz-fields label{display:block;font-size:13px;font-weight:600;color:var(--ink);margin-bottom:4px}
.wz-fields .field input{padding:12px 14px;font-size:15px;border-radius:12px}
.wz-preview-actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:8px}
.wz-preview .docpreview{height:50vh;min-height:320px}
/* "save this setup as a template" on the review step */
.wz-savetpl{margin:18px 0 4px;padding:16px;border:1px solid var(--line);border-radius:14px;background:#fbf9f4}
.wz-savetpl-check{display:flex;align-items:center;gap:10px;font-weight:600;font-size:14.5px;cursor:pointer}
.wz-savetpl-check input{width:18px;height:18px;accent-color:var(--green-forest)}
.wz-savetpl-name{margin:14px 0 0}
.wz-savetpl-name input{padding:12px 14px;font-size:15px;border-radius:12px}
/* signature-method guidance (collapsible <details>, CSP-safe — no JS) */
.method-guide{margin:10px 0 4px;border:1px solid var(--line);border-radius:14px;background:#fbf9f4;overflow:hidden}
.method-guide>summary{cursor:pointer;list-style:none;padding:12px 16px;font-size:14px;font-weight:600;color:var(--gold-label);display:flex;align-items:center;gap:8px}
.method-guide>summary::-webkit-details-marker{display:none}
.method-guide>summary::before{content:'?';display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;border-radius:999px;background:var(--green-deep);color:var(--gold-warm);font-size:12px;font-weight:700;flex:none}
.method-guide[open]>summary{border-bottom:1px solid var(--line)}
.mguide-list{list-style:none;margin:0;padding:4px 0}
.mguide-row{display:grid;grid-template-columns:130px 150px 1fr;gap:6px 16px;align-items:baseline;padding:12px 16px;border-bottom:1px solid var(--line)}
.mguide-row:last-child{border-bottom:0}
.mguide-method{font-family:var(--serif);font-size:16px;font-weight:600;color:var(--ink)}
.mguide-assurance{font-size:13px;font-weight:700;color:var(--green-forest);letter-spacing:.04em;white-space:nowrap}
.mguide-how{grid-column:3;color:var(--ink-soft);font-size:13.5px}
.mguide-best{grid-column:1 / -1;color:var(--muted);font-size:13px}
.mguide-best em{color:var(--gold-label);font-style:normal;font-weight:700}
.mguide-note{margin:0;padding:12px 16px;font-size:13px;color:var(--ink-soft);background:#fff}
@media(max-width:520px){.wizard{padding:22px 18px} .wz-step h2{font-size:22px} .wz-nav{flex-wrap:wrap}
  .mguide-row{grid-template-columns:1fr auto;gap:4px 10px}
  .mguide-method{grid-column:1}
  .mguide-assurance{grid-column:2;text-align:right}
  .mguide-how{grid-column:1 / -1}
}

  /* Private-preview password gate (src/site-gate.ts) */
  .gate-wrap{max-width:30rem;margin:8vh auto 0;text-align:center;padding:0 1.25rem}
  .gate-mark{font-family:var(--serif,Georgia,serif);font-size:2.6rem;letter-spacing:.04em;color:var(--gold-warm,#C9A961)}
  .gate-form{margin:1.5rem auto 1rem;max-width:22rem;text-align:left;display:flex;flex-direction:column;gap:.5rem}
  .gate-form label{font-size:.8rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted,#6B655A)}
  .gate-form input{width:100%;padding:.7rem .9rem;border:1px solid var(--line,#d8cca8);border-radius:.4rem;background:#fff;font-size:1rem}
  .gate-form button{margin-top:.4rem;padding:.7rem 1rem;border:0;border-radius:.4rem;background:var(--green-deep,#1B2A1D);color:#fff;font-size:1rem;cursor:pointer}
  .form-error{color:#9b2c2c;font-size:.9rem;margin:.25rem 0}

/* ── RTL / Arabic additive overrides ───────────────────────────────────────
   Activated by [dir="rtl"] on <html>. Uses logical properties where possible;
   explicit mirroring only where logical properties don't apply.
   References, hashes, phone numbers, and identifiers are wrapped in
   <bdi dir="ltr"> or <span dir="ltr"> in the template layer so they never
   flip regardless of page direction.                                        */
[dir="rtl"] body{font-family:'Segoe UI',system-ui,-apple-system,Tahoma,Arial,sans-serif}
[dir="rtl"] h1,[dir="rtl"] h2,[dir="rtl"] h3{font-family:'Segoe UI',system-ui,-apple-system,Tahoma,Arial,sans-serif;letter-spacing:0}
[dir="rtl"] .eyebrow{letter-spacing:.06em}

/* chrome */
[dir="rtl"] .topbar{flex-direction:row-reverse}
[dir="rtl"] .lang-toggle{margin-inline-start:0;margin-inline-end:auto}

/* cards & layout */
[dir="rtl"] .card>h2{flex-direction:row-reverse}
[dir="rtl"] .page-head{text-align:right}
[dir="rtl"] .signwrap{text-align:right}
[dir="rtl"] .signwrap .lead{margin:0 auto 6px}

/* forms */
[dir="rtl"] .field label{text-align:right}
[dir="rtl"] .field input,[dir="rtl"] .field select{text-align:right}
[dir="rtl"] .fieldgroup .eyebrow{text-align:right}
[dir="rtl"] .req{margin-inline-start:0;margin-inline-end:4px}
[dir="rtl"] .actions{flex-direction:row-reverse}
[dir="rtl"] .wz-nav{flex-direction:row-reverse}

/* stepper */
[dir="rtl"] .stepper{flex-direction:row-reverse}
[dir="rtl"] .step{flex-direction:row-reverse}

/* sign steps progress bar */
[dir="rtl"] .signsteps{flex-direction:row-reverse}
[dir="rtl"] .signsteps li::before{left:50%;right:auto}
[dir="rtl"] .signsteps li:last-child::before{display:none}
[dir="rtl"] .signsteps li:first-child::before{display:block}

/* signer rows */
[dir="rtl"] .signer-row{flex-direction:row-reverse}
[dir="rtl"] .signer-id{flex-direction:row-reverse}
[dir="rtl"] .sender-bar{flex-direction:row-reverse}
[dir="rtl"] .sender-bar-links{flex-direction:row-reverse}

/* status trail */
[dir="rtl"] .trail{flex-direction:row-reverse}
[dir="rtl"] .trail li+li::before{content:"";width:18px;height:2px;background:var(--line);margin:0 7px;border-radius:2px;order:0}

/* filters */
[dir="rtl"] .filters{flex-direction:row-reverse}

/* wizard */
[dir="rtl"] .wz-choices{text-align:right}
[dir="rtl"] .wz-choice{align-items:flex-end}
[dir="rtl"] .wz-head{flex-direction:row-reverse}
[dir="rtl"] .wz-cats{flex-direction:row-reverse}
[dir="rtl"] .wz-langs{flex-direction:row-reverse}
[dir="rtl"] .wz-summary li{flex-direction:row-reverse}
[dir="rtl"] .wz-summary li strong{text-align:left}
[dir="rtl"] .wz-savetpl-check{flex-direction:row-reverse}
[dir="rtl"] .method-guide>summary{flex-direction:row-reverse}
[dir="rtl"] .mguide-row{direction:rtl;text-align:right}
[dir="rtl"] .mguide-best{text-align:right}

/* OTP input stays LTR (digits) */
[dir="rtl"] .otp-input{direction:ltr;letter-spacing:.42em}

/* document preview */
[dir="rtl"] .docitem-head{flex-direction:row-reverse}
[dir="rtl"] .upload{flex-direction:row-reverse}
[dir="rtl"] .uaepass-prompt{flex-direction:row-reverse}
[dir="rtl"] .dropzone-inner{text-align:right}

/* admin (stays LTR even in AR pages — scope guard) */
[dir="rtl"] .admin{direction:ltr}

/* language toggle pill */
.lang-toggle{display:inline-flex;align-items:center;gap:1px;border:1px solid var(--sand-warm);border-radius:999px;overflow:hidden;background:#fff;font-size:12px;font-weight:700}
.lang-toggle a{padding:4px 10px;color:var(--muted);text-decoration:none;transition:background .12s,color .12s}
.lang-toggle a:hover{background:var(--sand-light);color:var(--ink)}
.lang-toggle a.active{background:var(--green-deep);color:var(--gold-warm)}
.lang-toggle span.sep{color:var(--line);user-select:none}
