/* ─────────────────────────────────────────────────────────────────────
   field.css · field-app specific styles
   Layered on top of components.css from the boss app, so all shared
   primitives (.btn, .modal, .form, .field-group, etc.) work as-is.
   This file only defines:
   - Top navy band + bottom tab nav layout
   - Side menu (slide-in)
   - Worker picker (pre-auth full-screen)
   - Clock card (idle vs live)
   - Summary cards, recent rows, entries, reimbursements, day-off rows
   - Empty states, boot status
   ───────────────────────────────────────────────────────────────────── */

/* Body offset for the fixed top bar + bottom nav.
   We use safe-area-inset to handle iPhone home indicator. */
html, body { background: var(--bg); }
body {
  padding-top:    calc(64px + env(safe-area-inset-top, 0px));
  padding-bottom: calc(72px + env(safe-area-inset-bottom, 0px));
  min-height: 100vh;
}

/* ─── 1. Top navy band ───────────────────────────────────────────── */
.field-top {
  position: fixed;
  top: 0; left: 0; right: 0;
  z-index: 50;
  background: #08111F;
  color: var(--ink);
  padding: env(safe-area-inset-top, 0px) 16px 0;
  height: calc(64px + env(safe-area-inset-top, 0px));
  display: flex;
  align-items: center;
  justify-content: space-between;
  border-bottom: 1px solid rgba(255, 255, 255, 0.06);
  box-shadow: 0 1px 0 rgba(255, 255, 255, 0.04) inset,
              0 4px 18px rgba(0, 0, 0, 0.4);
}
.ft-mark {
  display: flex;
  align-items: center;
  gap: 12px;
  min-width: 0;
  flex: 1;
}
.ft-monogram {
  width: 38px; height: 38px;
  flex-shrink: 0;
  display: grid; place-items: center;
  font-family: var(--font-serif);
  font-style: italic;
  font-weight: 600;
  font-size: 18px;
  color: var(--gold);
  border: 1px solid var(--gold);
  border-radius: 50%;
  letter-spacing: 0.02em;
}
.ft-meta { min-width: 0; }
.ft-name {
  font-family: var(--font-serif);
  font-size: 18px;
  font-weight: 500;
  letter-spacing: var(--tracking-tight);
  color: var(--on-navy);
  line-height: 1.1;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.ft-name em {
  font-style: italic;
  color: var(--gold);
  font-weight: 500;
}
.ft-eyebrow {
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: var(--tracking-mono);
  color: var(--on-navy-dim);
  margin-top: 4px;
  text-transform: uppercase;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.ft-menu-btn {
  width: 44px; height: 44px;
  background: transparent;
  border: 1px solid var(--on-navy-border);
  border-radius: 8px;
  color: var(--on-navy);
  font-size: 22px;
  line-height: 1;
  cursor: pointer;
  flex-shrink: 0;
  margin-left: 12px;
  display: grid; place-items: center;
  transition: background 120ms ease, border-color 120ms ease;
}
.ft-menu-btn:active,
.ft-menu-btn:hover { background: var(--on-navy-bg); border-color: var(--gold); }

/* ─── 2. Main panel host ─────────────────────────────────────────── */
.field-main {
  max-width: 720px;
  margin: 0 auto;
  padding: 16px 16px 8px;
  display: block;
}

/* ─── 3. Bottom tab nav ──────────────────────────────────────────── */
.bottom-nav {
  position: fixed;
  bottom: 0; left: 0; right: 0;
  z-index: 50;
  background: #060B1A;
  border-top: 1px solid rgba(212, 184, 114, 0.18);
  padding: 6px 4px calc(6px + env(safe-area-inset-bottom, 0px));
  display: flex;
  justify-content: space-around;
  box-shadow: 0 -1px 0 rgba(255, 255, 255, 0.04) inset,
              0 -4px 14px rgba(0, 0, 0, 0.40);
}
.bn-tab {
  flex: 1;
  background: transparent;
  border: none;
  color: var(--on-navy-dim);
  font-family: var(--font-sans);
  font-size: var(--fs-xs);
  font-weight: 600;
  letter-spacing: 0.02em;
  padding: 8px 4px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
  border-radius: 8px;
  cursor: pointer;
  transition: color 120ms ease, background 120ms ease;
  min-width: 0;
}
.bn-tab .bn-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 24px;
  height: 24px;
  color: inherit;
}
.bn-tab.active {
  color: var(--gold);
  background: rgba(201, 165, 87, 0.08);
}
.bn-tab.active .bn-icon { color: var(--gold); }
.bn-tab:active { background: rgba(255, 255, 255, 0.04); }

/* ─── 4. Side menu (slide-in) ────────────────────────────────────── */
.side-menu {
  position: fixed;
  top: 0; right: 0;
  height: 100vh;
  width: min(280px, 80vw);
  background: var(--surface);
  border-left: 1px solid var(--border);
  z-index: 100;
  transform: translateX(100%);
  transition: transform 220ms cubic-bezier(0.4, 0, 0.2, 1);
  padding: calc(80px + env(safe-area-inset-top, 0px)) 0 24px;
  display: flex;
  flex-direction: column;
  box-shadow: -8px 0 24px rgba(0, 0, 0, 0.08);
}
.side-menu.open { transform: translateX(0); }
.side-menu-overlay {
  position: fixed;
  inset: 0;
  background: rgba(14, 22, 28, 0.40);
  z-index: 90;
  opacity: 0;
  pointer-events: none;
  transition: opacity 220ms ease;
}
.side-menu-overlay.visible {
  opacity: 1;
  pointer-events: auto;
}
.sm-item {
  display: block;
  width: 100%;
  text-align: left;
  background: transparent;
  border: none;
  padding: 16px 20px;
  font-family: var(--font-sans);
  font-size: 15px;
  font-weight: 500;
  color: var(--ink);
  cursor: pointer;
  transition: background 120ms ease, color 120ms ease;
}
.sm-item:active,
.sm-item:hover { background: var(--surf2); color: var(--gold-deep); }
.sm-divider {
  height: 1px;
  background: var(--border);
  margin: 8px 16px;
}
.sm-item--switch {
  color: var(--muted);
  font-size: 13px;
  margin-top: auto;
}

/* ─── 5. Worker picker (pre-auth) ────────────────────────────────── */
.pick-worker {
  max-width: 480px;
  margin: 0 auto;
  padding: 16px 4px 32px;
}
.pw-eyebrow {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: var(--tracking-mono-wide);
  color: var(--gold-deep);
  text-transform: uppercase;
  text-align: center;
  margin-bottom: 8px;
}
.pw-title {
  font-family: var(--font-serif);
  font-size: 32px;
  font-weight: 400;
  letter-spacing: var(--tracking-tight);
  color: var(--ink);
  -webkit-text-fill-color: var(--ink);
  margin: 0 0 8px;
  text-align: center;
  line-height: 1.05;
}
.pw-title em {
  font-style: italic;
  color: var(--gold-deep);
  -webkit-text-fill-color: var(--gold-deep);
  font-weight: 500;
}
.pw-sub {
  text-align: center;
  font-size: 13px;
  color: var(--muted);
  margin-bottom: 24px;
}
.pw-list {
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.pw-card {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 14px 16px;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 12px;
  cursor: pointer;
  text-align: left;
  font: inherit;
  color: var(--ink);
  -webkit-text-fill-color: var(--ink);
  transition: background 120ms ease, border-color 120ms ease, transform 120ms ease;
}
.pw-card:active {
  transform: scale(0.985);
  background: var(--surf2);
  border-color: var(--gold);
}
.pw-card:hover { border-color: var(--gold-soft); }
.pw-avatar {
  width: 44px; height: 44px;
  border-radius: 50%;
  background: var(--surf2);
  border: 1px solid var(--gold);
  color: var(--gold);
  -webkit-text-fill-color: var(--gold);
  font-family: var(--font-serif);
  font-style: italic;
  font-size: 16px;
  font-weight: 500;
  display: grid;
  place-items: center;
  flex-shrink: 0;
}
.pw-info { flex: 1; min-width: 0; }
.pw-name {
  font-family: var(--font-serif);
  font-size: 18px;
  font-weight: 500;
  color: var(--ink);
  -webkit-text-fill-color: var(--ink);
  letter-spacing: var(--tracking-tight);
  line-height: 1.2;
}
.pw-name em {
  font-style: italic;
  color: var(--gold-deep);
  -webkit-text-fill-color: var(--gold-deep);
  font-weight: 500;
}
.pw-rate {
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--muted);
  -webkit-text-fill-color: rgba(245, 239, 227, 0.55);
  letter-spacing: var(--tracking-mono-tight);
  margin-top: 2px;
}
.pw-arrow {
  font-size: 20px;
  color: var(--gold-deep);
  flex-shrink: 0;
}

.pick-empty {
  max-width: 360px;
  margin: 80px auto;
  text-align: center;
  padding: 0 16px;
}
.pe-mark {
  width: 56px; height: 56px;
  margin: 0 auto 16px;
  border: 1px solid var(--gold);
  border-radius: 50%;
  display: grid; place-items: center;
  font-family: var(--font-serif);
  font-style: italic;
  font-weight: 500;
  font-size: 22px;
  color: var(--gold-deep);
}
.pe-title {
  font-family: var(--font-serif);
  font-size: 22px;
  color: var(--ink);
  font-weight: 500;
  margin-bottom: 8px;
}
.pe-body { color: var(--muted); font-size: 14px; line-height: 1.45; }

/* ─── 6. Clock card ──────────────────────────────────────────────── */
.clock-card {
  border-radius: 16px;
  padding: 24px 20px 20px;
  text-align: center;
  margin-bottom: 16px;
  position: relative;
  overflow: hidden;
}
.clock-card.idle {
  background: var(--surface);
  border: 1px solid var(--border);
  box-shadow: 0 1px 0 rgba(255, 255, 255, 0.7) inset;
}
.clock-card.live {
  background:
    radial-gradient(120% 80% at 50% 0%,
      rgba(201, 165, 87, 0.10) 0%,
      transparent 60%),
    var(--accent);
  color: var(--on-navy);
  border: 1px solid rgba(0, 0, 0, 0.20);
  box-shadow: 0 12px 32px rgba(14, 27, 53, 0.25);
}
.cc-eyebrow {
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: var(--tracking-mono-wide);
  color: var(--muted);
  text-transform: uppercase;
  margin-bottom: 12px;
}
.cc-eyebrow.live {
  color: var(--gold);
}
.cc-status {
  font-family: var(--font-serif);
  font-size: 22px;
  font-weight: 500;
  color: var(--ink);
  letter-spacing: var(--tracking-tight);
  margin-bottom: 20px;
}
.cc-project {
  font-family: var(--font-serif);
  font-size: 18px;
  font-weight: 500;
  color: var(--on-navy);
  margin-bottom: 8px;
  letter-spacing: var(--tracking-tight);
}
.cc-timer {
  font-family: var(--font-serif);
  font-size: 56px;
  font-weight: 500;
  color: var(--gold);
  letter-spacing: -0.02em;
  line-height: 1;
  font-variant-numeric: tabular-nums;
  margin: 4px 0 6px;
  font-feature-settings: "tnum" 1;
}
.cc-since {
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--on-navy-dim);
  letter-spacing: var(--tracking-mono-tight);
  margin-bottom: 16px;
}
.cc-locked {
  background: var(--on-navy-bg-2);
  border: 1px dashed var(--on-navy-border);
  color: var(--on-navy);
  font-size: 12px;
  padding: 10px 12px;
  border-radius: 8px;
  margin: 0 4px 12px;
  line-height: 1.4;
}
.cc-action {
  width: 100%;
  border: none;
  border-radius: 12px;
  padding: 18px;
  font-family: var(--font-sans);
  font-size: 17px;
  font-weight: 600;
  letter-spacing: 0.01em;
  cursor: pointer;
  transition: transform 100ms ease, background 120ms ease, box-shadow 120ms ease;
  -webkit-tap-highlight-color: transparent;
}
.cc-action:active { transform: scale(0.98); }
.cc-action--in {
  background: var(--accent);
  color: var(--gold);
  box-shadow: 0 6px 18px rgba(14, 27, 53, 0.25);
}
.cc-action--in:active { background: var(--accent-2); }
.cc-action--out {
  background: var(--gold);
  color: var(--ink);
  box-shadow: 0 6px 18px rgba(201, 165, 87, 0.40);
}
.cc-action--out:active { background: var(--gold-soft); }
.cc-action.is-disabled {
  opacity: 0.45;
  cursor: not-allowed;
  box-shadow: none;
}
.cc-action.is-disabled:active { transform: none; }
.cc-foot {
  font-family: var(--font-mono);
  font-size: 12px;
  color: var(--muted);
  margin-top: 12px;
  letter-spacing: var(--tracking-mono-tight);
}

