/**
 * Harbor Home Healthcare — QI Portal Design System v3
 * File: /wp-content/themes/harbor-child/css/harbor-qi.css
 *
 * Architecture:
 *  01 · TOKENS          — :root custom properties (single source of truth)
 *  02 · RESET + BASE    — box-sizing, body, links, headings
 *  03 · SHELL           — app wrapper, two-column grid
 *  04 · SIDEBAR + NAV   — fixed: section titles 12px, items 44px min
 *  05 · TOPBAR          — breadcrumbs, top action strip
 *  06 · BUTTONS         — 44px minimum across all interactive targets
 *  07 · MASTHEAD        — scaled-down editorial header
 *  08 · STATS STRIP     — KPI row
 *  09 · DASHBOARD       — two-col grid, domain rows, rail cards
 *  10 · FORMS + FIELDS  — fixed: labels 12px, inputs 44px
 *  11 · TABLES          — records listing, action buttons
 *  12 · DRAWER          — slide-over panel, 44px close button
 *  13 · STATUS BADGES   — pills, dots, service chips
 *  14 · REPORTS + GOV   — govreport structured layout
 *  15 · LOGIN MODAL     — hqim-* two-panel modal
 *  16 · ACCESSIBILITY   — skip link, focus-visible, sr-only, aria-live
 *  17 · RESPONSIVE      — breakpoints 1280 / 1024 / 768
 *  18 · PRINT           — single consolidated block (Letter, 0.55in margin)
 *
 * Design decisions:
 *  - All CSS variables on :root (not .qi-app) — fixes drawer/modal scoping
 *  - Single typography system: Inter throughout the QI app
 *  - !important appears ONLY in .sr-only and body.print-mode overrides
 *  - Touch targets ≥ 44px (WCAG 2.5.5 AAA / iOS HIG)
 *  - Contrast: --ink-meta replaces --ink-40 on text; nav section titles ≥ 3:1
 */

/* ═══════════════════════════════════════════════════════════
 * 01 · TOKENS
 * ═════════════════════════════════════════════════════════ */
:root {
  /* Ink palette */
  --ink:        #0A1F3D;
  --ink-90:     rgba(10,31,61,.90);
  --ink-70:     rgba(10,31,61,.70);
  --ink-60:     rgba(10,31,61,.60);
  --ink-meta:   rgba(10,31,61,.54);   /* min 4.5:1 on --paper — use instead of ink-40 */
  --ink-border: rgba(10,31,61,.20);
  --ink-divider:rgba(10,31,61,.10);
  --ink-surface:rgba(10,31,61,.06);
  --ink-subtle: rgba(10,31,61,.03);

  /* Surfaces */
  --paper:       #F6F3EA;
  --paper-warm:  #EEE9DB;
  --card:        #FDFBF5;
  --card-alt:    #FAF6EB;
  --rule:        #D6CFBC;
  --rule-soft:   #E6E0CD;

  /* Semantic colours */
  --oxblood:      #6B1926;
  --oxblood-soft: #F2E3E1;
  --oxblood-mid:  rgba(107,25,38,.18);

  --brass:      #A88B3C;
  --brass-soft: #F0E7CC;

  --sage:       #3D5A45;
  --sage-soft:  #DEE6D4;

  --coral:      #B04F3B;
  --coral-soft: #F5DDD2;

  --amber:      #B47A14;
  --amber-soft: #F4E7C4;

  /* Sidebar-specific (dark bg) */
  --sidebar-bg:         #0A1F3D;
  --sidebar-text:       rgba(246,243,234,.80);   /* ≥ 4.5:1 on sidebar-bg */
  --sidebar-text-dim:   rgba(246,243,234,.60);   /* ≥ 3.1:1 — used for section labels */
  --sidebar-text-muted: rgba(246,243,234,.42);   /* ≥ 2.1:1 — nav-item dot only */
  --sidebar-active-bg:  rgba(168,139,60,.14);
  --sidebar-active:     #C5A449;                 /* brass lightened for dark bg */
  --sidebar-hover-bg:   rgba(255,255,255,.06);
  --sidebar-divider:    rgba(255,255,255,.09);

  /* Focus */
  --focus-ring:     #6B1926;
  --focus-ring-glow:rgba(107,25,38,.22);

  /* Validation */
  --valid:    #1F7A4D;
  --valid-bg: #F0FFF6;
  --invalid:  #B42318;
  --invalid-bg:#FFF1F0;

  /* Typography */
  --body:    'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Arial, sans-serif;
  --mono:    'JetBrains Mono', ui-monospace, 'SF Mono', Consolas, monospace;

  /* Spacing scale */
  --sp-1: .25rem;  --sp-2: .5rem;   --sp-3: .75rem;  --sp-4: 1rem;
  --sp-5: 1.25rem; --sp-6: 1.5rem;  --sp-8: 2rem;    --sp-10: 2.5rem;
  --sp-12: 3rem;

  /* Radius */
  --r-sm: 4px;
  --r:    6px;
  --r-lg: 10px;
  --r-xl: 16px;

  /* Layout */
  --sidebar-w: 296px;
  --content-max: 1440px;
  --topbar-h: 56px;

  /* Touch target minimum */
  --touch: 44px;
}

/* ═══════════════════════════════════════════════════════════
 * 02 · RESET + BASE
 * ═════════════════════════════════════════════════════════ */
.qi-app, .qi-app *, .qi-app *::before, .qi-app *::after { box-sizing: border-box; }

.qi-app {
  font-family: var(--body);
  font-size: 16px;
  color: var(--ink);
  background: var(--paper);
  line-height: 1.55;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  min-height: 100vh;
}

.qi-app a { color: inherit; text-decoration: none; }
.qi-app a:hover { text-decoration: none; }

.qi-app h1, .qi-app h2, .qi-app h3, .qi-app h4 {
  font-family: var(--body);
  font-weight: 700;
  letter-spacing: -0.015em;
  color: var(--ink);
  margin: 0;
}

/* ═══════════════════════════════════════════════════════════
 * 03 · SHELL
 * ═════════════════════════════════════════════════════════ */
.qi-shell {
  display: grid;
  grid-template-columns: var(--sidebar-w) 1fr;
  min-height: 100vh;
}

/* ═══════════════════════════════════════════════════════════
 * 04 · SIDEBAR + NAV
 * ═════════════════════════════════════════════════════════ */
.qi-sidebar {
  background: var(--sidebar-bg);
  color: var(--sidebar-text);
  padding: 24px 18px 28px;
  position: sticky;
  top: 0;
  height: 100vh;
  overflow-y: auto;
  border-right: 1px solid var(--sidebar-divider);
  display: flex;
  flex-direction: column;
  gap: 0;
}

/* Admin bar compensation */
body.admin-bar .qi-sidebar {
  top: 32px;
  height: calc(100vh - 32px);
}

.qi-brand {
  padding-bottom: var(--sp-6);
  border-bottom: 1px solid var(--sidebar-divider);
  margin-bottom: var(--sp-6);
}

.qi-brand__mark {
  display: flex;
  align-items: center;
  gap: var(--sp-2);
  font-family: var(--body);
  font-size: 1.25rem;
  font-weight: 800;
  color: var(--paper);
  letter-spacing: -0.02em;
}

.qi-brand__mark::before {
  content: '';
  width: 8px;
  height: 8px;
  background: var(--sidebar-active);
  border-radius: 50%;
  flex-shrink: 0;
}

.qi-brand__sub {
  font-size: 11px;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--sidebar-text-dim);
  margin-top: var(--sp-1);
  padding-left: 1rem;
}

/* Toggle button (mobile only — hidden on desktop) */
.qi-sidebar__toggle {
  display: none;
  background: none;
  border: 1px solid rgba(255,255,255,.25);
  color: var(--paper);
  padding: 5px 12px;
  border-radius: var(--r-sm);
  cursor: pointer;
  font-size: .8125rem;
  font-family: var(--body);
  font-weight: 600;
}

.qi-nav-section { margin-bottom: var(--sp-6); }

/* FIXED: was 10px (0.625rem) — now 12px minimum */
.qi-nav-section__title {
  font-size: 12px;
  font-weight: 700;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--sidebar-text-dim);   /* 3.1:1+ on dark bg */
  margin-bottom: var(--sp-2);
  padding-left: var(--sp-3);
}

/* FIXED: min-height was 40px — now 44px (WCAG touch target) */
.qi-nav-item {
  display: flex;
  align-items: center;
  gap: var(--sp-2);
  padding: 12px 14px;
  min-height: var(--touch);
  font-size: 15px;
  font-weight: 600;
  color: var(--sidebar-text);
  border-radius: var(--r);
  margin-bottom: 2px;
  transition: background .13s, color .13s;
  cursor: pointer;
  line-height: 1.3;
  position: relative;
  text-decoration: none;
}

.qi-nav-item:hover { background: var(--sidebar-hover-bg); color: var(--paper); }

.qi-nav-item.is-active {
  background: var(--sidebar-active-bg);
  color: var(--sidebar-active);
}

.qi-nav-item.is-active::before {
  content: '';
  position: absolute;
  left: 0;
  top: 8px;
  bottom: 8px;
  width: 3px;
  background: var(--sidebar-active);
  border-radius: 2px;
}

.qi-nav-item__dot {
  font-family: var(--mono);
  font-size: 12px;
  color: var(--sidebar-text-muted);
  min-width: 2rem;
  font-weight: 500;
}

.qi-nav-item.is-active .qi-nav-item__dot { color: var(--sidebar-active); }

/* Sidebar footer */
.qi-sidebar__footer {
  margin-top: auto;
  padding-top: var(--sp-6);
  border-top: 1px solid var(--sidebar-divider);
}

.qi-user { display: flex; align-items: center; gap: var(--sp-3); }

.qi-user__avatar {
  width: 38px;
  height: 38px;
  border-radius: 50%;
  background: var(--sidebar-active);
  color: var(--ink);
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 700;
  font-size: .9375rem;
  flex-shrink: 0;
}

.qi-user__meta { line-height: 1.3; min-width: 0; }
.qi-user__name { font-size: .875rem; font-weight: 700; color: var(--paper); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.qi-user__role { font-size: 12px; color: var(--sidebar-text-dim); }

.qi-user__logout {
  display: block;
  margin-top: var(--sp-3);
  padding: .5rem var(--sp-3);
  min-height: var(--touch);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: .8125rem;
  font-weight: 600;
  color: var(--sidebar-text-dim);
  border: 1px solid var(--sidebar-divider);
  border-radius: var(--r);
  text-align: center;
  transition: all .13s;
}

.qi-user__logout:hover { color: var(--oxblood-soft); border-color: rgba(240,231,204,.22); }

/* ═══════════════════════════════════════════════════════════
 * 05 · TOPBAR
 * ═════════════════════════════════════════════════════════ */
.qi-main {
  min-width: 0;
  padding: var(--sp-10) var(--sp-10) 5rem;
  max-width: var(--content-max);  /* prevents ultra-wide line lengths */
}

.qi-topbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--sp-4);
  flex-wrap: wrap;
  padding-bottom: var(--sp-5);
  margin-bottom: var(--sp-8);
  border-bottom: 1px solid var(--ink-divider);
  min-height: var(--topbar-h);
}

.qi-crumbs {
  display: flex;
  align-items: center;
  gap: var(--sp-2);
  font-size: .875rem;
  color: var(--ink-60);
}

.qi-crumbs a:hover { color: var(--oxblood); }
.qi-crumbs__sep { color: var(--ink-border); }
.qi-crumbs__current { color: var(--ink); font-weight: 700; font-size: .875rem; }

.qi-topbar__actions { display: flex; gap: var(--sp-2); flex-wrap: wrap; }

/* ═══════════════════════════════════════════════════════════
 * 06 · BUTTONS  (FIXED: min-height 36→44px across all variants)
 * ═════════════════════════════════════════════════════════ */
.qi-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: .4rem;
  padding: .625rem 1rem;
  min-height: var(--touch);        /* 44px — was 36px */
  font-family: var(--body);
  font-size: .875rem;
  font-weight: 700;
  line-height: 1.2;
  color: var(--ink);
  background: var(--card);
  border: 1px solid var(--rule);
  border-radius: var(--r);
  cursor: pointer;
  transition: background .13s, border-color .13s, color .13s;
  white-space: nowrap;
  text-decoration: none;
  -webkit-appearance: none;
  appearance: none;
}

