/* PennOhio Waste Profile System — admin UI.
   Default light palette; dark palette restored via [data-theme="dark"].
   Layout-agnostic tokens (--radius) live alongside theme tokens. */

:root {
  --bg:        #f5f7fa;
  --bg-elev:   #ffffff;
  --bg-hover:  #eef1f6;
  --fg:        #1a1f2a;
  --muted:     #5a6573;
  --border:    #dde2ea;
  --border-strong: #c2cad5;
  --accent:    #2563eb;
  --accent-hover: #1d4fd4;
  --accent-fg: #ffffff;
  --warn:      #dc2626;
  --good:      #059669;
  --yellow:    #d97706;
  --role-admin:    #ff7849;
  --role-yellow:   #f5c518;
  --overlay:   rgba(20, 28, 40, 0.45);
  --form-paper-bg: #f8f8f4;
  --form-paper-fg: #16202b;
  --form-paper-muted: #94a4b6;
  --film-bg:   #000;
  --film-frame-bg: #fff;
  --radius:    8px;
  --shadow:    0 6px 20px rgba(20, 28, 40, 0.08);
}

[data-theme="dark"] {
  --bg:        #0f1216;
  --bg-elev:   #131820;
  --bg-hover:  #1a2029;
  --fg:        #e6e8ea;
  --muted:     #8a93a0;
  --border:    #1f2630;
  --border-strong: #2c3540;
  --accent:    #4ea3ff;
  --accent-hover: #6cb6ff;
  --accent-fg: #0a0d12;
  --warn:      #ef4444;
  --good:      #10b981;
  --yellow:    #f59e0b;
  --role-admin:    #ff7849;
  --role-yellow:   #f5c518;
  --overlay:   rgba(0, 0, 0, 0.5);
  --form-paper-bg: #f8f8f4;
  --form-paper-fg: #16202b;
  --form-paper-muted: #94a4b6;
  --film-bg:   #000;
  --film-frame-bg: #fff;
  --shadow:    0 6px 24px rgba(0,0,0,0.35);
}

* { box-sizing: border-box; }
html, body { height: 100%; }
body {
  margin: 0;
  background: var(--bg);
  color: var(--fg);
  font-family: -apple-system, BlinkMacSystemFont, "SF Pro Text", "Inter", system-ui, sans-serif;
  font-size: 14px;
  line-height: 1.45;
  /* Flex column so the persistent footer pins below the app content. #app
     grows to fill; the footer never scrolls away because .main scrolls
     internally (overflow-y) inside a 100%-height shell. */
  min-height: 100%;
  display: flex;
  flex-direction: column;
}
#app { flex: 1 0 auto; display: flex; flex-direction: column; min-width: 0; }

/* ── Boot splash ─────────────────────────────────────────────────────────── */
.boot-splash {
  position: fixed; inset: 0; display: grid; place-items: center;
  color: var(--muted); font-size: 14px;
}

/* ── Login screen ────────────────────────────────────────────────────────── */
.login-wrap { min-height: 100%; flex: 1 1 auto; display: grid; place-items: center; padding: 24px; }
.login-card {
  width: 100%; max-width: 380px; background: var(--bg-elev);
  border: 1px solid var(--border); border-radius: var(--radius);
  padding: 28px 26px; box-shadow: var(--shadow);
}
.login-card h1 { margin: 0 0 4px; font-size: 20px; font-weight: 600; }
.login-card .brand { color: var(--accent); }
.login-card .lede { color: var(--muted); font-size: 13px; margin-bottom: 18px; }
.login-card label { display: block; font-size: 12px; color: var(--muted); margin: 12px 0 4px; }
.login-card input[type="email"], .login-card input[type="password"] {
  width: 100%; padding: 9px 11px; background: var(--bg);
  border: 1px solid var(--border); border-radius: 6px; color: var(--fg);
  font-size: 14px;
}
.login-card input:focus { border-color: var(--accent); outline: none; }
.login-card .actions { margin-top: 18px; display: flex; align-items: center; gap: 10px; }
.login-card .err { color: var(--warn); font-size: 12px; min-height: 16px; }
.login-banner {
  background: color-mix(in srgb, var(--warn) 14%, transparent);
  border: 1px solid color-mix(in srgb, var(--warn) 40%, transparent);
  color: var(--warn); border-radius: 6px;
  padding: 10px 12px; margin-bottom: 14px;
  font-size: 13px; line-height: 1.4;
}
/* Unified login (2026-06-01) — single form, no PennOhio/Client toggle. The
   .login-type / .login-type-btn classes were dropped with that change. */
.login-foot { margin-top: 14px; text-align: center; font-size: 12px; }
.login-foot a { text-decoration: none; }
.login-foot a:hover { text-decoration: underline; }
/* Invite-redemption page reuses the login card */
.invite-summary {
  background: var(--bg); border: 1px solid var(--border); border-radius: 6px;
  padding: 10px 12px; margin: 4px 0 8px; font-size: 13px; line-height: 1.7;
}
.invite-summary .muted { display: inline-block; width: 56px; }
/* Show/hide password toggle */
.pw-row { position: relative; }
.pw-row input { padding-right: 60px !important; }
.pw-toggle {
  position: absolute; right: 6px; top: 50%; transform: translateY(-50%);
  background: transparent; border: none; color: var(--muted);
  font-size: 12px; padding: 4px 8px; cursor: pointer;
}
.pw-toggle:hover { color: var(--fg); }

/* ── Buttons ─────────────────────────────────────────────────────────────── */
button { font: inherit; cursor: pointer; }
.btn {
  padding: 7px 14px; border-radius: 6px; border: 1px solid var(--border-strong);
  background: var(--bg-elev); color: var(--fg); font-size: 13px;
}
.btn:hover:not(:disabled) { background: var(--bg-hover); }
.btn:disabled { opacity: 0.5; cursor: not-allowed; }
.btn-primary { background: var(--accent); color: var(--accent-fg); border-color: var(--accent); font-weight: 600; }
.btn-primary:hover:not(:disabled) { background: var(--accent-hover); }
.btn-danger { color: var(--warn); border-color: color-mix(in srgb, var(--warn) 50%, var(--border)); }
.btn-danger:hover:not(:disabled) { background: color-mix(in srgb, var(--warn) 15%, var(--bg-elev)); }
.btn-tiny { padding: 3px 9px; font-size: 12px; }
.btn-subtle { background: transparent; border-color: var(--border); color: var(--muted); }
.btn-subtle:hover:not(:disabled) { background: var(--bg-hover); color: var(--fg); }

/* ── Main layout ─────────────────────────────────────────────────────────── */
.shell { display: grid; grid-template-columns: 220px 1fr; min-height: 100%; flex: 1 1 auto; }

