:root{
  --primary:#4C1D95;
  --accent:#7C3AED;
  --bg:#F7F2FF;
  --text:#1F1140;
  --muted:#5B4C82;
  --muted2:#7A68A7;
  --border:#E7DDF7;
  --shadow:0 18px 45px rgba(76,29,149,.14);
  --radius:18px;
  --radius2:14px;
  --max:1100px;
  --font-ui:"Inter","Segoe UI Variable","Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  --font-signature:"Zapfino","Apple Chancery","Bradley Hand","Segoe Script",cursive;
}
*{box-sizing:border-box}
[hidden]{display:none !important}
body{
  margin:0;
  font-family:var(--font-ui);
  color:var(--text);
  line-height:1.45;
  background:
    radial-gradient(1000px 600px at 20% 0%, color-mix(in srgb, var(--primary) 14%, white), transparent 60%),
    radial-gradient(900px 500px at 90% 30%, color-mix(in srgb, var(--accent) 12%, white), transparent 55%),
    var(--bg);
}
a{color:inherit}
.muted{color:var(--muted)}
.small{font-size:13px}
.topbar{
  display:flex;justify-content:space-between;align-items:center;gap:16px;
  padding:18px 22px;border-bottom:1px solid var(--border);position:sticky;top:0;
  background:rgba(247,242,255,.84);backdrop-filter:blur(10px);z-index:1000;
}
.brand{display:flex;align-items:center;gap:12px}
.brand__mark{
  width:42px;height:42px;border-radius:14px;display:grid;place-items:center;font-weight:800;
  background:linear-gradient(135deg, #1D4ED8, #06B6D4);border:1px solid rgba(29,78,216,.45);
  box-shadow:0 12px 28px rgba(29,78,216,.22);text-decoration:none;color:#fff;
}
.brand__name{font-weight:700}
.brand__sub{color:var(--muted2);font-size:13px;margin-top:2px}
.container{max-width:var(--max);margin:22px auto 60px;padding:0 18px}
.footer{max-width:var(--max);margin:0 auto 22px;padding:0 18px}
.card{
  background:linear-gradient(180deg,#fff,#f8fafc);
  border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);
  padding:20px;margin-bottom:18px;
}
.panel{
  background:#fff;border:1px solid var(--border);border-radius:var(--radius2);padding:14px;
}
.h1{margin:0 0 10px;font-size:26px;font-weight:650}
.h2{margin:0 0 10px;font-size:16px;font-weight:620}
.actions{display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.spacer{flex:1}
.grid{display:grid;grid-template-columns:1.2fr .8fr;gap:18px}
@media(max-width:900px){.grid{grid-template-columns:1fr}}
.stats-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px}
@media(max-width:760px){.stats-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}
.stat-card{background:#fff;border:1px solid var(--border);border-radius:14px;padding:14px}
.stat-card__label{font-size:13px;color:var(--muted2)}
.stat-card__value{font-size:26px;font-weight:700;margin-top:4px}
.btn{
  border:1px solid color-mix(in srgb, var(--primary) 28%, #cbd5e1);
  background:linear-gradient(180deg, color-mix(in srgb, var(--primary) 92%, white), var(--primary));
  color:#fff;border-radius:12px;padding:10px 14px;font-weight:600;cursor:pointer;text-decoration:none;
  display:inline-flex;align-items:center;justify-content:center;
  box-sizing:border-box;min-height:40px;line-height:1.1;white-space:nowrap;
  font-family:inherit;font-size:14px;
}
.btn:hover{filter:brightness(1.03)}
.btn:disabled{opacity:.55;cursor:not-allowed}
.btn--secondary{
  background:#fff;color:var(--text);border:1px solid var(--border);
}
.btn--sm{padding:7px 10px;font-size:12px;border-radius:10px;min-height:32px}
.btn--icon-only{
  width:40px;
  min-width:40px;
  padding:0;
}
.btn--sm.btn--icon-only{
  width:32px;
  min-width:32px;
}
.btn--icon-only.is-busy{
  opacity:.7;
}
.icon-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:36px;
  height:36px;
  border-radius:10px;
  border:1px solid var(--border);
  background:#fff;
  color:var(--text);
  cursor:pointer;
  line-height:1;
  text-decoration:none;
}
.icon-btn:hover{
  border-color:color-mix(in srgb, var(--primary) 35%, var(--border));
  background:color-mix(in srgb, var(--primary) 8%, white);
}
.icon-btn--danger{
  color:#991b1b;
  border-color:#fca5a5;
}
.icon-btn--danger:hover{
  border-color:#ef4444;
  background:#fef2f2;
}
.icon-btn:disabled{
  opacity:.6;
  cursor:not-allowed;
}
.icon-btn__svg{
  width:18px;
  height:18px;
  display:block;
}
.icon-btn__spinner{
  width:16px;
  height:16px;
  border:2px solid currentColor;
  border-right-color:transparent;
  border-radius:999px;
  display:block;
  animation:busy-spin .8s linear infinite;
}
.btn--icon-only .icon-btn__svg{
  width:18px;
  height:18px;
}
.pill-row{display:flex;flex-wrap:wrap;gap:10px}
.pill{
  font-size:13px;padding:6px 10px;border-radius:999px;border:1px solid var(--border);background:#fff;
  display:inline-flex;align-items:center;
}
.page-indicator{gap:6px;white-space:nowrap}
.page-indicator__label{opacity:.86}
.page-indicator__sep{opacity:.64}
.page-indicator__value{
  display:inline-grid;place-items:center;min-width:1.6em;
  font-weight:700;color:var(--text);
}
.pill--select{text-decoration:none}
.pill--select.is-active{background:color-mix(in srgb, var(--primary) 12%, white);border-color:color-mix(in srgb, var(--primary) 45%, var(--border))}
.pill--draft{background:#fff7ed;border-color:#fed7aa;color:#9a3412}
.pill--sent,.pill--open{background:#eff6ff;border-color:#bfdbfe;color:#1d4ed8}
.pill--completed{background:#ecfdf5;border-color:#a7f3d0;color:#065f46}
.pill--closed{background:#f8fafc;border-color:#cbd5e1;color:#475569}
.table-wrap{overflow:auto}
.real-table{width:100%;border-collapse:separate;border-spacing:0 10px}
.real-table thead th{
  text-align:left;font-size:12px;color:var(--muted2);font-weight:600;padding:0 10px;
}
.real-table tbody tr{background:#fff}
.is-delete-pending{
  opacity:.52;
  filter:saturate(.2);
  pointer-events:none;
}
.is-delete-pending .icon-btn,
.is-delete-pending .btn,
.is-delete-pending a,
.is-delete-pending button{
  pointer-events:none;
}
.real-table tbody td{
  padding:12px 10px;border-top:1px solid var(--border);border-bottom:1px solid var(--border);vertical-align:top;
}
.real-table tbody td:first-child{border-left:1px solid var(--border);border-radius:12px 0 0 12px}
.real-table tbody td:last-child{border-right:1px solid var(--border);border-radius:0 12px 12px 0}
.real-table__actions-head{text-align:right}
.real-table__actions-cell{white-space:nowrap}
.real-table__actions{
  display:inline-flex;
  align-items:center;
  gap:8px;
  flex-wrap:nowrap;
  white-space:nowrap;
  overflow-x:auto;
  max-width:100%;
  padding-bottom:2px;
}
.real-table__actions form{
  display:inline-flex;
  margin:0;
}
.field-group{margin:0 0 12px}
.label{display:block;font-size:13px;color:var(--muted);margin:0 0 6px}
.field{
  width:100%;padding:10px 12px;border:1px solid var(--border);border-radius:12px;background:#fff;
  color:var(--text);font:inherit;
}
textarea.field{resize:vertical;min-height:72px}
textarea.field.field--single-line{
  min-height:42px;
  height:42px;
  resize:none;
}
input[type="file"].upload-dropzone__input{
  position:absolute;
  width:1px;
  height:1px;
  padding:0;
  margin:-1px;
  overflow:hidden;
  clip:rect(0 0 0 0);
  white-space:nowrap;
  border:0;
}
input[type="file"].upload-dropzone__input:focus + .upload-dropzone__surface{
  outline:2px solid #1d4ed8;
  outline-offset:3px;
}
.upload-dropzone{
  position:relative;
  display:block;
  cursor:pointer;
}
.upload-dropzone__surface{
  display:flex;
  align-items:center;
  gap:14px;
  min-height:104px;
  padding:16px;
  border:1px dashed color-mix(in srgb, var(--primary) 28%, var(--border));
  border-radius:16px;
  background:
    radial-gradient(180px 90px at 100% 0, color-mix(in srgb, var(--accent) 10%, white), transparent 70%),
    linear-gradient(180deg, #fff, #faf7ff);
  transition:border-color .18s ease, background-color .18s ease, box-shadow .18s ease, transform .18s ease;
}
.upload-dropzone:hover .upload-dropzone__surface,
.upload-dropzone.is-dragover .upload-dropzone__surface{
  border-color:color-mix(in srgb, var(--primary) 46%, var(--border));
  box-shadow:0 14px 28px rgba(76,29,149,.08);
  transform:translateY(-1px);
}
.upload-dropzone.is-selected .upload-dropzone__surface{
  border-style:solid;
  border-color:color-mix(in srgb, #16a34a 34%, var(--border));
  background:
    radial-gradient(180px 90px at 100% 0, color-mix(in srgb, #16a34a 10%, white), transparent 70%),
    linear-gradient(180deg, #fff, #f6fff8);
}
.upload-dropzone__glyph{
  flex:0 0 44px;
  width:44px;
  height:44px;
  display:grid;
  place-items:center;
  border-radius:14px;
  border:1px solid color-mix(in srgb, var(--primary) 20%, var(--border));
  background:color-mix(in srgb, var(--primary) 8%, white);
  color:var(--primary);
}
.upload-dropzone__body{
  min-width:0;
  flex:1 1 auto;
}
.upload-dropzone__title{
  font-weight:620;
}
.upload-dropzone__meta{
  margin-top:4px;
  color:var(--muted);
  font-size:13px;
  overflow-wrap:anywhere;
}
.upload-dropzone__hint{
  margin-top:8px;
  color:var(--muted2);
  font-size:12px;
}
.busy-overlay{
  position:absolute;
  inset:0;
  display:none;
  align-items:center;
  justify-content:center;
  padding:20px;
  background:rgba(15,23,42,.5);
  backdrop-filter:blur(2px);
  z-index:40;
}
.busy-overlay.is-open{
  display:flex;
}
.busy-overlay--fixed{
  position:fixed;
  inset:0;
  width:100vw;
  height:100vh;
  z-index:2000;
}
.busy-overlay__panel{
  background:#0f172a;
  color:#fff;
  padding:18px 22px;
  border-radius:14px;
  min-width:220px;
  max-width:min(92vw, 340px);
  text-align:center;
  box-shadow:0 20px 40px rgba(0,0,0,.32);
}
.busy-overlay__spinner{
  width:34px;
  height:34px;
  margin:0 auto 12px;
  border:3px solid rgba(255,255,255,.22);
  border-top-color:#fff;
  border-radius:50%;
  animation:busy-spin .9s linear infinite;
}
.busy-overlay__text{
  font-size:14px;
  line-height:1.4;
}
.app-toast{
  position:fixed;
  right:20px;
  bottom:20px;
  display:flex;
  align-items:center;
  gap:10px;
  min-width:220px;
  max-width:min(92vw, 420px);
  padding:12px 14px;
  border-radius:14px;
  border:1px solid #bbf7d0;
  background:#f0fdf4;
  color:#065f46;
  box-shadow:0 20px 40px rgba(15,23,42,.18);
  opacity:0;
  transform:translateY(8px);
  pointer-events:none;
  transition:opacity .18s ease, transform .18s ease;
  z-index:2100;
}
.app-toast.is-open{
  opacity:1;
  transform:translateY(0);
}
.app-toast--error{
  border-color:#fecaca;
  background:#fef2f2;
  color:#991b1b;
}
@keyframes busy-spin{
  to{transform:rotate(360deg)}
}
@media(max-width:760px){
  .upload-dropzone__surface{
    align-items:flex-start;
  }
  .app-toast{
    left:12px;
    right:12px;
    bottom:12px;
    min-width:0;
  }
}
.field + .ts-wrapper{width:100%}
.field + .ts-wrapper .ts-control{
  min-height:40px;
  padding:8px 12px;
  border-radius:12px;
  border:1px solid var(--border);
  background:#fff;
  box-shadow:none;
  display:flex;
  align-items:center;
  gap:6px;
}
.field + .ts-wrapper .ts-control input{font:inherit;line-height:1.2}
.field + .ts-wrapper.single .ts-control .item{line-height:1.2}
.field + .ts-wrapper.multi .ts-control{
  min-height:44px;
  height:auto;
  flex-wrap:wrap;
  align-items:flex-start;
}
.field + .ts-wrapper.focus .ts-control,
.field + .ts-wrapper:focus-within .ts-control{
  border-color:color-mix(in srgb, var(--primary) 35%, var(--border));
  box-shadow:0 0 0 3px color-mix(in srgb, var(--primary) 14%, transparent);
}
.field + .ts-wrapper .ts-dropdown{
  border-radius:12px;
  border:1px solid var(--border);
}
.field + .ts-wrapper .ts-dropdown .option{padding:9px 12px}
.checkbox{display:flex;align-items:center;gap:8px;font-size:14px}
.checkbox input{flex:0 0 auto}
.notice{
  border-radius:12px;padding:10px 12px;margin-bottom:12px;border:1px solid var(--border);background:#fff;
}
.notice--info{background:#f8fbff;border-color:#dbeafe}
.notice--success{background:#f0fdf4;border-color:#bbf7d0}
.notice--error{background:#fef2f2;border-color:#fecaca}
.toast-stack{
  position:fixed;
  top:86px;
  right:18px;
  z-index:1400;
  display:grid;
  gap:10px;
  pointer-events:none;
}
.toast{
  min-width:min(360px, calc(100vw - 36px));
  max-width:min(420px, calc(100vw - 36px));
  padding:12px 14px;
  border-radius:14px;
  border:1px solid var(--border);
  background:#fff;
  color:var(--text);
  box-shadow:0 18px 40px rgba(15,23,42,.14);
  display:flex;
  align-items:center;
  gap:10px;
  opacity:0;
  transform:translateY(-8px);
  animation:toast-in .18s ease-out forwards;
}
.toast--success{
  border-color:#bbf7d0;
  background:#f0fdf4;
}
.toast--error{
  border-color:#fecaca;
  background:#fef2f2;
}
.toast__icon{
  width:24px;
  height:24px;
  border-radius:999px;
  display:grid;
  place-items:center;
  flex:0 0 auto;
  font-size:13px;
  font-weight:700;
}
.toast--success .toast__icon{
  background:#dcfce7;
  color:#166534;
}
.toast--error .toast__icon{
  background:#fee2e2;
  color:#991b1b;
}
.toast__body{
  min-width:0;
  font-size:14px;
  font-weight:600;
}
.toast.is-leaving{
  animation:toast-out .16s ease-in forwards;
}
@keyframes toast-in{
  from{opacity:0;transform:translateY(-8px)}
  to{opacity:1;transform:translateY(0)}
}
@keyframes toast-out{
  from{opacity:1;transform:translateY(0)}
  to{opacity:0;transform:translateY(-6px)}
}
@media(max-width:760px){
  .toast-stack{
    top:auto;
    right:12px;
    left:12px;
    bottom:12px;
  }
  .toast{
    min-width:0;
    max-width:none;
  }
}
.matter-summary{
  display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;margin-top:14px;
}
@media(max-width:760px){.matter-summary{grid-template-columns:1fr}}
.matter-summary__item{background:#fff;border:1px solid var(--border);border-radius:14px;padding:12px}
.matter-summary__label{font-size:12px;color:var(--muted2)}
.matter-summary__value{font-size:20px;font-weight:700;margin-top:6px}
.list{list-style:none;padding:0;margin:0;display:grid;gap:8px}
.list__item{padding:10px 12px;border:1px solid var(--border);border-radius:12px;background:#fff}
.auth-card{max-width:520px;margin:6vh auto 0}
.kebab{position:relative}
.kebab-btn{
  border:1px solid var(--border);background:#fff;color:var(--text);
  border-radius:12px;padding:8px 12px;font-weight:600;cursor:pointer;
}
.kebab-menu{
  position:absolute;right:0;top:calc(100% + 8px);min-width:180px;background:#fff;border:1px solid var(--border);
  border-radius:12px;box-shadow:var(--shadow);padding:6px;z-index:1001;
}
.kebab-item{
  width:100%;display:block;text-align:left;border:0;background:transparent;padding:9px 10px;border-radius:8px;
  text-decoration:none;color:var(--text);cursor:pointer;font:inherit;
}
.kebab-item:hover{background:color-mix(in srgb, var(--primary) 7%, white)}
@media (max-width:760px){
  .real-table thead{display:none}
  .real-table tbody tr{display:block;border:1px solid var(--border);border-radius:14px;margin-bottom:12px}
  .real-table tbody td{
    display:flex;justify-content:space-between;gap:12px;border:0;border-top:1px solid #f1e9fb;padding:10px 12px;
  }
  .real-table tbody td:first-child{border-left:0;border-radius:14px 14px 0 0;border-top:0}
  .real-table tbody td:last-child{border-right:0;border-radius:0 0 14px 14px}
  .real-table tbody td::before{content:attr(data-label);font-size:12px;color:var(--muted2);flex:0 0 92px}
  .real-table tbody td.real-table__actions-cell{
    display:block;
  }
  .real-table tbody td.real-table__actions-cell::before{
    display:block;
    margin-bottom:6px;
  }
}

.esign-builder{display:grid;grid-template-columns:minmax(0,1.5fr) minmax(320px,.9fr);gap:14px;margin-top:12px}
.esign-builder__sidebar{min-width:0}
.esign-builder__viewer{min-width:0}
.esign-signer{display:grid;grid-template-columns:minmax(0,1.55fr) minmax(280px,.85fr);gap:14px;margin-top:12px}
.esign-signer__viewer,.esign-signer__sidebar{min-width:0}
@media(max-width:980px){.esign-builder,.esign-signer{grid-template-columns:1fr}}
.card--signer{
  padding:20px;
}
.signer-header{
  align-items:flex-start;
  margin-bottom:4px;
}
.signer-header__title{
  min-width:0;
}
.signer-viewer-toolbar{
  position:static;
  top:auto;
  z-index:auto;
  margin:-6px -6px 10px;
  padding:6px;
  border-radius:14px;
  background:rgba(255,255,255,.92);
  backdrop-filter:none;
  border:1px solid color-mix(in srgb, var(--primary) 10%, var(--border));
}
.signer-page-btn{
  min-width:58px;
}
.signer-form__meta{
  display:grid;
  grid-template-columns:repeat(2, minmax(0, 1fr));
  gap:12px;
  margin-top:12px;
}
.signer-meta-card{
  padding:12px;
  border:1px solid color-mix(in srgb, var(--primary) 10%, var(--border));
  border-radius:14px;
  background:linear-gradient(180deg, #fff, #fbfdff);
}
.signer-meta-card__field{
  margin-bottom:8px;
}
.signer-consent{
  min-height:100%;
  align-items:flex-start;
  line-height:1.5;
}
.signer-submit-bar{
  margin-top:12px;
  align-items:stretch;
}
.signer-submit-bar__primary{
  flex:1 1 260px;
}
.signer-submit-bar__secondary{
  flex:1 1 220px;
}
.signer-submit-bar__status{
  margin-top:8px;
}
.signer-side-panel .notice{
  overflow-wrap:anywhere;
}
.signer-field-list{
  display:grid;
  gap:8px;
}
.signer-field-list .list__item{
  min-height:62px;
  display:flex;
  flex-direction:column;
  justify-content:center;
}
.signer-field-list .list__item strong{
  overflow-wrap:anywhere;
}
.step-carousel{
  padding:16px;
  background:
    radial-gradient(420px 160px at 100% -10%, color-mix(in srgb, var(--accent) 12%, white), transparent 70%),
    linear-gradient(180deg, #fff, #fbfcff);
}
.step-carousel__header{
  display:flex;justify-content:space-between;align-items:flex-start;gap:12px;flex-wrap:wrap;
  margin-bottom:12px;padding-bottom:10px;border-bottom:1px solid color-mix(in srgb, var(--primary) 10%, var(--border));
}
.step-carousel__controls{display:flex;align-items:center;gap:10px;flex-wrap:wrap;justify-content:flex-end}
.step-carousel__nav{
  display:flex;gap:8px;flex-wrap:wrap;padding:4px;border-radius:14px;
  background:color-mix(in srgb, var(--primary) 3%, white);
  border:1px solid color-mix(in srgb, var(--primary) 10%, var(--border));
}
.step-carousel__tab{
  border:1px solid transparent;background:transparent;color:var(--text);border-radius:12px;
  padding:7px;font-weight:600;cursor:pointer;
  display:inline-flex;align-items:center;gap:8px;
  transition:background-color .16s ease,border-color .16s ease,box-shadow .16s ease,color .16s ease,transform .16s ease;
}
.step-carousel__tab:hover{
  background:rgba(255,255,255,.84);
  border-color:color-mix(in srgb, var(--primary) 16%, var(--border));
}
.step-carousel__tab-num{
  width:24px;height:24px;border-radius:999px;display:grid;place-items:center;
  font-size:12px;font-weight:800;background:#eef2ff;color:#4338ca;border:1px solid #c7d2fe;
}
.step-carousel__tab-num .icon-btn__svg{
  width:14px;
  height:14px;
}
.step-carousel__tab-label{white-space:nowrap}
.step-carousel__tab.is-active{
  background:#fff;
  border-color:color-mix(in srgb, var(--primary) 28%, var(--border));
  box-shadow:0 6px 14px rgba(76,29,149,.08), inset 0 -1px 0 rgba(76,29,149,.04);
  color:color-mix(in srgb, var(--primary) 75%, var(--text));
}
.step-carousel__tab.is-active .step-carousel__tab-num{
  background:linear-gradient(180deg, color-mix(in srgb, var(--primary) 18%, white), color-mix(in srgb, var(--primary) 12%, white));
  border-color:color-mix(in srgb, var(--primary) 28%, #cbd5e1);
  color:var(--primary);
}
.step-carousel__tab:focus-visible{outline:2px solid #1d4ed8;outline-offset:2px}
.step-carousel__pager{display:flex;align-items:center;gap:8px}
.step-carousel__arrow{
  width:36px;height:36px;border-radius:12px;border:1px solid color-mix(in srgb, var(--primary) 16%, var(--border));
  background:#fff;color:var(--text);font-size:22px;line-height:1;cursor:pointer;
  display:grid;place-items:center;box-shadow:0 6px 14px rgba(15,23,42,.04);
}
.step-carousel__arrow:hover{border-color:color-mix(in srgb, var(--primary) 30%, var(--border))}
.step-carousel__arrow:disabled{opacity:.45;cursor:not-allowed}
.step-carousel__viewport{
  position:relative;overflow:hidden;border-radius:16px;
  border:1px solid color-mix(in srgb, var(--primary) 12%, var(--border));
  background:linear-gradient(180deg,#ffffff,#fbfdff);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.7);
  transition:height .24s ease;
}
.step-carousel__viewport::before,
.step-carousel__viewport::after{
  content:"";position:absolute;top:0;bottom:0;width:18px;z-index:2;pointer-events:none;
}
.step-carousel__viewport::before{left:0;background:linear-gradient(90deg, rgba(255,255,255,.96), rgba(255,255,255,0))}
.step-carousel__viewport::after{right:0;background:linear-gradient(270deg, rgba(255,255,255,.96), rgba(255,255,255,0))}
.step-carousel__track{
  display:flex;gap:0;align-items:flex-start;will-change:transform;
  transition:transform .28s cubic-bezier(.2,.8,.2,1);
  padding:18px 0;
}
.step-carousel__panel{
  flex:0 0 100%;min-width:100%;box-sizing:border-box;
  padding:10px 18px 8px;opacity:.9;overflow:hidden;
}
.step-carousel__panel.is-active{opacity:1}
.step-carousel__panel .grid > *{min-width:0}
.step-carousel__panel .actions > *{min-width:0}
.step-carousel__panel .btn{
  max-width:100%;
  white-space:normal;
  overflow-wrap:anywhere;
}
.step-carousel__panel .muted,
.step-carousel__panel .small,
.step-carousel__panel .label,
.step-carousel__panel td,
.step-carousel__panel th,
.step-carousel__panel .list__item,
.step-carousel__panel .notice{
  overflow-wrap:anywhere;
  word-break:break-word;
}
.inspector-grid{gap:10px}
.inspector-grid--triple{grid-template-columns:repeat(3,minmax(0,1fr))}
.inspector-grid--double{grid-template-columns:repeat(2,minmax(0,1fr))}
@media(max-width:760px){
  .step-carousel__controls{width:100%;justify-content:space-between}
  .step-carousel__nav{flex:1 1 auto;overflow:auto;flex-wrap:nowrap}
  .step-carousel__tab{flex:0 0 auto}
  .step-carousel__track{padding:14px 0}
  .step-carousel__panel{padding:8px 14px 6px}
  .inspector-grid--triple,
  .inspector-grid--double{grid-template-columns:1fr}
  .field + .ts-wrapper .ts-control{min-height:44px}
}
@media (prefers-reduced-motion: reduce){
  .step-carousel__track,.step-carousel__viewport,.step-carousel__tab,.step-carousel__arrow{transition:none}
}
.viewer-toolbar{display:flex;justify-content:space-between;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:10px}
.viewer-toolbar__left,.viewer-toolbar__right{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.doc-stage-wrap{background:color-mix(in srgb, var(--primary) 4%, white);border:1px solid var(--border);border-radius:14px;padding:10px}
.doc-stage{position:relative;width:100%;min-height:640px;height:940px;background:#fff;border:1px solid #dbe3f0;border-radius:12px;overflow:hidden}
.doc-stage__placeholder{position:absolute;inset:0;display:grid;place-items:center;padding:20px;text-align:center;color:var(--muted);background:linear-gradient(180deg,#fff,#fafcff)}
.pdf-canvas{display:block;max-width:100%;height:auto;background:#fff}
.pdf-iframe{
  position:absolute;inset:0;width:100%;height:100%;
  border:0;background:#fff;pointer-events:none;
}
.field-overlay{position:absolute;inset:0;pointer-events:none;touch-action:none}
.field-overlay--signer{pointer-events:auto}
.overlay-field{
  position:absolute;display:flex;align-items:center;justify-content:flex-start;
  padding:2px 4px;border-radius:6px;border:1px dashed var(--field-accent, #8b5cf6);
  background:var(--field-bg, rgba(139,92,246,.08));color:var(--field-text, #4c1d95);pointer-events:auto;cursor:grab;
  text-align:left;font:inherit;box-sizing:border-box;overflow:hidden;
  will-change:left,top;
}
.overlay-field:active{cursor:grabbing}
.overlay-field:focus-visible{outline:2px solid #1d4ed8;outline-offset:2px}
.overlay-field.is-selected{
  border-style:solid;
  border-color:var(--field-accent, #4c1d95);
  box-shadow:0 0 0 2px var(--field-ring, rgba(76,29,149,.22)), 0 10px 24px var(--field-shadow, rgba(76,29,149,.12));
  background:var(--field-bg-strong, rgba(139,92,246,.14));
}
.overlay-field__text{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:block;max-width:100%;font-size:11px;line-height:1.05}
.overlay-field--checkbox,
.overlay-field--text,
.overlay-field--date{
  background:var(--field-bg, inherit);
  border-color:var(--field-accent, currentColor);
  color:var(--field-text, inherit);
}
.overlay-handle{
  position:absolute;width:10px;height:10px;border-radius:999px;background:#fff;
  border:2px solid var(--field-accent, #4c1d95);display:none;z-index:2;
}
.overlay-field.is-selected .overlay-handle{display:block}
.overlay-handle--nw{left:-6px;top:-6px;cursor:nwse-resize}
.overlay-handle--ne{right:-6px;top:-6px;cursor:nesw-resize}
.overlay-handle--sw{left:-6px;bottom:-6px;cursor:nesw-resize}
.overlay-handle--se{right:-6px;bottom:-6px;cursor:nwse-resize}
.field-crosshair{position:absolute;width:12px;height:12px;margin:-6px 0 0 -6px;border:2px solid #ef4444;border-radius:999px;background:rgba(239,68,68,.12);pointer-events:none;z-index:4}
.field-crosshair::before,.field-crosshair::after{content:"";position:absolute;background:#ef4444;opacity:.65}
.field-crosshair::before{left:50%;top:-12px;transform:translateX(-50%);width:1px;height:36px}
.field-crosshair::after{top:50%;left:-12px;transform:translateY(-50%);height:1px;width:36px}
.list__item--compact{padding:8px 10px}
.list__item.is-selected{
  border-color:color-mix(in srgb, var(--field-accent, var(--primary)) 45%, var(--border));
  background:color-mix(in srgb, var(--field-bg-strong, color-mix(in srgb, var(--primary) 8%, white)) 72%, white);
  box-shadow:0 8px 20px var(--field-shadow, rgba(76,29,149,.08));
}
.list__item.is-complete{
  border-color:color-mix(in srgb, #16a34a 42%, var(--border));
  background:color-mix(in srgb, #16a34a 7%, white);
}
.list__item--jumpable{cursor:pointer}
.list__item--jumpable:focus-visible{outline:2px solid #1d4ed8;outline-offset:2px}
.field-progress{font-weight:600}
.field-progress--complete{color:#065f46}
.field-progress--incomplete{color:#b91c1c}
.overlay-input{
  position:absolute;pointer-events:auto;display:flex;align-items:stretch;
  padding:0;border-radius:6px;border:1px solid rgba(76,29,149,.24);
  background:rgba(255,255,255,.92);box-shadow:0 6px 18px rgba(15,23,42,.08);
  box-sizing:border-box;overflow:hidden;
}
.overlay-input--readonly{
  background:rgba(255,255,255,.01);
  border:1px dashed rgba(76,29,149,.24);
  box-shadow:none;
}
.overlay-input.is-selected{
  border-color:#4c1d95;
  box-shadow:0 0 0 2px rgba(76,29,149,.2),0 10px 24px rgba(76,29,149,.16);
  background:rgba(255,255,255,.98);
}
.overlay-input--readonly.is-selected{
  background:rgba(76,29,149,.06);
  border-style:solid;
  box-shadow:0 0 0 2px rgba(76,29,149,.14);
}
.overlay-input__label{font-size:11px;color:var(--muted);line-height:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.overlay-input__readonly-signature{
  width:100%;height:100%;display:flex;align-items:center;justify-content:flex-start;
  padding:2px 8px;box-sizing:border-box;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;
  font-family:var(--font-signature);
  font-weight:500;letter-spacing:.01em;color:#3f1f70;
}
.overlay-input__readonly-signature.is-placeholder{
  font-family:inherit;font-size:11px;font-weight:600;letter-spacing:.02em;color:#5b4c82;
}
.overlay-input__readonly-signature-image{
  display:block;width:100%;height:100%;padding:2px 6px;object-fit:contain;object-position:left center;box-sizing:border-box;
}
.overlay-input input.field{
  width:100%;height:100%;min-height:0;min-width:0;
  padding:2px 6px;border:0;border-radius:0;background:transparent;
}
.overlay-input--checkbox{display:grid;place-items:center}
.overlay-input--checkbox input{width:16px;height:16px;margin:0}
.overlay-input--signature input{
  font-family:var(--font-signature);
  font-weight:500;
  letter-spacing:.01em;
}
.overlay-input--initial input{
  font-family:var(--font-signature);
  font-weight:500;
  letter-spacing:.01em;
}
.overlay-signature-launch{
  width:100%;height:100%;padding:0;border:0;background:transparent;cursor:pointer;display:block;
}
.overlay-signature-launch:focus-visible{
  outline:2px solid rgba(76,29,149,.36);
  outline-offset:-2px;
}
.overlay-input--signature .overlay-signature-input{padding-left:24px;padding-right:46px}
.overlay-input--signature .overlay-signature-canvas{
  display:none;width:100%;height:100%;border:0;background:transparent;touch-action:none;
}
.overlay-input--signature.is-draw .overlay-signature-canvas{display:block}
.overlay-input--signature.is-draw .overlay-signature-input{display:none}
.overlay-input--signature.is-draw .overlay-signature-size{display:none}
.overlay-signature-size{
  position:absolute;top:2px;bottom:2px;left:2px;width:16px;z-index:3;
  display:grid;grid-template-rows:repeat(2,minmax(0,1fr));gap:2px;
}
.overlay-signature-size__btn{
  width:16px;min-height:0;padding:0;border:1px solid rgba(91,76,130,.22);
  background:rgba(255,255,255,.82);color:#5b4c82;border-radius:999px;
  font-size:10px;line-height:1;cursor:pointer;opacity:.76;
  display:grid;place-items:center;
}
.overlay-signature-size__btn:hover,.overlay-signature-size__btn:focus-visible{opacity:1;border-color:rgba(91,76,130,.45)}
.overlay-signature-size__btn:disabled{opacity:.38;cursor:not-allowed}
.overlay-signature-toggle{
  position:absolute;top:2px;right:2px;z-index:3;
  border:1px solid rgba(91,76,130,.25);background:rgba(255,255,255,.84);
  color:#5b4c82;border-radius:999px;padding:1px 6px;font-size:10px;line-height:1.1;
  cursor:pointer;opacity:.78;
}
.overlay-signature-toggle:hover,.overlay-signature-toggle:focus-visible{opacity:1;border-color:rgba(91,76,130,.45)}
.overlay-signature-clear{
  position:absolute;top:2px;right:40px;z-index:3;
  border:1px solid rgba(91,76,130,.22);background:rgba(255,255,255,.82);
  color:#7a68a7;border-radius:999px;padding:1px 6px;font-size:10px;line-height:1.1;
  cursor:pointer;opacity:.72;
}
.overlay-signature-clear:hover,.overlay-signature-clear:focus-visible{opacity:1}
.signature-mode{display:flex;gap:6px;align-items:center;flex-wrap:wrap}
.signature-mode .btn{padding:5px 8px;min-width:0;flex:0 0 auto}
.signature-mode .btn.is-active{background:#efe7ff;border-color:#c9b7f5;color:#3f1f70}
.signature-draw{display:grid;gap:6px;min-width:0}
.signature-pad{width:100%;height:82px;border:1px dashed #cbb9ef;border-radius:8px;background:#fff;touch-action:none;cursor:crosshair}
.signature-draw__actions{display:flex;justify-content:flex-end;gap:6px;flex-wrap:wrap}
.signer-signature-modal-backdrop{
  background:rgba(15,23,42,.42);
  backdrop-filter:blur(4px);
  padding:20px;
  z-index:80;
}
.signer-signature-modal{
  width:min(100%, 760px);
  max-height:min(92vh, 860px);
  overflow:auto;
  border-radius:20px;
  background:#fff;
  box-shadow:0 28px 70px rgba(15,23,42,.24);
  padding:18px;
  display:grid;
  gap:14px;
}
.signer-signature-modal__mode{justify-content:flex-start}
.signer-signature-modal__size{display:flex;gap:6px;align-items:center}
.signer-signature-modal__surface{display:grid;gap:10px}
.signer-signature-modal__input{
  min-height:92px;
  padding:18px 20px;
  box-sizing:border-box;
  font-family:var(--font-signature);
  font-weight:500;
  letter-spacing:.01em;
}
.signer-signature-modal__draw{gap:10px}
.signer-signature-modal__canvas{height:260px}
.signer-signature-modal__actions{margin-top:4px}
body.modal-open{overflow:hidden}
body.dragging-field{cursor:grabbing}
body.dragging-field *{user-select:none !important}
@media(max-width:760px){
  .card--signer{
    padding:14px;
  }
  .signer-header{
    gap:8px;
    margin-bottom:8px;
  }
  .signer-header__spacer{
    display:none;
  }
  .esign-signer--responsive{
    gap:12px;
    padding-bottom:92px;
  }
  .signer-viewer-toolbar{
    position:static;
    top:auto;
    margin:-4px -4px 8px;
    padding:4px;
    gap:8px;
    backdrop-filter:none;
  }
  .signer-viewer-toolbar__left,
  .signer-viewer-toolbar__right{
    width:100%;
    justify-content:space-between;
  }
  .signer-viewer-toolbar__left{
    gap:6px;
  }
  .signer-page-btn{
    flex:1 1 0;
    min-width:0;
    min-height:40px;
    font-size:13px;
  }
  .page-indicator{
    flex:0 0 auto;
    min-height:40px;
    justify-content:center;
  }
  .doc-stage-wrap{
    padding:6px;
    border-radius:12px;
  }
  .doc-stage{
    min-height:380px;
    height:min(68vh, 620px);
    border-radius:10px;
  }
  .doc-stage__placeholder{
    padding:16px;
    font-size:13px;
  }
  .signer-form__meta{
    grid-template-columns:1fr;
    gap:10px;
  }
  .signer-meta-card{
    padding:10px;
  }
  .signer-consent{
    font-size:15px;
    gap:10px;
  }
  .signer-consent input{
    width:20px;
    height:20px;
    margin-top:1px;
  }
  .signer-submit-bar{
    position:static;
    bottom:auto;
    z-index:auto;
    margin:12px -4px 0;
    padding:8px;
    border-radius:16px;
    background:rgba(255,255,255,.96);
    border:1px solid color-mix(in srgb, var(--primary) 12%, var(--border));
    box-shadow:0 16px 32px rgba(15,23,42,.12);
    backdrop-filter:none;
  }
  .signer-submit-bar__primary,
  .signer-submit-bar__secondary{
    flex:1 1 100%;
    width:100%;
    min-height:46px;
  }
  .signer-submit-bar__status{
    width:100%;
    margin-top:2px;
    text-align:center;
  }
  .esign-signer__sidebar{
    order:-1;
    display:flex;
    flex-direction:column;
    gap:10px;
  }
  .signer-side-panel{
    margin-top:0 !important;
  }
  .esign-signer__viewer{
    order:3;
  }
  .signer-field-list{
    grid-auto-flow:column;
    grid-auto-columns:minmax(180px, 72%);
    overflow:auto;
    padding-bottom:4px;
    scroll-snap-type:x proximity;
    overscroll-behavior-x:contain;
  }
  .signer-field-list .list__item{
    scroll-snap-align:start;
    min-height:72px;
    border-radius:14px;
    padding:10px 12px;
  }
  .overlay-input{
    border-radius:10px;
  }
  .overlay-input input.field{
    padding:4px 8px;
  }
  .overlay-input--checkbox input{
    width:min(20px, calc(100% - 6px));
    height:min(20px, calc(100% - 6px));
  }
  .overlay-input__readonly-signature{
    padding:3px 8px;
  }
  .overlay-input--signature .overlay-signature-input{
    padding-left:28px;
    padding-right:64px;
  }
  .overlay-signature-size{
    width:20px;
  }
  .overlay-signature-size__btn{
    width:20px;
    font-size:11px;
  }
  .overlay-signature-toggle,
  .overlay-signature-clear{
    min-height:20px;
    padding:2px 7px;
    font-size:11px;
    opacity:.94;
  }
  .overlay-signature-clear{
    right:46px;
  }
  .signer-signature-modal-backdrop{
    padding:12px;
  }
  .signer-signature-modal{
    width:100%;
    max-height:94vh;
    border-radius:16px;
    padding:14px;
    gap:12px;
  }
  .signer-signature-modal__mode{
    gap:8px;
  }
  .signer-signature-modal__mode .btn{
    flex:1 1 0;
    min-height:42px;
  }
  .signer-signature-modal__size{
    width:100%;
    justify-content:flex-end;
  }
  .signer-signature-modal__input{
    min-height:84px;
    padding:14px 16px;
  }
  .signer-signature-modal__canvas{
    height:220px;
  }
}
