/* ============================================================
   Clarity Value — Card, table, status pill, tag, empty/loading/error
   ============================================================ */

/* ---- Card ---- */
.cv-card {
  background: var(--cv-surface-card);
  border: 0.5px solid var(--cv-line-hairline);
  border-radius: var(--cv-r-3);
  box-shadow: var(--cv-shadow-card);
}
.cv-card-h {
  padding: var(--cv-pad-card-v) var(--cv-pad-card-h);
  border-bottom: 0.5px solid var(--cv-line-hairline);
  display: flex; align-items: center; justify-content: space-between; gap: 12px;
}
.cv-card-h-title { font-size: 13px; font-weight: 500; line-height: 1.3; color: var(--cv-text-primary); }
.cv-card-h-meta  { font-size: 11px; color: var(--cv-text-tertiary); margin-top: 2px; }
.cv-card-h-actions { display: flex; align-items: center; gap: 8px; }
.cv-card-b { padding: var(--cv-pad-card-v) var(--cv-pad-card-h); }
.cv-card-b--flush { padding: 0; }

/* ============================================================
   Table primitive
   ============================================================ */
.cv-tbl { width: 100%; border-collapse: collapse; font-size: 12px; }
.cv-tbl thead th {
  text-align: left;
  font-size: 11px; font-weight: 500; line-height: 1.3;
  letter-spacing: 0.02em;
  color: var(--cv-text-tertiary);
  padding: var(--cv-pad-table-head-v) var(--cv-pad-table-cell-h);
  background: var(--cv-surface-page);
  border-bottom: 0.5px solid var(--cv-line-hairline);
  border-top: 0.5px solid var(--cv-line-hairline);
  white-space: nowrap;
}
.cv-tbl tbody td {
  padding: var(--cv-pad-table-cell-v) var(--cv-pad-table-cell-h);
  border-bottom: 0.5px solid var(--cv-line-hairline);
  color: var(--cv-text-primary);
  vertical-align: middle;
  height: 36px;
}
.cv-tbl tbody tr { transition: background 80ms; }
.cv-tbl tbody tr:hover { background: var(--cv-surface-page); }
.cv-tbl tbody tr.is-selected td { background: var(--cv-brand-blue-tint); }
.cv-tbl-id {
  font-family: var(--cv-font-mono);
  font-size: 11px;
  color: var(--cv-text-tertiary);
}
.cv-tbl-step { display: flex; align-items: center; gap: 7px; }
.cv-tbl-step svg { width: 13px; height: 13px; color: var(--cv-text-muted); flex-shrink: 0; }
.cv-tbl-step-name { color: var(--cv-text-primary); }

/* Checkbox */
.cv-chk {
  width: 14px; height: 14px;
  border-radius: 3px;
  border: 1px solid var(--cv-line-stronger);
  display: inline-flex; align-items: center; justify-content: center;
  cursor: pointer;
  background: #fff;
  transition: background var(--cv-dur-fast), border-color var(--cv-dur-fast);
}
.cv-chk.is-checked { background: var(--cv-brand-blue); border-color: var(--cv-brand-blue); }
.cv-chk.is-checked::after {
  content: "";
  width: 7px; height: 4px;
  border: 1.5px solid #fff;
  border-top: 0; border-right: 0;
  transform: rotate(-45deg) translate(1px, -2px);
}

/* ============================================================
   Status pill (.cv-pill — leading dot, 999 radius, 5 severities)
   ============================================================ */
.cv-pill {
  display: inline-flex; align-items: center; gap: 5px;
  font-size: 11px; font-weight: 500; line-height: 1.45;
  padding: 2px 8px;
  border-radius: var(--cv-r-pill);
  border: 0.5px solid transparent;
  white-space: nowrap;
}
.cv-pill::before {
  content: ""; width: 5px; height: 5px;
  border-radius: 50%; background: currentColor;
  flex-shrink: 0;
}
.cv-pill--muted {
  background: var(--cv-status-muted-bg);
  color:      var(--cv-status-muted-text);
  border-color: var(--cv-status-muted-border);
}
.cv-pill--blue {
  background: var(--cv-status-blue-bg);
  color:      var(--cv-status-blue-text);
  border-color: var(--cv-status-blue-border);
}
.cv-pill--green {
  background: var(--cv-status-green-bg);
  color:      var(--cv-status-green-text);
  border-color: var(--cv-status-green-border);
}
.cv-pill--amber {
  background: var(--cv-status-amber-bg);
  color:      var(--cv-status-amber-text);
  border-color: var(--cv-status-amber-border);
}
.cv-pill--red {
  background: var(--cv-status-red-bg);
  color:      var(--cv-status-red-text);
  border-color: var(--cv-status-red-border);
}

/* ============================================================
   Tag (.cv-tag — categorical, no dot, 4px radius)
   ============================================================ */