/* ─── 7. Summary (today / week) ──────────────────────────────────── */
.fld-summary-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
  margin-bottom: 16px;
}
.fld-summary {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 14px 14px 12px;
}
.fld-summary-row {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: 6px;
}
.fld-summary-row + .fld-summary-row {
  margin-top: 6px;
  padding-top: 6px;
  border-top: 1px dashed var(--border-soft);
}
.fs-lbl {
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: var(--tracking-mono-tight);
  color: var(--muted);
  text-transform: uppercase;
}
.fs-val {
  font-family: var(--font-serif);
  font-size: 20px;
  font-weight: 500;
  color: var(--ink);
  font-variant-numeric: tabular-nums;
  letter-spacing: var(--tracking-tight);
}
.fs-money {
  font-family: var(--font-mono);
  font-size: 13px;
  font-weight: 500;
  color: var(--gold-deep);
  letter-spacing: 0.01em;
}

/* ─── 8. Section eyebrow ─────────────────────────────────────────── */
.fld-section-eyebrow {
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: var(--tracking-mono-wide);
  color: var(--gold-deep);
  text-transform: uppercase;
  margin: 20px 4px 8px;
}

/* ─── 9. Recent rows ─────────────────────────────────────────────── */
.fld-recent {
  margin-top: 4px;
}
.fld-recent-row {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 10px 12px;
  margin-bottom: 8px;
}
.fld-recent-row.is-adjusted {
  border-left: 3px solid var(--gold);
}
.rr-top {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: 8px;
  margin-bottom: 4px;
}
.rr-proj {
  font-family: var(--font-serif);
  font-size: 15px;
  color: var(--ink);
  font-weight: 500;
  letter-spacing: var(--tracking-tight);
  flex: 1;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.rr-hrs {
  font-family: var(--font-serif);
  font-size: 17px;
  color: var(--ink);
  font-weight: 500;
  font-variant-numeric: tabular-nums;
}
.rr-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  font-family: var(--font-mono);
  font-size: 12px;
  color: var(--muted);
  letter-spacing: var(--tracking-mono-tight);
}
.rr-tag {
  color: var(--gold-deep);
  font-weight: 500;
}