/* ── Site footer (VST / BGA branding) ────────────────────────────────────── */
.site-footer {
  flex-shrink: 0;
  background: var(--bg-elev);
  border-top: 1px solid var(--border);
  color: var(--muted);
  font-size: 12px;
  padding: 12px 20px;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
}
.site-footer a.dev-link {
  color: var(--accent);
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-weight: 500;
}
.site-footer a.dev-link:hover { text-decoration: underline; }
/* Text wordmark placeholder — swap for the real VST logo <img> when supplied. */
.site-footer .vst-wordmark {
  font-weight: 800;
  letter-spacing: 0.5px;
  color: var(--accent);
  border: 1.5px solid var(--accent);
  border-radius: 4px;
  padding: 1px 6px;
  font-size: 12px;
  line-height: 1.4;
}
.sidebar {
  background: var(--bg-elev); border-right: 1px solid var(--border);
  padding: 18px 0;
}
.sidebar-brand {
  display: flex; align-items: flex-start; gap: 10px; justify-content: space-between;
  padding: 0 18px 16px; margin-bottom: 6px;
  border-bottom: 1px solid var(--border);
}
.sidebar-brand-title { flex: 1 1 auto; min-width: 0; }
.sidebar-brand .title { font-size: 14px; font-weight: 600; }
.sidebar-brand .title .brand { color: var(--accent); }
.sidebar-brand .sub { font-size: 11px; color: var(--muted); margin-top: 2px; }
.theme-toggle {
  flex: 0 0 auto;
  width: 28px; height: 28px;
  display: inline-grid; place-items: center;
  background: var(--bg);
  border: 1px solid var(--border);
  border-radius: 6px;
  color: var(--muted);
  font-size: 14px;
  cursor: pointer;
  line-height: 1;
  padding: 0;
}
.theme-toggle:hover { background: var(--bg-hover); color: var(--fg); }
.theme-toggle:focus-visible { outline: 2px solid var(--accent); outline-offset: 1px; }

/* Bell button + badge (phase-notification-prefs). Sits next to the theme
   toggle in .sidebar-brand. The badge is a red pip overlay; dropdown is a
   floating panel anchored below the bell. */