.cv-tag {
  display: inline-flex; align-items: center;
  font-size: 11px; font-weight: 500; line-height: 1.45;
  padding: 2px 7px;
  border-radius: var(--cv-r-1);
  white-space: nowrap;
}
.cv-tag--blue   { background: var(--cv-tag-blue-bg);   color: var(--cv-tag-blue-text); }
.cv-tag--teal   { background: var(--cv-tag-teal-bg);   color: var(--cv-tag-teal-text); }
.cv-tag--green  { background: var(--cv-tag-green-bg);  color: var(--cv-tag-green-text); }
.cv-tag--amber  { background: var(--cv-tag-amber-bg);  color: var(--cv-tag-amber-text); }
.cv-tag--coral  { background: var(--cv-tag-coral-bg);  color: var(--cv-tag-coral-text); }
.cv-tag--pink   { background: var(--cv-tag-pink-bg);   color: var(--cv-tag-pink-text); }
.cv-tag--purple { background: var(--cv-tag-purple-bg); color: var(--cv-tag-purple-text); }
.cv-tag--muted  { background: var(--cv-tag-muted-bg);  color: var(--cv-tag-muted-text); }

/* Status icon-tile (for list-row icons next to entity names) */
.cv-tile {
  width: 28px; height: 28px;
  border-radius: var(--cv-r-2);
  display: inline-flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.cv-tile svg { width: 14px; height: 14px; }
.cv-tile--blue  { background: var(--cv-tile-blue-bg);  color: var(--cv-tile-blue-fg); }
.cv-tile--green { background: var(--cv-tile-green-bg); color: var(--cv-tile-green-fg); }
.cv-tile--amber { background: var(--cv-tile-amber-bg); color: var(--cv-tile-amber-fg); }
.cv-tile--red   { background: var(--cv-tile-red-bg);   color: var(--cv-tile-red-fg); }
.cv-tile--muted { background: var(--cv-tile-muted-bg); color: var(--cv-tile-muted-fg); }

/* ============================================================
   Empty / Loading / Error states
   ============================================================ */
.cv-empty {
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  padding: 64px 24px;
  text-align: center;
  background: var(--cv-surface-card);
  border: 0.5px solid var(--cv-line-hairline);
  border-radius: var(--cv-r-3);
}
.cv-empty-icon {
  width: 48px; height: 48px;
  border-radius: var(--cv-r-3);
  background: var(--cv-brand-blue-tint);
  color: var(--cv-brand-blue);
  display: flex; align-items: center; justify-content: center;
  margin-bottom: 14px;
}
.cv-empty-icon svg { width: 22px; height: 22px; }
.cv-empty-title { font-size: 14px; font-weight: 500; color: var(--cv-text-primary); margin-bottom: 4px; }
.cv-empty-desc  { font-size: 12px; color: var(--cv-text-tertiary); max-width: 380px; line-height: 1.55; margin-bottom: 14px; }
.cv-empty-actions { display: flex; align-items: center; gap: 8px; }

/* Loading skeleton */
.cv-skel {
  background: linear-gradient(90deg, #EDEFF2 25%, #F5F6F8 50%, #EDEFF2 75%);
  background-size: 200% 100%;
  animation: cv-skel-shimmer 1.4s ease-in-out infinite;
  border-radius: var(--cv-r-1);
}
@keyframes cv-skel-shimmer {
  0%   { background-position: 200% 0; }
  100% { background-position: -200% 0; }
}
.cv-skel-line { height: 8px; }
.cv-skel-text { height: 10px; }
.cv-skel-pill { height: 18px; width: 60px; border-radius: var(--cv-r-pill); }

/* Error */
.cv-err {
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  padding: 64px 24px; text-align: center;
  background: var(--cv-surface-card);
  border: 0.5px solid var(--cv-line-hairline);
  border-radius: var(--cv-r-3);
}
.cv-err-icon {
  width: 48px; height: 48px;
  border-radius: 50%;
  background: var(--cv-status-red-bg);
  color: var(--cv-status-red-text);
  display: flex; align-items: center; justify-content: center;
  margin-bottom: 14px;
  border: 0.5px solid var(--cv-status-red-border);
}
.cv-err-icon svg { width: 22px; height: 22px; }
.cv-err-title { font-size: 14px; font-weight: 500; color: var(--cv-text-primary); margin-bottom: 4px; }
.cv-err-desc  { font-size: 12px; color: var(--cv-text-tertiary); max-width: 420px; line-height: 1.55; margin-bottom: 6px; }
.cv-err-detail {
  font-family: var(--cv-font-mono);
  font-size: 11px;
  color: var(--cv-text-muted);
  background: var(--cv-surface-page);
  border: 0.5px solid var(--cv-line-hairline);
  border-radius: var(--cv-r-2);
  padding: 8px 12px; margin-bottom: 14px;
  max-width: 540px;
}
.cv-err-actions { display: flex; align-items: center; gap: 8px; }

/* ============================================================
   Modal
   ============================================================ */
.cv-modal-overlay {
  position: fixed; inset: 0;
  background: rgba(15,19,38,0.55);
  display: flex; align-items: center; justify-content: center;
  z-index: 40;
  backdrop-filter: blur(3px);
}
.cv-modal {
  width: 480px; max-width: calc(100vw - 48px);
  background: var(--cv-surface-card);
  border-radius: var(--cv-r-5);
  box-shadow: var(--cv-shadow-modal);
  overflow: hidden;
  animation: cv-modal-in var(--cv-dur-slow) var(--cv-ease-decel);
}
@keyframes cv-modal-in {
  from { opacity: 0; transform: translateY(8px) scale(0.98); }
  to   { opacity: 1; transform: translateY(0)   scale(1); }
}
.cv-modal-h {
  padding: 16px 20px;
  border-bottom: 0.5px solid var(--cv-line-hairline);
  display: flex; align-items: flex-start; justify-content: space-between; gap: 12px;
}
.cv-modal-h-title { font-size: 14px; font-weight: 500; color: var(--cv-text-primary); }
.cv-modal-h-sub   { font-size: 12px; color: var(--cv-text-tertiary); margin-top: 2px; }
.cv-modal-close {
  width: 24px; height: 24px;
  border-radius: var(--cv-r-1);
  border: none; background: transparent; cursor: pointer;
  color: var(--cv-text-muted);
  display: flex; align-items: center; justify-content: center;
  transition: background var(--cv-dur-fast), color var(--cv-dur-fast);
}
.cv-modal-close:hover { background: var(--cv-surface-page); color: var(--cv-text-primary); }
.cv-modal-b {
  padding: 16px 20px;
  font-size: 12.5px; line-height: 1.6;
  color: var(--cv-text-secondary);
}
.cv-modal-b strong { color: var(--cv-text-primary); font-weight: 500; }
.cv-modal-f {
  padding: 12px 20px;
  border-top: 0.5px solid var(--cv-line-hairline);
  display: flex; justify-content: flex-end; gap: 8px;
  background: var(--cv-surface-page);
}

/* ============================================================
   Snackbar (anchored bottom-right)
   ============================================================ */
.cv-sn {
  position: fixed; bottom: 18px; right: 18px;
  display: flex; align-items: flex-start; gap: 10px;
  padding: 11px 14px 11px 12px;
  background: #1F2940;
  color: #F3F4F6;
  border-radius: var(--cv-r-3);
  box-shadow: var(--cv-shadow-pop);
  max-width: 380px;
  z-index: 30;
  animation: cv-sn-in 220ms var(--cv-ease-decel);
}
@keyframes cv-sn-in {
  from { opacity: 0; transform: translateY(8px); }
  to   { opacity: 1; transform: translateY(0); }
}
.cv-sn-icon {
  width: 20px; height: 20px;
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.cv-sn-icon svg { width: 11px; height: 11px; color: #fff; }
.cv-sn--success .cv-sn-icon { background: #3B6D11; }
.cv-sn--error   .cv-sn-icon { background: #9F1818; }
.cv-sn-title { font-size: 12.5px; font-weight: 500; line-height: 1.35; }
.cv-sn-desc  { font-size: 11.5px; color: #C8CDDA; line-height: 1.45; margin-top: 1px; }
.cv-sn-x {
  background: transparent; border: none; cursor: pointer;
  color: #9CA0B5; width: 18px; height: 18px;
  display: flex; align-items: center; justify-content: center;
  border-radius: var(--cv-r-1); flex-shrink: 0;
}
.cv-sn-x:hover { background: rgba(255,255,255,0.08); color: #fff; }

/* ============================================================
   Section eyebrow header (caps, hairline below)
   ============================================================ */
.cv-section-h {
  font-size: 11px; font-weight: 500; line-height: 1.3;
  letter-spacing: 0.05em; text-transform: uppercase;
  color: var(--cv-text-tertiary);
  padding-bottom: 8px;
  border-bottom: 0.5px solid var(--cv-line-hairline);
  margin-bottom: 14px;
}

/* ============================================================
   Wait banner (informational, gov-pending feel)
   ============================================================ */
.cv-wait {
  display: flex; align-items: flex-start; gap: 10px;
  padding: 10px 14px;
  background: var(--cv-status-amber-bg);
  border: 0.5px solid var(--cv-status-amber-border);
  border-radius: var(--cv-r-2);
  color: var(--cv-status-amber-text);
  font-size: 12px; line-height: 1.55;
}
.cv-wait svg { width: 14px; height: 14px; flex-shrink: 0; margin-top: 2px; }
.cv-wait strong { font-weight: 500; }