/* ─── 10. Week summary + entries ─────────────────────────────────── */
.fld-week-summary {
  display: flex;
  align-items: baseline;
  gap: 10px;
  background: var(--gold-bg);
  border: 1px solid var(--gold);
  border-radius: 10px;
  padding: 8px 12px;
  margin: 4px 0 10px;
}
.fws-lbl {
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: var(--tracking-mono-tight);
  color: var(--gold-deep);
  text-transform: uppercase;
  flex: 1;
}
.fws-val {
  font-family: var(--font-serif);
  font-size: 18px;
  color: var(--ink);
  font-weight: 500;
  font-variant-numeric: tabular-nums;
}
.fws-money {
  font-family: var(--font-mono);
  font-size: 12px;
  color: var(--gold-deep);
  font-weight: 500;
}

.fld-entries { display: flex; flex-direction: column; gap: 8px; }

.fld-entry-row {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 10px 12px;
  position: relative;
}
.fld-entry-row.is-adjusted { border-left: 3px solid var(--gold); }
.fld-entry-row.is-live {
  border-left: 3px solid var(--green);
  background: var(--green-soft);
}
.fer-top {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: 8px;
  margin-bottom: 4px;
}
.fer-proj {
  font-family: var(--font-serif);
  font-size: 15px;
  font-weight: 500;
  letter-spacing: var(--tracking-tight);
  color: var(--ink);
  flex: 1;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.fer-hrs {
  font-family: var(--font-serif);
  font-size: 17px;
  color: var(--ink);
  font-weight: 500;
  font-variant-numeric: tabular-nums;
}
.fer-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  font-family: var(--font-mono);
  font-size: 12px;
  color: var(--muted);
  letter-spacing: var(--tracking-mono-tight);
}
.fer-tag {
  color: var(--gold-deep);
  font-weight: 500;
}
.fer-tag--live {
  color: var(--green);
  font-weight: 600;
}
.fer-was {
  font-family: var(--font-mono);
  font-size: 12px;
  color: var(--muted);
  margin-top: 4px;
  font-style: italic;
}

/* ─── 11. Reimbursement rows ────────────────────────────────────── */
.fld-reimb-row {
  display: flex;
  gap: 12px;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 10px;
  margin-bottom: 8px;
  align-items: stretch;
}
.frr-thumb {
  width: 64px; height: 64px;
  flex-shrink: 0;
  border-radius: 8px;
  object-fit: cover;
  background: var(--surf2);
  border: 1px solid var(--border);
}
.frr-thumb--blank {
  display: grid; place-items: center;
  font-family: var(--font-mono);
  font-size: 12px;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: var(--tracking-mono-tight);
  white-space: pre-line;
  text-align: center;
  line-height: 1.2;
}
.frr-body { flex: 1; min-width: 0; display: flex; flex-direction: column; gap: 4px; }
.frr-top {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 8px;
}
.frr-amount {
  font-family: var(--font-serif);
  font-size: 18px;
  font-weight: 500;
  color: var(--ink);
  font-variant-numeric: tabular-nums;
  letter-spacing: var(--tracking-tight);
}
.frr-pill {
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: var(--tracking-mono-tight);
  text-transform: uppercase;
  padding: 3px 8px;
  border-radius: 999px;
  font-weight: 500;
  white-space: nowrap;
}
.frr-pill--pending  { background: var(--blue-soft);  color: var(--blue);     border: 1px solid var(--blue-line); }
.frr-pill--approved { background: var(--green-soft); color: var(--green);    border: 1px solid var(--green-line); }
.frr-pill--paid     { background: var(--gold-bg-2);  color: var(--gold-deep); border: 1px solid var(--gold); }
.frr-pill--denied,
.frr-pill--rejected { background: var(--red-soft);   color: var(--red);      border: 1px solid var(--red-line); }
.frr-pill--draft    { background: var(--surf2);      color: var(--muted);    border: 1px solid var(--border); }
.frr-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  font-family: var(--font-mono);
  font-size: 12px;
  color: var(--muted);
  letter-spacing: var(--tracking-mono-tight);
}
.frr-tag {
  background: var(--surf2);
  border: 1px solid var(--border);
  border-radius: 4px;
  padding: 1px 6px;
  color: var(--ink);
  text-transform: capitalize;
}
.frr-desc {
  font-size: 12px;
  color: var(--ink);
  line-height: 1.4;
  margin-top: 2px;
}