.bell-toggle {
  position: relative;
  flex: 0 0 auto;
  width: 28px; height: 28px;
  display: inline-grid; place-items: center;
  background: var(--bg);
  border: 1px solid var(--border);
  border-radius: 6px;
  color: var(--muted);
  font-size: 14px;
  cursor: pointer;
  line-height: 1;
  padding: 0;
  margin-right: 6px;
}
.bell-toggle:hover { background: var(--bg-hover); color: var(--fg); }
.bell-toggle:focus-visible { outline: 2px solid var(--accent); outline-offset: 1px; }
.bell-badge {
  position: absolute;
  top: -4px; right: -4px;
  min-width: 16px; height: 16px;
  padding: 0 4px;
  background: var(--danger, #dc2626);
  color: #ffffff;
  font-size: 10px; font-weight: 700; line-height: 16px;
  border-radius: 8px;
  text-align: center;
  box-shadow: 0 0 0 2px var(--bg-elev);
}
.bell-dropdown {
  position: absolute;
  top: 56px; right: 12px;
  width: 360px; max-width: calc(100vw - 24px);
  max-height: 480px; overflow: auto;
  background: var(--bg-elev);
  border: 1px solid var(--border);
  border-radius: 8px;
  box-shadow: 0 8px 24px rgba(0,0,0,0.12);
  z-index: 50;
}
.bell-dropdown-loading,
.bell-dropdown-empty { padding: 20px; text-align: center; }
.bell-dropdown-head {
  display: flex; align-items: center; justify-content: space-between;
  padding: 10px 14px;
  border-bottom: 1px solid var(--border);
  position: sticky; top: 0; background: var(--bg-elev); z-index: 1;
}
.bell-dropdown-title { font-weight: 600; font-size: 13px; }
.bell-dropdown-list { display: flex; flex-direction: column; }
.bell-row {
  display: flex; flex-direction: column; gap: 2px;
  padding: 10px 14px;
  border: none; border-bottom: 1px solid var(--border);
  background: transparent;
  text-align: left;
  cursor: pointer;
  color: var(--fg);
  font: inherit;
}
.bell-row:hover { background: var(--bg-hover); }
.bell-row.is-unread { background: color-mix(in srgb, var(--accent) 8%, var(--bg-elev)); }
.bell-row.is-unread:hover { background: color-mix(in srgb, var(--accent) 14%, var(--bg-elev)); }
.bell-row-kind { font-size: 12px; color: var(--muted); }
.bell-row-suppressed {
  display: inline-block; margin-left: 6px; padding: 0 6px;
  font-size: 10px; font-weight: 600;
  background: var(--warn-soft, #fef3c7); color: var(--warn-fg, #92400e);
  border-radius: 3px; line-height: 14px;
}
.bell-row-subject { font-size: 13px; font-weight: 500; line-height: 1.35; }
.bell-row-meta { font-size: 11px; }

/* Notifications settings page: pref-row labels with checkboxes. */
.notif-pref-list { display: flex; flex-direction: column; gap: 4px; }
.notif-pref-row {
  display: flex; align-items: center; gap: 10px;
  padding: 8px 10px;
  border: 1px solid transparent;
  border-radius: 6px;
  cursor: pointer;
}
.notif-pref-row:hover { background: var(--bg-hover); border-color: var(--border); }
.notif-pref-row input[type=checkbox] { flex: 0 0 auto; }
.notif-pref-label { flex: 1 1 auto; font-size: 14px; }
.notif-pref-kind { flex: 0 0 auto; font-size: 11px; }
.nav { display: flex; flex-direction: column; padding: 8px 8px 0; gap: 1px; }
.nav-item {
  display: flex; align-items: center; gap: 10px; padding: 8px 10px;
  border-radius: 6px; color: var(--fg); font-size: 14px; cursor: pointer;
  background: transparent; border: none; text-align: left; width: 100%;
}
.nav-item:hover { background: var(--bg-hover); }
.nav-item.active { background: var(--bg-hover); color: var(--accent); }
.nav-item .icon { font-size: 16px; opacity: 0.85; width: 18px; text-align: center; }
.nav-spacer { flex: 1; }
.sidebar-foot {
  padding: 12px 18px; border-top: 1px solid var(--border); margin-top: 16px;
  font-size: 12px; color: var(--muted);
}
.sidebar-foot .who { color: var(--fg); margin-bottom: 6px; }
.sidebar-foot .role-pill { display: inline-block; padding: 1px 7px; font-size: 10px; border-radius: 999px; background: var(--bg-hover); color: var(--muted); text-transform: uppercase; letter-spacing: 0.05em; margin-left: 4px; }

.main { padding: 28px 32px; overflow-y: auto; }

/* ── Page header ─────────────────────────────────────────────────────────── */
.page-header {
  display: flex; align-items: center; gap: 16px; margin-bottom: 18px;
  padding-bottom: 14px; border-bottom: 1px solid var(--border);
}
.page-header h1 { margin: 0; font-size: 20px; font-weight: 600; }
.page-header .grow { flex: 1; }
.page-header .crumbs { font-size: 12px; color: var(--muted); margin-bottom: 4px; }
.page-header .crumbs a { color: var(--muted); cursor: pointer; }
.page-header .crumbs a:hover { color: var(--accent); }

/* ── Filter bar ──────────────────────────────────────────────────────────── */
.filter-bar { display: flex; gap: 10px; align-items: center; margin-bottom: 14px; flex-wrap: wrap; }
.filter-bar input[type="search"], .filter-bar input[type="text"], .filter-bar select {
  padding: 7px 10px; background: var(--bg-elev); border: 1px solid var(--border);
  border-radius: 6px; color: var(--fg); font-size: 13px; min-width: 200px;
}
.filter-bar input:focus, .filter-bar select:focus { border-color: var(--accent); outline: none; }
.filter-bar .muted { color: var(--muted); font-size: 12px; }

/* ── Table ───────────────────────────────────────────────────────────────── */
.tbl-wrap { background: var(--bg-elev); border: 1px solid var(--border); border-radius: var(--radius); overflow: hidden; }
.tbl { width: 100%; border-collapse: collapse; font-size: 13px; }
.tbl th {
  text-align: left; padding: 9px 12px; font-size: 11px; font-weight: 600;
  color: var(--muted); text-transform: uppercase; letter-spacing: 0.04em;
  background: var(--bg); border-bottom: 1px solid var(--border);
}
.tbl td { padding: 9px 12px; border-bottom: 1px solid var(--border); }
.tbl tr:last-child td { border-bottom: none; }
.tbl tr.clickable { cursor: pointer; }
.tbl tr.clickable:hover td { background: var(--bg-hover); }
.tbl .right { text-align: right; }
.tbl .num { font-variant-numeric: tabular-nums; }
.tbl-empty { padding: 30px; text-align: center; color: var(--muted); font-size: 13px; }
.empty-state-row { padding: 0 !important; background: transparent; }
.empty-state {
  display: flex; flex-direction: column; align-items: center; gap: 10px;
  padding: 48px 24px; text-align: center;
}
.empty-state-icon { font-size: 36px; line-height: 1; }
.empty-state h3 { margin: 0; font-size: 16px; font-weight: 600; color: var(--fg); }
.empty-state p { margin: 0; max-width: 460px; font-size: 13px; }
.empty-state .btn { margin-top: 8px; }
/* Friendly not-found / load-error card */
.load-error-card {
  max-width: 480px; margin: 60px auto;
  background: var(--bg-elev); border: 1px solid var(--border);
  border-radius: var(--radius); box-shadow: var(--shadow);
  padding: 36px 28px; text-align: center;
}
.load-error-icon { font-size: 42px; line-height: 1; margin-bottom: 8px; }
.load-error-card h3 { margin: 6px 0 8px; font-size: 17px; font-weight: 600; }
.load-error-card p { margin: 0 auto 18px; max-width: 360px; font-size: 13px; }
.load-error-card .actions { justify-content: center; }

/* ── Pills / chips ───────────────────────────────────────────────────────── */
.pill {
  display: inline-block; padding: 2px 8px; border-radius: 999px;
  font-size: 11px; line-height: 1.4; background: var(--bg-hover); color: var(--muted);
}
.pill-good { background: color-mix(in srgb, var(--good) 18%, var(--bg-elev)); color: var(--good); }
.pill-warn { background: color-mix(in srgb, var(--warn) 18%, var(--bg-elev)); color: var(--warn); }
.pill-accent { background: color-mix(in srgb, var(--accent) 18%, var(--bg-elev)); color: var(--accent); }
.pill-yellow { background: color-mix(in srgb, var(--yellow) 18%, var(--bg-elev)); color: var(--yellow); }
.pill-muted { background: color-mix(in srgb, var(--muted) 16%, var(--bg-elev)); color: var(--muted); }

/* ── Pagination ──────────────────────────────────────────────────────────── */
.pager { display: flex; gap: 8px; align-items: center; padding-top: 12px; color: var(--muted); font-size: 12px; }
.pager .grow { flex: 1; }

/* ── Detail view ─────────────────────────────────────────────────────────── */
.detail-grid { display: grid; grid-template-columns: 2fr 1fr; gap: 20px; align-items: start; }
@media (max-width: 1100px) { .detail-grid { grid-template-columns: 1fr; } }
.card {
  background: var(--bg-elev); border: 1px solid var(--border);
  border-radius: var(--radius); padding: 18px 18px;
}
.card h3 { margin: 0 0 12px; font-size: 14px; font-weight: 600; color: var(--muted); text-transform: uppercase; letter-spacing: 0.04em; }
.kv { display: grid; grid-template-columns: 130px 1fr; gap: 6px 14px; font-size: 13px; }
.kv dt { color: var(--muted); }
.kv dd { margin: 0; word-break: break-word; }
.kv dd.empty { color: var(--muted); font-style: italic; }
.card .actions { display: flex; gap: 8px; margin-top: 14px; }

.subsec { margin-top: 18px; }
.subsec h4 { font-size: 12px; font-weight: 600; color: var(--muted); text-transform: uppercase; letter-spacing: 0.05em; margin: 0 0 8px; }

/* ── Audit list ──────────────────────────────────────────────────────────── */
.audit-list { display: flex; flex-direction: column; gap: 6px; }
.audit-row {
  padding: 9px 10px; background: var(--bg);
  border: 1px solid var(--border); border-radius: 6px; font-size: 12px;
  display: grid; grid-template-columns: auto 1fr auto; gap: 8px; align-items: baseline;
}
.audit-row .ts { color: var(--muted); font-variant-numeric: tabular-nums; font-size: 11px; white-space: nowrap; }
.audit-row .action { font-weight: 600; color: var(--accent); margin-right: 4px; }
.audit-row .changed { color: var(--muted); font-size: 11px; }
.audit-row .actor { color: var(--muted); font-size: 11px; white-space: nowrap; }
.audit-empty { color: var(--muted); font-style: italic; font-size: 12px; padding: 8px 0; }

/* ── Modal ───────────────────────────────────────────────────────────────── */
.modal-overlay { position: fixed; inset: 0; background: var(--overlay); display: grid; place-items: center; z-index: 50; }
.modal-card { width: 100%; max-width: 560px; background: var(--bg-elev); border: 1px solid var(--border); border-radius: var(--radius); box-shadow: var(--shadow); max-height: 90vh; display: flex; flex-direction: column; }
.modal-header { display: flex; align-items: center; padding: 14px 18px; border-bottom: 1px solid var(--border); }
.modal-header h2 { margin: 0; font-size: 15px; font-weight: 600; }
.modal-header .grow { flex: 1; }
.modal-header .close { background: none; border: none; color: var(--muted); font-size: 18px; cursor: pointer; padding: 4px; }
.modal-header .close:hover { color: var(--fg); }
.modal-body { padding: 16px 18px; overflow-y: auto; flex: 1; }
.modal-foot { display: flex; gap: 8px; padding: 12px 18px; border-top: 1px solid var(--border); justify-content: flex-end; }

/* ── Forms ───────────────────────────────────────────────────────────────── */
.form-subsection {
  margin: 18px 0 10px;
  padding: 6px 0 6px 12px;
  border-left: 3px solid var(--accent);
  background: color-mix(in srgb, var(--accent) 6%, var(--bg-elev));
  border-radius: 0 4px 4px 0;
}
.form-subsection-title { font-size: 12px; font-weight: 600; color: var(--fg); }
.form-subsection-hint  { font-size: 11px; color: var(--muted); margin-top: 2px; }
.form-row { display: grid; grid-template-columns: 130px 1fr; gap: 10px; align-items: start; margin-bottom: 12px; }
.form-row label { color: var(--muted); font-size: 12px; padding-top: 7px; }
.form-row input[type="text"], .form-row input[type="email"], .form-row input[type="password"], .form-row select, .form-row textarea {
  width: 100%; padding: 7px 10px; background: var(--bg); border: 1px solid var(--border);
  border-radius: 6px; color: var(--fg); font-size: 13px; font-family: inherit;
}
.form-row textarea { resize: vertical; min-height: 70px; }
.form-row .hint { font-size: 11px; color: var(--muted); margin-top: 3px; }
.form-row .checkbox { display: flex; align-items: center; gap: 8px; padding-top: 7px; }
.form-row .checkbox input { width: 14px; height: 14px; accent-color: var(--accent); }
.form-row.split { grid-template-columns: 130px 1fr 1fr; }
.form-row.split input { flex: 1; }
.form-err { color: var(--warn); font-size: 12px; min-height: 14px; }

/* ── Wizard ──────────────────────────────────────────────────────────────── */
.wizard-bar {
  display: flex; gap: 6px; align-items: stretch; margin-bottom: 14px; flex-wrap: wrap;
}
.wizard-step {
  display: flex; align-items: center; gap: 8px; padding: 8px 14px;
  background: var(--bg-elev); border: 1px solid var(--border); border-radius: 6px;
  color: var(--muted); font-size: 13px; cursor: pointer; flex: 1 1 auto; min-width: 130px;
  text-align: left;
}
.wizard-step:hover { background: var(--bg-hover); color: var(--fg); }
.wizard-step.active { background: var(--bg-hover); color: var(--accent); border-color: color-mix(in srgb, var(--accent) 50%, var(--border)); }
.wizard-step.done { color: var(--good); }
.wizard-step .step-num {
  display: inline-grid; place-items: center;
  width: 20px; height: 20px; border-radius: 50%; background: var(--bg);
  color: var(--muted); font-size: 11px; font-weight: 600;
  border: 1px solid var(--border);
}
.wizard-step.active .step-num { background: var(--accent); color: var(--accent-fg); border-color: var(--accent); }
.wizard-step.done .step-num    { background: color-mix(in srgb, var(--good) 25%, transparent); color: var(--good); border-color: color-mix(in srgb, var(--good) 50%, var(--border)); }

.wizard-foot {
  display: flex; gap: 8px; align-items: center;
  margin-top: 14px; padding: 14px 16px;
  background: var(--bg-elev); border: 1px solid var(--border); border-radius: var(--radius);
  position: sticky; bottom: 0;
}

#wizardForm h3:not(:first-child) { margin-top: 22px; }

/* ── Signature widget ────────────────────────────────────────────────────── */
.sig-widget {
  background: var(--bg);
  border: 1px solid var(--border);
  border-radius: 6px;
  padding: 12px;
}
.sig-tabs {
  display: inline-flex; gap: 4px;
  background: var(--bg-elev);
  border: 1px solid var(--border);
  border-radius: 6px;
  padding: 3px;
  margin-bottom: 10px;
}
.sig-tab {
  padding: 4px 14px; border: none; border-radius: 4px;
  background: transparent; color: var(--muted); font-size: 12px; cursor: pointer;
}
.sig-tab.active { background: var(--bg-hover); color: var(--fg); }
.sig-tab:hover:not(.active) { color: var(--fg); }
.sig-body { display: none; }
.sig-body.active { display: block; }

/* Type-mode (restored 2026-06-01 — earlier 2026-05-15 collapse undone):
   a PLAIN text input for the user's name, a cursive-style chip picker, and
   a separate preview block that renders the typed name in the chosen font.
   The signer's choice persists via KV `signer_signature_font`. */
.sig-typed-label {
  display: block; font-size: 12px; color: var(--muted);
  margin-bottom: 6px;
}
.sig-typed-input {
  display: block; width: 100%;
  padding: 10px 12px;
  background: var(--bg-elev);
  color: var(--fg);
  border: 1px solid var(--border);
  border-radius: 6px;
  font-family: -apple-system, BlinkMacSystemFont, "SF Pro Text", "Inter", system-ui, sans-serif;
  font-size: 15px; line-height: 1.4;
  outline: none;
}
.sig-typed-input::placeholder { color: var(--muted); }
.sig-typed-input:focus { border-color: var(--accent); }

.sig-font-picker {
  display: flex; flex-wrap: wrap; gap: 8px;
  margin: 12px 0 12px;
}
.sig-font-chip {
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  gap: 2px;
  padding: 6px 12px;
  background: var(--bg-elev);
  border: 1px solid var(--border);
  border-radius: 6px;
  cursor: pointer;
  color: var(--fg);
  min-width: 72px;
  /* font-family is applied inline per chip so each chip previews its own face */
}
.sig-font-chip:hover { border-color: color-mix(in srgb, var(--accent) 50%, var(--border)); }
.sig-font-chip.active {
  border-color: var(--accent);
  background: color-mix(in srgb, var(--accent) 10%, var(--bg-elev));
  box-shadow: 0 0 0 1px var(--accent) inset;
}
.sig-font-chip-sample { font-size: 22px; line-height: 1.1; }
.sig-font-chip-label {
  font-family: -apple-system, BlinkMacSystemFont, "SF Pro Text", "Inter", system-ui, sans-serif;
  font-style: normal;
  font-size: 11px; color: var(--muted); margin-top: 2px;
}

.sig-preview {
  background: var(--form-paper-bg);
  color: var(--form-paper-fg);
  border: 1px solid var(--border);
  border-radius: 6px;
  padding: 18px 16px;
  font-size: 36px;
  line-height: 1.2;
  min-height: 64px;
  /* font-family is set via JS to the active font's stack */
  font-style: italic;
}
.sig-preview-placeholder {
  font-family: -apple-system, BlinkMacSystemFont, "SF Pro Text", "Inter", system-ui, sans-serif;
  font-style: italic; font-size: 14px; color: var(--form-paper-muted);
}

.sig-canvas-wrap {
  background: var(--form-paper-bg);
  border: 1px solid var(--border);
  border-radius: 6px;
  position: relative;
  touch-action: none;             /* don't let the page scroll while signing */
}
.sig-canvas { display: block; width: 100%; height: 160px; cursor: crosshair; background: transparent; }
.sig-canvas-hint {
  position: absolute; left: 12px; top: 10px;
  color: var(--form-paper-muted); font-size: 12px; pointer-events: none;
}
.sig-canvas-actions { display: flex; gap: 8px; margin-top: 8px; }

/* ── Attachments panel (unlocked add/remove, post-2026-05-13) ────────────── */
.att-panel { display: flex; flex-direction: column; gap: 10px; }
.att-panel-head { display: flex; align-items: center; gap: 8px; }
.att-panel-title { margin: 0; font-size: 15px; font-weight: 600; }

.att-filter-row {
  display: flex; flex-wrap: wrap; gap: 6px;
}
.att-filter-chip {
  padding: 4px 12px; font-size: 12px;
  background: var(--bg); border: 1px solid var(--border); border-radius: 999px;
  color: var(--fg); cursor: pointer;
}
.att-filter-chip:hover { background: var(--bg-hover); }
.att-filter-chip.active {
  background: color-mix(in srgb, var(--accent) 20%, var(--bg-elev));
  border-color: color-mix(in srgb, var(--accent) 50%, var(--border));
  color: var(--fg);
}

.att-dropzone {
  display: flex; flex-direction: column; align-items: center; gap: 6px;
  padding: 14px 12px; border: 1px dashed var(--border-strong);
  border-radius: 8px; background: var(--bg);
  text-align: center; transition: border-color 80ms ease, background 80ms ease;
}
.att-dropzone:focus { outline: none; border-color: var(--accent); }
.att-dropzone.drag-over {
  border-color: var(--accent);
  background: color-mix(in srgb, var(--accent) 8%, var(--bg-elev));
}
.att-dropzone-prompt { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; justify-content: center; }
.att-dropzone-or { font-size: 12px; }
.att-dropzone-hint { font-size: 11px; }

.att-pending { display: flex; flex-direction: column; gap: 8px; }
.att-pending-row {
  border: 1px solid var(--border); border-radius: 6px;
  padding: 10px 12px; background: var(--bg);
  display: flex; flex-direction: column; gap: 6px;
}
.att-pending-row.att-pending-err { border-color: color-mix(in srgb, var(--warn) 50%, var(--border)); }
.att-pending-row.att-pending-done { border-color: color-mix(in srgb, var(--good) 50%, var(--border)); }
.att-pending-head { display: flex; align-items: center; gap: 10px; font-size: 13px; }
.att-pending-name { flex: 1; min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.att-pending-size { white-space: nowrap; font-size: 12px; }
.att-pending-controls {
  display: flex; flex-wrap: wrap; gap: 6px; align-items: center;
}
.att-pending-label { font-size: 11px; }
.att-pending-type {
  padding: 4px 8px; background: var(--bg-elev); border: 1px solid var(--border);
  border-radius: 4px; color: var(--fg); font-size: 12px; font-family: inherit;
}
.att-pending-desc-wrap { flex: 1; min-width: 180px; }
.att-pending-desc {
  width: 100%; padding: 5px 9px; background: var(--bg-elev);
  border: 1px solid var(--border); border-radius: 4px; color: var(--fg);
  font-size: 12px; font-family: inherit;
}
.att-pending-desc:focus { outline: none; border-color: var(--accent); }
.att-pending-progress {
  height: 4px; background: var(--bg-elev); border-radius: 2px; overflow: hidden;
}
.att-pending-bar {
  height: 100%; width: 0%;
  background: linear-gradient(to right, var(--accent), var(--accent-hover));
  transition: width 120ms ease;
}
.att-pending-row.att-pending-done .att-pending-bar { background: var(--good); }
.att-pending-row.att-pending-err .att-pending-bar { background: var(--warn); }
.att-pending-status { font-size: 11px; }
.att-pending-row.att-pending-err .att-pending-status { color: var(--warn); }
.att-pending-row.att-pending-done .att-pending-status { color: var(--good); }

.att-list { display: flex; flex-direction: column; gap: 6px; }
.att-row {
  display: flex; align-items: center; gap: 12px;
  padding: 10px; background: var(--bg); border: 1px solid var(--border);
  border-radius: 8px; font-size: 13px;
}
.att-thumb-btn {
  background: transparent; border: none; padding: 0; cursor: pointer;
  flex: 0 0 auto;
}
.att-thumb {
  width: 44px; height: 44px; border-radius: 6px; overflow: hidden;
  background: var(--bg-elev); border: 1px solid var(--border);
  display: block; object-fit: cover;
}
.att-thumb-icon {
  display: grid; place-items: center;
  font-size: 11px; font-weight: 600; color: var(--muted);
  letter-spacing: 0.04em;
}
.att-row-body { flex: 1; min-width: 0; display: flex; flex-direction: column; gap: 2px; }
.att-row-head {
  display: flex; align-items: center; gap: 8px; flex-wrap: wrap;
}
.att-row-head .att-name {
  flex: 1; min-width: 0;
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
  font-weight: 500;
}
.att-row-head .att-size { font-size: 11px; }
.att-type-chip { font-size: 10px; padding: 2px 8px; }
.att-post-approval-badge {
  font-size: 10px; padding: 2px 8px;
  background: color-mix(in srgb, var(--yellow) 16%, var(--bg-elev));
  border-color: color-mix(in srgb, var(--yellow) 40%, var(--border));
  color: var(--yellow);
}
.att-row-desc {
  font-size: 12px; color: var(--fg);
  padding: 4px 8px; background: var(--bg-elev); border-radius: 4px;
  overflow: hidden; text-overflow: ellipsis;
  display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical;
}
.att-row-meta { font-size: 11px; }
.att-row-actions { display: flex; gap: 6px; flex: 0 0 auto; flex-wrap: wrap; }
.att-row-actions .btn-tiny { padding: 3px 9px; }

.att-hint {
  padding: 8px 10px; border-radius: 6px; font-size: 12px;
}
.att-hint.warn { background: color-mix(in srgb, var(--warn) 18%, var(--bg-elev)); color: var(--warn); }
.att-hint.good { background: color-mix(in srgb, var(--good) 18%, var(--bg-elev)); color: var(--good); }

/* ── Attachment preview modal ────────────────────────────────────────────── */
.att-preview-overlay {
  position: fixed; inset: 0; z-index: 60;
  background: color-mix(in srgb, var(--overlay) 70%, rgba(0,0,0,0.5));
  display: grid; place-items: center;
  padding: 24px;
  animation: att-fade-in 100ms ease;
}
@keyframes att-fade-in { from { opacity: 0; } to { opacity: 1; } }
.att-preview-card {
  width: 100%; max-width: 960px; max-height: calc(100vh - 48px);
  background: var(--bg-elev); border: 1px solid var(--border-strong);
  border-radius: var(--radius); box-shadow: var(--shadow);
  display: flex; flex-direction: column; overflow: hidden;
}
.att-preview-head {
  display: flex; align-items: center; gap: 10px; flex-wrap: wrap;
  padding: 12px 16px; border-bottom: 1px solid var(--border);
}
.att-preview-titles {
  display: flex; align-items: center; gap: 8px;
  flex: 1; min-width: 0;
}
.att-preview-name {
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
  font-size: 14px;
}
.att-preview-desc {
  flex-basis: 100%; font-size: 12px; padding: 0;
  order: 99; /* push under the title row */
}
.att-preview-close {
  background: none; border: none; color: var(--muted); font-size: 18px;
  cursor: pointer; padding: 4px 8px;
}
.att-preview-close:hover { color: var(--fg); }
.att-preview-body {
  flex: 1; min-height: 0; display: flex; background: var(--film-bg);
  align-items: center; justify-content: center;
}
.att-preview-iframe {
  width: 100%; height: 100%; min-height: 60vh; border: none;
  background: var(--film-frame-bg);
}
.att-preview-img-wrap {
  width: 100%; height: 100%; min-height: 60vh;
  display: grid; place-items: center;
  overflow: auto;
  touch-action: pinch-zoom;
}
.att-preview-img {
  max-width: 100%; max-height: calc(100vh - 140px);
  object-fit: contain; user-select: none;
}
.att-preview-fallback {
  padding: 36px 24px; text-align: center; color: var(--fg);
  background: var(--bg);
}
.att-preview-fallback p { margin: 0 0 16px; }

.sign-errors { margin: 0; padding-left: 20px; color: var(--warn); font-size: 13px; }
.sign-errors-card { border-color: color-mix(in srgb, var(--warn) 50%, var(--border)); }
.sign-errors-title { margin: 0 0 10px; color: var(--warn); font-size: 14px; }
.sign-errors-step { margin: 10px 0; padding: 8px 0; border-top: 1px solid var(--border); }
.sign-errors-step:first-of-type { border-top: none; padding-top: 0; }
.sign-errors-step-head { display: flex; align-items: center; gap: 8px; margin-bottom: 4px; font-size: 13px; }
.sign-errors-jump { margin-left: auto; }
/* Per-field error state on form rows */
.form-row.has-error input,
.form-row.has-error select,
.form-row.has-error textarea {
  border-color: var(--warn);
  background: color-mix(in srgb, var(--warn) 6%, var(--bg));
}
.form-row.has-error label { color: var(--warn); }
.field-error {
  margin-top: 4px; font-size: 12px; color: var(--warn);
}
.sign-errors li { margin: 2px 0; }

/* ── Profiles list status pills + ID stamp ───────────────────────────────── */
.status-pills { display: flex; flex-wrap: wrap; gap: 6px; margin-bottom: 12px; }
.status-pills .pill {
  cursor: pointer; padding: 4px 12px; font-size: 12px;
  background: var(--bg-elev); border: 1px solid var(--border);
}
.status-pills .pill:hover { background: var(--bg-hover); }
.status-pills .pill.pill-accent { border-color: color-mix(in srgb, var(--accent) 50%, var(--border)); }

.profile-id-stamp {
  margin-top: 14px;
  padding: 10px 14px;
  background: color-mix(in srgb, var(--good) 12%, var(--bg-elev));
  border: 1px solid color-mix(in srgb, var(--good) 40%, var(--border));
  border-radius: 6px;
  font-size: 13px;
}
.profile-id-stamp strong { font-size: 15px; color: var(--good); }

/* ── Global search (sidebar) ─────────────────────────────────────────────── */
.sidebar-search { position: relative; padding: 10px 12px; }
.sidebar-search input {
  width: 100%; padding: 6px 32px 6px 10px;
  background: var(--bg); border: 1px solid var(--border);
  border-radius: 6px; color: var(--fg); font-size: 13px;
}
.sidebar-search input:focus { outline: none; border-color: var(--accent); }
.sidebar-search input:focus + .sidebar-search-kbd { display: none; }
.sidebar-search-kbd {
  position: absolute; right: 18px; top: 50%; transform: translateY(-50%);
  background: var(--bg-elev); border: 1px solid var(--border); border-radius: 4px;
  padding: 1px 5px; font-size: 10px; color: var(--muted); pointer-events: none;
  font-family: -apple-system, system-ui, sans-serif;
}
.sidebar-search-results {
  position: absolute; top: calc(100% - 4px); left: 12px; right: 12px;
  background: var(--bg-elev); border: 1px solid var(--border-strong);
  border-radius: 6px; box-shadow: var(--shadow);
  max-height: 540px; overflow-y: auto; z-index: 40;
}
.search-group { padding: 4px 0; }
.search-group + .search-group { border-top: 1px solid var(--border); }
.search-group-heading {
  font-size: 10px; text-transform: uppercase; letter-spacing: 0.06em;
  color: var(--muted); padding: 6px 12px 4px;
}
.search-item {
  display: block; width: 100%; text-align: left; padding: 6px 12px;
  background: transparent; border: none; cursor: pointer; color: var(--fg);
}
.search-item:hover { background: var(--bg-hover); }
.search-item-label { font-size: 13px; font-weight: 500; }
.search-item-sub { font-size: 11px; }
.search-item-snippet { font-size: 11px; margin-top: 2px; line-height: 1.3; }
.search-item-snippet mark { background: color-mix(in srgb, var(--accent) 30%, transparent); color: inherit; padding: 0 1px; }
.search-empty { padding: 12px; font-size: 12px; }

/* ── Dashboard ───────────────────────────────────────────────────────────── */
.dash-counts-row {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
  gap: 10px; margin-bottom: 18px;
}
.dash-count {
  background: var(--bg-elev); border: 1px solid var(--border);
  border-radius: var(--radius); padding: 14px 16px; cursor: pointer;
  text-align: left; color: var(--fg); transition: border-color 0.15s ease;
}
.dash-count:hover { border-color: var(--accent); }
.dash-count-num { font-size: 24px; font-weight: 600; }
.dash-count-label { font-size: 11px; color: var(--muted); text-transform: uppercase; letter-spacing: 0.04em; margin-top: 2px; }

.dash-exp-row {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(110px, 1fr));
  gap: 8px; margin-bottom: 14px;
}
.dash-stat {
  background: var(--bg); border: 1px solid var(--border);
  border-radius: 6px; padding: 10px 12px; cursor: pointer;
  text-align: left; color: var(--fg);
}
.dash-stat:hover { background: var(--bg-hover); }
.dash-stat-warn { border-color: color-mix(in srgb, var(--warn) 40%, var(--border)); }
.dash-stat-accent { border-color: color-mix(in srgb, var(--accent) 40%, var(--border)); }
.dash-stat-muted { border-color: var(--border); }
.dash-stat-num { font-size: 20px; font-weight: 600; }
.dash-stat-label { font-size: 11px; color: var(--muted); text-transform: uppercase; letter-spacing: 0.04em; margin-top: 2px; }

.dash-subhead { font-size: 11px; text-transform: uppercase; letter-spacing: 0.04em; color: var(--muted); margin: 12px 0 6px; }
.dash-list { display: flex; flex-direction: column; gap: 4px; }
.dash-row {
  display: flex; align-items: center; gap: 8px;
  padding: 7px 10px; background: var(--bg); border: 1px solid var(--border);
  border-radius: 6px; font-size: 13px; cursor: pointer;
  text-align: left; color: var(--fg);
}
.dash-row:hover { background: var(--bg-hover); }
.dash-row-strong { font-weight: 500; }
.dash-row .grow { flex: 1; }
.card-foot { margin-top: 12px; padding-top: 10px; border-top: 1px solid var(--border); }

/* ── Toast ───────────────────────────────────────────────────────────────── */
.toast-host { position: fixed; bottom: 16px; right: 16px; display: flex; flex-direction: column; gap: 8px; z-index: 100; }
.toast {
  background: var(--bg-elev); border: 1px solid var(--border-strong);
  padding: 9px 14px; border-radius: 6px; font-size: 13px; min-width: 220px;
  box-shadow: var(--shadow); animation: slide-in 0.2s ease-out;
}
.toast.err { border-color: color-mix(in srgb, var(--warn) 50%, var(--border)); }
@keyframes slide-in {
  from { transform: translateX(20px); opacity: 0; }
  to   { transform: translateX(0); opacity: 1; }
}

/* ── Clients-overview tree (PennOhio dashboard) ──────────────────────────── */
.tree { display: flex; flex-direction: column; gap: 6px; }
.tree-client {
  background: var(--bg); border: 1px solid var(--border); border-radius: 6px;
}
.tree-client > summary {
  display: flex; align-items: center; gap: 10px;
  padding: 8px 12px; cursor: pointer; font-size: 13px; user-select: none;
  list-style: none;
}
.tree-client > summary::marker, .tree-client > summary::-webkit-details-marker { display: none; }
.tree-client > summary::before {
  content: '▸'; color: var(--muted); transition: transform 0.15s ease;
  display: inline-block; width: 12px;
}
.tree-client[open] > summary::before { transform: rotate(90deg); }
.tree-client > summary:hover { background: var(--bg-hover); }
.tree-client-name { font-weight: 500; }
.tree-client .grow { flex: 1; }
.tree-generators {
  display: flex; flex-direction: column; gap: 3px;
  padding: 4px 6px 8px 32px;
}
.tree-gen {
  display: flex; align-items: center; gap: 8px;
  padding: 6px 10px; font-size: 12px;
  background: var(--bg-elev); border: 1px solid var(--border); border-radius: 4px;
}
.tree-gen .grow { flex: 1; }

/* ── Mobile responsiveness pass (≤760px) ─────────────────────────────────── */
@media (max-width: 760px) {
  .shell {
    grid-template-columns: 1fr;
    grid-template-rows: auto 1fr;
    min-height: 100%;
  }
  .sidebar {
    border-right: none;
    border-bottom: 1px solid var(--border);
    padding: 6px 0 0;
  }
  .sidebar-brand {
    padding: 8px 16px 10px;
    border-bottom: 1px solid var(--border);
  }
  .sidebar-search { padding: 8px 12px; }
  .sidebar-search input { font-size: 14px; }
  .sidebar-search-results { left: 12px; right: 12px; max-height: 50vh; }
  .nav {
    flex-direction: row;
    overflow-x: auto;
    gap: 4px;
    padding: 6px 8px;
    border-top: 1px solid var(--border);
  }
  .nav-item { flex: 0 0 auto; padding: 8px 12px; font-size: 13px; }
  .nav-item .icon { font-size: 14px; }
  .nav-spacer { display: none; }
  .sidebar-foot {
    display: flex; align-items: center; gap: 10px; flex-wrap: wrap;
    padding: 8px 12px;
    border-top: 1px solid var(--border);
    margin-top: 0;
  }
  .sidebar-foot .who { margin-bottom: 0; flex: 1 1 auto; min-width: 0; }
  .sidebar-foot .who, .sidebar-foot .muted { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
  .main { padding: 14px; }
  .page-header { gap: 8px; padding-bottom: 10px; margin-bottom: 12px; }
  .page-header h1 { font-size: 17px; }
  .form-row {
    grid-template-columns: 1fr;
    gap: 4px;
  }
  .form-row label { padding-top: 0; }
  .form-row.split { grid-template-columns: 1fr; }
  .wizard-bar {
    overflow-x: auto;
    flex-wrap: nowrap;
  }
  .wizard-step { flex: 0 0 auto; min-width: auto; padding: 6px 10px; font-size: 12px; }
  .wizard-foot {
    flex-wrap: wrap; gap: 6px;
    padding: 10px 12px;
  }
  .modal-card {
    margin: 8px;
    max-width: calc(100vw - 16px);
    max-height: calc(100vh - 16px);
  }
  .modal-body { padding: 12px 14px; }
  .modal-header, .modal-foot { padding: 10px 14px; }
  .detail-grid { grid-template-columns: 1fr; gap: 12px; }
  .card { padding: 14px 14px; }
  .kv { grid-template-columns: 1fr; }
  .kv dt { color: var(--muted); margin-top: 4px; font-size: 11px; }
  .tbl { font-size: 12px; }
  .tbl-wrap { overflow-x: auto; }
  .tbl th, .tbl td { padding: 7px 8px; }
  .dash-counts-row { grid-template-columns: repeat(2, 1fr); gap: 6px; }
  .dash-count { padding: 10px 12px; }
  .dash-count-num { font-size: 18px; }
  .dash-exp-row { grid-template-columns: repeat(2, 1fr); gap: 6px; }
  .dash-row { font-size: 12px; }
  .login-card { padding: 22px 18px; }
  .toast-host { left: 8px; right: 8px; bottom: 8px; }
  .toast { min-width: 0; }

  /* Attachments panel — collapse controls to full-width on narrow screens. */
  .att-filter-chip { padding: 6px 12px; font-size: 12px; }
  .att-pending-controls { flex-direction: column; align-items: stretch; }
  .att-pending-type { width: 100%; }
  .att-pending-desc-wrap { min-width: 0; width: 100%; }
  .att-pending-upload, .att-pending-cancel { width: 100%; }
  .att-dropzone-prompt { flex-direction: column; }

  /* Preview modal goes full-viewport. */
  .att-preview-overlay { padding: 0; }
  .att-preview-card {
    width: 100vw; max-width: 100vw;
    height: 100vh; max-height: 100vh;
    border-radius: 0;
  }
  .att-preview-iframe, .att-preview-img-wrap { min-height: calc(100vh - 64px); }
}

/* ── Stacked attachment rows at very narrow viewports (≤480px) ───────────── */
@media (max-width: 480px) {
  .att-row { flex-direction: column; align-items: stretch; gap: 8px; }
  .att-thumb-btn { align-self: flex-start; }
  .att-row-actions { justify-content: flex-end; }
  .att-row-actions .btn-tiny, .att-row-actions a.btn-tiny { flex: 1 1 30%; text-align: center; }
}

/* ── Mobile readability + no-horizontal-overflow (added 2026-05-13) ──────── */
/* Bumps core text sizes for legibility and constrains common overflow        */
/* culprits without hiding overflow at the page level (which would kill       */
/* legitimate scroll on `.tbl-wrap` and similar). Inputs are ≥16px so iOS     */
/* Safari doesn't auto-zoom on focus — that auto-zoom is the loudest          */
/* contributor to the "page keeps zooming" sensation.                          */
@media (max-width: 760px) {
  html, body { -webkit-text-size-adjust: 100%; }
  body { font-size: 16px; }
  /* Defensive wraps so long unbroken strings (URLs, EPA IDs, audit JSON)    */
  /* break onto the next line instead of forcing horizontal page scroll.     */
  .main, .card, .kv, .att-preview-card, .modal-card, p, li { overflow-wrap: anywhere; word-break: break-word; }
  /* Tables stay un-broken inside their wrapper so columns keep their shape; */
  /* `.tbl-wrap` already has overflow-x:auto so they scroll horizontally.    */
  .tbl-wrap { overflow-x: auto; -webkit-overflow-scrolling: touch; }
  /* Media + frames clamped to container width. */
  img, iframe, video, .att-preview-iframe, .att-preview-img { max-width: 100%; }
  /* Flex/grid children sometimes refuse to shrink below their content size  */
  /* unless explicitly told they can. This prevents cards from forcing the   */
  /* dashboard grid wider than the viewport (the "asymmetric" symptom).      */
  .dash-counts-row > *, .dash-exp-row > *, .detail-grid > *, .att-row > * { min-width: 0; }
  /* Bump readable text up; keep proportions roughly the same as desktop. */
  .page-header h1 { font-size: 20px; }
  .tbl { font-size: 15px; }
  .tbl th { font-size: 12px; }
  .kv { font-size: 15px; grid-template-columns: 110px 1fr; }
  .card h3 { font-size: 13px; }
  .subsec h4 { font-size: 13px; }
  .nav-item { font-size: 15px; padding: 9px 13px; }
  .nav-item .icon { font-size: 16px; }
  .btn, .btn-primary, .btn-secondary { font-size: 15px; padding: 9px 14px; }
  .btn-tiny { font-size: 13px; padding: 5px 11px; }
  .pill, .badge, .chip { font-size: 12px; }
  .muted, .small, .crumbs { font-size: 13px; }
  .empty-state h3 { font-size: 17px; }
  .empty-state p { font-size: 14px; }
  .audit-row, .audit-row .ts { font-size: 12px; }
  .wizard-step { font-size: 13px; padding: 7px 12px; }
  /* Inputs at ≥16px so iOS doesn't auto-zoom on focus (the big offender for  */
  /* the "page keeps zooming in/out" sensation).                              */
  input, select, textarea,
  .form-row input, .form-row select, .form-row textarea,
  .sidebar-search input, .filter-bar input, .filter-bar select { font-size: 16px; }
}

/* ── Utility ─────────────────────────────────────────────────────────────── */
.muted { color: var(--muted); }
.truncate { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
a.link { color: var(--accent); text-decoration: none; cursor: pointer; }
a.link:hover { text-decoration: underline; }

/* ── Roles overhaul (2026-05-13) ─────────────────────────────────────────── */
/* Contact-role chips (4 tones). Used in list views + detail KV blocks. */
.role-chip {
  display: inline-block;
  padding: 2px 8px;
  font-size: 11px;
  font-weight: 600;
  border-radius: 999px;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  border: 1px solid transparent;
}
.role-chip-admin   { background: color-mix(in srgb, var(--role-admin) 22%, var(--bg-elev)); color: color-mix(in srgb, var(--role-admin) 70%, var(--fg)); border-color: color-mix(in srgb, var(--role-admin) 45%, transparent); }
.role-chip-manager { background: color-mix(in srgb, var(--yellow) 22%, var(--bg-elev)); color: var(--yellow); border-color: color-mix(in srgb, var(--yellow) 45%, transparent); }
.role-chip-signer  { background: color-mix(in srgb, var(--good) 22%, var(--bg-elev)); color: var(--good); border-color: color-mix(in srgb, var(--good) 45%, transparent); }
.role-chip-viewer  { background: var(--bg-hover); color: var(--muted); border-color: var(--border); }

/* "Show inactive" toggle on list pages. */
.filter-bar .show-inactive {
  display: inline-flex; align-items: center; gap: 6px;
  color: var(--muted); font-size: 12px; cursor: pointer; user-select: none;
  margin-left: 8px;
}
.filter-bar .show-inactive input { accent-color: var(--accent); }

/* Inactive rows dim across all list tables. */
.tbl tr.inactive-row td { opacity: 0.55; }
.tbl tr.inactive-row td:first-child::after {
  content: ' (inactive)';
  color: var(--muted);
  font-size: 11px;
  margin-left: 4px;
}
.inactive-text { color: var(--muted); }

/* Owner-only "Delete (permanent)" modal — extra friction with type-DELETE. */
.danger-modal { border: 1px solid color-mix(in srgb, var(--warn) 55%, var(--border-strong)); }
.danger-modal .modal-header h2 { color: var(--warn); }
.danger-modal .modal-body p { margin: 0 0 12px; }
.danger-modal #confirmInput {
  width: 100%; padding: 9px 11px; margin-top: 4px;
  background: var(--bg); border: 1px solid var(--border-strong);
  border-radius: 6px; color: var(--fg); font-family: ui-monospace, SFMono-Regular, Menlo, monospace;
  font-size: 14px; letter-spacing: 0.08em;
}
.danger-modal #confirmInput:focus { border-color: var(--warn); outline: none; }
.danger-modal code {
  background: var(--bg); padding: 1px 6px; border-radius: 4px;
  color: var(--warn); font-family: ui-monospace, SFMono-Regular, Menlo, monospace;
}
.danger-modal .btn-danger:not(:disabled) {
  background: var(--warn); color: var(--bg);
  border-color: var(--warn);
}
.danger-modal .btn-danger:not(:disabled):hover { filter: brightness(1.05); }

/* ── Typeahead picker (2026-05-15) ────────────────────────────────────────── */
/* Generic primitive used by the new-profile flow's client + generator pickers
   and the "Send for signing" recipient picker. */
.typeahead-card { max-width: 540px; }
.typeahead-input {
  width: 100%; padding: 9px 11px; margin-bottom: 4px;
  background: var(--bg); border: 1px solid var(--border-strong);
  border-radius: 6px; color: var(--fg); font-size: 14px;
}
.typeahead-input:focus { border-color: var(--accent); outline: none; }
.typeahead-list {
  margin-top: 8px;
  border: 1px solid var(--border); border-radius: 6px;
  background: var(--bg);
  max-height: 304px;        /* ~8 rows */
  overflow-y: auto;
}
.typeahead-row {
  padding: 8px 11px; cursor: pointer;
  display: flex; flex-direction: column; gap: 2px;
  border-bottom: 1px solid var(--border);
}
.typeahead-row:last-child { border-bottom: none; }
.typeahead-row:hover { background: var(--bg-elev); }
.typeahead-row.is-highlight {
  background: color-mix(in srgb, var(--accent) 18%, var(--bg));
  border-left: 3px solid var(--accent);
  padding-left: 8px;
}
.typeahead-row-main { font-size: 14px; font-weight: 500; color: var(--fg); }
.typeahead-row-sub  { font-size: 12px; color: var(--muted); }
.typeahead-empty {
  padding: 14px 12px; color: var(--muted); font-size: 13px;
  text-align: center;
}

/* ── Signature-request badges (2026-05-15) ────────────────────────────────── */
/* Surfaces drafts that PennOhio has sent for a specific client_user's signature
   ("Awaiting your signature") and signed profiles bounced back with reasons
   ("Changes requested"). Color-coded to read at a glance in busy lists. */
.signature-badge {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 2px 8px; border-radius: 999px;
  font-size: 11px; font-weight: 600;
  border: 1px solid;
  white-space: nowrap;
}
.signature-badge-awaiting {
  background: color-mix(in srgb, var(--role-yellow) 14%, var(--bg));
  border-color: color-mix(in srgb, var(--role-yellow) 65%, var(--border));
  color: color-mix(in srgb, var(--role-yellow) 80%, var(--fg));
}
.signature-badge-changes {
  background: color-mix(in srgb, var(--warn) 14%, var(--bg));
  border-color: color-mix(in srgb, var(--warn) 65%, var(--border));
  color: var(--warn);
}
.changes-reason {
  margin-top: 6px; padding: 8px 10px;
  background: color-mix(in srgb, var(--warn) 8%, var(--bg));
  border: 1px solid color-mix(in srgb, var(--warn) 40%, var(--border));
  border-radius: 6px;
  font-size: 12px; color: var(--fg);
}
.changes-reason strong { color: var(--warn); }
.signature-status-pane {
  padding: 10px 12px; margin-top: 10px;
  background: color-mix(in srgb, var(--role-yellow) 8%, var(--bg-elev));
  border: 1px solid color-mix(in srgb, var(--role-yellow) 45%, var(--border));
  border-radius: 6px;
  font-size: 13px;
}
.signature-status-pane strong { color: var(--fg); }

/* Dashboard counter for surfacing signature workflow alerts. */
.dash-count.dash-count-warn {
  border-color: color-mix(in srgb, var(--warn) 55%, var(--border));
  background: color-mix(in srgb, var(--warn) 8%, var(--bg-elev));
}
.dash-count.dash-count-warn .dash-count-num { color: var(--warn); }

/* Stale-draft banner (wizard step 1, both portals): yellow nudge that
   appears when a draft has been untouched for 10+ days. Visually echoes
   the signature-status-pane so the two warn-toned banners read as the
   same "you need to look at this" family. */
.stale-banner {
  padding: 10px 12px; margin-top: 10px;
  background: color-mix(in srgb, var(--warn) 10%, var(--bg-elev));
  border: 1px solid color-mix(in srgb, var(--warn) 45%, var(--border));
  border-radius: 6px;
  font-size: 13px;
}
.stale-banner strong { color: var(--fg); }

/* ─── Getting-started guide (interactive tour) ─────────────────────────────── */
.tour-overlay { position: fixed; inset: 0; z-index: 9000; }
.tour-spot {
  position: fixed; border-radius: 8px; border: 2px solid #fff; pointer-events: none;
  box-shadow: 0 0 0 9999px rgba(15, 23, 32, .55);
  transition: left .2s ease, top .2s ease, width .2s ease, height .2s ease;
}
.tour-pop {
  position: fixed; width: 300px; max-width: calc(100vw - 24px); z-index: 9001;
  background: var(--bg-elev, #fff); color: var(--fg, #1a1f2a);
  border: 1px solid var(--border, #e2e2dc); border-radius: 12px;
  box-shadow: 0 16px 40px rgba(0, 0, 0, .32); padding: 16px 18px;
}
.tour-pop-step { font-size: 11px; letter-spacing: .05em; text-transform: uppercase; color: var(--muted, #8a8a80); margin-bottom: 4px; }
.tour-pop h3 { margin: 0 0 6px; font-size: 16px; }
.tour-pop p { margin: 0 0 14px; font-size: 13px; line-height: 1.5; color: var(--muted, #555); }
.tour-pop-actions { display: flex; align-items: center; gap: 8px; }

/* Re-sign change summary — "what PennOhio changed since your last signature" */
.change-summary-card { border-left: 4px solid #b8860b; background: rgba(184,134,11,0.06); }
.change-summary { margin: 8px 0 0; padding-left: 18px; }
.change-summary li { margin: 4px 0; line-height: 1.5; }
.change-summary .cs-old { color: var(--muted); text-decoration: line-through; }
.change-summary .cs-new { font-weight: 600; }