.qi-btn:hover { background: var(--paper-warm); border-color: var(--ink-border); }

.qi-btn:focus-visible {
  outline: 2px solid var(--focus-ring);
  outline-offset: 2px;
  box-shadow: 0 0 0 4px var(--focus-ring-glow);
}

.qi-btn.is-active { background: var(--ink); color: var(--paper); border-color: var(--ink); }

.qi-btn--primary { background: var(--ink); color: var(--paper); border-color: var(--ink); }
.qi-btn--primary:hover { background: var(--oxblood); border-color: var(--oxblood); color: var(--paper); }

.qi-btn--outline { background: var(--card); color: var(--ink); border-color: var(--rule); }
.qi-btn--outline:hover { background: var(--paper-warm); }

.qi-btn--ghost { background: transparent; border-color: transparent; color: var(--ink-70); }
.qi-btn--ghost:hover { background: var(--ink-surface); color: var(--ink); border-color: transparent; }

.qi-btn--danger { color: var(--oxblood); border-color: var(--oxblood-soft); }
.qi-btn--danger:hover { background: var(--oxblood-soft); }

.qi-btn--burgundy { background: var(--oxblood); color: var(--paper); border-color: var(--oxblood); }
.qi-btn--burgundy:hover { background: #861f30; border-color: #861f30; color: var(--paper); }

.qi-btn--lock { border-color: var(--oxblood); color: var(--oxblood); }
.qi-btn--lock:hover { background: var(--oxblood); color: var(--paper); }

/* Small variant — 36px visual for dense table use; touch area expanded on the
 * container via padding-block so finger taps land on a 44px surface. */
.qi-btn--sm {
  min-height: 36px;
  padding: .375rem .75rem;
  font-size: .8125rem;
}

/* Row action container — 44px touch area without forcing visual row height up */
.qi-row-actions {
  display: flex;
  gap: .375rem;
  align-items: center;
  flex-wrap: wrap;
  /* Expand tappable surface to 44px (WCAG 2.5.5) while keeping visual at 36px */
  padding-block: calc((44px - 36px) / 2);
  margin-block:  calc((44px - 36px) / -2);
}
.qi-row-actions .qi-btn { min-height: 36px; padding: .375rem .75rem; font-size: .8125rem; }

/* ═══════════════════════════════════════════════════════════
 * 07 · MASTHEAD  (FIXED: title scaled from 4rem → 2.25rem)
 * ═════════════════════════════════════════════════════════ */
.qi-masthead {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: var(--sp-8);
  align-items: end;
  padding-bottom: var(--sp-6);
  border-bottom: 2px solid var(--ink);
  margin-bottom: var(--sp-8);
}

.qi-masthead--compact { padding-bottom: var(--sp-4); margin-bottom: var(--sp-6); }

.qi-masthead__kicker {
  display: flex;
  align-items: center;
  gap: var(--sp-3);
  margin-bottom: var(--sp-3);
}

/* FIXED: was clamp(2.25rem, 4.5vw, 4rem) — now 2.25rem max */
.qi-masthead__title {
  font-size: clamp(1.625rem, 2.5vw, 2.25rem);
  font-weight: 800;
  line-height: 1.05;
  letter-spacing: -0.025em;
  color: var(--ink);
  margin: 0;
}

.qi-masthead__title em { font-style: normal; color: var(--oxblood); }

.qi-masthead__sub {
  font-size: .9375rem;
  color: var(--ink-70);
  margin-top: var(--sp-2);
  line-height: 1.5;
}

.qi-masthead__right {
  text-align: right;
  color: var(--ink-60);
  font-size: .875rem;
  line-height: 1.5;
  max-width: 280px;
}

.qi-masthead__right strong {
  display: block;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--ink);
  margin-bottom: .375rem;
}

.qi-label {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--ink-60);
}
.qi-label--accent { color: var(--oxblood); letter-spacing: .22em; }

.qi-issue-date { font-size: .875rem; color: var(--ink-60); }

.qi-rule-small { height: 1px; background: var(--ink-border); width: 2rem; display: block; }

/* ═══════════════════════════════════════════════════════════
 * 08 · STATS STRIP  (FIXED: stat value from 3rem → 2.25rem)
 * ═════════════════════════════════════════════════════════ */
.qi-stats {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  border-top: 1px solid var(--ink-border);
  border-bottom: 1px solid var(--ink-border);
  margin-bottom: var(--sp-10);
}

.qi-stats--four  { grid-template-columns: repeat(4, 1fr); }
.qi-stats--three { grid-template-columns: repeat(3, 1fr); }
.qi-stats--five  { grid-template-columns: repeat(5, 1fr); }

.qi-stat {
  padding: var(--sp-5) var(--sp-5);
  border-right: 1px solid var(--ink-border);
}
.qi-stat:last-child { border-right: none; }

.qi-stat__label {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--ink-meta);
  margin-bottom: var(--sp-2);
}

/* FIXED: was 3rem — now 2.25rem. Reduces vertical footprint 25% */
.qi-stat__value {
  font-family: var(--mono);
  font-size: 2.25rem;
  font-weight: 600;
  line-height: 1;
  color: var(--ink);
  letter-spacing: -0.03em;
  font-variant-numeric: tabular-nums;
}

.qi-stat__value small { font-size: 1.1rem; color: var(--ink-meta); font-weight: 400; margin-left: .1em; }

.qi-stat__note { font-size: .8125rem; color: var(--ink-meta); margin-top: var(--sp-1); }

.qi-stat--highlight .qi-stat__value { color: var(--oxblood); }
.qi-stat--alert .qi-stat__value { color: var(--coral); }
.qi-stat--success .qi-stat__value { color: var(--sage); }

/* ═══════════════════════════════════════════════════════════
 * 09 · DASHBOARD LAYOUT
 * ═════════════════════════════════════════════════════════ */
.qi-content-grid {
  display: grid;
  grid-template-columns: 2fr 1fr;
  gap: var(--sp-10);
  align-items: start;
}

.qi-section-head {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  margin-bottom: var(--sp-6);
  padding-bottom: var(--sp-3);
  border-bottom: 1px solid var(--ink-border);
}

.qi-section-head__title { font-size: 1.5rem; font-weight: 700; letter-spacing: -.02em; }
.qi-section-head__title em { font-style: normal; color: var(--oxblood); }
.qi-section-head__meta { font-size: .8125rem; color: var(--ink-meta); }

.qi-group-label {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--oxblood);
  margin: var(--sp-8) 0 var(--sp-4);
  display: flex;
  align-items: center;
  gap: var(--sp-4);
}

.qi-group-label::after { content: ''; flex: 1; height: 1px; background: var(--ink-border); }

.qi-domain-row {
  display: grid;
  grid-template-columns: 48px 1fr 200px 80px;
  gap: var(--sp-5);
  align-items: center;
  padding: var(--sp-4) 0;
  border-bottom: 1px solid var(--ink-surface);
  transition: background .13s;
}
.qi-domain-row:hover { background: var(--ink-subtle); }
.qi-domain-row:last-child { border-bottom: none; }

.qi-domain-row__code { font-family: var(--mono); font-size: 1rem; font-weight: 600; color: var(--ink-60); }
.qi-domain-row__name { font-size: 1rem; font-weight: 500; color: var(--ink); line-height: 1.3; }

.qi-bar-track { height: 6px; background: var(--ink-surface); border-radius: 3px; overflow: hidden; }
.qi-bar-fill { height: 100%; border-radius: 3px; transition: width .3s ease; }
.qi-bar-fill--healthy { background: var(--sage); }
.qi-bar-fill--review  { background: var(--brass); }
.qi-bar-fill--action  { background: var(--coral); }
.qi-bar-fill--none    { background: var(--ink-border); width: 100%; }

.qi-domain-row__pct { font-family: var(--mono); font-size: .9375rem; font-weight: 600; color: var(--ink); text-align: right; font-variant-numeric: tabular-nums; }
.qi-none { font-style: italic; font-weight: 400; font-size: .8125rem; color: var(--ink-meta); }

/* Rail (sidebar column) */
.qi-rail { display: flex; flex-direction: column; gap: var(--sp-8); }

.qi-rail-card {
  background: var(--card);
  border: 1px solid var(--rule);
  border-radius: var(--r-lg);
  padding: var(--sp-6);
  position: relative;
  overflow: hidden;
}

.qi-rail-card::before { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 3px; background: var(--ink); border-radius: var(--r-lg) var(--r-lg) 0 0; }
.qi-rail-card--brass::before   { background: var(--brass); }
.qi-rail-card--oxblood::before { background: var(--oxblood); }
.qi-rail-card--sage::before    { background: var(--sage); }

.qi-rail-card__title { font-size: 1.125rem; font-weight: 700; letter-spacing: -.01em; margin: 0 0 var(--sp-1); }
.qi-rail-card__title em { font-style: normal; color: var(--oxblood); }
.qi-rail-card__sub { font-size: .8125rem; color: var(--ink-meta); margin: 0 0 var(--sp-5); padding-bottom: var(--sp-4); border-bottom: 1px solid var(--ink-surface); }

.qi-actions-list { display: flex; flex-direction: column; gap: var(--sp-3); }

.qi-action-item {
  display: flex;
  align-items: center;
  gap: var(--sp-3);
  padding: var(--sp-2) 0;
  border-bottom: 1px dashed var(--ink-surface);
  transition: transform .13s;
  min-height: var(--touch);
}
.qi-action-item:last-child { border-bottom: none; }
.qi-action-item:hover { transform: translateX(4px); }

.qi-action-item__num { font-size: 1.25rem; font-weight: 700; color: var(--brass); min-width: 2rem; line-height: 1; }
.qi-action-item__body { flex: 1; }
.qi-action-item__title { font-size: .9375rem; font-weight: 700; color: var(--ink); line-height: 1.3; }
.qi-action-item__desc { font-size: .8125rem; color: var(--ink-meta); margin-top: 2px; }
.qi-action-item__arrow { color: var(--ink-border); font-size: 1.125rem; }

/* Activity feed */
.qi-feed-item { display: grid; grid-template-columns: auto 1fr; gap: var(--sp-3); padding: var(--sp-3) 0; border-bottom: 1px solid var(--ink-surface); }
.qi-feed-item:last-child { border-bottom: none; }
.qi-feed-item__date { font-family: var(--mono); font-size: 11px; font-weight: 600; color: var(--ink-meta); padding-top: 3px; min-width: 56px; text-transform: uppercase; }
.qi-feed-item__body { line-height: 1.4; min-width: 0; }
.qi-feed-item__domain { font-size: 11px; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; color: var(--oxblood); margin-bottom: 2px; display: flex; align-items: center; gap: .375rem; }
.qi-feed-item__title { font-size: .9375rem; font-weight: 500; color: var(--ink); }
.qi-feed-item__meta { font-family: var(--mono); font-size: 11px; color: var(--ink-meta); margin-top: 2px; }

/* Dots */
.qi-dot { display: inline-block; width: 7px; height: 7px; border-radius: 50%; vertical-align: middle; }
.qi-dot--ok   { background: var(--sage); }
.qi-dot--flag { background: var(--coral); }
.qi-dot--info { background: var(--brass); }

/* Compliance callout */
.qi-compliance {
  background: var(--ink);
  color: var(--paper);
  padding: var(--sp-6);
  border-radius: var(--r-lg);
  position: relative;
  overflow: hidden;
}
.qi-compliance::before { content: '§'; position: absolute; top: -1rem; right: -0.5rem; font-size: 9rem; font-weight: 700; color: rgba(168,139,60,.12); line-height: 1; pointer-events: none; }
.qi-compliance__label { font-size: 11px; font-weight: 700; letter-spacing: .2em; text-transform: uppercase; color: var(--sidebar-active); margin-bottom: var(--sp-3); }
.qi-compliance__statement { font-size: 1rem; font-weight: 400; line-height: 1.55; color: var(--paper); position: relative; z-index: 1; }
.qi-compliance__cite { font-family: var(--mono); font-size: .75rem; color: rgba(246,243,234,.50); margin-top: var(--sp-4); padding-top: var(--sp-4); border-top: 1px solid rgba(168,139,60,.22); letter-spacing: .03em; }

/* ═══════════════════════════════════════════════════════════
 * 10 · FORMS + FIELDS  (FIXED: labels 11px→12px, inputs 44px)
 * ═════════════════════════════════════════════════════════ */
