/* Attendance trust & manual-entry governance components.
   Pairs with tokens.css + components.css. Vanilla CSS, BEM-ish.
   Covers: review-state pills, source badges, orthogonal flags,
   provenance line, change history, governed modal, Today-view upgrades. */

/* ====== Review-state pill ================================================ */
/* The single canonical status. One per record, everywhere. */
.spill {
  display: inline-flex; align-items: center; gap: 5px;
  font-family: var(--font-mono);
  font-size: 10px; font-weight: 500; letter-spacing: 0.04em;
  text-transform: uppercase;
  padding: 2px 8px 2px 7px;
  border-radius: var(--r-full);
  line-height: 1.5; white-space: nowrap;
  border: 1px solid transparent;
}
.spill::before {
  content: ''; width: 6px; height: 6px; border-radius: 99px;
  background: currentColor; flex-shrink: 0; opacity: 0.9;
}
.spill--pending    { background: var(--warn-soft);  color: var(--warn-ink); }
.spill--approved   { background: var(--good-soft);  color: var(--good-ink); }
.spill--rejected   { background: var(--bad-soft);   color: var(--bad-ink); }
.spill--resubmitted{ background: var(--accent-soft);color: var(--accent-ink); }
.spill--locked     { background: var(--paper-3);    color: var(--ink-3); }
.spill--locked::before {
  width: 9px; height: 9px; border-radius: 1px;
  background: none;
  -webkit-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2.4'%3E%3Crect x='4' y='11' width='16' height='10' rx='2'/%3E%3Cpath d='M8 11V7a4 4 0 0 1 8 0v4'/%3E%3C/svg%3E") center/contain no-repeat;
          mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2.4'%3E%3Crect x='4' y='11' width='16' height='10' rx='2'/%3E%3Cpath d='M8 11V7a4 4 0 0 1 8 0v4'/%3E%3C/svg%3E") center/contain no-repeat;
  background: currentColor;
}
.spill--lg { font-size: 11px; padding: 3px 10px 3px 9px; }

/* ====== Source badge ===================================================== */
/* Where the record was born. Manual must NEVER look like a clock punch. */
.src {
  display: inline-flex; align-items: center; gap: 5px;
  font-family: var(--font-mono);
  font-size: 10px; font-weight: 500; letter-spacing: 0.05em;
  text-transform: uppercase;
  padding: 2px 7px;
  border-radius: var(--r-sm);
  line-height: 1.5; white-space: nowrap;
  border: 1px solid var(--line);
  background: var(--paper);
  color: var(--ink-3);
}
.src > svg { width: 11px; height: 11px; flex-shrink: 0; }
/* Clock — the trusted, neutral default */
.src--clock { color: var(--ink-3); border-color: var(--line); background: var(--paper); }
/* Manual — amber, dashed border: deliberately conspicuous */
.src--manual {
  color: var(--warn-ink);
  border-color: var(--warn);
  border-style: dashed;
  background: var(--warn-soft);
}
/* Correction — employee-proposed, HR-approved */
.src--correction { color: var(--accent-ink); border-color: var(--accent-line); background: var(--accent-soft); }
/* Import — bulk loaded */
.src--import { color: var(--ink-3); border-color: var(--line); background: var(--paper-3); border-style: dotted; }

/* ====== Orthogonal flags ================================================= */
/* Independent of review-state. A record can be Approved AND Exception. */
.flag {
  display: inline-flex; align-items: center; gap: 4px;
  font-family: var(--font-mono);
  font-size: 10px; font-weight: 500; letter-spacing: 0.04em;
  text-transform: uppercase;
  padding: 2px 7px;
  border-radius: var(--r-full);
  line-height: 1.5; white-space: nowrap;
}
.flag > svg { width: 11px; height: 11px; flex-shrink: 0; }
.flag--exception { background: var(--warn-soft); color: var(--warn-ink); }
/* Self-approved — a flag, not an approval. Designed to stand out. */
.flag--self {
  background: transparent;
  color: var(--bad-ink);
  border: 1px dashed var(--bad);
  padding: 1px 7px;
}
.flag--awaiting {
  background: transparent;
  color: var(--accent-ink);
  border: 1px solid var(--accent-line);
  padding: 1px 7px;
}
.flag--locked { background: var(--paper-3); color: var(--ink-3); }

