/* FabSync Job Board — matches landing page design tokens */
:root {
  --bg-primary: #0d0f11;
  --bg-secondary: #14171c;
  --bg-card: #1a1e24;
  --bg-card-hover: #1e242c;
  --fg-primary: #e8e9eb;
  --fg-secondary: #9ba1ab;
  --fg-muted: #5c6370;
  --accent: #e87a2e;
  --accent-glow: rgba(232, 122, 46, 0.15);
  --accent-dim: #b85d1f;
  --border: rgba(255, 255, 255, 0.06);
  --border-subtle: rgba(255,255,255,0.04);
  --radius: 12px;
  --radius-sm: 8px;
  --font-display: 'Space Grotesk', sans-serif;
  --font-body: 'Inter', sans-serif;

  /* Status colours */
  --c-cutting:  #3b82f6;
  --c-fitting:  #8b5cf6;
  --c-welding:  #f59e0b;
  --c-painting: #ec4899;
  --c-qc:       #10b981;
  --c-shipped:  #6b7280;
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

html { font-size: 16px; scroll-behavior: smooth; }

body {
  background: var(--bg-primary);
  color: var(--fg-primary);
  font-family: var(--font-body);
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
  min-height: 100vh;
}

/* ── Nav ──────────────────────────────────────────────────────────────── */
.nav {
  background: var(--bg-secondary);
  border-bottom: 1px solid var(--border);
  position: sticky;
  top: 0;
  z-index: 100;
}
.nav-inner {
  max-width: 1600px;
  margin: 0 auto;
  padding: 0 1.5rem;
  height: 56px;
  display: flex;
  align-items: center;
  gap: 2rem;
}
.nav-logo {
  font-family: var(--font-display);
  font-size: 1.2rem;
  font-weight: 700;
  color: var(--fg-primary);
  text-decoration: none;
  letter-spacing: -0.02em;
}
.nav-logo span { color: var(--accent); }

.nav-links { display: flex; gap: 0.25rem; }
.nav-link {
  font-size: 0.875rem;
  color: var(--fg-secondary);
  text-decoration: none;
  padding: 0.4rem 0.75rem;
  border-radius: var(--radius-sm);
  transition: color 0.15s, background 0.15s;
}
.nav-link:hover, .nav-link.active {
  color: var(--fg-primary);
  background: var(--accent-glow);
}
.nav-link.active { color: var(--accent); }

.nav-user {
  margin-left: auto;
  display: flex;
  align-items: center;
  gap: 0.75rem;
}
.nav-user-name {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 0.875rem;
  color: var(--fg-secondary);
}
.nav-role-badge {
  font-size: 0.7rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  padding: 0.15rem 0.45rem;
  border-radius: 4px;
}
.nav-role-admin  { background: rgba(232,122,46,0.15); color: var(--accent); }
.nav-role-foreman { background: rgba(99,102,241,0.15); color: #818cf8; }

.btn-logout {
  background: transparent;
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: var(--radius-sm);
  color: var(--fg-muted);
  cursor: pointer;
  font-size: 0.8rem;
  padding: 0.3rem 0.65rem;
  transition: color 0.15s, border-color 0.15s;
}
.btn-logout:hover { color: var(--fg-primary); border-color: rgba(255,255,255,0.18); }

/* ── Stats bar ────────────────────────────────────────────────────────── */
.stats-bar {
  background: var(--bg-secondary);
  border-bottom: 1px solid var(--border);
  padding: 0.5rem 1.5rem;
}
.stats-inner {
  max-width: 1600px;
  margin: 0 auto;
  display: flex;
  gap: 0.5rem;
  flex-wrap: wrap;
}
.stat-pill {
  display: flex;
  align-items: center;
  gap: 0.4rem;
  padding: 0.3rem 0.8rem;
  border-radius: 100px;
  font-size: 0.8rem;
  font-weight: 500;
  border: 1px solid transparent;
}
.stat-count { font-family: var(--font-display); font-weight: 700; font-size: 0.95rem; }
.stat-label { color: var(--fg-secondary); font-size: 0.75rem; }

.stat-cutting  { background: rgba(59,130,246,0.1);  border-color: rgba(59,130,246,0.2);  color: #93c5fd; }
.stat-fitting  { background: rgba(139,92,246,0.1);  border-color: rgba(139,92,246,0.2);  color: #c4b5fd; }
.stat-welding  { background: rgba(245,158,11,0.1);  border-color: rgba(245,158,11,0.2);  color: #fcd34d; }
.stat-painting { background: rgba(236,72,153,0.1);  border-color: rgba(236,72,153,0.2);  color: #f9a8d4; }
.stat-qc       { background: rgba(16,185,129,0.1);  border-color: rgba(16,185,129,0.2);  color: #6ee7b7; }
.stat-shipped  { background: rgba(107,114,128,0.1); border-color: rgba(107,114,128,0.2); color: #9ca3af; }

/* ── Toolbar ──────────────────────────────────────────────────────────── */
.toolbar { padding: 1rem 1.5rem 0; }
.toolbar-inner {
  max-width: 1600px;
  margin: 0 auto;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
}
.board-title {
  font-family: var(--font-display);
  font-size: 1.4rem;
  font-weight: 700;
  letter-spacing: -0.02em;
  display: flex;
  align-items: center;
  gap: 0.6rem;
}
.title-badge {
  font-size: 0.7rem;
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  background: var(--accent-glow);
  color: var(--accent);
  border: 1px solid rgba(232,122,46,0.25);
  padding: 0.2rem 0.6rem;
  border-radius: 100px;
}
.toolbar-actions { display: flex; gap: 0.5rem; }

/* ── Buttons ──────────────────────────────────────────────────────────── */
.btn {
  font-family: var(--font-display);
  font-size: 0.875rem;
  font-weight: 600;
  padding: 0.5rem 1rem;
  border-radius: var(--radius-sm);
  border: 1px solid transparent;
  cursor: pointer;
  transition: all 0.15s;
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
}
.btn-primary {
  background: var(--accent);
  color: #fff;
  border-color: var(--accent);
}
.btn-primary:hover { background: var(--accent-dim); border-color: var(--accent-dim); }

.btn-ghost {
  background: transparent;
  color: var(--fg-secondary);
  border-color: var(--border);
}
.btn-ghost:hover { color: var(--fg-primary); border-color: rgba(255,255,255,0.15); background: var(--bg-card); }

.btn-danger-ghost {
  background: transparent;
  color: #f87171;
  border-color: rgba(248,113,113,0.2);
  margin-top: 1rem;
}
.btn-danger-ghost:hover { background: rgba(248,113,113,0.08); }

/* ── Board / Kanban ───────────────────────────────────────────────────── */
.board-wrap {
  padding: 1rem 1.5rem 3rem;
  overflow-x: auto;
}
.kanban {
  display: flex;
  gap: 1rem;
  min-width: max-content;
  max-width: 1600px;
  margin: 0 auto;
  align-items: flex-start;
}

.column {
  width: 280px;
  flex-shrink: 0;
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

.col-header {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.6rem 0.75rem;
  border-radius: var(--radius-sm);
  font-family: var(--font-display);
  font-size: 0.85rem;
  font-weight: 600;
  letter-spacing: 0.02em;
  text-transform: uppercase;
  background: var(--bg-secondary);
  border: 1px solid var(--border);
}
.col-icon { font-size: 1rem; }
.col-label { flex: 1; }
.col-count {
  background: rgba(255,255,255,0.08);
  color: var(--fg-secondary);
  font-size: 0.75rem;
  padding: 0.1rem 0.5rem;
  border-radius: 100px;
  min-width: 1.5rem;
  text-align: center;
}

.col-cutting  .col-count { background: rgba(59,130,246,0.15);  color: #93c5fd; }
.col-fitting  .col-count { background: rgba(139,92,246,0.15);  color: #c4b5fd; }
.col-welding  .col-count { background: rgba(245,158,11,0.15);  color: #fcd34d; }
.col-painting .col-count { background: rgba(236,72,153,0.15);  color: #f9a8d4; }
.col-qc       .col-count { background: rgba(16,185,129,0.15);  color: #6ee7b7; }
.col-shipped  .col-count { background: rgba(107,114,128,0.15); color: #9ca3af; }

.col-body {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  min-height: 120px;
}

/* ── Job Card ─────────────────────────────────────────────────────────── */
.job-card {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 0.875rem;
  cursor: default;
  transition: border-color 0.15s, background 0.15s, transform 0.2s;
}
.job-card:hover {
  border-color: rgba(255,255,255,0.12);
  background: var(--bg-card-hover);
}
.job-card.updating { opacity: 0.6; }
.job-card.just-moved {
  animation: flash-in 0.5s ease-out;
}
@keyframes flash-in {
  from { border-color: var(--accent); box-shadow: 0 0 0 2px var(--accent-glow); }
  to   { border-color: var(--border); box-shadow: none; }
}

.job-card-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 0.4rem;
}
.job-number {
  font-family: var(--font-display);
  font-size: 0.72rem;
  font-weight: 600;
  letter-spacing: 0.06em;
  color: var(--accent);
  text-transform: uppercase;
}
.job-detail-btn {
  background: none;
  border: none;
  color: var(--fg-muted);
  cursor: pointer;
  font-size: 1.1rem;
  padding: 0 0.2rem;
  border-radius: 4px;
  line-height: 1;
  transition: color 0.15s;
}
.job-detail-btn:hover { color: var(--fg-primary); background: rgba(255,255,255,0.06); }

.job-title {
  font-weight: 500;
  font-size: 0.9rem;
  line-height: 1.4;
  margin-bottom: 0.35rem;
}
.job-notes {
  font-size: 0.78rem;
  color: var(--fg-secondary);
  line-height: 1.45;
  margin-bottom: 0.5rem;
}

.job-footer {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-top: 0.5rem;
  margin-bottom: 0.6rem;
}
.job-due {
  font-size: 0.75rem;
  color: var(--fg-muted);
}
.job-due.due-soon { color: #fbbf24; font-weight: 500; }
.job-due.due-overdue { color: #f87171; font-weight: 600; }

.job-crew { display: flex; gap: 0.2rem; }
.crew-avatar {
  width: 24px;
  height: 24px;
  border-radius: 50%;
  background: var(--accent-glow);
  color: var(--accent);
  font-size: 0.6rem;
  font-weight: 700;
  display: flex;
  align-items: center;
  justify-content: center;
  border: 1px solid rgba(232,122,46,0.25);
  cursor: default;
  font-family: var(--font-display);
}
.crew-avatar.crew-more {
  background: rgba(255,255,255,0.05);
  color: var(--fg-secondary);
  border-color: var(--border);
  font-size: 0.55rem;
}

.status-move { margin-top: 0.5rem; }
.status-select {
  width: 100%;
  background: var(--bg-secondary);
  border: 1px solid var(--border);
  color: var(--fg-secondary);
  font-size: 0.78rem;
  padding: 0.35rem 0.6rem;
  border-radius: var(--radius-sm);
  cursor: pointer;
  outline: none;
  font-family: var(--font-body);
  transition: border-color 0.15s;
}
.status-select:hover, .status-select:focus {
  border-color: rgba(255,255,255,0.2);
  color: var(--fg-primary);
}
.status-select option { background: #1a1e24; }

/* ── Modal ────────────────────────────────────────────────────────────── */
.modal-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.7);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 200;
  padding: 1rem;
  backdrop-filter: blur(4px);
}
.modal {
  background: var(--bg-secondary);
  border: 1px solid rgba(255,255,255,0.1);
  border-radius: var(--radius);
  width: 100%;
  max-width: 480px;
  max-height: 90vh;
  overflow-y: auto;
}
.modal-wide { max-width: 760px; }

.modal-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 1.25rem 1.5rem 1rem;
  border-bottom: 1px solid var(--border);
}
.modal-header h2 {
  font-family: var(--font-display);
  font-size: 1.1rem;
  font-weight: 700;
}
.modal-close {
  background: none;
  border: none;
  color: var(--fg-muted);
  font-size: 1rem;
  cursor: pointer;
  padding: 0.25rem 0.5rem;
  border-radius: 4px;
  transition: color 0.15s;
}
.modal-close:hover { color: var(--fg-primary); background: rgba(255,255,255,0.06); }

.form-row {
  display: flex;
  flex-direction: column;
  gap: 0.4rem;
  padding: 1rem 1.5rem 0;
}
.form-row label {
  font-size: 0.8rem;
  font-weight: 500;
  color: var(--fg-secondary);
  letter-spacing: 0.02em;
}
.form-row input,
.form-row select,
.form-row textarea {
  background: var(--bg-card);
  border: 1px solid var(--border);
  color: var(--fg-primary);
  font-size: 0.875rem;
  padding: 0.6rem 0.75rem;
  border-radius: var(--radius-sm);
  outline: none;
  font-family: var(--font-body);
  transition: border-color 0.15s;
  width: 100%;
}
.form-row input:focus,
.form-row select:focus,
.form-row textarea:focus {
  border-color: var(--accent);
}
.form-row textarea { resize: vertical; }
.form-row select option { background: var(--bg-card); }

.form-actions {
  display: flex;
  justify-content: flex-end;
  gap: 0.5rem;
  padding: 1.25rem 1.5rem;
}

/* ── Detail Modal ─────────────────────────────────────────────────────── */
.detail-loading {
  padding: 2rem;
  text-align: center;
  color: var(--fg-muted);
}
.detail-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0;
}
.detail-section {
  padding: 1.25rem 1.5rem;
}
.detail-section:first-child {
  border-right: 1px solid var(--border);
}
.detail-section h3 {
  font-family: var(--font-display);
  font-size: 0.8rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--fg-secondary);
  margin-bottom: 0.75rem;
}

.crew-checkboxes {
  display: flex;
  flex-direction: column;
  gap: 0.4rem;
}
.crew-check {
  display: flex;
  align-items: center;
  gap: 0.6rem;
  padding: 0.5rem 0.6rem;
  border-radius: var(--radius-sm);
  border: 1px solid var(--border);
  cursor: pointer;
  transition: border-color 0.15s, background 0.15s;
  font-size: 0.875rem;
}
.crew-check:hover { border-color: rgba(255,255,255,0.15); }
.crew-check.checked { border-color: rgba(232,122,46,0.3); background: var(--accent-glow); }
.crew-check input { accent-color: var(--accent); }
.crew-name { flex: 1; }
.crew-role {
  font-size: 0.7rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  padding: 0.15rem 0.5rem;
  border-radius: 100px;
}
.role-welder    { background: rgba(245,158,11,0.12);  color: #fcd34d; }
.role-fitter    { background: rgba(139,92,246,0.12);  color: #c4b5fd; }
.role-painter   { background: rgba(236,72,153,0.12);  color: #f9a8d4; }
.role-inspector { background: rgba(16,185,129,0.12);  color: #6ee7b7; }
.role-foreman   { background: rgba(232,122,46,0.12);  color: var(--accent); }
.role-general   { background: rgba(107,114,128,0.12); color: #9ca3af; }

.history-list { display: flex; flex-direction: column; gap: 0.6rem; }
.history-empty { font-size: 0.85rem; color: var(--fg-muted); font-style: italic; }
.history-item { display: flex; flex-direction: column; gap: 0.2rem; }
.history-arrow {
  display: flex;
  align-items: center;
  gap: 0.4rem;
  font-size: 0.8rem;
}
.history-chevron { color: var(--fg-muted); }
.history-meta { font-size: 0.72rem; color: var(--fg-muted); }

.status-chip {
  font-size: 0.72rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  padding: 0.15rem 0.5rem;
  border-radius: 100px;
}
.chip-cutting  { background: rgba(59,130,246,0.15);  color: #93c5fd; }
.chip-fitting  { background: rgba(139,92,246,0.15);  color: #c4b5fd; }
.chip-welding  { background: rgba(245,158,11,0.15);  color: #fcd34d; }
.chip-painting { background: rgba(236,72,153,0.15);  color: #f9a8d4; }
.chip-qc       { background: rgba(16,185,129,0.15);  color: #6ee7b7; }
.chip-shipped  { background: rgba(107,114,128,0.15); color: #9ca3af; }

.detail-actions { margin-top: 1rem; }

/* ── Toast ────────────────────────────────────────────────────────────── */
.toast {
  position: fixed;
  bottom: 1.5rem;
  left: 50%;
  transform: translateX(-50%) translateY(20px);
  background: var(--bg-card);
  border: 1px solid var(--border);
  color: var(--fg-primary);
  font-size: 0.875rem;
  padding: 0.6rem 1.2rem;
  border-radius: 100px;
  z-index: 500;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.2s, transform 0.2s;
  white-space: nowrap;
}
.toast.show {
  opacity: 1;
  transform: translateX(-50%) translateY(0);
}
.toast.toast-error {
  border-color: rgba(248,113,113,0.3);
  color: #f87171;
  background: rgba(248,113,113,0.08);
}
.toast.toast-success { border-color: rgba(16,185,129,0.25); }

/* ── Responsive ───────────────────────────────────────────────────────── */
@media (max-width: 600px) {
  .board-wrap { padding: 0.75rem; }
  .column { width: 260px; }
  .detail-grid { grid-template-columns: 1fr; }
  .detail-section:first-child { border-right: none; border-bottom: 1px solid var(--border); }
}