.qi-section-card { background: var(--card); border: 1px solid var(--rule); border-radius: var(--r-lg); margin-bottom: var(--sp-6); }
.qi-section-card:focus-within { border-color: rgba(107,25,38,.38); box-shadow: 0 0 0 3px var(--focus-ring-glow); }

.qi-section-card__head {
  padding: var(--sp-4) var(--sp-6);
  border-bottom: 1px solid var(--rule-soft);
  background: var(--card-alt);
  display: flex;
  align-items: center;
  gap: var(--sp-3);
  border-radius: var(--r-lg) var(--r-lg) 0 0;
}

.qi-section-card__num { font-size: 1rem; font-weight: 700; color: var(--brass); }
.qi-section-card__title { font-size: 11px; font-weight: 700; letter-spacing: .18em; text-transform: uppercase; color: var(--ink); margin: 0; }
.qi-section-card__body { padding: var(--sp-6); }

.qi-grid { display: grid; grid-template-columns: repeat(12, minmax(0, 1fr)); gap: var(--sp-5); }
.qi-field { display: flex; flex-direction: column; gap: var(--sp-2); }
.qi-field--c3  { grid-column: span 3; }
.qi-field--c4  { grid-column: span 4; }
.qi-field--c5  { grid-column: span 5; }
.qi-field--c6  { grid-column: span 6; }
.qi-field--c8  { grid-column: span 8; }
.qi-field--c12 { grid-column: span 12; }

/* FIXED: was 0.6875rem (11px) — now 12px */
.qi-field__label {
  font-size: 12px;
  font-weight: 700;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--ink-70);
}

.qi-field__label .qi-req { color: var(--invalid); margin-left: .2em; font-size: .9em; }

/* FIXED: min-height 42px → 44px (touch target) */
.qi-field input, .qi-field select, .qi-field textarea {
  width: 100%;
  min-height: var(--touch);
  padding: .6875rem .9375rem;
  font-family: var(--body);
  font-size: 1rem;
  color: var(--ink);
  background: #FFFEFA;
  border: 1.5px solid var(--rule);
  border-radius: var(--r);
  transition: border-color .13s, box-shadow .13s, background .13s;
  -webkit-appearance: none;
  appearance: none;
}

.qi-field select {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='%230A1F3D' d='M6 8L0 0h12z'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 1rem center;
  padding-right: 2.25rem;
}

.qi-field textarea { min-height: 120px; resize: vertical; line-height: 1.55; }

.qi-field input::placeholder, .qi-field textarea::placeholder { color: var(--ink-meta); font-style: italic; }

.qi-field input:hover, .qi-field select:hover, .qi-field textarea:hover { border-color: var(--ink-60); }

.qi-field input:focus, .qi-field select:focus, .qi-field textarea:focus {
  outline: none;
  border-color: var(--focus-ring);
  background: #fff;
  box-shadow: 0 0 0 3px var(--focus-ring-glow);
}

.qi-field.is-valid input, .qi-field.is-valid select, .qi-field.is-valid textarea { border-color: var(--valid); background: var(--valid-bg); box-shadow: inset 4px 0 0 var(--valid); }
.qi-field.is-invalid input, .qi-field.is-invalid select, .qi-field.is-invalid textarea { border-color: var(--invalid); background: var(--invalid-bg); box-shadow: inset 4px 0 0 var(--invalid); }
.qi-field.is-invalid .qi-field__label { color: var(--invalid); }

.qi-field__error { display: none; color: var(--invalid); font-size: .8125rem; font-weight: 700; line-height: 1.35; }
.qi-field.is-invalid .qi-field__error { display: block; }

/* FIXED: was 0.75rem (12px) at base — now .8125rem */
.qi-field__help, .qi-field__hint { font-size: .8125rem; color: var(--ink-meta); line-height: 1.45; }

/* Required badge on field */
.qi-field.is-required .qi-field__label::before {
  content: 'Required';
  display: inline-flex;
  align-items: center;
  min-height: 18px;
  padding: 0 .35rem;
  margin-right: .4rem;
  border-radius: 999px;
  background: #FFF7E6;
  color: #8A4B00;
  border: 1px solid #F2C36B;
  font-size: 10px;
  font-weight: 800;
  letter-spacing: .06em;
  text-transform: uppercase;
  vertical-align: middle;
}

/* Readonly fields */
.qi-field input[readonly], .qi-field textarea[readonly] { background: #F0E7CC; cursor: not-allowed; }

/* Form toolbar */
.qi-form-toolbar {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: var(--sp-5);
  flex-wrap: wrap;
  padding: var(--sp-5);
  background: var(--card);
  border: 1.5px solid var(--rule);
  border-left: 5px solid var(--brass);
  border-radius: var(--r-lg);
  margin-bottom: var(--sp-6);
}
.qi-form-toolbar__left { min-width: 280px; display: flex; flex-direction: column; gap: var(--sp-2); }
.qi-form-toolbar__right { display: flex; gap: var(--sp-2); flex-wrap: wrap; }

.qi-form-actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp-3);
  align-items: center;
  padding-top: var(--sp-5);
  margin-top: var(--sp-2);
  border-top: 1px solid var(--ink-divider);
}

/* Pill */
.qi-pill { display: inline-flex; align-items: center; min-height: 28px; padding: 0 .75rem; background: var(--paper-warm); border: 1px solid var(--rule); border-radius: 999px; font-size: .8125rem; font-weight: 700; color: var(--ink-70); letter-spacing: .02em; }
.qi-pill--accent { color: var(--oxblood); border-color: rgba(107,25,38,.28); background: #F9DFDC; }
.qi-pill--sage   { color: var(--sage);    border-color: rgba(61,90,69,.25);  background: var(--sage-soft); }
.qi-pill--coral  { color: var(--coral);   border-color: rgba(176,79,59,.25); background: var(--coral-soft); }
.qi-pill--brass  { color: var(--amber);   border-color: rgba(180,122,20,.25);background: var(--amber-soft); }

/* Messages */
.qi-message { display: none; margin-top: var(--sp-4); padding: .875rem var(--sp-4); border-radius: var(--r); font-size: .9375rem; font-weight: 600; border-left: 4px solid transparent; }
.qi-message.is-success { display: block; background: var(--sage-soft); color: var(--sage); border-left-color: var(--sage); }
.qi-message.is-error   { display: block; background: var(--coral-soft); color: var(--coral); border-left-color: var(--coral); }

/* Progress */
.qi-progress { height: 5px; background: var(--ink-surface); border-radius: 0; overflow: hidden; }
.qi-progress__fill { height: 100%; background: var(--brass); transition: width .3s cubic-bezier(.4,0,.2,1); }
.qi-progress-head { display: flex; justify-content: space-between; font-size: 11px; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; color: var(--ink-meta); margin-bottom: var(--sp-2); }

/* Filters bar */
.qi-filters {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: var(--sp-4);
  padding: var(--sp-5);
  background: var(--card);
  border: 1px solid var(--rule);
  border-radius: var(--r-lg);
  margin-bottom: var(--sp-6);
  align-items: end;
}
.qi-filters--sticky { position: sticky; top: 0; z-index: 10; }
.qi-filter__actions { display: flex; gap: var(--sp-2); align-items: flex-end; }

/* ═══════════════════════════════════════════════════════════
 * 11 · TABLES
 * ═════════════════════════════════════════════════════════ */
.qi-table-wrap { overflow-x: auto; border: 1px solid var(--rule); border-radius: var(--r-lg); background: var(--card); }

.qi-table { width: 100%; border-collapse: collapse; font-size: .9375rem; }

.qi-table thead th {
  background: var(--card-alt);
  color: var(--ink-meta);
  font-size: 12px;          /* FIXED: consistent 12px for th */
  font-weight: 700;
  letter-spacing: .12em;
  text-transform: uppercase;
  padding: .875rem var(--sp-4);
  text-align: left;
  border-bottom: 1px solid var(--rule);
  white-space: nowrap;
}

.qi-table tbody td {
  padding: var(--sp-4) var(--sp-4);
  border-bottom: 1px solid var(--ink-surface);
  color: var(--ink-90);
  vertical-align: top;
  font-size: .9375rem;
  line-height: 1.45;
}

.qi-table tbody tr:last-child td { border-bottom: none; }
.qi-table tbody tr:hover { background: var(--paper-warm); transition: background .1s; }
.qi-table tbody tr.is-overdue > td:first-child { border-left: 3px solid var(--coral); }

.qi-table td.is-id, .qi-table td .qi-id { font-family: var(--mono); font-size: .875rem; color: var(--ink-meta); letter-spacing: .02em; }
.qi-table td.is-name { font-size: 1rem; font-weight: 500; }
.qi-table td.is-actions { white-space: nowrap; }
.qi-table__empty { text-align: center; padding: var(--sp-10); font-style: italic; color: var(--ink-meta); }

/* ═══════════════════════════════════════════════════════════
 * 12 · DRAWER  (FIXED: close button 36→44px)
 * ═════════════════════════════════════════════════════════ */
.qi-drawer-backdrop {
  position: fixed;
  inset: 0;
  background: rgba(10,31,61,.42);
  z-index: 99990;
  display: none;
  opacity: 0;
  pointer-events: none;
}
.qi-drawer-backdrop.is-open { display: block; opacity: 1; pointer-events: auto; }

body.admin-bar .qi-drawer-backdrop { top: 32px; }

.qi-drawer {
  position: fixed;
  top: 0;
  right: 0;
  width: min(660px, 100%);
  height: 100vh;
  max-height: 100vh;
  background: var(--paper);
  z-index: 99991;
  display: flex;
  flex-direction: column;
  transform: translate3d(105%, 0, 0);
  visibility: hidden;
  pointer-events: none;
  transition: transform .28s cubic-bezier(.4,0,.2,1);
  box-shadow: -8px 0 40px rgba(10,31,61,.18);
  border-left: 1px solid var(--rule);
}
.qi-drawer.is-open { transform: translate3d(0,0,0); visibility: visible; pointer-events: auto; }

body.admin-bar .qi-drawer { top: 32px; height: calc(100vh - 32px); max-height: calc(100vh - 32px); }

.qi-drawer__head {
  padding: var(--sp-6) var(--sp-8) var(--sp-5);
  border-bottom: 1px solid var(--ink-divider);
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: var(--sp-4);
  background: var(--card);
  flex-shrink: 0;
}

.qi-drawer__head-left { min-width: 0; }
.qi-drawer__kicker { font-size: 11px; font-weight: 700; letter-spacing: .2em; text-transform: uppercase; color: var(--oxblood); margin-bottom: var(--sp-1); }
.qi-drawer__title { font-size: 1.5rem; font-weight: 800; letter-spacing: -.02em; color: var(--ink); line-height: 1.1; }
.qi-drawer__sub { margin-top: var(--sp-1); font-size: .875rem; color: var(--ink-meta); }

.qi-drawer__head-right { display: flex; align-items: center; gap: var(--sp-3); flex-shrink: 0; }

/* FIXED: was 36×36px — now 44×44px */
.qi-drawer__close {
  width: 44px;
  height: 44px;
  min-width: 44px;
  border: 1px solid var(--rule);
  background: var(--paper);
  color: var(--ink);
  border-radius: var(--r);
  cursor: pointer;
  font-size: 1.375rem;
  line-height: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all .13s;
  flex-shrink: 0;
}
.qi-drawer__close:hover { background: var(--oxblood-soft); border-color: var(--oxblood); color: var(--oxblood); }
.qi-drawer__close:focus-visible { outline: 2px solid var(--focus-ring); outline-offset: 2px; }

.qi-drawer__tabs {
  display: flex;
  gap: var(--sp-2);
  padding: var(--sp-3) var(--sp-8);
  background: var(--card);
  border-bottom: 1px solid var(--rule);
  flex-shrink: 0;
  flex-wrap: wrap;
}

.qi-drawer__tab {
  -webkit-appearance: none;
  appearance: none;
  border: 1px solid var(--rule);
  background: var(--paper);
  color: var(--ink-70);
  border-radius: var(--r);
  padding: .5rem .875rem;
  min-height: 36px;
  font-family: var(--body);
  font-size: .8125rem;
  font-weight: 700;
  cursor: pointer;
  transition: background .12s, color .12s;
  white-space: nowrap;
}
.qi-drawer__tab:hover { background: var(--paper-warm); color: var(--ink); }
.qi-drawer__tab.is-active, .qi-drawer__tab[aria-selected="true"] { background: var(--ink); color: var(--paper); border-color: var(--ink); }
.qi-drawer__tab:focus-visible { outline: 2px solid var(--focus-ring); outline-offset: 2px; }

.qi-drawer__body { flex: 1 1 auto; overflow-y: auto; padding: var(--sp-6) var(--sp-8); min-height: 0; }
.qi-drawer__panel { display: none; }
.qi-drawer__panel.is-active { display: block; }

/* Detail grid inside drawer */
.qi-detail-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: var(--sp-4); }
.qi-detail { padding: .875rem var(--sp-4); background: var(--card); border: 1px solid var(--rule); border-radius: var(--r); }
.qi-detail--full { grid-column: 1 / -1; }
.qi-detail__label { font-size: 12px; font-weight: 700; letter-spacing: .12em; text-transform: uppercase; color: var(--ink-meta); margin-bottom: .375rem; }
.qi-detail__value { font-size: .9375rem; color: var(--ink); line-height: 1.5; word-break: break-word; white-space: pre-wrap; }

