/* ============================================================
   ProjectTelemetry — Payroll module styles
   assets/payroll.css
   ============================================================ */
.pr-load{ padding:50px 0; text-align:center; color:var(--ink-soft); font-size:14px; }
.pr-load .ti{ animation:spin 1s linear infinite; margin-right:6px; }
.pr-empty{ text-align:center; padding:56px 20px; color:var(--ink-soft); }
.pr-empty .ti{ font-size:34px; color:var(--ink-faint); }
.pr-empty h3{ margin:12px 0 4px; font-size:15px; color:var(--ink); }

/* ── Tabs ──────────────────────────────────────────────────── */
.pr-tabs{ display:flex; gap:4px; border-bottom:1px solid var(--bd); margin-bottom:18px; }
.pr-tab{ background:none; border:none; padding:10px 14px; font-size:13.5px; font-weight:600; color:var(--ink-soft);
  cursor:pointer; border-bottom:2px solid transparent; margin-bottom:-1px; display:flex; align-items:center; gap:6px; }
.pr-tab:hover{ color:var(--ink); }
.pr-tab.on{ color:var(--accent); border-bottom-color:var(--accent); }

/* ── Summary tiles ─────────────────────────────────────────── */
.pr-tiles{ display:grid; grid-template-columns:repeat(6,1fr); gap:10px; margin-bottom:16px; }
.pr-tile{ text-align:left; background:var(--white); border:1px solid var(--bd); border-radius:var(--radius);
  padding:12px 14px; cursor:pointer; transition:.12s; display:flex; flex-direction:column; gap:2px; }
