/* HaulBase — Drivers Roster page (.dr-* prefix, design-system rev)
 *
 * Source: Haulbase_Claude_Design/assets/design/Drivers Roster.html
 *
 * Loaded AFTER assets/drivers.css so the new design's .dr-* rules
 * override the older inline-edit table styling on conflicting class
 * names. Legacy classes that aren't in the new design (e.g. .dr-cell,
 * .dr-th, .dr-table-wrap, .dr-empty, .dr-sub) still resolve from the
 * older drivers.css and are used by the in-place add/edit form
 * helpers, which weren't redesigned in this pass.
 */

/* ============== PAGE ============== */
.dr-page { padding: 24px 28px 64px; }

.dr-page-head {
  display: flex; align-items: flex-end; justify-content: space-between;
  gap: 24px; margin-bottom: 22px;
}
.dr-page-head h1 {
  margin: 0;
  font: 700 28px/1.05 var(--font-display);
  letter-spacing: -0.015em; color: var(--fg-1);
}
.dr-page-head .sub { color: var(--fg-3); font-size: 13.5px; margin-top: 6px; }
.dr-page-head .sub b { color: var(--fg-2); font-weight: 600; }

.dr-actions { display: flex; gap: 8px; align-items: center; }
.dr-btn {
  height: 34px; padding: 0 13px; border-radius: var(--r-md);
  background: var(--bg-card); border: 1px solid var(--border-2);
  color: var(--fg-2);
  font: 600 12.5px/1 var(--font-display); letter-spacing: .01em;
  display: inline-flex; align-items: center; gap: 6px; cursor: pointer;
  text-decoration: none;
}
.dr-btn:hover { color: var(--fg-1); border-color: var(--border-3); }
.dr-btn svg { width: 14px; height: 14px; }
.dr-btn.primary {
  background: var(--brand-cta); color: var(--brand-cta-fg);
  border-color: var(--brand-cta);
}
.dr-btn.primary:hover {
  background: var(--brand-cta-hover); border-color: var(--brand-cta-hover);
}

/* --- Search + filter chips --- */
.dr-bar {
  display: grid; grid-template-columns: minmax(260px, 380px) 1fr; gap: 14px;
  align-items: center; margin-bottom: 14px;
}
.dr-search { position: relative; display: flex; align-items: center; }
.dr-search svg.glass {
  position: absolute; left: 11px; top: 50%; transform: translateY(-50%);
  width: 15px; height: 15px; color: var(--fg-4);
}
.dr-search input {
  width: 100%; height: 36px; padding: 0 12px 0 36px;
  background: var(--bg-card); border: 1px solid var(--border-2);
  border-radius: var(--r-md);
  color: var(--fg-1); font: 400 13.5px/1 var(--font-body); outline: none;
}
.dr-search input::placeholder { color: var(--fg-4); }
.dr-search input:focus {
  border-color: var(--accent-500);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--accent-500) 18%, transparent);
}