/* ─── 12. Day-off rows ──────────────────────────────────────────── */
.fld-dayoff-row {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 12px;
  margin-bottom: 8px;
}
.fdo-top {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 8px;
  margin-bottom: 6px;
}
.fdo-range {
  font-family: var(--font-serif);
  font-size: 15px;
  font-weight: 500;
  color: var(--ink);
  letter-spacing: var(--tracking-tight);
}
.fdo-reason {
  font-size: 13px;
  color: var(--ink);
  line-height: 1.4;
  margin-bottom: 6px;
  padding: 6px 10px;
  background: var(--surf2);
  border-left: 2px solid var(--gold-soft);
  border-radius: 4px;
}
.fdo-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  font-family: var(--font-mono);
  font-size: 12px;
  color: var(--muted);
  letter-spacing: var(--tracking-mono-tight);
}

/* ─── 13. Panel head + empty state ──────────────────────────────── */
.panel-head {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: 12px;
  margin: 4px 4px 16px;
}
.panel-head h2 {
  font-family: var(--font-serif);
  font-size: 24px;
  font-weight: 500;
  color: var(--ink);
  margin: 0;
  letter-spacing: var(--tracking-tight);
}
.panel-head h2 em {
  font-style: italic;
  color: var(--gold-deep);
  font-weight: 500;
}
.btn-small {
  padding: 6px 12px;
  font-size: 12px;
  font-weight: 500;
}
.empty-block {
  margin: 32px auto;
  max-width: 360px;
  text-align: center;
  padding: 24px 16px;
  background: var(--surface);
  border: 1px dashed var(--border);
  border-radius: 12px;
}
.eb-title {
  font-family: var(--font-serif);
  font-size: 18px;
  font-weight: 500;
  color: var(--ink);
  margin-bottom: 6px;
}
.eb-body {
  color: var(--muted);
  font-size: 13px;
  line-height: 1.5;
}

/* ─── 14. Boot status ───────────────────────────────────────────── */
.boot-status {
  margin: 80px auto;
  max-width: 320px;
  text-align: center;
}
.bs-mark {
  width: 48px; height: 48px;
  margin: 0 auto 16px;
  border: 1px solid var(--gold);
  border-radius: 50%;
  display: grid; place-items: center;
  font-family: var(--font-serif);
  font-style: italic;
  color: var(--gold-deep);
  font-size: 20px;
  font-weight: 500;
  animation: bs-pulse 1.4s ease-in-out infinite;
}
@keyframes bs-pulse {
  0%, 100% { opacity: 1; }
  50%      { opacity: 0.45; }
}
.bs-msg {
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--muted);
  letter-spacing: var(--tracking-mono-tight);
  text-transform: uppercase;
}

/* ─── 15. Mobile breakpoint adjustments ─────────────────────────── */
@media (max-width: 380px) {
  .fld-summary-grid { grid-template-columns: 1fr; }
  .cc-timer { font-size: 48px; }
  .pw-title { font-size: 26px; }
}

/* ═════════════════════════════════════════════════════════════════════
   16. PIN entry screen (setup + verify)
   Full-screen layout. Reuses the navy band header but takes over the
   main content area.
   ═════════════════════════════════════════════════════════════════════ */
.pin-screen {
  min-height: calc(100vh - 64px - env(safe-area-inset-top, 0px));
  padding: 24px 20px calc(40px + env(safe-area-inset-bottom, 0px));
  display: flex;
  flex-direction: column;
  align-items: center;
  background: var(--bg);
}
.pin-eyebrow {
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: var(--tracking-mono);
  color: var(--muted);
  text-transform: uppercase;
  margin-bottom: 12px;
}
.pin-name {
  font-family: var(--font-serif);
  font-size: 22px;
  font-weight: 500;
  letter-spacing: var(--tracking-tight);
  color: var(--ink);
  margin-bottom: 24px;
  text-align: center;
}
.pin-name em {
  font-style: italic;
  color: var(--gold-deep);
}
.pin-title {
  font-family: var(--font-serif);
  font-size: 28px;
  font-weight: 500;
  color: var(--ink);
  letter-spacing: var(--tracking-tight);
  margin-bottom: 6px;
  text-align: center;
}
.pin-sub {
  font-family: var(--font-sans);
  font-size: 13px;
  color: var(--muted);
  line-height: 1.4;
  margin-bottom: 28px;
  max-width: 320px;
  text-align: center;
}

.pin-dots {
  display: flex;
  gap: 16px;
  margin-bottom: 12px;
}
.pin-dot {
  width: 14px; height: 14px;
  border-radius: 50%;
  border: 1.5px solid var(--gold-deep);
  background: transparent;
  transition: background 120ms ease, transform 120ms ease;
}
.pin-dot.filled {
  background: var(--gold-deep);
  transform: scale(1.05);
}

.pin-error {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: var(--tracking-mono-tight);
  color: var(--red);
  text-transform: uppercase;
  margin-bottom: 18px;
  min-height: 16px;
  text-align: center;
}
.pin-error--ghost {
  color: transparent;
}

.pin-keypad {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
  width: min(320px, 100%);
}
.pin-key {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  font-family: var(--font-serif);
  font-weight: 400;
  font-size: 28px;
  color: var(--ink);
  height: 64px;
  display: grid;
  place-items: center;
  cursor: pointer;
  transition: background 120ms ease, transform 80ms ease;
  -webkit-tap-highlight-color: transparent;
}
.pin-key:active {
  background: var(--surf2);
  transform: scale(0.97);
}
.pin-key:disabled {
  opacity: 0.5;
  pointer-events: none;
}
.pin-key--side {
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: var(--tracking-mono-tight);
  text-transform: uppercase;
  color: var(--muted);
}