.pr-tile:hover{ box-shadow:var(--shadow-md); }
.pr-tile.sel{ border-color:var(--accent); box-shadow:0 0 0 2px var(--accent-bg); }
.pr-tile-n{ font-size:22px; font-weight:800; color:var(--ink); font-variant-numeric:tabular-nums; line-height:1.1; }
.pr-tile-l{ font-size:11.5px; color:var(--ink-soft); font-weight:600; }
.pr-tile.warn .pr-tile-n{ color:#B45309; }
.pr-tile.late .pr-tile-n{ color:#B91C1C; }
.pr-tile.ok .pr-tile-n{ color:#047857; }
@media (max-width:900px){ .pr-tiles{ grid-template-columns:repeat(3,1fr); } }

/* ── Filters ───────────────────────────────────────────────── */
.pr-filters{ display:flex; gap:8px; align-items:center; flex-wrap:wrap; margin-bottom:14px; }
.pr-sel, .pr-input{ border:1px solid var(--bd); border-radius:6px; padding:7px 10px; font-size:13px; background:var(--white); color:var(--ink); }
.pr-sel{ min-width:180px; }
.pr-input{ min-width:200px; }

/* ── Table ─────────────────────────────────────────────────── */
.pr-tablewrap{ border:1px solid var(--bd); border-radius:var(--radius); overflow:hidden; background:var(--white); box-shadow:var(--shadow); }
.pr-table{ width:100%; border-collapse:collapse; font-size:13px; }
.pr-table th{ background:var(--bg2); color:var(--ink-soft); font-size:11px; text-transform:uppercase; letter-spacing:.03em;
  font-weight:600; text-align:left; padding:9px 14px; border-bottom:1px solid var(--bd); white-space:nowrap; }
.pr-table th.r{ text-align:right; }
.pr-table td{ padding:10px 14px; border-bottom:1px solid var(--bd); vertical-align:middle; }
.pr-table tbody tr:last-child td{ border-bottom:none; }
.pr-row{ transition:background .1s; }
.pr-row:hover{ background:var(--bg2); }
.pr-row.late{ box-shadow:inset 3px 0 0 #DC2626; }
.pr-emp{ font-weight:650; color:var(--ink); }
.pr-proj{ color:var(--ink-soft); }
.pr-hrs, .r{ text-align:right; font-variant-numeric:tabular-nums; }
.pr-actions{ text-align:right; }
.pr-actwrap{ display:flex; gap:6px; justify-content:flex-end; align-items:center; }
.pr-none{ text-align:center; color:var(--ink-faint); padding:28px 14px !important; font-size:13px; }

/* ── Badges ────────────────────────────────────────────────── */
.pr-badge{ font-size:11px; font-weight:650; padding:3px 9px; border-radius:100px; white-space:nowrap; margin-right:4px; display:inline-block; }
.pr-badge.muted{ background:var(--bg2); color:var(--ink-soft); border:1px solid var(--bd); }
.pr-badge.warn{ background:#FFF7ED; color:#B45309; border:1px solid #FED7AA; }
.pr-badge.ok{ background:#ECFDF5; color:#047857; border:1px solid #A7F3D0; }
.pr-badge.neg{ background:#FEF2F2; color:#B91C1C; border:1px solid #FECACA; }
.pr-badge.late{ background:#FEF2F2; color:#B91C1C; border:1px solid #FECACA; }

/* ── Review modal ──────────────────────────────────────────── */
/* max-width override required — .cp-modal caps at 520px, which would scroll the week. */
.pr-rv{ width:min(1100px,97vw); max-width:min(1100px,97vw); max-height:92vh; display:flex; flex-direction:column; }
.pr-rv .cp-body{ overflow:auto; }
.pr-rv-sub{ font-size:12.5px; color:var(--ink-soft); }
.pr-reject{ background:#FEF2F2; border:1px solid #FECACA; color:#B91C1C; border-radius:var(--radius); padding:9px 12px; font-size:12.5px; margin-bottom:14px; }
.pr-rvwrap{ overflow-x:auto; border:1px solid var(--bd); border-radius:var(--radius); }
.pr-rvtable{ width:100%; border-collapse:collapse; font-size:12.5px; min-width:720px; }
.pr-rvtable th{ background:var(--bg2); color:var(--ink-soft); font-size:10.5px; text-transform:uppercase; letter-spacing:.02em;
  font-weight:600; text-align:center; padding:7px 5px; border-bottom:1px solid var(--bd); white-space:nowrap; }
.pr-rvtable th:first-child{ text-align:left; padding-left:10px; }
.pr-rvtable th span{ display:block; font-size:9.5px; font-weight:500; color:var(--ink-faint); text-transform:none; }
.pr-rvtable td{ padding:6px 5px; border-bottom:1px solid var(--bd); text-align:center; }
.pr-rvtable td.r, .pr-rvtable th.r{ text-align:right; padding-right:10px; font-variant-numeric:tabular-nums; }
.pr-rc{ text-align:left !important; padding-left:10px !important; font-weight:650; color:var(--ink); font-variant-numeric:tabular-nums; }
.pr-rvtable .we{ background:rgba(0,0,0,.02); }
.pr-cw{ font-size:13px; font-weight:650; color:var(--ink); font-variant-numeric:tabular-nums; }
.pr-cs{ display:flex; justify-content:center; gap:5px; margin-top:1px; }
.pr-cs span{ font-size:10px; color:var(--ink-faint); font-variant-numeric:tabular-nums; }
.pr-cs span.on{ color:var(--ink-soft); font-weight:650; }
.pr-meta td{ background:rgba(0,0,0,.012); }
.pr-rvtable tfoot td{ border-top:2px solid var(--bd); background:var(--bg2); font-weight:700; padding:9px 5px; }
.pr-grand{ color:var(--accent); font-size:14px; }

/* ── Rules tab ─────────────────────────────────────────────── */
.pr-rules{ max-width:680px; }
.pr-scoperow{ display:flex; gap:8px; align-items:center; margin-bottom:16px; flex-wrap:wrap; }
.pr-scoperow .pr-sel{ min-width:280px; }

/* ── Agreement editor card ─────────────────────────────────── */
.pr-agr-card{ border:1px solid var(--bd); border-radius:var(--radius); background:var(--bg2); padding:14px; margin-bottom:18px; }
.pr-agr-fields{ display:flex; gap:12px; flex-wrap:wrap; }
.pr-field{ display:flex; flex-direction:column; gap:4px; flex:1; min-width:150px; }
.pr-field span{ font-size:11px; text-transform:uppercase; letter-spacing:.03em; color:var(--ink-soft); font-weight:600; }
.pr-field .pr-input{ min-width:0; width:100%; }
.pr-field-sm{ flex:0 0 90px; min-width:90px; }
.pr-agr-projs{ margin-top:14px; }
.pr-agr-projs-h{ font-size:11px; text-transform:uppercase; letter-spacing:.03em; color:var(--ink-soft); font-weight:650; margin-bottom:8px; }
.pr-projlist{ display:flex; flex-wrap:wrap; gap:6px; }
.pr-projchk{ display:inline-flex; align-items:center; gap:6px; font-size:12.5px; color:var(--ink-soft);
  background:var(--white); border:1px solid var(--bd); border-radius:100px; padding:5px 11px; cursor:pointer; user-select:none; }
.pr-projchk.on{ background:var(--accent-bg); border-color:transparent; color:var(--accent); font-weight:600; }
.pr-projchk input{ width:14px; height:14px; margin:0; accent-color:var(--accent); }
.pr-proj-on{ color:var(--ink-faint); font-size:11px; font-style:italic; }
.pr-agr-del{ color:#DC2626; margin-top:14px; }
.pr-rules-top{ display:flex; gap:16px; align-items:flex-start; justify-content:space-between; margin-bottom:18px; flex-wrap:wrap; }
.pr-rules-h{ font-size:16px; font-weight:700; color:var(--ink); }
.pr-rules-sub{ font-size:12.5px; color:var(--ink-soft); line-height:1.55; margin-top:4px; max-width:440px; }
.pr-rules-sub b, .pr-cba-note b{ color:var(--ink); font-weight:650; }
.pr-rmatrix{ width:100%; border-collapse:collapse; border:1px solid var(--bd); border-radius:var(--radius); overflow:hidden; }
.pr-rmatrix th{ background:var(--bg2); color:var(--ink-soft); font-size:11px; text-transform:uppercase; letter-spacing:.03em;
  font-weight:600; text-align:center; padding:9px 8px; border-bottom:1px solid var(--bd); }
.pr-rmatrix th:first-child{ text-align:left; }
.pr-rmatrix td{ padding:9px 8px; border-bottom:1px solid var(--bd); text-align:center; }
.pr-rmatrix tr:last-child td{ border-bottom:none; }
.pr-rlbl{ text-align:left !important; font-size:13.5px; font-weight:600; color:var(--ink); }
.pr-rin{ width:82px; border:1px solid var(--bd); border-radius:6px; padding:7px 9px; font-size:13px; text-align:center;
  background:var(--white); color:var(--ink); font-variant-numeric:tabular-nums; -moz-appearance:textfield; }
.pr-rin::-webkit-outer-spin-button, .pr-rin::-webkit-inner-spin-button{ -webkit-appearance:none; margin:0; }
.pr-rin:focus{ outline:none; border-color:var(--accent); box-shadow:0 0 0 2px var(--accent-bg); }
.pr-reg{ margin-top:14px; font-size:12px; color:var(--ink-soft); background:var(--bg2); border:1px solid var(--bd);
  border-radius:var(--radius); padding:10px 12px; line-height:1.7; }
.pr-reg b{ color:var(--ink); font-weight:700; }
.pr-cba-note{ margin-top:22px; font-size:12.5px; color:var(--ink-soft); background:var(--accent-bg); border:1px solid transparent;
  border-radius:var(--radius); padding:11px 13px; line-height:1.5; }
.pr-cba-note .ti{ color:var(--accent); margin-right:5px; }

/* ── Holiday calendar ──────────────────────────────────────── */
.pr-hol-h{ font-size:15px; font-weight:700; color:var(--ink); }
.pr-hol-sub{ font-size:12.5px; font-weight:400; color:var(--ink-soft); }
.pr-hol-note{ font-size:12.5px; color:var(--ink-soft); background:var(--accent-bg); border-radius:var(--radius);
  padding:9px 12px; margin-top:10px; line-height:1.5; }
.pr-hol-note .ti{ color:var(--accent); margin-right:4px; }
.pr-hol-note b{ color:var(--ink); font-weight:650; }
.pr-hollist{ display:flex; flex-direction:column; gap:5px; margin-top:12px; }
.pr-holrow{ display:flex; align-items:center; justify-content:space-between; gap:10px; padding:8px 12px;
  border:1px solid var(--bd); border-radius:var(--radius); background:var(--white); }
.pr-holdate{ font-size:13px; font-weight:650; color:var(--ink); font-variant-numeric:tabular-nums; }
.pr-holname{ font-size:12.5px; color:var(--ink-soft); margin-left:10px; }
.pr-hol-empty{ font-size:12.5px; color:var(--ink-faint); padding:8px 2px; }
.pr-hol-del{ color:var(--ink-faint); }
.pr-hol-del:hover{ color:#DC2626; }
.pr-hol-add{ display:flex; gap:8px; align-items:center; flex-wrap:wrap; margin-top:12px; }
.pr-hol-add .pr-input{ min-width:auto; }
.pr-hol-add #pr-hol-name{ flex:1; min-width:180px; }
.pr-hol-prefill{ display:flex; gap:8px; align-items:center; flex-wrap:wrap; margin-top:12px;
  padding-top:12px; border-top:1px dashed var(--bd); font-size:12.5px; color:var(--ink-soft); }
.pr-yr{ width:82px; min-width:0 !important; text-align:center; }
.pr-hol-note2{ font-size:11.5px; color:var(--ink-faint); }

/* ── Home local / CBA (traveler / portability) ─────────────── */
.pr-tbadge{ display:inline-block; font-size:10px; font-weight:800; text-transform:uppercase; letter-spacing:.04em;
  color:#B45309; background:#FEF3C7; border:1px solid #FDE68A; border-radius:20px; padding:1px 7px; vertical-align:middle; }
.pr-home{ display:block; font-size:11.5px; color:var(--ink-faint); margin-top:2px; }
.pr-home.trav{ color:#B45309; font-weight:600; }
.pr-home i{ font-size:12px; }
.pr-homebar{ display:flex; align-items:center; gap:14px; flex-wrap:wrap; margin-bottom:14px;
  padding:10px 14px; background:var(--bg2); border:1px solid var(--bd); border-radius:8px; font-size:13px; }
.pr-homebar > i{ font-size:17px; color:var(--ink-faint); }
.pr-homebar.trav{ background:#FEF3C7; border-color:#FDE68A; }
.pr-homebar.trav > i{ color:#B45309; }
.pr-hl{ color:var(--ink); } .pr-hl b{ color:var(--ink-soft); font-weight:600; }
.pr-htag{ margin-left:auto; font-size:12px; font-weight:700; color:#B45309; }

body[data-theme="blueprint"] .pr-rvtable .we{ background:rgba(255,255,255,.03); }
body[data-theme="blueprint"] .pr-tbadge, body[data-theme="blueprint"] .pr-homebar.trav{ color:#FBBF24; background:rgba(251,191,36,.12); border-color:rgba(251,191,36,.35); }
body[data-theme="blueprint"] .pr-home.trav, body[data-theme="blueprint"] .pr-homebar.trav > i, body[data-theme="blueprint"] .pr-htag{ color:#FBBF24; }