.qi-drawer__record-actions { display: flex; gap: var(--sp-2); flex-wrap: wrap; margin-top: var(--sp-5); padding-top: var(--sp-4); border-top: 1px solid var(--ink-divider); }

/* Chain (traceability) */
.qi-chain { display: grid; gap: var(--sp-3); }
.qi-chain__node { background: var(--card); border: 1px solid var(--rule); border-radius: var(--r); padding: var(--sp-4); }
.qi-chain__node--source { border-left: 4px solid var(--brass); }
.qi-chain__node-label { font-size: 12px; font-weight: 700; letter-spacing: .12em; text-transform: uppercase; color: var(--ink-meta); margin-bottom: var(--sp-1); }
.qi-chain__node-value { color: var(--ink); line-height: 1.45; }
.qi-chain__arrow { text-align: center; color: var(--ink-border); font-size: 1.25rem; line-height: 1; }

body.qi-drawer-open { overflow: hidden; }

/* ═══════════════════════════════════════════════════════════
 * 13 · STATUS BADGES + PILLS + SERVICE CHIPS
 * ═════════════════════════════════════════════════════════ */
.qi-status {
  display: inline-flex;
  align-items: center;
  gap: .375rem;
  padding: .3rem .625rem;
  min-height: 26px;
  font-size: .75rem;
  font-weight: 800;
  letter-spacing: .06em;
  text-transform: uppercase;
  border-radius: var(--r-sm);
}
.qi-status--ok      { background: #E3F4E8; color: #1F5E38; border: 1px solid rgba(31,94,56,.25); }
.qi-status--flag    { background: #FCE7E2; color: #9F2A18; border: 1px solid rgba(159,42,24,.25); }
.qi-status--info    { background: var(--brass-soft); color: #7A4A00; border: 1px solid rgba(122,74,0,.25); }
.qi-status--pending { background: #F8EBC8; color: #7A4A00; border: 1px solid rgba(122,74,0,.25); }
.qi-status--none    { background: #F3F4F6; color: #6B7280; border: 1px solid #E5E7EB; }

.qi-status--quorum-met   { background: #d1fae5; color: #065f46; border: 1px solid #6ee7b7; border-radius: var(--r-sm); padding: .15rem .6rem; font-size: .78rem; font-weight: 700; }
.qi-status--quorum-unmet { background: #fee2e2; color: #991b1b; border: 1px solid #fca5a5; border-radius: var(--r-sm); padding: .15rem .6rem; font-size: .78rem; font-weight: 700; }

.qi-minutes-filed--yes { background: #d1fae5; color: #065f46; border: 1px solid #6ee7b7; border-radius: var(--r-sm); padding: .15rem .5rem; font-size: .78rem; font-weight: 600; }
.qi-minutes-filed--no  { background: #fee2e2; color: #991b1b; border: 1px solid #fca5a5; border-radius: var(--r-sm); padding: .15rem .5rem; font-size: .78rem; font-weight: 600; }

/* Source state badges */
.qi-source-state { display: inline-block; padding: .18em .55em; border-radius: var(--r-sm); font-size: .78rem; font-weight: 600; white-space: nowrap; vertical-align: middle; }
.qi-source-state--no-source  { background: var(--coral-soft); color: var(--coral); border: 1px solid rgba(176,79,59,.25); }
.qi-source-state--no-activity{ background: var(--amber-soft); color: var(--amber); border: 1px solid rgba(180,122,20,.25); }
.qi-source-state--ok         { background: var(--sage-soft);  color: var(--sage);  border: 1px solid rgba(61,90,69,.25); }
.qi-source-state--ca-linked  { background: var(--brass-soft); color: var(--brass); border: 1px solid rgba(168,139,60,.25); }
.qi-source-state--ca-needed  { background: var(--oxblood-soft); color: var(--oxblood); border: 1px solid rgba(107,25,38,.25); }

/* Service chips */
.qi-svc { display: inline-flex; align-items: center; min-height: 26px; padding: .28rem .65rem; border-radius: var(--r-sm); font-size: .75rem; font-weight: 800; letter-spacing: .05em; text-transform: uppercase; white-space: nowrap; }
.qi-svc--pc     { background: var(--sage-soft); color: var(--sage); border: 1px solid rgba(61,90,69,.25); }
.qi-svc--rep    { background: var(--brass-soft); color: var(--amber); border: 1px solid rgba(180,122,20,.25); }
.qi-svc--system { background: var(--brass-soft); color: var(--ink); border: 1px solid var(--rule); }

/* Row highlight states */
.qi-table tr.qi-row--no-source td { border-left: 3px solid var(--coral); background: rgba(176,79,59,.04); }
.qi-table tr.qi-row--no-activity td { border-left: 3px solid var(--amber); background: rgba(180,122,20,.04); }
.qi-table tr.qi-row--warning td { border-left: 3px solid var(--brass); }
.qi-table tr.qi-row--alert td { border-left: 3px solid var(--oxblood); background: rgba(107,25,38,.04); }

/* ═══════════════════════════════════════════════════════════
 * 14 · REPORTS + GOV REPORT
 * ═════════════════════════════════════════════════════════ */
.qi-tabs {
  display: flex;
  gap: var(--sp-3);
  margin-bottom: var(--sp-8);
  border-bottom: 1px solid var(--ink-border);
  flex-wrap: wrap;
}

.qi-tab {
  padding: .75rem var(--sp-6);
  min-height: var(--touch);
  display: inline-flex;
  align-items: center;
  font-size: .9375rem;
  font-weight: 700;
  color: var(--ink-70);
  cursor: pointer;
  border-bottom: 2px solid transparent;
  margin-bottom: -1px;
  transition: color .13s, border-color .13s;
  background: transparent;
  border-top: none;
  border-left: none;
  border-right: none;
  font-family: var(--body);
}
.qi-tab:hover { color: var(--ink); }
.qi-tab.is-active { color: var(--ink); border-bottom-color: var(--oxblood); }
.qi-tab:focus-visible { outline: 2px solid var(--focus-ring); outline-offset: 2px; }

.qi-note {
  background: var(--brass-soft);
  border-left: 3px solid var(--brass);
  border-radius: 0 var(--r) var(--r) 0;
  padding: var(--sp-5) var(--sp-6);
  margin-bottom: var(--sp-6);
}
.qi-note__label { font-size: 11px; font-weight: 700; letter-spacing: .18em; text-transform: uppercase; color: var(--amber); margin-bottom: var(--sp-2); }
.qi-note__body { font-size: .9375rem; line-height: 1.55; color: var(--ink); margin: 0; }
.qi-note--reports-purpose { background: var(--card-alt); border: 1px solid var(--rule); border-radius: var(--r-lg); border-left: none; padding: var(--sp-4) var(--sp-5); }

/* Gov report */
.qi-govreport--structured { background: #FFFEFA; border: 1px solid var(--ink); padding: var(--sp-8); color: var(--ink); font-size: 1rem; line-height: 1.55; border-radius: var(--r); }
.qi-govreport__cover { background: var(--card); border: 1px solid var(--rule); border-radius: var(--r-lg); margin-bottom: var(--sp-6); overflow: hidden; }
.qi-govreport__cover-body { padding: var(--sp-8) var(--sp-8); text-align: center; }
.qi-govreport__cover-footer { text-align: center; font-size: .75rem; color: var(--ink-meta); padding: .85rem var(--sp-8); border-top: 1px solid var(--rule-soft); letter-spacing: .04em; text-transform: uppercase; background: rgba(10,31,61,.02); }
.qi-govreport__agency-logo { font-size: 1.25rem; font-weight: 800; color: var(--paper); background: var(--ink); padding: var(--sp-5) var(--sp-8); text-align: center; border-bottom: 4px solid var(--oxblood); }
.qi-govreport__cover-title { font-size: clamp(1.75rem, 3vw, 2.5rem); font-weight: 800; margin-bottom: var(--sp-2); }
.qi-govreport__cover-subtitle { font-size: 1.125rem; font-weight: 700; text-align: center; margin: 0 0 var(--sp-2); }
.qi-govreport__compliance-line { text-align: center; font-weight: 800; letter-spacing: .07em; text-transform: uppercase; color: var(--oxblood); }

.qi-govreport--structured .qi-govreport__section { padding: var(--sp-6) 0; border-top: 1px solid var(--rule); }
.qi-govreport--structured .qi-govreport__section-title { font-size: 1.5rem; margin: 0 0 var(--sp-4); }
.qi-govreport__subhead { font-size: 1.125rem; font-weight: 700; margin: var(--sp-5) 0 var(--sp-3); color: var(--oxblood); }
.qi-govreport__note { background: #fff7ed; border-left: 4px solid var(--brass); padding: .75rem var(--sp-4); margin: var(--sp-4) 0; border-radius: 0 var(--r) var(--r) 0; }
.qi-govreport__critical-note { background: #fef2f2; border-left: 4px solid #991b1b; color: #7f1d1d; padding: .85rem var(--sp-4); font-weight: 700; margin: var(--sp-4) 0; }
.qi-govreport__certification { font-size: .875rem; color: var(--ink-70); line-height: 1.6; margin: var(--sp-4) 0 var(--sp-2); padding: .75rem var(--sp-4); border-top: 1px solid var(--rule-soft); border-bottom: 1px solid var(--rule-soft); background: rgba(10,31,61,.02); }

.qi-govreport__table { width: 100%; border-collapse: collapse; margin: .75rem 0 var(--sp-4); font-size: .9375rem; }
.qi-govreport__table th { background: var(--ink); color: var(--paper); border: 1px solid var(--rule); padding: .65rem; text-align: left; vertical-align: top; font-weight: 700; font-size: .875rem; }
.qi-govreport__table td { border: 1px solid var(--rule); padding: .65rem; vertical-align: top; background: #FFFEFA; font-size: .9rem; }
.qi-govreport__table tr:nth-child(even) td { background: var(--card); }
.qi-govreport__table tbody tr:hover td { background: var(--paper-warm); }
.qi-table-total td, .qi-govreport__table .qi-table-total td { background: var(--brass-soft); font-weight: 700; }

.qi-govreport__ca-item { border: 1px solid var(--rule); background: var(--card); padding: var(--sp-4); margin: var(--sp-4) 0; border-radius: var(--r); }
.qi-govreport__ca-item.qi-row-alert { border-left: 5px solid var(--coral); }

.qi-govreport__checklist { list-style: none; padding: 0; margin: 0; }
.qi-govreport__checklist li { margin: .35rem 0; line-height: 1.5; }

.qi-govreport__section-cite { font-size: .7rem; font-weight: 600; color: var(--ink-meta); font-family: var(--mono); letter-spacing: .04em; vertical-align: middle; margin-left: .6rem; background: var(--ink-surface); padding: 2px 7px; border-radius: 20px; }

/* Govreport specialized tables */
.qi-govreport__table--signatures th { font-size: .75rem; text-transform: uppercase; letter-spacing: .05em; background: rgba(10,31,61,.04); color: var(--ink-70); }
.qi-govreport__table--signatures td { height: 2.5rem; vertical-align: middle; }
.qi-govreport__table--action-steps th { font-size: .78rem; background: rgba(107,25,38,.04); }
.qi-govreport__table--action-steps td { font-size: .875rem; padding: .5rem .65rem; }
.qi-govreport__table--attendance th { background: rgba(10,31,61,.04); font-size: .78rem; text-transform: uppercase; letter-spacing: .04em; }
.qi-govreport__table--attendance td { font-size: .875rem; padding: .4rem .6rem; vertical-align: top; }

/* Govreport toolbar + workflow */
.qi-govreport-toolbar { display: flex; align-items: center; justify-content: space-between; gap: var(--sp-3); flex-wrap: wrap; padding-bottom: .85rem; margin-bottom: .75rem; border-bottom: 1px solid var(--ink-divider); }
.qi-govreport-toolbar__left { display: flex; align-items: center; gap: var(--sp-3); flex-wrap: wrap; }
.qi-govreport-toolbar__right { display: flex; gap: var(--sp-2); align-items: center; flex-wrap: wrap; }
.qi-govreport-workflow { margin: 0 0 var(--sp-5); padding: .9rem var(--sp-5); border-left: 4px solid var(--ink); background: var(--paper-warm); color: var(--ink); display: grid; gap: var(--sp-1); border-radius: 0 var(--r) var(--r) 0; }
.qi-govreport-workflow__status { font-weight: 700; font-size: .9375rem; }
.qi-govreport-workflow__text { font-size: .875rem; line-height: 1.5; color: var(--ink-70); }
.qi-govreport-alert { padding: .85rem var(--sp-5); border-radius: var(--r); margin-bottom: var(--sp-4); font-size: .9375rem; font-weight: 600; line-height: 1.4; }
.qi-govreport-alert--info { background: var(--brass-soft); border-left: 4px solid var(--brass); color: #63380a; }
.qi-govreport-alert--success { background: var(--sage-soft); border-left: 4px solid var(--sage); color: #0a3320; }
.qi-govreport-download { background: var(--ink); color: var(--paper); border-color: var(--ink); min-width: 145px; text-align: center; font-weight: 700; }
.qi-govreport-download:hover { background: var(--oxblood); border-color: var(--oxblood); color: var(--paper); }
.qi-btn--burgundy-lg { background: var(--oxblood); color: var(--paper); border-color: var(--oxblood); font-weight: 700; }

/* Signature blocks */
.qi-sign-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: var(--sp-6); margin-top: var(--sp-4); }
.qi-sign { padding: var(--sp-6); background: var(--card); border: 1px solid var(--rule); border-radius: var(--r-lg); }
.qi-sign__label { font-size: 12px; font-weight: 700; letter-spacing: .18em; text-transform: uppercase; color: var(--ink-meta); margin-bottom: var(--sp-10); }
.qi-sign__line { border-top: 1px solid var(--ink); margin-bottom: var(--sp-2); }
.qi-sign__cap { font-size: .8125rem; color: var(--ink-meta); }
.qi-govreport__sig-block { border: 1px solid var(--ink-border); border-radius: var(--r); padding: var(--sp-4) var(--sp-5); background: var(--card); }
.qi-govreport__sig-signed { display: inline-block; font-family: Georgia, serif; font-size: 1.1rem; color: var(--ink); padding-bottom: var(--sp-1); border-bottom: 1px solid var(--ink-border); }
.qi-govreport__sig-label { font-size: .75rem; font-weight: 700; text-transform: uppercase; letter-spacing: .07em; color: var(--ink-meta); margin-top: var(--sp-2); }
.qi-govreport__sig-name { font-weight: 600; font-size: .9rem; margin-top: .2rem; }
.qi-govreport__sig-date-row { display: flex; align-items: baseline; gap: var(--sp-2); font-size: .875rem; margin-top: var(--sp-1); color: var(--ink-70); }
.qi-govreport__sig-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--sp-6); margin-top: var(--sp-4); }

/* Readiness panel */
.qi-readiness-panel { padding: var(--sp-4) var(--sp-5); border-radius: var(--r); font-size: .9375rem; line-height: 1.55; background: var(--sage-soft); border: 1px solid rgba(61,90,69,.3); color: var(--sage); margin-bottom: var(--sp-6); }
.qi-readiness-panel--warning { background: var(--oxblood-soft); border-color: rgba(107,25,38,.3); color: var(--ink); }
.qi-readiness-list { margin: .75rem 0 0; padding-left: 1.5rem; list-style: disc; }
.qi-readiness-list li { margin-bottom: .35rem; line-height: 1.45; }
.qi-readiness-item--error { color: var(--oxblood); font-weight: 600; }
.qi-readiness-item--warning { color: var(--amber); }

/* Source link + drilldown */
.qi-source-link { appearance: none; background: transparent; border: 0; border-bottom: 1px solid var(--oxblood); color: var(--oxblood); cursor: pointer; font: inherit; font-weight: 700; padding: 0 0 1px; text-align: left; }
.qi-source-link:hover, .qi-source-link:focus-visible { color: var(--ink); border-bottom-style: solid; outline: 2px solid var(--focus-ring-glow); outline-offset: 2px; }
.qi-check { display: inline-flex; align-items: center; gap: .3rem; margin: 0 .45rem .25rem 0; white-space: nowrap; font-size: .875rem; }
.qi-check input[type="checkbox"] { width: 16px; height: 16px; accent-color: var(--oxblood); }

/* Source drawer */
.qi-source-drawer-backdrop { position: fixed; inset: 0; background: rgba(10,31,61,.42); z-index: 99990; display: none; }
.qi-source-drawer-backdrop.is-open { display: block; }
.qi-source-drawer { position: fixed; top: 0; right: 0; width: min(760px, 100%); height: 100vh; background: var(--paper); z-index: 99991; transform: translateX(105%); transition: transform .25s ease; box-shadow: -10px 0 36px rgba(10,31,61,.22); border-left: 1px solid var(--rule); display: flex; flex-direction: column; }
.qi-source-drawer.is-open { transform: translateX(0); }
.qi-source-drawer__head { background: var(--card); border-bottom: 1px solid var(--rule); padding: var(--sp-6) var(--sp-7); display: flex; justify-content: space-between; gap: var(--sp-4); }
.qi-source-drawer__body { overflow-y: auto; padding: var(--sp-5) var(--sp-7) var(--sp-8); }
.qi-source-card { background: var(--card); border: 1px solid var(--rule); border-radius: var(--r); padding: var(--sp-4); margin-bottom: var(--sp-4); }
.qi-source-card__top { display: flex; justify-content: space-between; gap: var(--sp-4); border-bottom: 1px solid var(--ink-divider); padding-bottom: var(--sp-2); margin-bottom: var(--sp-3); }
.qi-source-card__grid { display: grid; grid-template-columns: 150px 1fr; gap: .45rem .75rem; margin: 0 0 .9rem; }
.qi-source-card__grid dt { font-weight: 700; color: var(--ink-70); }
.qi-source-card__grid dd { margin: 0; color: var(--ink); }

/* Attachment list */
.qi-attachment-list { list-style: none; margin: 0 0 var(--sp-4); padding: 0; }
.qi-attachment-item { display: flex; align-items: center; gap: var(--sp-3); padding: var(--sp-2) 0; border-bottom: 1px dashed var(--rule-soft); font-size: .875rem; }
.qi-attachment-item:last-child { border-bottom: none; }
.qi-attachment-link { color: var(--ink); font-weight: 600; text-decoration: underline; text-underline-offset: 2px; }
.qi-attachment-link:hover { color: var(--oxblood); }
.qi-attachment-meta { color: var(--ink-meta); font-size: .75rem; font-family: var(--mono); }
.qi-attachment-empty { color: var(--ink-border); font-style: italic; font-size: .875rem; padding: var(--sp-2) 0; }
.qi-attachment-form { padding-top: var(--sp-3); border-top: 1px solid var(--rule-soft); margin-top: var(--sp-2); }

/* FIXED: Audit log — was 0.8rem (12.8px) — now 12px with clearer grid */
.qi-audit-list { list-style: none; margin: 0; padding: 0; font-size: 12px; font-family: var(--mono); }
.qi-audit-entry { display: grid; grid-template-columns: 9rem 1fr 1fr; gap: var(--sp-3); padding: .4rem 0; border-bottom: 1px dashed var(--rule-soft); }
.qi-audit-action { font-weight: 700; color: var(--oxblood); text-transform: uppercase; font-size: 11px; letter-spacing: .06em; }
.qi-audit-user  { color: var(--ink); font-size: 12px; }
.qi-audit-time  { color: var(--ink-meta); font-size: 11px; }

/* Tracking callout */
.qi-tracking-callout { background: var(--card); border: 1px solid var(--rule); border-left: 4px solid var(--oxblood); padding: var(--sp-4) var(--sp-5); margin: var(--sp-4) 0 var(--sp-5); }
.qi-tracking-callout strong { display: block; color: var(--oxblood); font-size: .8125rem; letter-spacing: .12em; text-transform: uppercase; margin-bottom: var(--sp-1); }
.qi-tracking-callout p { margin: 0; font-size: .9375rem; line-height: 1.5; }
.qi-tracking-callout--uid { display: flex; align-items: center; gap: var(--sp-3); padding: .6rem var(--sp-5); background: var(--brass-soft); border-left: 3px solid var(--brass); font-size: .875rem; margin-bottom: var(--sp-3); flex-wrap: wrap; border-radius: 0 var(--r) var(--r) 0; }
.qi-miss-chip { display: inline-flex; align-items: center; min-height: 24px; padding: .2rem .55rem; border-radius: 999px; background: var(--oxblood-soft); color: var(--oxblood); border: 1px solid rgba(107,25,38,.22); font-size: .75rem; font-weight: 800; letter-spacing: .04em; text-transform: uppercase; }
.qi-form-alert { display: none; margin: var(--sp-4) 0; padding: .85rem var(--sp-4); border-radius: var(--r); font-size: .9375rem; line-height: 1.45; }
.qi-form-alert.is-error { display: block; background: var(--coral-soft); border: 1px solid rgba(176,79,59,.25); color: #7f2f1f; }
.qi-form-alert.is-success { display: block; background: var(--sage-soft); border: 1px solid rgba(61,90,69,.25); color: #2f4b39; }

/* Reporting period display */
.qi-field--reporting-period input[readonly], #qi_reporting_period_display {
  display: block;
  width: 100%;
  min-height: var(--touch);
  padding: .75rem var(--sp-4);
  font-size: 1rem;
  font-weight: 800;
  color: var(--ink);
  background: var(--oxblood-soft);
  border: 1.5px solid var(--oxblood);
  border-radius: var(--r);
  cursor: default;
}

/* Govreport modal row check */
.qi-ca-inline-form { padding-top: var(--sp-5); margin-top: var(--sp-5); border-top: 1px solid var(--rule-soft); }
.qi-ca-system-note { margin: var(--sp-2) 0 0; color: var(--ink-70); font-size: .9rem; }
.qi-btn--create-ca { border-color: var(--oxblood); color: var(--oxblood); background: var(--card); }
.qi-btn--create-ca:hover { background: var(--oxblood-soft); }

/* Print overlay */
.qi-print-overlay { position: fixed; inset: 0; display: none; overflow-y: auto; background: rgba(10,31,61,.42); z-index: 99995; padding: var(--sp-8); }
.qi-print-overlay.is-open { display: block; }
.qi-print-overlay__inner { max-width: 920px; margin: 0 auto; background: var(--paper); color: var(--ink); border: 1px solid var(--rule); padding: var(--sp-8); box-shadow: 0 18px 50px rgba(10,31,61,.22); }
.qi-print-header, .qi-print-footer { display: flex; justify-content: space-between; gap: var(--sp-4); flex-wrap: wrap; font-family: var(--mono); font-size: .75rem; color: var(--ink-meta); border-bottom: 1px solid var(--rule); padding-bottom: .75rem; margin-bottom: var(--sp-4); }
.qi-print-footer { border-top: 1px solid var(--rule); border-bottom: none; padding-top: .75rem; margin-top: var(--sp-6); margin-bottom: var(--sp-4); }
.qi-print-meta-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: .75rem; }
.qi-print-meta-row { border: 1px solid var(--rule); background: var(--card); padding: .75rem; border-radius: var(--r); }
.qi-print-meta-label { display: block; font-size: 11px; font-weight: 700; letter-spacing: .13em; text-transform: uppercase; color: var(--ink-meta); margin-bottom: .25rem; }
.qi-print-meta-value { display: block; font-size: .9rem; color: var(--ink); line-height: 1.45; white-space: pre-wrap; word-break: break-word; }
.qi-print-signature-row { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--sp-4); margin-top: var(--sp-8); }
.qi-print-sig-line { display: block; border-bottom: 1px solid var(--ink); height: 2rem; margin-bottom: var(--sp-1); }
.qi-print-sig-label { font-size: .75rem; color: var(--ink-meta); }
.qi-print-overlay__screen-controls { display: flex; justify-content: flex-end; gap: var(--sp-2); margin-top: var(--sp-6); }

/* Meeting forms */
.qi-meeting-form { background: var(--card); border: 1px solid var(--rule); border-radius: var(--r-lg); padding: var(--sp-6); margin-bottom: var(--sp-8); }
.qi-meeting-form__title { font-size: 1.0625rem; font-weight: 700; color: var(--ink); margin: 0 0 var(--sp-5); padding-bottom: var(--sp-3); border-bottom: 1px solid var(--rule-soft); }
.qi-meeting-form__grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: var(--sp-4); margin-bottom: var(--sp-4); }
.qi-meeting-form__actions { display: flex; gap: var(--sp-2); margin-top: var(--sp-5); padding-top: var(--sp-4); border-top: 1px solid var(--rule-soft); flex-wrap: wrap; }
.qi-form-grid--meeting { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: var(--sp-4); }
.qi-field--full { grid-column: 1 / -1; }
.qi-attendance-editor { margin-top: var(--sp-5); padding-top: var(--sp-4); border-top: 1px solid var(--rule-soft); }
.qi-attendance-edit-table input, .qi-attendance-edit-table select { width: 100%; min-height: 40px; font-size: .9375rem; }
.qi-attendance-edit-table th, .qi-attendance-edit-table td, .qi-attendance-table th, .qi-attendance-table td { font-size: .9375rem; line-height: 1.45; vertical-align: top; }

/* Action tracker */
.qi-action-table-wrap .qi-section-head { padding: 0 var(--sp-4) var(--sp-4); }
.qi-action-table { font-size: .9rem; }
.qi-action-table td.is-issue { max-width: 320px; font-size: .9rem; }
.qi-ca-cell { font-family: var(--mono); }

/* Colophon */
.qi-colophon { margin-top: var(--sp-12); padding-top: var(--sp-8); border-top: 1px solid var(--ink-border); display: flex; justify-content: space-between; align-items: baseline; font-size: .8125rem; color: var(--ink-meta); flex-wrap: wrap; gap: var(--sp-3); }
.qi-colophon__mono { font-family: var(--mono); font-style: normal; font-size: 11px; letter-spacing: .1em; text-transform: uppercase; }

/* Auth gate notice */
.qi-auth-gate-notice { display: flex; flex-direction: column; align-items: center; justify-content: center; min-height: 50vh; text-align: center; padding: var(--sp-12) var(--sp-6); color: var(--ink-70); }
.qi-auth-gate-notice h2 { font-size: 1.75rem; font-weight: 800; color: var(--ink); margin: 0 0 var(--sp-3); }
.qi-auth-gate-notice p { font-size: .9375rem; margin-bottom: var(--sp-6); line-height: 1.7; max-width: 360px; }
.qi-auth-gate-notice button { min-height: var(--touch); padding: .625rem var(--sp-6); background: var(--ink); color: var(--paper); border: none; border-radius: var(--r); font-size: .9375rem; font-weight: 700; cursor: pointer; font-family: var(--body); transition: background .13s; }
.qi-auth-gate-notice button:hover { background: var(--oxblood); }

/* Empty + finding card */
.qi-empty-panel { background: var(--card); border: 1px solid var(--rule); border-radius: var(--r); padding: var(--sp-5); }
.qi-empty-panel p { margin: 0 0 var(--sp-4); color: var(--ink-70); }
.qi-finding-card { background: var(--card); border: 1px solid var(--rule); border-radius: var(--r); padding: var(--sp-5); }

/* Domain related */
.qi-domain-related { display: block; margin-top: var(--sp-1); color: var(--ink-meta); font-size: .8125rem; }
.qi-section-card--related { border-color: var(--brass); box-shadow: 0 0 0 2px rgba(168,139,60,.12) inset; }
.qi-section-card--related .qi-section-card__num { color: var(--brass); }

/* ═══════════════════════════════════════════════════════════
 * 15 · LOGIN MODAL
 * ═════════════════════════════════════════════════════════ */
.hqim-bg { display: none; position: fixed; inset: 0; background: rgba(0,0,0,.55); backdrop-filter: blur(3px); z-index: 9999; align-items: center; justify-content: center; padding: 16px; }
.hqim-bg.hqim-open { display: flex; }
.hqim-modal { background: #fff; border-radius: var(--r-xl); overflow: hidden; width: 100%; max-width: 780px; box-shadow: 0 32px 80px rgba(0,0,0,.28); display: flex; animation: hqim-in .22s cubic-bezier(.34,1.56,.64,1); }
@keyframes hqim-in { from { opacity:0; transform:scale(.94) translateY(16px); } to { opacity:1; transform:none; } }

.hqim-left { width: 38%; min-width: 220px; background: var(--sidebar-bg); padding: 38px 32px; display: flex; flex-direction: column; justify-content: space-between; position: relative; overflow: hidden; gap: 0; }
.hqim-left::after { content: ''; position: absolute; bottom: -80px; right: -80px; width: 220px; height: 220px; border-radius: 50%; background: rgba(122,31,43,.18); pointer-events: none; }
.hqim-brand { font-size: 16px; font-weight: 800; color: #fff; margin-bottom: 3px; }
.hqim-left .hqim-sub { font-size: 10px; color: rgba(255,255,255,.5); font-weight: 700; letter-spacing: .18em; text-transform: uppercase; margin-bottom: 28px; display: block; }
.hqim-headline { font-size: 1.375rem; font-weight: 800; color: #fff; line-height: 1.25; margin: 0 0 12px; }
.hqim-desc { font-size: 13px; color: rgba(255,255,255,.72); line-height: 1.7; margin: 0; }
.hqim-tls { display: inline-flex; align-items: center; gap: 7px; background: rgba(34,197,94,.14); border: 1px solid rgba(34,197,94,.35); border-radius: 999px; padding: 6px 14px; font-size: 12px; color: #4ade80; font-weight: 700; margin-top: 24px; width: fit-content; }
.hqim-tls::before { content: ''; width: 7px; height: 7px; border-radius: 50%; background: #22c55e; flex-shrink: 0; box-shadow: 0 0 0 3px rgba(34,197,94,.2); }
.hqim-domain { font-size: 11px; color: rgba(255,255,255,.25); padding-top: 24px; margin-top: auto; }
.hqim-dismiss { position: absolute; top: 14px; right: 14px; background: rgba(255,255,255,.12); border: none; color: rgba(255,255,255,.7); font-size: 20px; cursor: pointer; padding: 5px 9px; border-radius: var(--r); line-height: 1; transition: background .13s; }
.hqim-dismiss:hover { background: rgba(255,255,255,.22); color: #fff; }
.hqim-dismiss:focus-visible { outline: 2px solid rgba(255,255,255,.6); outline-offset: 2px; }

.hqim-right { flex: 1; padding: 40px 38px; display: flex; flex-direction: column; justify-content: center; }
.hqim-right h3 { font-size: 1.5rem; font-weight: 800; color: var(--sidebar-bg); margin: 0 0 6px; letter-spacing: -.3px; }
.hqim-sub-text { font-size: 13px; color: #6b7280; margin: 0 0 24px; line-height: 1.5; }
.hqim-error { display: none; background: #fef2f2; border: 1px solid #fecaca; border-left: 3px solid #dc2626; border-radius: var(--r); padding: 10px 14px; font-size: 13px; color: #b91c1c; font-weight: 700; margin-bottom: 16px; }
.hqim-error.hqim-error--show { display: block; }
.hqim-field { margin-bottom: 16px; }
.hqim-field label { display: block; font-size: 11px; font-weight: 700; color: #374151; margin-bottom: 6px; text-transform: uppercase; letter-spacing: .1em; }
.hqim-field input[type="email"], .hqim-field input[type="password"] { width: 100%; padding: 12px 14px; min-height: var(--touch); border: 1.5px solid #e5e7eb; border-radius: var(--r); font-size: 15px; font-family: inherit; outline: none; color: #111827; background: #fff; transition: border .13s, box-shadow .13s; }
.hqim-field input:focus { border-color: var(--sidebar-bg); box-shadow: 0 0 0 3px rgba(13,47,82,.1); }
.hqim-field input::placeholder { color: #9ca3af; }
.hqim-submit { width: 100%; padding: 13px 16px; min-height: var(--touch); background: var(--sidebar-bg); color: #fff; border: none; border-radius: var(--r); font-size: 1rem; font-weight: 700; font-family: inherit; cursor: pointer; transition: background .13s, transform .1s; display: flex; align-items: center; justify-content: center; margin-bottom: 14px; }
.hqim-submit:hover { background: var(--oxblood); transform: translateY(-1px); }
.hqim-submit:active { transform: none; }
.hqim-submit:disabled { opacity: .6; cursor: not-allowed; transform: none; }
.hqim-submit:focus-visible { outline: 2px solid var(--oxblood); outline-offset: 2px; }
.hqim-links { text-align: center; font-size: 13px; color: #6b7280; margin-bottom: 12px; }
.hqim-links a { color: var(--oxblood); font-weight: 700; }
.hqim-links a:hover { text-decoration: underline; }
.hqim-or { display: flex; align-items: center; gap: 12px; margin: 4px 0 12px; color: #9ca3af; font-size: 12px; font-weight: 600; text-transform: uppercase; letter-spacing: .08em; }
.hqim-or::before, .hqim-or::after { content: ''; flex: 1; height: 1px; background: #e5e7eb; }
.hqim-access { text-align: center; font-size: 13px; color: #6b7280; }
.hqim-access a { color: var(--sidebar-bg); font-weight: 700; text-decoration: underline; text-underline-offset: 2px; }
.hqim-access a:hover { color: var(--oxblood); }

/* ═══════════════════════════════════════════════════════════
 * 16 · ACCESSIBILITY
 * ═════════════════════════════════════════════════════════ */

/* Skip to main content link */
.qi-skip-link {
  position: absolute;
  top: -9999px;
  left: var(--sp-4);
  z-index: 999999;
  background: var(--ink);
  color: var(--paper);
  padding: .75rem var(--sp-4);
  border-radius: 0 0 var(--r) var(--r);
  font-size: .9375rem;
  font-weight: 700;
  text-decoration: none;
  white-space: nowrap;
  transition: top 0s;
}
.qi-skip-link:focus {
  top: 0;
  outline: 2px solid var(--sidebar-active);
  outline-offset: 2px;
}

/* Screen reader only */
.sr-only {
  position: absolute !important;
  width: 1px !important;
  height: 1px !important;
  padding: 0 !important;
  margin: -1px !important;
  overflow: hidden !important;
  clip: rect(0,0,0,0) !important;
  white-space: nowrap !important;
  border: 0 !important;
}

/* Live region for AJAX status announcements */
.qi-live-region {
  position: absolute;
  width: 1px;
  height: 1px;
  overflow: hidden;
  clip: rect(0,0,0,0);
  white-space: nowrap;
}

/* Focus visible — consistent across all interactive elements */
.qi-btn:focus-visible,
.qi-nav-item:focus-visible,
.qi-tab:focus-visible,
.qi-drawer__tab:focus-visible,
.qi-action-item:focus-visible {
  outline: 2px solid var(--focus-ring);
  outline-offset: 2px;
  box-shadow: 0 0 0 4px var(--focus-ring-glow);
}

/* Toast notification system */
.qi-toast-container {
  position: fixed;
  top: var(--sp-5);
  right: var(--sp-5);
  z-index: 999998;
  display: flex;
  flex-direction: column;
  gap: var(--sp-2);
  pointer-events: none;
}

body.admin-bar .qi-toast-container { top: calc(32px + var(--sp-5)); }

.qi-toast {
  display: flex;
  align-items: flex-start;
  gap: var(--sp-3);
  min-width: 280px;
  max-width: 420px;
  padding: var(--sp-4) var(--sp-5);
  background: var(--ink);
  color: var(--paper);
  border-radius: var(--r-lg);
  font-size: .9375rem;
  font-weight: 600;
  line-height: 1.4;
  pointer-events: auto;
  box-shadow: 0 4px 24px rgba(10,31,61,.28);
  animation: qi-toast-in .22s cubic-bezier(.34,1.56,.64,1);
  transition: opacity .2s, transform .2s;
}

.qi-toast.is-leaving { opacity: 0; transform: translateX(20px); }
.qi-toast--success { background: var(--sage); }
.qi-toast--error   { background: var(--oxblood); }
.qi-toast--warning { background: var(--amber); color: var(--ink); }
.qi-toast__icon    { font-size: 1.125rem; flex-shrink: 0; margin-top: 1px; }
.qi-toast__body    { flex: 1; }
.qi-toast__dismiss { background: none; border: none; color: inherit; cursor: pointer; font-size: 1.25rem; line-height: 1; padding: 0; opacity: .7; margin-left: var(--sp-2); flex-shrink: 0; }
.qi-toast__dismiss:hover { opacity: 1; }

@keyframes qi-toast-in {
  from { opacity: 0; transform: translateX(24px); }
  to   { opacity: 1; transform: none; }
}

/* ═══════════════════════════════════════════════════════════
 * 17 · RESPONSIVE
 * ═════════════════════════════════════════════════════════ */
@media (max-width: 1280px) {
  .qi-content-grid { grid-template-columns: 1fr; gap: var(--sp-8); }
  .qi-stats { grid-template-columns: repeat(3, 1fr); }
  .qi-stat:nth-child(3) { border-right: none; }
  .qi-stat:nth-child(4), .qi-stat:nth-child(5) { border-top: 1px solid var(--ink-border); }
  .qi-main { padding: var(--sp-8) var(--sp-8) 4rem; }
}

@media (max-width: 1024px) {
  :root { --sidebar-w: 240px; }
  .qi-main { padding: var(--sp-6) var(--sp-6) 4rem; }
  .qi-sidebar { padding: var(--sp-6) var(--sp-4); }
  .qi-masthead { grid-template-columns: 1fr; gap: var(--sp-4); }
  .qi-masthead__right { text-align: left; max-width: none; }
  .qi-sign-grid { grid-template-columns: 1fr; }
  .qi-govreport__sig-grid { grid-template-columns: 1fr; }
}

@media (max-width: 768px) {
  .qi-shell { grid-template-columns: 1fr; }

  .qi-sidebar {
    position: static;
    height: auto;
    max-height: 56px;
    overflow: hidden;
    padding: .75rem var(--sp-4);
    flex-direction: row;
    align-items: center;
    justify-content: space-between;
  }
  .qi-sidebar.is-open { max-height: 100vh; height: auto; flex-direction: column; align-items: flex-start; padding: var(--sp-6) var(--sp-4); overflow-y: auto; }
  .qi-brand { padding-bottom: 0; border-bottom: none; margin-bottom: 0; }
  .qi-sidebar__toggle { display: flex; }
  .qi-nav-section, .qi-sidebar__footer { display: none; }
  .qi-sidebar.is-open .qi-nav-section, .qi-sidebar.is-open .qi-sidebar__footer { display: block; }

  .qi-main { padding: var(--sp-5) var(--sp-4) var(--sp-10); }
  .qi-stats { grid-template-columns: 1fr 1fr; }
  .qi-stat { border-right: none; border-bottom: 1px solid var(--ink-border); }
  .qi-stat:nth-child(2n+1) { border-right: 1px solid var(--ink-border); }
  .qi-domain-row { grid-template-columns: 36px 1fr 60px; gap: var(--sp-3); }
  .qi-domain-row .qi-bar-track { display: none; }
  .qi-grid { grid-template-columns: 1fr; }
  .qi-field--c3, .qi-field--c4, .qi-field--c5, .qi-field--c6, .qi-field--c8, .qi-field--c12 { grid-column: auto; }
  .qi-form-actions .qi-btn { flex: 1; }
  .qi-detail-grid { grid-template-columns: 1fr; }
  .qi-drawer { width: 100%; }
  .qi-drawer__head, .qi-drawer__tabs, .qi-drawer__body { padding-left: var(--sp-5); padding-right: var(--sp-5); }
  .qi-drawer__tabs { overflow-x: auto; }
  .qi-print-meta-grid, .qi-print-signature-row { grid-template-columns: 1fr; }
  .qi-print-overlay { padding: var(--sp-3); }
  .qi-govreport-toolbar { flex-direction: column; align-items: flex-start; }
  .qi-govreport-toolbar__right { width: 100%; }
  .qi-govreport__cover-table td { display: block; width: 100%; }
  .qi-form-grid--meeting { grid-template-columns: 1fr; }
  .qi-meeting-form__grid { grid-template-columns: 1fr; }
  .qi-table-wrap { overflow-x: auto; -webkit-overflow-scrolling: touch; }
  .qi-topbar__actions { display: none; }  /* Hidden on mobile — nav handles routing */
  .qi-sign-grid { grid-template-columns: 1fr; }
  .qi-tabs { gap: var(--sp-1); }
  .qi-tab { padding: .625rem var(--sp-4); font-size: .875rem; }

  .hqim-modal { flex-direction: column; max-height: 92vh; overflow-y: auto; }
  .hqim-left { width: 100%; padding: 28px 24px 24px; min-width: 0; }
  .hqim-headline { font-size: 1.125rem; }
  .hqim-right { padding: 28px 24px; }
  .hqim-domain { display: none; }

  body.admin-bar .qi-sidebar { top: 46px; }
  body.admin-bar .qi-toast-container { top: calc(46px + var(--sp-5)); }
}

@media screen and (max-width: 782px) {
  body.admin-bar .qi-drawer, body.admin-bar .qi-drawer-backdrop { top: 46px; height: calc(100vh - 46px); max-height: calc(100vh - 46px); }
}

/* ═══════════════════════════════════════════════════════════
 * 18 · PRINT  (single consolidated block)
 * ═════════════════════════════════════════════════════════ */
@media print {
  @page { size: Letter; margin: 0.55in; }

  html, body { background: #fff; }

  /* Hide UI chrome */
  .qi-sidebar, .qi-topbar, .qi-topbar__actions, .qi-tabs, .qi-btn,
  .qi-filters, .qi-form-actions, .qi-govreport-toolbar, .qi-report-year-form,
  .qi-report-actions, .qi-user__logout, .qi-skip-link,
  .qi-toast-container, .qi-drawer, .qi-drawer-backdrop, .qi-source-drawer,
  .qi-source-drawer-backdrop, .qi-print-overlay__screen-controls,
  .qi-modal, .hqim-bg, no-print { display: none !important; }

  /* Flatten layout */
  .qi-app, .qi-shell, .qi-main, .qi-govreport { display: block; background: #fff; color: #000; width: 100%; max-width: none; min-height: auto; box-shadow: none; }
  .qi-main { padding: 0; }
  .qi-masthead { margin-bottom: 1.5rem; border-bottom: 2px solid #000; }
  .qi-govreport--structured { border: none; padding: 0; background: #fff; font-size: 10.5pt; line-height: 1.42; }
  .qi-govreport--structured .qi-govreport__section-title { font-size: 16pt; }
  .qi-govreport__subhead { font-size: 12.5pt; }

  /* Tables */
  .qi-table, .qi-govreport__table { width: 100%; border-collapse: collapse; font-size: 9pt; }
  .qi-table th, .qi-table td, .qi-govreport__table th, .qi-govreport__table td { border: 1px solid #ccc; padding: 5pt; font-size: 9pt; vertical-align: top; }
  .qi-govreport__table th { background: #0A1F3D; color: #fff; -webkit-print-color-adjust: exact; print-color-adjust: exact; }
  .qi-govreport__agency-logo { background: #0A1F3D; color: #fff; -webkit-print-color-adjust: exact; print-color-adjust: exact; }

  /* Page breaks */
  .qi-govreport__section, .qi-govreport__ca-item, .qi-govreport__cover, .qi-sign, .qi-rail-card, .qi-table-wrap, .page-break-avoid { break-inside: avoid; page-break-inside: avoid; }
  .page-break-before { break-before: page; page-break-before: always; }
  .page-break-after  { break-after: page; page-break-after: always; }
  h1, h2, h3 { page-break-after: avoid; }

  /* Source links become plain text */
  .qi-source-link { border: 0; color: #000; font-weight: inherit; }

  /* Hide interactive elements in print */
  .qi-readiness-panel, .qi-govreport__critical-note input { display: none; }
  .qi-govreport__critical-note { border-left: 3pt solid #000; background: #fff; color: #000; }

  /* Print-mode page body */
  body.print-mode .qi-app > *:not(.qi-print-overlay),
  body.print-mode header, body.print-mode footer,
  body.print-mode .qi-sidebar, body.print-mode .qi-topbar,
  body.print-mode .qi-masthead, body.print-mode .qi-filters,
  body.print-mode .qi-table-wrap { display: none; }
  body.print-mode .qi-print-overlay.is-open { display: block; position: static; inset: auto; overflow: visible; background: #fff; padding: 0; }
  body.print-mode .qi-print-overlay__inner { box-shadow: none; border: none; max-width: none; padding: 0; }
  body.print-mode { overflow: visible; }

  /* Suppress href display after links */
  a[href]::after { content: "" !important; }
}

/* Governing Body Report v4.1 executive summary additions */
.qi-govreport__category-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1rem;
  margin: 1rem 0 1.25rem;
}
.qi-govreport__category-card {
  border: 1px solid var(--rule, rgba(10,31,61,.18));
  border-left: 5px solid var(--brass, #A88B3C);
  border-radius: var(--r-lg, 10px);
  background: var(--card, #FDFBF5);
  padding: 1rem;
  box-shadow: 0 8px 20px rgba(10,31,61,.05);
}
.qi-govreport__category-card.is-action-needed { border-left-color: var(--oxblood, #6B1926); }
.qi-govreport__category-card.is-clear { border-left-color: var(--sage, #3D5A45); }
.qi-govreport__category-card h3 { margin: 0 0 .25rem; font-size: 1.05rem; }
.qi-govreport__category-domains { margin: 0 0 .75rem; color: var(--ink-meta, rgba(10,31,61,.54)); font-size: .875rem; font-family: var(--mono, monospace); }
.qi-govreport__category-metrics { display:grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap:.55rem .75rem; margin:0; }
.qi-govreport__category-metrics div { padding:.55rem; border:1px solid var(--rule-soft, rgba(10,31,61,.10)); border-radius: var(--r, 6px); background:rgba(255,255,255,.42); }
.qi-govreport__category-metrics dt { font-size:.68rem; text-transform:uppercase; letter-spacing:.08em; color:var(--ink-meta); margin:0 0 .2rem; }
.qi-govreport__category-metrics dd { margin:0; font-weight:700; color:var(--ink); }
.qi-row-alert { border-left: 4px solid var(--invalid, #B42318); background: var(--invalid-bg, #FFF1F0); }
.qi-row-warning { border-left: 4px solid var(--amber, #B47A14); background: var(--amber-soft, #F4E7C4); }
.qi-text-danger { color: var(--invalid, #B42318); font-weight: 700; }
.qi-govreport__table--ca-register th,
.qi-govreport__table--ca-register td,
.qi-govreport__table--findings th,
.qi-govreport__table--findings td,
.qi-govreport__table--open-actions th,
.qi-govreport__table--open-actions td { vertical-align: top; }
@media (max-width: 1100px) {
  .qi-govreport__category-grid { grid-template-columns: 1fr; }
}
@media print {
  .qi-govreport__category-grid { display:block; }
  .qi-govreport__category-card { break-inside: avoid; margin-bottom: .75rem; box-shadow:none; }
}

/* QI routes should behave like a full-width admin app, not a centered marketing page. */
body:has(.qi-app) .site,
body:has(.qi-app) .site-content,
body:has(.qi-app) .content-area,
body:has(.qi-app) .ast-container,
body:has(.qi-app) .entry-content,
body:has(.qi-app) .wp-site-blocks {
  width: 100%;
  max-width: none;
  margin-left: 0;
  margin-right: 0;
  padding-left: 0;
  padding-right: 0;
}
.qi-app, .qi-shell, .qi-main {
  width: 100%;
  max-width: none;
  margin-left: 0;
  margin-right: 0;
}


/* QI Analytics + sidebar integration refinements */
.qi-sidebar {
  scrollbar-width: thin;
  scrollbar-color: rgba(255,255,255,.22) transparent;
}
.qi-sidebar::-webkit-scrollbar { width: 8px; }
.qi-sidebar::-webkit-scrollbar-thumb { background: rgba(255,255,255,.22); border-radius: 999px; }
.qi-sidebar::-webkit-scrollbar-track { background: transparent; }

.qi-nav-item[aria-current="page"] {
  background: var(--sidebar-active-bg);
  color: var(--sidebar-active);
}
.qi-nav-item[aria-current="page"]::before {
  content: '';
  position: absolute;
  left: 0;
  top: 8px;
  bottom: 8px;
  width: 3px;
  background: var(--sidebar-active);
  border-radius: 2px;
}

body:has(.qi-app) .site,
body:has(.qi-app) .site-content,
body:has(.qi-app) .content-area,
body:has(.qi-app) .ast-container,
body:has(.qi-app) .entry-content,
body:has(.qi-app) .wp-site-blocks {
  width: 100%;
  max-width: none;
  margin-left: 0;
  margin-right: 0;
  padding-left: 0;
  padding-right: 0;
}

.qi-app,
.qi-shell,
.qi-main {
  width: 100%;
  max-width: none;
}


/* Final QI button readability fix: dark action buttons must never render blank. */
.qi-btn--primary,
.qi-btn--primary:link,
.qi-btn--primary:visited,
.qi-btn--primary:hover,
.qi-btn--primary:focus,
.qi-btn--primary:active,
.qi-btn--burgundy,
.qi-btn--burgundy:link,
.qi-btn--burgundy:visited,
.qi-btn--burgundy:hover,
.qi-btn--burgundy:focus,
.qi-btn--burgundy:active,
.qi-btn--burgundy-lg,
.qi-btn--burgundy-lg:link,
.qi-btn--burgundy-lg:visited,
.qi-btn--burgundy-lg:hover,
.qi-btn--burgundy-lg:focus,
.qi-btn--burgundy-lg:active { color: #fff !important; }


/* Delete / Void record management controls */
.qi-btn.qi-btn--danger-soft {
  background: #fcebea !important;
  border-color: #e0aaa6 !important;
  color: #7f2323 !important;
}
.qi-btn--danger-soft:hover,
.qi-btn--danger-soft:focus {
  background: #f7d3d0 !important;
  border-color: #9f2f2f !important;
  color: #641919 !important;
}
.qi-record-management {
  border-left: 5px solid #9f2f2f !important;
}
.qi-table tr.is-voided,
tr.is-voided {
  opacity: .72;
  background: #f7f8fb !important;
}
.qi-table tr.is-voided td {
  color: #5b6575;
}

/* Targeted QI privacy/compliance update: visible incident-to-domain mapping banner */
.qi-mapping-banner {
  margin-top: .75rem;
  padding: .75rem .9rem;
  border: 1px solid var(--brass, #A88B3C);
  border-radius: 14px;
  background: var(--brass-soft, #F0E7CC);
  color: var(--ink, #0A1F3D);
  font-size: 14px;
  line-height: 1.45;
}
.qi-mapping-banner strong {
  font-weight: 800;
}


/* ═══════════════════════════════════════════════════════════
 * 19 · DESIGN/WORFLOW IMPLEMENTATION PATCH — May 2026
 * Targeted admin-app improvements: Inter font alignment, clearer action
 * hierarchy, guided record entry, validation summaries, sticky filters,
 * saved views, data-completeness states, and report-readiness cards.
 * ═════════════════════════════════════════════════════════ */
:root {
  --primary: var(--oxblood);
  --primary-hover: #861f30;
  --warning: var(--amber);
  --danger: #991B1B;
  --danger-soft: #FEE2E2;
  --success: var(--sage);
}

.qi-app,
.qi-app button,
.qi-app input,
.qi-app select,
.qi-app textarea { font-family: var(--body); }

.is-id,
.qi-id,
.qi-link-id,
.qi-incident-uid,
.qi-ca-number,
.qi-table td.is-id { font-family: var(--mono); font-variant-numeric: tabular-nums; }

.qi-u-mt-3 { margin-top: .85rem; }
.qi-u-auto-left { margin-left: auto; }
.qi-u-hidden { display: none; }

.qi-app :focus-visible {
  outline: 3px solid var(--focus-ring);
  outline-offset: 3px;
  box-shadow: 0 0 0 5px var(--focus-ring-glow);
}

.qi-btn {
  min-height: var(--touch);
  border-radius: 999px;
  font-weight: 700;
  letter-spacing: .01em;
  transition: background .16s ease, border-color .16s ease, color .16s ease, transform .16s ease, box-shadow .16s ease;
}
.qi-btn:hover { transform: translateY(-1px); box-shadow: 0 8px 20px rgba(10,31,61,.08); }
.qi-btn:disabled { opacity: .58; cursor: not-allowed; transform: none; box-shadow: none; }
.qi-btn--primary,
.qi-btn--burgundy,
.qi-btn--burgundy-lg,
.qi-govreport-download { background: var(--primary); border-color: var(--primary); color: #fff; }
.qi-btn--primary:hover,
.qi-btn--burgundy:hover,
.qi-btn--burgundy-lg:hover,
.qi-govreport-download:hover { background: var(--primary-hover); border-color: var(--primary-hover); color: #fff; }
.qi-btn--outline { background: var(--card); border-color: var(--rule); color: var(--ink); }
.qi-btn--ghost { color: var(--ink-70); }
.qi-btn--create-ca,
.qi-btn--flag-promote { background: var(--amber-soft); border-color: rgba(180,122,20,.42); color: #6b4308; }
.qi-btn--create-ca:hover,
.qi-btn--flag-promote:hover { background: var(--warning); border-color: var(--warning); color: #fff; }
.qi-btn--danger,
.qi-btn--delete,
.qi-btn--void { background: #fff; border-color: rgba(153,27,27,.36); color: var(--danger); }
.qi-btn--danger:hover,
.qi-btn--delete:hover,
.qi-btn--void:hover { background: var(--danger); border-color: var(--danger); color: #fff; }
.qi-btn--icon { width: 44px; min-width: 44px; padding-left: 0; padding-right: 0; justify-content: center; }

.qi-form-toolbar {
  position: sticky;
  top: calc(var(--adminbar-h, 0px) + .5rem);
  z-index: 35;
  backdrop-filter: blur(12px);
  box-shadow: 0 14px 38px rgba(10,31,61,.08);
}
.qi-form-toolbar__right { align-items: flex-start; justify-content: flex-end; }

.qi-form-workflow {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: .75rem;
  margin: var(--sp-5) 0 var(--sp-6);
}
.qi-step {
  display: flex;
  gap: .75rem;
  align-items: flex-start;
  background: var(--card);
  border: 1px solid var(--rule-soft);
  border-radius: var(--r-lg);
  padding: .85rem 1rem;
  min-height: 76px;
}
.qi-step__num {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 30px;
  height: 30px;
  border-radius: 999px;
  background: var(--ink-surface);
  color: var(--ink);
  font-weight: 800;
  flex: 0 0 auto;
}
.qi-step__label { display: block; font-size: .9rem; font-weight: 800; color: var(--ink); }
.qi-step__hint { display: block; font-size: .76rem; color: var(--ink-meta); line-height: 1.35; margin-top: .12rem; }
.qi-step.is-active { border-color: var(--primary); box-shadow: 0 0 0 3px var(--focus-ring-glow); }
.qi-step.is-active .qi-step__num { background: var(--primary); color: #fff; }
.qi-step.is-complete .qi-step__num { background: var(--success); color: #fff; }

.qi-chip-row { display: inline-flex; flex-wrap: wrap; gap: .4rem; margin-top: .35rem; }
.qi-domain-chip {
  display: inline-flex;
  align-items: center;
  min-height: 30px;
  padding: .25rem .65rem;
  border-radius: 999px;
  background: var(--brass-soft);
  border: 1px solid rgba(168,139,60,.35);
  color: var(--ink);
  font-size: .82rem;
  font-weight: 800;
}
.qi-domain-chip--related { background: var(--oxblood-soft); border-color: var(--oxblood-mid); color: var(--oxblood); }

.qi-form-alert[role="alert"],
.qi-form-error-summary {
  border-left-width: 5px;
  border-left-style: solid;
}
.qi-form-error-summary {
  display: none;
  margin: var(--sp-4) 0;
  padding: 1rem 1.1rem;
  border-radius: var(--r-lg);
  background: #FFF1F0;
  border-color: var(--danger);
  color: #7f1d1d;
}
.qi-form-error-summary.is-visible { display: block; }
.qi-form-error-summary strong { display: block; margin-bottom: .45rem; }
.qi-form-error-summary ul { margin: .35rem 0 0 1.15rem; padding: 0; }
.qi-form-error-summary a { color: #7f1d1d; text-decoration: underline; font-weight: 700; }

.qi-field__error { min-height: 1rem; }
.qi-field.is-invalid { scroll-margin-top: 160px; }
.qi-field.is-invalid .qi-field__error { display: block; }
.qi-field.is-invalid .qi-field__error:empty::before { content: 'Required before saving.'; }

.qi-form-review {
  background: linear-gradient(180deg, var(--card), #fffaf0);
  border-left: 5px solid var(--brass);
}
.qi-review-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: .75rem;
}
.qi-review-item {
  border: 1px solid var(--rule-soft);
  border-radius: var(--r);
  background: rgba(255,255,255,.56);
  padding: .7rem .8rem;
}
.qi-review-item dt {
  margin: 0 0 .18rem;
  color: var(--ink-meta);
  font-size: .7rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .08em;
}
.qi-review-item dd { margin: 0; font-weight: 800; color: var(--ink); }

.qi-filters.qi-filters--sticky {
  position: sticky;
  top: calc(var(--adminbar-h, 0px) + .5rem);
  z-index: 28;
  box-shadow: 0 12px 30px rgba(10,31,61,.08);
}
.qi-saved-views {
  display: flex;
  flex-wrap: wrap;
  gap: .5rem;
  align-items: center;
  margin: var(--sp-3) 0 var(--sp-4);
}
.qi-saved-views__label {
  font-size: .72rem;
  font-weight: 800;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--ink-meta);
}
.qi-data-quality {
  display: inline-flex;
  max-width: 190px;
  align-items: center;
  gap: .35rem;
  padding: .28rem .55rem;
  border-radius: 999px;
  font-size: .78rem;
  font-weight: 800;
  line-height: 1.25;
}
.qi-data-quality--ok { background: var(--sage-soft); color: #203d2b; }
.qi-data-quality--warn { background: var(--amber-soft); color: #6b4308; }
.qi-data-quality--danger { background: var(--danger-soft); color: #7f1d1d; }

.qi-readiness-summary {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: .75rem;
  margin: 0 0 var(--sp-5);
}
.qi-readiness-card {
  display: grid;
  gap: .3rem;
  background: var(--card);
  border: 1px solid var(--rule-soft);
  border-left: 5px solid var(--ink-border);
  border-radius: var(--r-lg);
  padding: .85rem 1rem;
}
.qi-readiness-card.is-ok { border-left-color: var(--sage); }
.qi-readiness-card.is-warning { border-left-color: var(--amber); }
.qi-readiness-card.is-error { border-left-color: var(--danger); }
.qi-readiness-card__label { font-size: .72rem; font-weight: 800; letter-spacing: .1em; text-transform: uppercase; color: var(--ink-meta); }
.qi-readiness-card__value { font-size: 1rem; font-weight: 800; color: var(--ink); }
.qi-readiness-card__note { font-size: .8rem; color: var(--ink-70); line-height: 1.35; }
.qi-govreport-next-actions {
  display: flex;
  flex-wrap: wrap;
  gap: .5rem;
  align-items: center;
  padding: .85rem 1rem;
  margin: 0 0 var(--sp-5);
  background: var(--paper-warm);
  border: 1px solid var(--rule);
  border-radius: var(--r-lg);
}
.qi-govreport-next-actions strong { margin-right: .25rem; }

@media (max-width: 1024px) {
  .qi-form-workflow,
  .qi-review-grid,
  .qi-readiness-summary { grid-template-columns: repeat(2, minmax(0,1fr)); }
}
@media (max-width: 720px) {
  .qi-form-workflow,
  .qi-review-grid,
  .qi-readiness-summary { grid-template-columns: 1fr; }
  .qi-form-toolbar { position: static; }
  .qi-form-toolbar__right .qi-btn { flex: 1 1 100%; }
}

@media print {
  .qi-form-workflow,
  .qi-saved-views,
  .qi-govreport-next-actions { display: none !important; }
}