/* ─── Clock-in project cards ──────────────────────────────────── */
.cl-body { display: flex; flex-direction: column; gap: var(--sp-3); }
.cl-eyebrow {
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: var(--tracking-mono);
  text-transform: uppercase;
  color: var(--muted);
}
.cl-cards { display: flex; flex-direction: column; gap: var(--sp-3); }
.cl-proj-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  padding: var(--sp-3);
  cursor: pointer;
  transition: background 160ms ease, border-color 160ms ease, box-shadow 160ms ease, transform 160ms var(--ease-out-expo);
  display: flex;
  flex-direction: column;
  gap: var(--sp-2);
}
.cl-proj-card:hover {
  border-color: var(--gold-deep);
  transform: translateY(-1px);
}
.cl-proj-card.is-selected {
  border-color: var(--gold);
  background: var(--gold-bg);
  box-shadow: 0 0 0 2px rgba(201, 165, 87, 0.20);
}
.cl-proj-head {
  display: flex;
  align-items: center;
  gap: var(--sp-3);
}
.cl-proj-radio {
  width: 18px; height: 18px;
  border-radius: 50%;
  border: 2px solid var(--border);
  flex-shrink: 0;
  position: relative;
  transition: border-color 140ms ease;
}
.cl-proj-card.is-selected .cl-proj-radio {
  border-color: var(--gold);
}
.cl-proj-card.is-selected .cl-proj-radio::after {
  content: '';
  position: absolute;
  top: 50%; left: 50%;
  transform: translate(-50%, -50%);
  width: 8px; height: 8px;
  border-radius: 50%;
  background: var(--gold);
}
.cl-proj-name {
  font-family: var(--font-serif);
  font-weight: 500;
  font-size: 19px;
  letter-spacing: var(--tracking-tight);
  color: var(--ink);
  flex: 1;
  min-width: 0;
}
.cl-proj-addr {
  display: flex;
  align-items: center;
  gap: var(--sp-2);
  padding: var(--sp-2) var(--sp-3);
  background: var(--surf2);
  border: 1px solid var(--border-soft);
  border-radius: var(--r);
  text-decoration: none;
  color: var(--ink);
  transition: background 140ms ease;
}
.cl-proj-addr:hover {
  background: var(--gold-bg);
  border-color: var(--gold-deep);
}
.cl-proj-addr-text {
  flex: 1;
  font-family: var(--font-sans);
  font-size: 14px;
  line-height: 1.35;
}
.cl-proj-addr-go {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: var(--tracking-mono);
  color: var(--gold-deep);
  text-transform: uppercase;
  font-weight: 600;
  white-space: nowrap;
}
.cl-icon {
  color: var(--gold-deep);
  flex-shrink: 0;
}
.cl-proj-addr-missing {
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--muted);
  letter-spacing: 0.05em;
  font-style: italic;
}
.cl-proj-owner {
  display: flex;
  align-items: baseline;
  gap: var(--sp-3);
  flex-wrap: wrap;
  padding-top: var(--sp-2);
  border-top: 1px dashed var(--border-soft);
}
.cl-owner-label {
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: var(--tracking-mono);
  text-transform: uppercase;
  color: var(--muted);
  flex-shrink: 0;
}
.cl-owner-name {
  font-family: var(--font-serif);
  font-size: 14px;
  color: var(--ink);
  flex: 1;
  min-width: 0;
}
.cl-owner-phone {
  font-family: var(--font-mono);
  font-size: 13px;
  color: var(--gold-deep);
  text-decoration: none;
  letter-spacing: 0.02em;
  white-space: nowrap;
}
.cl-owner-phone:hover { text-decoration: underline; }

/* ─── Home · Job sites preview ────────────────────────────────── */
.fld-jobsites {
  margin: var(--sp-4) 0;
}
.fld-jobsites-list {
  display: flex;
  flex-direction: column;
  gap: var(--sp-3);
  margin-top: var(--sp-3);
}
.js-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  padding: var(--sp-3);
  display: flex;
  flex-direction: column;
  gap: var(--sp-2);
  cursor: pointer;
  transition: background 160ms ease, border-color 160ms ease, transform 160ms var(--ease-out-expo);
}
.js-card:hover, .js-card:active {
  border-color: var(--gold);
  background: var(--gold-bg);
  transform: translateY(-1px);
}
.js-card-head {
  display: flex;
  align-items: baseline;
  gap: var(--sp-3);
}
.js-card-name {
  flex: 1;
  font-family: var(--font-serif);
  font-weight: 500;
  font-size: 18px;
  letter-spacing: var(--tracking-tight);
  color: var(--ink);
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.js-card-clockin {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: var(--tracking-mono);
  color: var(--gold-deep);
  text-transform: uppercase;
  font-weight: 600;
  white-space: nowrap;
  flex-shrink: 0;
}
.js-card-addr {
  display: flex;
  align-items: center;
  gap: var(--sp-2);
  padding: 8px var(--sp-2);
  background: var(--surf2);
  border: 1px solid var(--border-soft);
  border-radius: var(--r);
  text-decoration: none;
  color: var(--ink);
  font-family: var(--font-sans);
  font-size: 13px;
  line-height: 1.35;
  transition: background 140ms ease;
}
.js-card-addr:hover { background: var(--gold-bg); }
.js-card-addr-text { flex: 1; min-width: 0; }
.js-card-addr-go {
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: var(--tracking-mono);
  color: var(--gold-deep);
  text-transform: uppercase;
  font-weight: 600;
  white-space: nowrap;
  flex-shrink: 0;
}
.js-icon { color: var(--gold-deep); flex-shrink: 0; }
.js-card-addr-missing {
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--muted);
  font-style: italic;
}
.js-card-owner {
  display: flex;
  align-items: baseline;
  gap: var(--sp-3);
  flex-wrap: wrap;
  padding-top: 4px;
  border-top: 1px dashed var(--border-soft);
  font-size: 12px;
}
.js-owner-name {
  font-family: var(--font-serif);
  color: var(--ink);
  flex: 1;
  min-width: 0;
}
.js-owner-phone {
  font-family: var(--font-mono);
  color: var(--gold-deep);
  text-decoration: none;
  font-size: 12px;
  letter-spacing: 0.02em;
  white-space: nowrap;
}
.js-owner-phone:hover { text-decoration: underline; }

/* ════════════════════════════════════════════════════════════════
   FIELD HOME · redesigned dashboard
   ════════════════════════════════════════════════════════════════ */