.dr-chips { display: flex; gap: 6px; flex-wrap: wrap; }
.dr-chip {
  height: 30px; padding: 0 10px; border-radius: var(--r-pill);
  background: var(--bg-input); border: 1px solid var(--border-2);
  color: var(--fg-3);
  font: 500 12px/1 var(--font-display);
  display: inline-flex; align-items: center; gap: 6px; cursor: pointer;
  white-space: nowrap;
}
.dr-chip:hover { color: var(--fg-1); border-color: var(--border-3); }
.dr-chip.on {
  background: var(--link-active-bg); border-color: var(--link-active-bd);
  color: var(--link-active-fg);
}
.dr-chip .count {
  font: 600 10px/1 var(--font-mono);
  padding: 2px 5px; border-radius: 3px;
  background: var(--bg-card); color: var(--fg-3);
}
.dr-chip.on .count { background: var(--accent-500); color: #0f172a; }

/* --- Body grid --- */
.dr-grid {
  display: grid; grid-template-columns: minmax(0, 1fr) 320px; gap: 22px;
  align-items: start;
}

/* --- Table card (NEW design — overrides older drivers.css) --- */
.dr-card {
  background: var(--bg-card); border: 1px solid var(--border-1);
  border-radius: var(--r-lg); overflow: hidden;
}
.dr-card-head {
  display: flex; align-items: center; gap: 10px;
  padding: 11px 18px; border-bottom: 1px solid var(--border-1);
  background: var(--bg-card-2);
}
.dr-card-head h3 {
  margin: 0;
  font: 600 10.5px/1 var(--font-body); text-transform: uppercase;
  letter-spacing: .14em; color: var(--fg-3);
}
.dr-card-head .spacer { flex: 1; }
.dr-card-head .meta {
  font: 500 11.5px/1 var(--font-mono); color: var(--fg-4);
}

/* New design's table override. Reset any inherited Radix table styling
 * from the older drivers.css by explicitly resetting layout. */
.dr-table {
  width: 100%; border-collapse: separate; border-spacing: 0; background: var(--bg-card);
}
.dr-table thead th {
  text-align: left; padding: 10px 16px;
  background: var(--bg-card-2); border-bottom: 1px solid var(--border-1);
  font: 600 9.5px/1 var(--font-body); text-transform: uppercase;
  letter-spacing: .14em; color: var(--fg-4); white-space: nowrap;
}
.dr-table thead th.act { width: 96px; }
.dr-table tbody td {
  padding: 12px 16px; vertical-align: middle;
  font: 400 13.5px/1.4 var(--font-body); color: var(--fg-2);
  background: transparent;
}
.dr-table tbody tr + tr td { border-top: 1px solid var(--border-1); }
.dr-table tbody tr:hover td { background: var(--bg-input); }
.dr-table tbody tr:hover .dr-namecell .full { color: var(--accent-300); }
.dr-table tbody tr.disabled td { color: var(--fg-4); }
.dr-table tbody tr.disabled .dr-av { opacity: .45; }
.dr-table tbody tr.disabled .dr-namecell .full { color: var(--fg-3); }

/* name cell (NEW shape — replaces older .dr-name behavior) */
.dr-namecell { display: flex; align-items: center; gap: 12px; min-width: 0; }
.dr-av {
  width: 36px; height: 36px; border-radius: 50%;
  display: inline-grid; place-items: center;
  font: 700 12.5px/1 var(--font-display); color: #0f172a;
  flex-shrink: 0;
}
.dr-av.c1 { background: linear-gradient(135deg, #fbbf24, #d97706); }
.dr-av.c2 { background: linear-gradient(135deg, #6ee7b7, #10b981); color: #064e3b; }
.dr-av.c3 { background: linear-gradient(135deg, #93c5fd, #3b82f6); color: #1e3a8a; }
.dr-av.c4 { background: linear-gradient(135deg, #c4b5fd, #8b5cf6); color: #4c1d95; }
.dr-av.c5 { background: linear-gradient(135deg, #fca5a5, #ef4444); color: #7f1d1d; }
.dr-av.c6 { background: linear-gradient(135deg, #fcd34d, #f59e0b); }

.dr-namecell .full {
  font: 600 14px/1.2 var(--font-display); color: var(--fg-1);
  display: block;
}
.dr-namecell .nick {
  font: 500 11.5px/1 var(--font-mono); color: var(--fg-4);
  letter-spacing: .02em; display: block; margin-top: 3px;
}
.dr-namecell .nick::before { content: "@"; opacity: .6; }

.dr-phone {
  font-family: var(--font-mono); font-size: 13px; color: var(--fg-2);
  white-space: nowrap;
}

/* truck cell */
.dr-truck { display: flex; align-items: center; gap: 10px; min-width: 0; }
.dr-truck-mono {
  width: 38px; height: 26px; border-radius: 4px;
  background: var(--bg-input); border: 1px solid var(--border-2);
  display: inline-grid; place-items: center;
  font: 600 11px/1 var(--font-mono); color: var(--fg-1);
  letter-spacing: .04em;
  flex-shrink: 0;
}
.dr-truck-info {
  display: flex; flex-direction: column; gap: 3px; min-width: 0;
}
.dr-truck-info .desc {
  font: 500 13px/1.2 var(--font-body); color: var(--fg-2); white-space: nowrap;
}
.dr-truck-info .desc a {
  color: inherit; text-decoration: none;
  border-bottom: 1px dashed var(--border-2);
}
.dr-truck-info .desc a:hover {
  color: var(--accent-300); border-color: var(--accent-400);
}
.dr-truck-info .plate {
  font: 500 11px/1 var(--font-mono); color: var(--fg-4); letter-spacing: .04em;
}
.dr-truck-tbd {
  font: 600 11px/1 var(--font-body); text-transform: uppercase;
  letter-spacing: .12em;
  padding: 4px 8px; border-radius: var(--r-md);
  background: var(--status-issue-bg); color: var(--status-issue-fg);
  border: 1px dashed var(--status-issue-bd);
}

/* status cell — uses .pill plus extra "progress" data */
.dr-status {
  display: flex; align-items: center; gap: 8px; flex-wrap: wrap;
}
.dr-stop { font: 500 11.5px/1 var(--font-mono); color: var(--fg-3); }
.dr-stop b { color: var(--fg-1); font-weight: 600; }

/* homebase cell — house glyph + location name. Max-width is generous
 * enough to fit typical "Fuzion Field Services Greeley Yard"-class
 * names without the ellipsis kicking in; the truncation pattern stays
 * as a defensive fallback for pathologically long entries. */
.dr-homebase {
  display: inline-flex; align-items: center; gap: 8px;
  min-width: 0; max-width: 320px;
}
.dr-homebase svg { color: var(--fg-4); flex-shrink: 0; }
.dr-homebase .name {
  color: var(--fg-2);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.dr-homebase-empty { color: var(--fg-4); }

/* Off pill — not in tokens.css, scoped here */
.pill-off { color: var(--fg-4); background: var(--bg-input); border-color: var(--border-2); }
.pill-off::before { background: var(--fg-4); }

/* link / action buttons (NEW shape — overrides older .dr-icon-btn) */
.dr-row-acts {
  display: flex; gap: 4px; justify-content: flex-end; align-items: center;
}
/* Override older drivers.css block-level / "send" sizing — new spec is
 * a square 30px icon button, no inline label. The Send-link "Send Link"
 * inline span is now just an icon-only button per the design.
 */
.dr-row-acts .dr-icon-btn {
  width: 30px; height: 30px; padding: 0;
  border-radius: var(--r-md);
  background: transparent; border: 1px solid transparent;
  color: var(--fg-3);
  display: grid; place-items: center; cursor: pointer;
  position: relative;
}
.dr-row-acts .dr-icon-btn:hover {
  background: var(--bg-card); border-color: var(--border-2); color: var(--fg-1);
}
.dr-row-acts .dr-icon-btn:disabled {
  opacity: .4; cursor: not-allowed;
}
.dr-row-acts .dr-icon-btn:disabled:hover {
  background: transparent; border-color: transparent;
}
.dr-row-acts .dr-icon-btn svg { width: 14px; height: 14px; }
/* Hide any text spans inside the new icon-button shape — older code
 * paired the icon with a label; the design is icon-only. */
.dr-row-acts .dr-icon-btn span:not(.tip):not(.dr-flash-toast):not(.kbd) {
  display: none;
}

.dr-row-acts .dr-icon-btn.danger:hover {
  color: var(--status-issue-fg);
  border-color: var(--status-issue-bd);
  background: var(--status-issue-bg);
}
.dr-row-acts .dr-icon-btn.primary {
  background: var(--brand-cta); color: var(--brand-cta-fg);
  border-color: var(--brand-cta);
}
.dr-row-acts .dr-icon-btn.primary:hover {
  background: var(--brand-cta-hover); border-color: var(--brand-cta-hover);
}

/* table footer */
.dr-foot {
  display: flex; align-items: center; justify-content: space-between;
  padding: 11px 18px;
  border-top: 1px solid var(--border-1); background: var(--bg-card-2);
  color: var(--fg-3); font: 500 12px/1 var(--font-body);
}
.dr-foot b { color: var(--fg-1); font-weight: 600; }
.dr-foot .note {
  font-size: 11.5px; color: var(--fg-4); font-family: var(--font-mono);
}

/* ============== RIGHT RAIL ============== */
.dr-rail-card {
  background: var(--bg-card); border: 1px solid var(--border-1);
  border-radius: var(--r-lg); overflow: hidden;
}
.dr-rail-card + .dr-rail-card { margin-top: 18px; }

.dr-cov-summary {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 0;
  border-bottom: 1px solid var(--border-1);
}
.dr-cov-cell {
  padding: 14px 16px; text-align: center;
  border-right: 1px solid var(--border-1);
}
.dr-cov-cell:last-child { border-right: 0; }
.dr-cov-cell .num {
  font: 700 26px/1 var(--font-display); color: var(--fg-1);
  letter-spacing: -0.01em;
}
.dr-cov-cell .lbl {
  font: 600 9px/1 var(--font-body); text-transform: uppercase;
  letter-spacing: .14em; color: var(--fg-4); margin-top: 6px;
}
.dr-cov-cell.out .num { color: var(--status-complete-fg); }
.dr-cov-cell.idle .num { color: var(--accent-400); }

.dr-truck-list { padding: 6px 8px 12px; }
.dr-truck-list-section { padding: 10px 10px 4px; }
.dr-truck-list-section .lbl {
  font: 600 9px/1 var(--font-body); text-transform: uppercase;
  letter-spacing: .14em; color: var(--fg-4);
}
.dr-truck-list-section .lbl .ct {
  color: var(--fg-3); margin-left: 5px;
  font-family: var(--font-mono); font-size: 10px;
}

.dr-truck-row {
  display: flex; align-items: center; gap: 10px;
  padding: 9px 10px; border-radius: var(--r-md);
}
.dr-truck-row:hover { background: var(--bg-input); }
.dr-truck-row .mono {
  width: 38px; height: 26px; border-radius: 4px;
  background: var(--bg-input); border: 1px solid var(--border-2);
  display: inline-grid; place-items: center;
  font: 600 11px/1 var(--font-mono); color: var(--fg-1); flex-shrink: 0;
}
.dr-truck-row .body {
  display: flex; flex-direction: column; gap: 3px; min-width: 0; flex: 1;
}
.dr-truck-row .desc {
  font: 500 12.5px/1.2 var(--font-body); color: var(--fg-2);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.dr-truck-row .who {
  font: 500 11px/1 var(--font-mono); color: var(--fg-3);
}
.dr-truck-row.out .mono {
  background: rgba(110, 231, 183, 0.1);
  border-color: var(--status-complete-bd); color: var(--status-complete-fg);
}
.dr-truck-row.idle .mono {
  background: rgba(245, 158, 11, 0.1);
  border-color: var(--accent-500); color: var(--accent-300);
}
.dr-truck-row .dot {
  width: 8px; height: 8px; border-radius: 50%;
  background: var(--fg-5); flex-shrink: 0;
}
.dr-truck-row.out .dot {
  background: var(--status-complete-fg);
  box-shadow: 0 0 6px rgba(110, 231, 183, .5);
}
.dr-truck-row.idle .dot { background: var(--accent-400); }

/* shift card */
.dr-shift { padding: 14px 16px 16px; }
.dr-shift-stat {
  display: flex; align-items: baseline; justify-content: space-between;
  padding: 8px 0;
}
.dr-shift-stat + .dr-shift-stat { border-top: 1px dashed var(--border-1); }
.dr-shift-stat .k {
  font: 500 12.5px/1 var(--font-body); color: var(--fg-3);
}
.dr-shift-stat .v {
  font: 600 13px/1 var(--font-mono); color: var(--fg-1);
}
.dr-shift-stat .v .sub {
  color: var(--fg-4); font-weight: 500; margin-left: 5px;
}

/* Add-form card — wraps the existing add_form helper so it sits inside
 * a token-styled card (the inner Tailwind grid is left intact). Only
 * displayed when the chip view warrants editing. */
.dr-add-card {
  background: var(--bg-card); border: 1px solid var(--border-1);
  border-radius: var(--r-lg);
  margin-bottom: 18px;
  padding: 16px 18px;
}
.dr-add-card .dr-card-head {
  margin: -16px -18px 14px; padding: 11px 18px;
}
