/* ═══════════════════════════════════════════
   JOBS TOOLBAR
═══════════════════════════════════════════ */
.view-header { display: flex; align-items: center; gap: 14px; margin-bottom: 20px; }
.view-title  { font-family: var(--font-display); font-size: 24px; font-weight: 700; color: var(--text-1); }
.view-count  {
  font-family: var(--font-mono); font-size: 12px; color: var(--text-2);
  background: var(--surface); border: 1px solid var(--border);
  padding: 3px 10px; border-radius: 20px;
}
.toolbar { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; flex-wrap: wrap; }
.select-filter {
  background: var(--surface) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='11' height='11' viewBox='0 0 24 24' fill='none' stroke='%239aabb8' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E") no-repeat right 9px center;
  border: 1px solid var(--border);
  color: var(--text-1); border-radius: var(--r-sm);
  padding: 7px 28px 7px 12px; font-size: 12.5px; outline: none; cursor: pointer;
  appearance: none;
}

/* ═══════════════════════════════════════════
   JOB LIST CARDS (with colored left stripe)
═══════════════════════════════════════════ */
.job-list { display: flex; flex-direction: column; gap: 8px; }
.job-card {
  background: var(--surface); border: 1px solid var(--border);
  border-radius: var(--r-md); padding: 13px 16px;
  display: grid; grid-template-columns: 4px 1fr auto;
  gap: 13px; align-items: center; cursor: pointer;
  transition: border-color 0.12s, box-shadow 0.12s;
  text-decoration: none; color: inherit;
  animation: risein 0.3s ease both;
}
.job-card:hover { border-color: var(--brass); box-shadow: 0 1px 8px rgba(0,0,0,0.06); }
.job-card.selected { border-color: var(--brass); box-shadow: 0 0 0 3px var(--brass-soft); }
.job-stripe { width: 4px; height: 42px; border-radius: 3px; flex-shrink: 0; }
.job-body   { min-width: 0; }
.job-top    { display: flex; align-items: center; gap: 8px; margin-bottom: 3px; }
.job-num    { font-family: var(--font-mono); font-size: 11px; color: var(--brass); letter-spacing: 0.04em; }
.job-client { font-weight: 600; font-size: 14px; color: var(--text-1); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.job-addr   { font-size: 11.5px; color: var(--text-2); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; margin-top: 1px; }
.job-tags   { display: flex; gap: 4px; margin-top: 5px; }
.job-meta   { display: flex; flex-direction: column; align-items: flex-end; gap: 5px; flex-shrink: 0; }
.job-amount { font-family: var(--font-display); font-size: 16px; font-weight: 600; color: var(--text-1); }
.job-crew   { display: flex; align-items: center; gap: 5px; font-size: 11px; color: var(--text-2); }
.crew-pip   { width: 8px; height: 8px; border-radius: 50%; flex-shrink: 0; }

/* Full list job cards (6-col) — jobs index */
.list-header {
  display: grid;
  grid-template-columns: 4px 2fr 1fr 1fr 1fr auto;
  gap: 14px; padding: 0 18px 8px; margin-bottom: 2px;
}
.list-header span {
  font-family: var(--font-mono); font-size: 9.5px;
  text-transform: uppercase; letter-spacing: 0.12em; color: var(--text-3);
}
.jobs-full-list { display: flex; flex-direction: column; gap: 8px; }
.job-card-lg {
  background: var(--surface); border: 1px solid var(--border);
  border-radius: var(--r-md); padding: 13px 18px;
  display: grid; grid-template-columns: 4px 2fr 1fr 1fr 1fr auto;
  gap: 14px; align-items: center; cursor: pointer;
  transition: border-color 0.12s, box-shadow 0.12s;
  animation: risein 0.3s ease both;
}
.job-card-lg:hover { border-color: var(--brass); box-shadow: 0 1px 8px rgba(0,0,0,0.06); }
.jlg-stripe { width: 4px; height: 38px; border-radius: 3px; }
.jlg-main   { min-width: 0; }
.jlg-num    { font-family: var(--font-mono); font-size: 10.5px; color: var(--brass); }
.jlg-client { font-weight: 600; font-size: 13.5px; color: var(--text-1); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.jlg-addr   { font-size: 11.5px; color: var(--text-2); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.jlg-stage  { display: flex; align-items: center; }
.jlg-services { display: flex; gap: 4px; flex-wrap: wrap; }
.jlg-crew   { font-size: 12px; color: var(--text-2); display: flex; align-items: center; gap: 5px; }
.jlg-amount { font-family: var(--font-display); font-size: 15px; font-weight: 600; color: var(--text-1); white-space: nowrap; }
.job-unassigned { font-size: 11px; color: var(--text-3); font-style: italic; }

.jobs-toolbar { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; flex-wrap: wrap; }
.jobs-count {
  font-family: var(--font-mono); font-size: 12px; color: var(--text-2);
  background: var(--surface); border: 1px solid var(--border);
  padding: 3px 10px; border-radius: 20px;
}

/* ═══════════════════════════════════════════
   STAGE TRACKER (::before/::after lines)
═══════════════════════════════════════════ */
.stage-track-wrap {
  background: var(--surface); border: 1px solid var(--border);
  border-radius: var(--r-lg); padding: 18px 24px; margin-bottom: 22px;
  overflow-x: auto;
}
.stage-track { display: flex; align-items: flex-start; min-width: 600px; }
.stage-track-step {
  display: flex; flex-direction: column; align-items: center;
  flex: 1; position: relative;
}
.stage-track-step::before {
  content: '';
  position: absolute; top: 10px; left: 0; width: 50%; height: 2px;
  background: var(--border); z-index: 0;
}
.stage-track-step::after {
  content: '';
  position: absolute; top: 10px; left: 50%; width: 50%; height: 2px;
  background: var(--border); z-index: 0;
}
.stage-track-step:first-child::before { display: none; }
.stage-track-step:last-child::after   { display: none; }
.stage-track-step.done::before,
.stage-track-step.done::after  { background: var(--brass); }
.stage-track-step.current::before { background: var(--brass); }

.step-dot {
  width: 22px; height: 22px; border-radius: 50%;
  border: 2px solid var(--border); background: var(--surface-hi);
  position: relative; z-index: 1; flex-shrink: 0;
  display: flex; align-items: center; justify-content: center;
  transition: all 0.2s; margin-bottom: 5px;
}
.stage-track-step.done .step-dot {
  border-color: var(--brass); background: var(--brass);
}
.stage-track-step.done .step-dot::after {
  content: '';
  position: absolute; top: 4px; left: 7px;
  width: 5px; height: 8px;
  border-right: 2px solid #fff; border-bottom: 2px solid #fff;
  transform: rotate(45deg);
}
.stage-track-step.current .step-dot {
  border-color: var(--brass); background: var(--brass);
  box-shadow: 0 0 0 3px var(--brass-soft);
}

.step-label {
  font-family: var(--font-mono);
  font-size: 9px; text-transform: uppercase; letter-spacing: 0.05em;
  color: var(--text-3); text-align: center; white-space: nowrap; line-height: 1;
}
.stage-track-step.done    .step-label { color: var(--brass-lo); }
.stage-track-step.current .step-label { color: var(--brass); font-weight: 600; }

/* ═══════════════════════════════════════════
   PRE-PRODUCTION CHECKLIST ITEMS
═══════════════════════════════════════════ */
.preprod-group { margin-bottom: 20px; }
.preprod-group-title { font-family: var(--font-mono); font-size: 9.5px; text-transform: uppercase; letter-spacing: 0.14em; color: var(--text-3); margin-bottom: 10px; padding-bottom: 6px; border-bottom: 1px solid var(--border-lo); }
.preprod-item { display: flex; gap: 10px; align-items: flex-start; padding: 10px 12px; background: var(--surface-hi); border-radius: var(--r-sm); border: 1px solid var(--border-lo); margin-bottom: 8px; }
.preprod-check { width: 18px; height: 18px; border-radius: 4px; border: 2px solid var(--border); flex-shrink: 0; margin-top: 1px; display: flex; align-items: center; justify-content: center; }
.preprod-check.done { background: var(--s-complete); border-color: var(--s-complete); }
.preprod-check.warn { background: #f59e0b; border-color: #f59e0b; }
.preprod-check svg { width: 10px; height: 10px; }
.preprod-body { flex: 1; }
.preprod-label  { font-size: 13px; font-weight: 600; color: var(--text-1); }
.preprod-detail { font-size: 11px; color: var(--text-2); margin-top: 2px; }
.preprod-meta   { font-family: var(--font-mono); font-size: 10px; color: var(--brass); margin-top: 3px; }

/* ═══════════════════════════════════════════
   VIEW TOOLBAR (filter row above lists)
═══════════════════════════════════════════ */
.view-toolbar {
  display: flex; align-items: center; gap: 10px;
  flex-wrap: wrap; margin-bottom: 18px;
}
.search-input-inline {
  background: var(--surface); border: 1px solid var(--border);
  border-radius: var(--r-sm); padding: 7px 12px;
  font-size: 12.5px; color: var(--text-1); outline: none;
  transition: border-color 0.15s; min-width: 220px;
}
.search-input-inline::placeholder { color: var(--text-3); }
.search-input-inline:focus { border-color: var(--brass); }
.select-inline {
  background: var(--surface) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='11' height='11' viewBox='0 0 24 24' fill='none' stroke='%239aabb8' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E") no-repeat right 9px center;
  border: 1px solid var(--border);
  border-radius: var(--r-sm); padding: 7px 28px 7px 10px;
  font-size: 12.5px; color: var(--text-1); outline: none;
  cursor: pointer; appearance: none;
}

/* Stage advance controls */
.stage-advance-group {
  display: flex; align-items: center; gap: 10px; flex-wrap: wrap;
}
.stage-jump-label {
  font-size: 11px; color: var(--text-3); white-space: nowrap;
}

/* ═══════════════════════════════════════════
   JOB SHOW HEADER
═══════════════════════════════════════════ */
.job-show-header {
  display: flex; align-items: center; gap: 12px;
  margin-bottom: 20px; flex-wrap: wrap;
}
.job-show-meta { display: flex; align-items: center; gap: 6px; }

/* ═══════════════════════════════════════════
   JOB CARD COLUMN HELPERS
═══════════════════════════════════════════ */
.job-date    { text-align: right; }

/* ═══════════════════════════════════════════
   PROPOSAL OPTIONS
═══════════════════════════════════════════ */
.prop-option-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 14px; margin-bottom: 22px; }
.prop-option-card { border: 2px solid var(--border); border-radius: var(--r-lg); padding: 18px; cursor: pointer; transition: border-color 0.15s, box-shadow 0.15s; position: relative; }
.prop-option-card:hover { border-color: var(--text-3); }
.prop-option-card.selected { border-color: var(--brass); box-shadow: 0 0 0 3px var(--brass-soft); }
.poc-tier  { font-family: var(--font-mono); font-size: 9px; text-transform: uppercase; letter-spacing: 0.12em; color: var(--text-3); margin-bottom: 5px; }
.poc-label { font-family: var(--font-display); font-size: 20px; font-weight: 700; color: var(--text-1); margin-bottom: 10px; }
.poc-price { font-family: var(--font-display); font-size: 28px; font-weight: 700; color: var(--text-1); }
.poc-sel-badge { position: absolute; top: 12px; right: 12px; background: var(--brass); color: #fff; font-family: var(--font-mono); font-size: 8px; text-transform: uppercase; letter-spacing: 0.1em; padding: 2px 8px; border-radius: 20px; }

/* Material order status badges */
.mat-order { display: flex; gap: 10px; align-items: flex-start; padding: 10px 12px; background: var(--surface-hi); border-radius: var(--r-sm); border: 1px solid var(--border-lo); margin-bottom: 8px; }
.mat-status { display: inline-flex; align-items: center; gap: 4px; font-family: var(--font-mono); font-size: 9px; text-transform: uppercase; letter-spacing: 0.08em; padding: 2px 7px; border-radius: 20px; flex-shrink: 0; }
.mat-ordered   { background: #eff6ff; color: #2563eb; }
.mat-confirmed { background: #fffbeb; color: #b45309; }
.mat-delivered { background: #f0fdf4; color: #16a34a; }