/* ─── Greeting row ──────────────────────────────────────────────── */
.fh-greet-row {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: var(--sp-3);
  margin: var(--sp-3) 0 var(--sp-4) 0;
}
.fh-greet-hello {
  font-family: var(--font-serif);
  font-weight: 600;
  font-size: 32px;
  line-height: 1.1;
  color: var(--ink);
  letter-spacing: var(--tracking-tight);
}
.fh-greet-date {
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: 0.04em;
  color: var(--muted);
  margin-top: 4px;
}
.fh-signout {
  background: transparent;
  border: 1px solid var(--border);
  color: var(--ink);
  font-family: var(--font-sans);
  font-size: 13px;
  padding: 8px 16px;
  border-radius: var(--r);
  cursor: pointer;
  flex-shrink: 0;
  transition: border-color 140ms ease, background 140ms ease;
}
.fh-signout:hover {
  border-color: var(--gold);
  background: var(--gold-bg);
}

/* ─── Stats row ─────────────────────────────────────────────────── */
.fh-stats-row {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--sp-2);
  margin-bottom: var(--sp-4);
}
.fh-stat {
  background: var(--surface);
  border: 1px solid var(--border-soft);
  border-radius: var(--r);
  padding: var(--sp-3);
  display: flex;
  flex-direction: column;
  gap: 6px;
  min-height: 88px;
}
.fh-stat-label {
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: var(--tracking-mono);
  text-transform: uppercase;
  color: var(--muted);
}
.fh-stat-value {
  font-family: var(--font-mono);
  font-size: 18px;
  font-weight: 500;
  color: var(--gold-deep);
  letter-spacing: 0.02em;
  font-variant-numeric: tabular-nums;
  margin-top: auto;
}

/* ─── Active card (on shift) ────────────────────────────────────── */
.fh-active {
  background: var(--surface);
  border: 1.5px solid var(--green);
  border-radius: var(--r-lg);
  padding: var(--sp-4);
  margin-bottom: var(--sp-5);
  box-shadow: 0 0 0 4px var(--green-soft);
}
.fh-active-head {
  display: flex;
  align-items: center;
  gap: var(--sp-2);
  margin-bottom: var(--sp-2);
}
.fh-active-dot {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: var(--green);
  flex-shrink: 0;
  animation: pulse 2.6s ease-in-out infinite;
}
@keyframes pulse {
  0%, 100% { opacity: 1;   transform: scale(1); }
  50%      { opacity: 0.7; transform: scale(0.92); }
}
.fh-active-title {
  font-family: var(--font-mono);
  font-weight: 600;
  font-size: 14px;
  letter-spacing: 0.04em;
  color: var(--green);
  text-transform: uppercase;
}
.fh-active-on {
  font-family: var(--font-sans);
  font-weight: 400;
  text-transform: none;
  letter-spacing: 0;
}
.fh-active-since {
  font-family: var(--font-mono);
  font-size: 12px;
  color: var(--muted);
  margin-bottom: 8px;
  letter-spacing: 0.04em;
}
.fh-active-timer {
  font-family: var(--font-mono);
  font-weight: 500;
  font-size: 44px;
  color: var(--green);
  letter-spacing: 0.04em;
  font-variant-numeric: tabular-nums;
  line-height: 1;
}

/* ─── Section eyebrow ───────────────────────────────────────────── */
.fh-section-eyebrow {
  display: flex;
  align-items: center;
  gap: var(--sp-3);
  margin-bottom: var(--sp-3);
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: var(--tracking-mono);
  text-transform: uppercase;
  color: var(--muted);
}
.fh-rule {
  flex: 1;
  height: 1px;
  background: var(--border-soft);
}