/* ====== Actor badge (who signed off) ===================================== */
.actor {
  display: inline-flex; align-items: center; gap: 6px;
  font-size: 11px; color: var(--ink-2);
}
.actor__chk {
  width: 16px; height: 16px; border-radius: 99px;
  display: inline-flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.actor__chk svg { width: 10px; height: 10px; stroke-width: 2.5; }
.actor--system .actor__chk { background: var(--paper-3); color: var(--ink-3); }
.actor--human  .actor__chk { background: var(--good-soft); color: var(--good-ink); }
.actor__name { font-weight: 500; color: var(--ink); }
.actor__sub  { font-family: var(--font-mono); font-size: 10px; color: var(--ink-3); }

/* ====== Provenance line (record detail) ================================= */
.prov {
  display: grid; grid-template-columns: 96px 1fr; gap: 8px 14px;
  font-size: 12px; align-items: baseline;
}
.prov__k {
  font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.06em;
  text-transform: uppercase; color: var(--ink-3);
}
.prov__v { color: var(--ink); }
.prov__v .reason {
  display: block; color: var(--ink-2);
  background: var(--paper-2); border: 1px solid var(--line-2);
  border-left: 2px solid var(--ink-4);
  padding: 6px 10px; border-radius: var(--r-sm);
  font-size: 12px; line-height: 1.5;
}

/* ====== Change history (audit, expandable) ============================== */
.chist { display: flex; flex-direction: column; gap: 0; }
.chist__row {
  display: grid; grid-template-columns: 14px 1fr;
  gap: 12px; padding: 10px 0;
  border-top: 1px solid var(--line-2);
}
.chist__row:first-child { border-top: 0; }
.chist__dot {
  width: 9px; height: 9px; border-radius: 99px; margin-top: 4px;
  background: var(--paper); border: 2px solid var(--ink-4);
}
.chist__dot--edit   { border-color: var(--warn); background: var(--warn); }
.chist__dot--create { border-color: var(--good); background: var(--good); }
.chist__dot--void   { border-color: var(--bad);  background: var(--bad); }
.chist__main { min-width: 0; }
.chist__what { font-size: 12px; color: var(--ink); font-weight: 500; }
.chist__diff {
  display: inline-flex; align-items: center; gap: 6px;
  font-family: var(--font-mono); font-size: 11px;
  margin-top: 3px;
}
.chist__diff .from { color: var(--bad-ink); text-decoration: line-through; opacity: 0.8; }
.chist__diff .to   { color: var(--good-ink); font-weight: 600; }
.chist__diff .arr  { color: var(--ink-4); }
.chist__by {
  font-family: var(--font-mono); font-size: 10px; color: var(--ink-3);
  margin-top: 4px; letter-spacing: 0.02em;
}
.chist__by .reason { color: var(--ink-2); }

/* ====== Awaiting-approver banner (self-approval block) ================== */
.awaiting-banner {
  display: flex; align-items: flex-start; gap: 10px;
  padding: 12px 14px;
  background: var(--accent-soft);
  border: 1px solid var(--accent-line);
  border-radius: var(--r-lg);
  font-size: 12px; color: var(--accent-ink);
}
.awaiting-banner svg { width: 16px; height: 16px; flex-shrink: 0; margin-top: 1px; }
.awaiting-banner strong { display: block; font-size: 12px; margin-bottom: 2px; color: var(--accent-ink); }
.awaiting-banner p { color: var(--ink-2); line-height: 1.5; }

/* ====== Locked banner =================================================== */
.locked-banner {
  display: flex; align-items: flex-start; gap: 10px;
  padding: 12px 14px;
  background: var(--paper-2);
  border: 1px solid var(--line);
  border-radius: var(--r-lg);
  font-size: 12px;
}
.locked-banner svg { width: 16px; height: 16px; flex-shrink: 0; margin-top: 1px; color: var(--ink-3); }
.locked-banner strong { display: block; font-size: 12px; margin-bottom: 2px; color: var(--ink); }
.locked-banner p { color: var(--ink-2); line-height: 1.5; }

/* ====== Modal (governed manual / correct / reject / void) =============== */
.mscrim {
  position: fixed; inset: 0;
  background: oklch(0.18 0.01 260 / 0.45);
  z-index: 80; display: none;
  align-items: flex-start; justify-content: center;
  padding: 7vh 20px 40px;
  overflow-y: auto;
}
.mscrim[data-open="true"] { display: flex; animation: mfade .15s var(--ease); }
@keyframes mfade { from { opacity: 0; } to { opacity: 1; } }
.amodal {
  width: 100%; max-width: 540px;
  background: var(--paper);
  border: 1px solid var(--line);
  border-radius: var(--r-2xl);
  box-shadow: var(--shadow-lg);
  overflow: hidden;
  animation: mrise .2s var(--ease);
}
.amodal--wide { max-width: 600px; }
@keyframes mrise { from { transform: translateY(12px); opacity: 0; } to { transform: translateY(0); opacity: 1; } }
.amodal__head {
  display: flex; align-items: flex-start; justify-content: space-between;
  padding: 18px 20px 14px;
  border-bottom: 1px solid var(--line-2);
}
.amodal__head h2 { font-size: var(--t-lg); }
.amodal__head p { font-size: 12px; color: var(--ink-3); margin-top: 3px; }
.amodal__body { padding: 18px 20px; display: flex; flex-direction: column; gap: 16px; }
.amodal__foot {
  display: flex; align-items: center; gap: 10px;
  padding: 14px 20px;
  border-top: 1px solid var(--line-2);
  background: var(--paper-2);
}
.amodal__foot .spacer { flex: 1; }

/* Source toggle inside the modal (nudge to correction over manual) */
.mtoggle { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; }
.mtoggle__opt {
  display: flex; flex-direction: column; gap: 4px;
  padding: 12px; text-align: left;
  border: 1px solid var(--line); border-radius: var(--r-lg);
  background: var(--paper); cursor: pointer;
  transition: border-color .12s, background .12s;
}
.mtoggle__opt:hover { border-color: var(--ink-4); }
.mtoggle__opt[aria-pressed="true"] { border-color: var(--accent); background: var(--accent-soft); box-shadow: 0 0 0 3px var(--accent-soft); }
.mtoggle__opt__t { font-size: 13px; font-weight: 600; display: flex; align-items: center; gap: 7px; }
.mtoggle__opt__d { font-size: 11px; color: var(--ink-3); line-height: 1.4; }
.mtoggle__opt .recommended {
  font-family: var(--font-mono); font-size: 9px; letter-spacing: 0.06em;
  color: var(--accent-ink); background: var(--paper); border: 1px solid var(--accent-line);
  padding: 0 5px; border-radius: var(--r-full); text-transform: uppercase;
}

/* Time-pair inputs */
.mtimes { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.mfield { display: flex; flex-direction: column; gap: 6px; }
.mfield__label {
  font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.06em;
  text-transform: uppercase; color: var(--ink-3);
  display: flex; align-items: center; gap: 6px;
}
.mfield__label .req { color: var(--bad-ink); }
.minput {
  height: 38px; padding: 0 12px;
  background: var(--paper); color: var(--ink);
  border: 1px solid var(--line); border-radius: var(--r-md);
  font-size: 13px; font-family: var(--font-mono);
  transition: border-color .12s, box-shadow .12s;
}
.minput:focus { outline: none; border-color: var(--accent); box-shadow: 0 0 0 3px var(--accent-soft); }
.minput--invalid { border-color: var(--bad); box-shadow: 0 0 0 3px var(--bad-soft); }
textarea.minput { height: auto; min-height: 64px; padding: 10px 12px; resize: vertical; font-family: var(--font-sans); }

/* Live policy preview inside the modal */
.mpreview {
  border: 1px solid var(--line); border-radius: var(--r-lg);
  background: var(--paper-2); overflow: hidden;
}
.mpreview__head {
  display: flex; align-items: center; gap: 8px;
  padding: 9px 12px; border-bottom: 1px solid var(--line-2);
  font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.06em;
  text-transform: uppercase; color: var(--ink-3);
}
.mpreview__head svg { width: 13px; height: 13px; }
.mpreview__body { padding: 12px; display: flex; flex-wrap: wrap; gap: 8px 10px; align-items: center; }
.mpreview__row { display: flex; align-items: center; gap: 10px; width: 100%; justify-content: space-between; }
.mpreview__metric { font-family: var(--font-mono); font-variant-numeric: tabular-nums; font-size: 15px; font-weight: 600; color: var(--ink); }
.mpreview__metric small { font-size: 11px; color: var(--ink-3); font-weight: 400; }

/* ====== Today view upgrades ============================================= */
/* Live rollup bar */
.live-rollup {
  display: flex; align-items: center; gap: 0;
  border: 1px solid var(--line); border-radius: var(--r-lg);
  background: var(--paper); overflow: hidden;
  margin-bottom: 14px;
}
.live-rollup__item {
  display: flex; align-items: center; gap: 8px;
  padding: 10px 14px; flex: 1;
  border-right: 1px solid var(--line-2);
}
.live-rollup__item:last-child { border-right: 0; }
.live-rollup__dot { width: 8px; height: 8px; border-radius: 99px; flex-shrink: 0; }
.live-rollup__n { font-family: var(--font-mono); font-variant-numeric: tabular-nums; font-size: 17px; font-weight: 600; color: var(--ink); }
.live-rollup__l { font-size: 11px; color: var(--ink-3); }
.live-rollup__pulse { animation: lr-pulse 2s var(--ease) infinite; }
@keyframes lr-pulse { 0%,100% { opacity: 1; } 50% { opacity: 0.4; } }

/* Today legend */
.today-legend {
  display: flex; flex-wrap: wrap; gap: 6px 16px; align-items: center;
  padding: 8px 16px; border-bottom: 1px solid var(--line-2);
  background: var(--paper-2);
  font-size: 11px; color: var(--ink-2);
}
.today-legend__chip { display: inline-flex; align-items: center; gap: 6px; white-space: nowrap; }
.today-legend__chip > i { width: 12px; height: 12px; border-radius: 3px; display: inline-block; flex-shrink: 0; }
.today-legend__chip > i.is-break {
  background: repeating-linear-gradient(45deg, var(--warn) 0 2px, var(--warn-soft) 2px 4px);
}
.today-legend__chip > i.is-now { width: 2px; height: 14px; border-radius: 0; background: var(--bad); }

/* Per-person presence chip */
.pchip {
  display: inline-flex; align-items: center; gap: 5px;
  font-family: var(--font-mono); font-size: 10px; font-weight: 500;
  letter-spacing: 0.03em; text-transform: uppercase;
  padding: 2px 8px 2px 7px; border-radius: var(--r-full);
  white-space: nowrap;
}
.pchip::before { content: ''; width: 6px; height: 6px; border-radius: 99px; background: currentColor; flex-shrink: 0; }
.pchip--active     { background: var(--good-soft); color: var(--good-ink); }
.pchip--active::before { animation: lr-pulse 2s var(--ease) infinite; }
.pchip--break      { background: var(--warn-soft); color: var(--warn-ink); }
.pchip--late       { background: var(--warn-soft); color: var(--warn-ink); }
.pchip--out        { background: var(--paper-3); color: var(--ink-3); }
.pchip--absent     { background: var(--bad-soft); color: var(--bad-ink); }
.pchip--leave      { background: var(--accent-soft); color: var(--accent-ink); }

/* Break segment on the timeline */
.timeline__block--break {
  background: repeating-linear-gradient(45deg, var(--warn) 0 3px, var(--warn-soft) 3px 6px) !important;
  top: 12px; bottom: 12px; border-radius: 1px;
}

/* Today row summary (right-aligned tabular) */
.today-sum {
  display: flex; gap: 14px; align-items: center;
  font-family: var(--font-mono); font-variant-numeric: tabular-nums;
  font-size: 11px; color: var(--ink-3);
  white-space: nowrap;
}
.today-sum b { color: var(--ink); font-weight: 600; }
.today-sum .warn { color: var(--warn-ink); }

/* Source dot on register cells (compact source signal) */
.srcdot {
  position: absolute; bottom: 6px; right: 8px;
  width: 12px; height: 12px;
}
.srcdot svg { width: 12px; height: 12px; }
.srcdot--manual { color: var(--warn-ink); }
.srcdot--correction { color: var(--accent-ink); }