/* ─── Project card ──────────────────────────────────────────────── */
.fh-proj-list {
  display: flex;
  flex-direction: column;
  gap: var(--sp-3);
}
.fh-pcard {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  padding: var(--sp-4);
  display: flex;
  flex-direction: column;
  gap: var(--sp-3);
  transition: border-color 200ms ease;
}
.fh-pcard.is-active {
  border-color: var(--green);
  box-shadow: 0 0 0 3px var(--green-soft);
}
.fh-pcard-info {
  display: flex;
  flex-direction: column;
  gap: var(--sp-2);
}
.fh-pcard-head {
  display: flex;
  align-items: center;
  gap: var(--sp-3);
  min-width: 0;
}
.fh-pcard-num {
  width: 32px;
  height: 32px;
  border-radius: var(--r);
  background: var(--surf2);
  border: 1px solid var(--border-soft);
  display: grid;
  place-items: center;
  font-family: var(--font-mono);
  font-weight: 600;
  font-size: var(--fs-sm);
  color: var(--muted);
  flex-shrink: 0;
}
.fh-pcard.is-active .fh-pcard-num {
  border-color: var(--green);
  color: var(--green);
}
.fh-pcard-name {
  flex: 1;
  font-family: var(--font-serif);
  font-weight: 600;
  font-size: var(--fs-lg);
  color: var(--ink);
  letter-spacing: var(--tracking-tight);
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.fh-pcard-pill {
  font-family: var(--font-mono);
  font-size: var(--fs-xs);
  letter-spacing: var(--tracking-mono);
  text-transform: uppercase;
  color: var(--green);
  border: 1px solid var(--green);
  border-radius: 99px;
  padding: 4px 10px;
  font-weight: 600;
  flex-shrink: 0;
}
/* Compact metadata strip: owner · address · ... */
.fh-pcard-meta {
  font-family: var(--font-sans);
  font-size: var(--fs-sm);
  color: var(--muted);
  line-height: 1.4;
  padding-left: 44px; /* aligns with name, past the number badge */
  overflow: hidden;
  text-overflow: ellipsis;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
}
.fh-pcard-details {
  align-self: flex-start;
  background: transparent;
  border: none;
  font-family: var(--font-sans);
  font-size: var(--fs-xs);
  font-weight: 500;
  color: var(--gold-deep);
  letter-spacing: 0.02em;
  cursor: pointer;
  padding: 4px 0;
  margin-left: 44px;
  text-align: left;
}
.fh-pcard-details:hover { text-decoration: underline; }

.fh-pcard-details-block {
  display: flex;
  flex-direction: column;
  gap: var(--sp-2);
  padding: var(--sp-3);
  background: var(--surf2);
  border-radius: var(--r);
  border-left: 3px solid var(--gold);
}
.fh-detail-row, .fh-detail-link {
  display: flex;
  flex-direction: column;
  gap: 2px;
  text-decoration: none;
  color: var(--ink);
}
.fh-detail-link { cursor: pointer; }
.fh-detail-label {
  font-family: var(--font-mono);
  font-size: var(--fs-xs);
  letter-spacing: var(--tracking-mono);
  text-transform: uppercase;
  color: var(--muted);
}
.fh-detail-value {
  font-family: var(--font-sans);
  font-size: var(--fs-sm);
  color: var(--ink);
  line-height: 1.4;
}
.fh-detail-arrow {
  font-family: var(--font-mono);
  font-size: var(--fs-xs);
  color: var(--gold-deep);
  letter-spacing: 0.02em;
  margin-top: 2px;
}
.fh-detail-notes {
  font-family: var(--font-sans);
  font-size: var(--fs-sm);
  color: var(--ink);
  line-height: 1.5;
  white-space: pre-wrap;
  padding-top: var(--sp-2);
  border-top: 1px dashed var(--border-soft);
  margin-top: var(--sp-2);
}

/* ─── Clock-in / clock-out button (dominant, per-card) ──────────── */
.fh-clock-btn {
  width: 100%;
  padding: 22px 16px;
  min-height: 64px;
  border-radius: var(--r);
  border: none;
  font-family: var(--font-sans);
  font-weight: 700;
  font-size: var(--fs-md);
  letter-spacing: 0.10em;
  text-transform: uppercase;
  cursor: pointer;
  transition: filter 160ms ease, transform 100ms ease;
  background: linear-gradient(180deg, var(--green) 0%, #15583A 100%);
  color: #FFFFFF;
  box-shadow: 0 2px 6px rgba(31, 107, 67, 0.30);
}
.fh-clock-btn:hover { filter: brightness(1.05); }
.fh-clock-btn:active { transform: scale(0.99); }
.fh-clock-btn--out {
  background: linear-gradient(180deg, #B83B32 0%, #8E2620 100%);
  box-shadow: 0 2px 6px rgba(155, 45, 36, 0.30);
}
.fh-clock-btn.is-disabled {
  background: var(--surf2);
  color: var(--muted);
  cursor: not-allowed;
  opacity: 0.55;
  box-shadow: none;
}
.fh-clock-btn.is-disabled:hover { filter: none; }

/* ─── Empty state ───────────────────────────────────────────────── */
.fh-empty-card {
  background: var(--surface);
  border: 1px dashed var(--border);
  border-radius: var(--r-lg);
  padding: var(--sp-5) var(--sp-4);
  text-align: center;
}
.fh-empty-title {
  font-family: var(--font-serif);
  font-size: 18px;
  color: var(--ink);
  margin-bottom: var(--sp-2);
}
.fh-empty-sub {
  font-family: var(--font-sans);
  font-size: 13px;
  color: var(--muted);
  line-height: 1.5;
  max-width: 320px;
  margin: 0 auto;
}

/* ════════════════════════════════════════════════════════════════
   PROFILE PANEL
   ════════════════════════════════════════════════════════════════ */
.pf-worker {
  display: flex;
  align-items: center;
  gap: var(--sp-3);
  padding: var(--sp-4);
  background: var(--surface);
  border: 1px solid var(--gold);
  border-radius: var(--r-lg);
  margin-bottom: var(--sp-4);
}
.pf-avatar {
  width: 56px;
  height: 56px;
  border-radius: 50%;
  background: var(--accent);
  border: 2px solid var(--gold);
  color: var(--gold);
  font-family: var(--font-serif);
  font-weight: 600;
  font-size: 22px;
  display: grid;
  place-items: center;
  flex-shrink: 0;
}
.pf-worker-info { flex: 1; min-width: 0; }
.pf-worker-name {
  font-family: var(--font-serif);
  font-weight: 500;
  font-size: 22px;
  color: var(--ink);
  letter-spacing: var(--tracking-tight);
}
.pf-worker-rate {
  font-family: var(--font-mono);
  font-size: 12px;
  color: var(--gold-deep);
  letter-spacing: 0.04em;
  margin-top: 4px;
}

.pf-stats {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--sp-2);
  margin-bottom: var(--sp-4);
}
.pf-stat {
  background: var(--surface);
  border: 1px solid var(--border-soft);
  border-radius: var(--r);
  padding: var(--sp-3);
}
.pf-stat-label {
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: var(--tracking-mono);
  text-transform: uppercase;
  color: var(--muted);
  margin-bottom: 6px;
}
.pf-stat-value {
  font-family: var(--font-mono);
  font-size: 20px;
  font-weight: 500;
  color: var(--ink);
  font-variant-numeric: tabular-nums;
}
.pf-stat-money {
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--gold-deep);
  margin-top: 2px;
  letter-spacing: 0.02em;
}

.pf-action {
  width: 100%;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r);
  padding: var(--sp-3) var(--sp-4);
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 4px;
  cursor: pointer;
  transition: border-color 140ms ease, background 140ms ease, transform 140ms var(--ease-out-expo);
  margin-bottom: var(--sp-3);
  font-family: var(--font-sans);
  text-align: left;
}
.pf-action:hover { border-color: var(--gold); transform: translateY(-1px); }
.pf-action-label {
  font-family: var(--font-serif);
  font-size: 16px;
  color: var(--ink);
  font-weight: 500;
}
.pf-action-sub {
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: var(--tracking-mono);
  color: var(--muted);
  text-transform: uppercase;
}
.pf-action--primary {
  background: var(--gold-bg);
  border-color: var(--gold);
}
.pf-action--danger {
  margin-top: var(--sp-4);
  text-align: center;
  align-items: center;
  color: var(--red);
  border-color: var(--border);
  font-family: var(--font-mono);
  font-size: 13px;
  letter-spacing: var(--tracking-mono);
  text-transform: uppercase;
}
.pf-action--danger:hover { border-color: var(--red); background: rgba(168, 52, 43, 0.06); }

/* ─── Profile · sections ──────────────────────────────────────── */
.pf-section {
  background: var(--surface);
  border: 1px solid var(--border-soft);
  border-radius: var(--r-lg);
  padding: var(--sp-3);
  margin-bottom: var(--sp-3);
}
.pf-section-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: var(--sp-3);
}
.pf-section-title {
  font-family: var(--font-serif);
  font-weight: 500;
  font-size: 16px;
  color: var(--ink);
}
.pf-section-add {
  background: transparent;
  border: 1px solid var(--gold);
  color: var(--gold-deep);
  font-family: var(--font-mono);
  font-size: 11px;
  padding: 6px 12px;
  border-radius: var(--r-sm);
  cursor: pointer;
  letter-spacing: 0.04em;
}
.pf-section-add:hover { background: var(--gold-bg); }
.pf-empty {
  font-family: var(--font-sans);
  font-size: 13px;
  color: var(--muted);
  text-align: center;
  padding: var(--sp-3) 0;
  font-style: italic;
}
.pf-doff-list { display: flex; flex-direction: column; gap: 6px; }
.pf-doff-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 8px 12px;
  background: var(--surf2);
  border-radius: var(--r-sm);
  font-size: 13px;
}
.pf-doff-dates {
  font-family: var(--font-mono);
  font-size: 12px;
  color: var(--ink);
}
.pf-doff-status {
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: var(--tracking-mono);
  text-transform: uppercase;
  padding: 4px 10px;
  border-radius: 99px;
  font-weight: 600;
}
.pf-doff-status--pending  { background: var(--gold-bg); color: var(--gold-deep); }
.pf-doff-status--approved { background: var(--green-soft); color: var(--green); }
.pf-doff-status--denied   { background: var(--red-soft); color: var(--red); }

/* ─── Print picker (modal) ────────────────────────────────────── */
.pf-print-picker {
  display: flex;
  flex-direction: column;
  gap: var(--sp-2);
}
.pf-print-eyebrow {
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: var(--tracking-mono);
  text-transform: uppercase;
  color: var(--muted);
  margin-bottom: var(--sp-2);
}
.pf-print-opt {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r);
  padding: var(--sp-3);
  cursor: pointer;
  text-align: left;
  display: flex;
  flex-direction: column;
  gap: 4px;
  transition: border-color 140ms ease, background 140ms ease, transform 140ms var(--ease-out-expo);
}
.pf-print-opt:hover {
  border-color: var(--gold);
  background: var(--gold-bg);
  transform: translateY(-1px);
}
.pf-print-opt-title {
  font-family: var(--font-serif);
  font-weight: 500;
  font-size: 16px;
  color: var(--ink);
}
.pf-print-opt-sub {
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--muted);
  letter-spacing: 0.04em;
}

/* ─── Job description block (worker-facing) ───────────────────── */
.fh-detail-jobdesc {
  display: flex;
  flex-direction: column;
  gap: 6px;
  padding: var(--sp-3);
  background: var(--gold-bg-2);
  border-left: 3px solid var(--gold);
  border-radius: 0 var(--r-sm) var(--r-sm) 0;
  margin-bottom: var(--sp-2);
}
.fh-detail-jobdesc-text {
  font-family: var(--font-sans);
  font-size: 14px;
  color: var(--ink);
  line-height: 1.55;
  white-space: pre-wrap;
  word-break: break-word;
}

/* ─── Branded dialog (alert/confirm replacement) ───────────────── */
.dialog-overlay {
  position: fixed;
  inset: 0;
  z-index: 200;
  background: rgba(14, 27, 53, 0.55);
  -webkit-backdrop-filter: blur(6px);
  backdrop-filter: blur(6px);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--sp-4);
  opacity: 0;
  pointer-events: none;
  transition: opacity 200ms ease;
}
.dialog-overlay.open {
  opacity: 1;
  pointer-events: auto;
}

.dialog {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  padding: var(--sp-5);
  max-width: 380px;
  width: 100%;
  box-shadow:
    0 20px 50px -8px rgba(0, 0, 0, 0.45),
    0 0 0 1px rgba(201, 165, 87, 0.20);
  transform: translateY(8px) scale(0.98);
  transition: transform 220ms cubic-bezier(0.16, 1, 0.3, 1);
}
.dialog-overlay.open .dialog {
  transform: translateY(0) scale(1);
}

.dialog--success { border-color: var(--green-line); }
.dialog--warning { border-color: var(--gold); }
.dialog--danger  { border-color: var(--red-line); }

.dialog-title {
  font-family: var(--font-serif);
  font-weight: 500;
  font-size: 19px;
  color: var(--ink);
  letter-spacing: var(--tracking-tight);
  margin-bottom: var(--sp-3);
  line-height: 1.3;
}

.dialog-message {
  font-family: var(--font-sans);
  font-size: 14px;
  color: var(--ink);
  line-height: 1.55;
  margin-bottom: var(--sp-5);
  word-break: break-word;
}
.dialog-message p {
  margin: 0 0 var(--sp-3) 0;
}
.dialog-message p:last-child {
  margin-bottom: 0;
}

.dialog-buttons {
  display: flex;
  gap: var(--sp-2);
  justify-content: flex-end;
  flex-wrap: wrap;
}

.dialog-btn {
  background: transparent;
  border: 1px solid var(--border);
  color: var(--ink);
  padding: 10px 18px;
  border-radius: var(--r);
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: var(--tracking-mono-tight);
  text-transform: uppercase;
  font-weight: 600;
  cursor: pointer;
  transition: background 140ms ease, border-color 140ms ease, transform 80ms ease;
  min-width: 92px;
}
.dialog-btn:hover {
  border-color: var(--gold);
  background: var(--gold-bg);
}
.dialog-btn:active {
  transform: scale(0.97);
}

.dialog-btn--primary {
  background: var(--gold);
  border-color: var(--gold);
  color: var(--accent);
}
.dialog-btn--primary:hover {
  background: var(--gold-deep);
  border-color: var(--gold-deep);
  color: var(--accent);
}

.dialog-btn--danger {
  background: var(--red);
  border-color: var(--red);
  color: #FFFFFF;
}
.dialog-btn--danger:hover {
  background: var(--red);
  border-color: var(--red);
  filter: brightness(1.08);
  color: #FFFFFF;
}

@media (max-width: 380px) {
  .dialog {
    padding: var(--sp-4);
  }
  .dialog-buttons {
    flex-direction: column-reverse;
  }
  .dialog-btn {
    width: 100%;
  }
}


/* ── Design polish pass (aesthetic only) ─────────────────────────
   Touch-first: taps shouldn't leave cards stuck in lifted hover
   state; presses get immediate feedback instead.                  */
@media (hover: none) {
  .cl-proj-card:hover,
  .pf-action:hover,
  .pf-print-opt:hover,
  .js-card:hover { transform: none; }
}
.cl-proj-card:active { transform: scale(0.99); }
.pf-action:active,
.pf-print-opt:active { transform: scale(0.98); }

@media (prefers-reduced-motion: reduce) {
  .bn-tab, .cc-action, .fh-clock-btn { transition-duration: 0.01ms; }
  [class*="skel"] { animation-duration: 0.01ms; }
  *[style*="bs-pulse"], .bs-dot, .live-dot { animation: none; }
}
