:root{
  --bg:#0b0f17;
  --panel:#0f1622;
  --panel-soft:#0c121d;
  --panel-2:#141d2e;
  --text:#e9edf5;
  --muted:#9aa6c2;
  --border:#1c2536;
  --accent:#3e8dfd;
  --accent-2:#4fd1c5;
  --ok:#22c58a;
  --danger:#ff6b6b;
  --shadow:0 16px 40px rgba(0,0,0,.35);

  --dot-purple:#9b8dfc; /* checked in */
  --dot-gold:#f5d16b;   /* in production */
  --dot-green:#48d8a4;  /* completed */

  --actions-col:180px;
  --sync-col:130px;
}

*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  background:var(--bg);
  color:var(--text);
  font:15px/1.5 'Manrope','Segoe UI',system-ui,sans-serif;
  letter-spacing:0.1px;
  -webkit-font-smoothing:antialiased;
}

/* Layout */
.app-container{
  display:flex;
  min-height:100vh;
  background:
    radial-gradient(120% 120% at 12% -10%, rgba(62,141,253,.09), transparent 45%),
    radial-gradient(110% 120% at 80% 0%, rgba(79,209,197,.08), transparent 42%),
    var(--bg);
}
.sidebar{
  width:240px;
  background:linear-gradient(180deg, #0f141f 0%, #0c111a 100%);
  border-right:1px solid var(--border);
  padding:22px 18px;
  position:sticky;
  top:0;
  height:100vh;
  display:flex;
  flex-direction:column;
  gap:20px;
}
.sidebar-top{display:flex;align-items:center;gap:12px}
.logo-mark{
  width:38px;height:38px;border-radius:12px;
  background:linear-gradient(135deg, var(--accent), #5f8dfd 70%);
  color:#fff;font-weight:800;display:flex;align-items:center;justify-content:center;
  box-shadow:0 10px 24px rgba(0,0,0,.25);
}
.logo-text{display:flex;flex-direction:column;gap:2px}
.sidebar-logo{margin:0;font-size:18px;font-weight:800}
.sidebar-sub{color:var(--muted);font-size:12px;letter-spacing:0.3px}
.nav-group{display:flex;flex-direction:column;gap:10px}
.nav-heading{font-size:12px;text-transform:uppercase;letter-spacing:0.8px;color:var(--muted)}
.nav-tabs{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px}
.nav-tabs li{
  padding:10px 12px;
  border-radius:10px;
  color:var(--muted);
  cursor:pointer;
  user-select:none;
  display:flex;
  align-items:center;
  gap:10px;
  border:1px solid transparent;
  transition:all .18s ease;
}
.nav-tabs li:hover{color:#fff;background:rgba(255,255,255,.03)}
.nav-tabs li.active{
  color:#fff;
  background:var(--panel-2);
  border-color:var(--border);
  box-shadow:inset 3px 0 0 var(--accent);
}
.nav-footer{
  margin-top:auto;
  border-top:1px solid var(--border);
  padding-top:12px;
  color:var(--muted);
  font-size:12px;
  display:flex;
  flex-direction:column;
  gap:8px;
}
.nav-foot-label{font-weight:700;letter-spacing:0.4px}

.main-content{flex:1;padding:28px 32px;min-width:0}
.tab-content{display:none}
.tab-content.active{display:block}

/* Type + utility */
.eyebrow{color:var(--muted);font-size:12px;letter-spacing:0.8px;text-transform:uppercase;margin:0}
.muted{color:var(--muted)}
.small{font-size:12px}

/* Buttons & pills */
.btn{
  appearance:none;border:none;border-radius:10px;padding:10px 12px;background:var(--panel-2);color:#fff;cursor:pointer;
  line-height:1.1;font-weight:700;transition:all .16s ease;border:1px solid transparent;
}
.btn:hover{filter:brightness(1.06)}
.btn.primary{background:var(--accent);color:#fff}
.btn.success{background:var(--ok);color:#04130e}
.btn.secondary{background:var(--accent-2);color:#052821}
.btn.danger{background:var(--danger);color:#2c0c0c}
.btn.outline{background:transparent;border:1px solid var(--border);color:#fff}
.btn.icon-only{padding:8px 10px;width:38px;text-align:center}
.btn.small{padding:7px 10px;font-size:12px;border-radius:8px}
.btn.pill-btn{background:rgba(255,255,255,.06);border:1px solid var(--border)}
.pill,.scan-pill-text{
  background:#1a2231;
  color:#d3ddf6;
  padding:6px 10px;
  border-radius:999px;
  font-size:12px;
  border:1px solid var(--border);
}
.pill-muted{background:#151c29;color:var(--muted);border-color:var(--border)}
.status-note{color:var(--muted);font-weight:600}

/* Hero / cards */
.hero-card{
  background:linear-gradient(135deg, #121a2a 0%, #0e131f 100%);
  border:1px solid var(--border);
  border-radius:18px;
  padding:18px 16px 20px;
  box-shadow:var(--shadow);
  max-width:720px;
}
.hero-card h1{margin:6px 0 4px;font-size:28px;letter-spacing:-0.4px}
.hero-actions{margin-top:12px}
.card{
  background:var(--panel);
  border:1px solid var(--border);
  border-radius:14px;
  box-shadow:var(--shadow);
}
.card-head{
  display:flex;align-items:center;justify-content:space-between;
  padding:12px 14px;border-bottom:1px solid var(--border);
}
.card-head h2{margin:0;font-size:18px}
.card-actions{display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.card-body{padding:14px 16px}

.page-header{
  display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;
  margin-bottom:12px;
}
.page-header h1{margin:6px 0 0;font-size:30px;letter-spacing:-0.5px}
.header-actions{display:flex;align-items:center;gap:10px;flex-wrap:wrap}

/* Board shell */
.board-shell{border-radius:16px;overflow:hidden;border:1px solid var(--border);background:var(--panel);box-shadow:var(--shadow);margin-top:8px}
.board-shell-head{
  display:flex;align-items:center;justify-content:space-between;
  padding:14px 16px;
  border-bottom:1px solid var(--border);
  gap:12px;
  flex-wrap:wrap;
}
.board-status{display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.status-legend{display:flex;gap:14px;align-items:center;flex-wrap:wrap;color:var(--muted);font-size:12px}
#labels-toolbar{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-left:auto}
.board-shell #board{padding:0 14px 16px;}

/* Groups */
.group{
  position:relative;
  margin:16px 0;
  border:1px solid var(--border);
  border-radius:14px;
  overflow:hidden;
  background:linear-gradient(180deg, var(--panel-soft) 0%, var(--panel-2) 100%);
  box-shadow:0 8px 24px rgba(0,0,0,.22);
}
.group::before{
  content:"";
  position:absolute;left:0;top:0;bottom:0;width:6px;
  background:var(--group-accent, var(--accent));
}
.group-title{
  width:100%;text-align:left;display:flex;gap:12px;align-items:center;background:transparent;color:#fff;
  border:none;padding:14px 16px 13px 22px;font-weight:800;cursor:pointer;letter-spacing:0.4px;text-transform:uppercase;
}
.group .chev{
  width:10px;height:10px;border-right:2px solid #cbd5f1;border-bottom:2px solid #cbd5f1;transform:rotate(-45deg);transition:transform .2s ease
}
.group.collapsed .chev{transform:rotate(-135deg)}
.group-title .group-meta{display:flex;flex-direction:column;gap:4px;align-items:flex-start}
.group-name{font-size:15px}
.group-count{color:var(--muted);font-size:12px;text-transform:none;letter-spacing:0}
.group-content{padding:12px 14px 16px;background:transparent}
.group.collapsed .group-content{display:none}

/* Group colour mapping */
.group[data-group-key*="hold"]{--group-accent:#d94c64}
.group[data-group-key*="office"]{--group-accent:#f24c4c}
.group[data-group-key*="print"]{--group-accent:#f3d14b}
.group[data-group-key*="embroidery"]{--group-accent:#f18b2e}
.group[data-group-key*="pre-production"]{--group-accent:#2ec983}
.group[data-group-key*="to-sample"]{--group-accent:#47c47c}
.group[data-group-key*="completed"]{--group-accent:#35d07f}

/* Table */
.data-table{width:100%;border-collapse:collapse;background:var(--panel-soft);border:1px solid var(--border);table-layout:fixed}
.data-table th,.data-table td{border:1px solid var(--border);padding:12px 10px}
.data-table thead th{background:var(--panel-2);color:#cdd6ee;text-align:left;font-weight:800;font-size:12px;letter-spacing:0.5px;text-transform:uppercase}
.data-table td{vertical-align:middle;background:rgba(255,255,255,.02)}
.data-table tbody tr:hover td{background:rgba(255,255,255,.03)}

/* Board grid (replaces table for dashboard board) */
.board-grid{display:flex;flex-direction:column;border:1px solid var(--border);border-radius:10px;overflow:hidden}
.grid-row{display:grid;grid-template-columns: var(--actions-col) 1fr var(--sync-col);align-items:center;width:100%;}
.grid-row:not(.grid-head){border-top:1px solid var(--border);}
.grid-head .grid-cell{background:var(--panel-2);color:#cdd6ee;font-weight:800;font-size:12px;letter-spacing:0.5px;text-transform:uppercase;border-right:1px solid var(--border);}
.grid-row .grid-cell{padding:12px 12px;min-width:0;background:rgba(255,255,255,.02);}
.grid-row.job-row:hover .grid-cell{background:rgba(255,255,255,.03);}
.grid-head .grid-cell:last-child,
.grid-row .grid-cell:last-child{border-right:none;}

.actions-cell{display:flex;align-items:center;gap:8px;}
.job-cell{display:flex;align-items:center;gap:10px;min-width:0;}
.title-cell{width:100%;}
.title-wrap{display:flex;align-items:center;gap:10px;min-width:0;width:100%}
.job-title{font-weight:800;font-size:17px;color:#f1f5ff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1;min-width:0}
.sync-cell{display:flex;justify-content:flex-end;}

.status-cell{width:100%;text-align:right}
.status-cell .status-dots{ justify-content:flex-end; margin-left:auto; margin-right:0; }
.row-toggle,.row-toggle-spacer{
  width:24px;height:24px;display:inline-flex;align-items:center;justify-content:center;border-radius:8px;flex:0 0 auto;
}
.row-toggle{border:1px solid var(--border);background:var(--panel-2);cursor:pointer;position:relative}
.row-toggle::before{
  content:"";width:8px;height:8px;border-right:2px solid #cbd5f1;border-bottom:2px solid #cbd5f1;transform:rotate(-45deg);transition:transform .2s ease
}
.row-toggle.open::before{transform:rotate(45deg)}
.row-toggle-spacer{opacity:0}

.job-action{
  min-width:38px;height:38px;border-radius:10px;border:1px solid var(--border);
  background:var(--panel-2);color:#fff;font-weight:700;display:inline-flex;align-items:center;justify-content:center;
  gap:6px;padding:0 12px;box-shadow:0 6px 14px rgba(0,0,0,.25);
}
.job-action.primary{background:var(--accent);border-color:transparent;color:#fff}
.job-action.success{background:var(--ok);border-color:transparent;color:#04130e}
.camera-btn{min-width:38px;width:38px;padding:0;font-size:16px;line-height:1;text-align:center;border-radius:10px}

.sub-head,
.sub-row{grid-template-columns: var(--actions-col) 2fr 1fr 1fr 1fr 0.8fr var(--sync-col);}
.sub-row.hidden,.sub-head.hidden{display:none}
.sub-head .grid-cell{background:var(--panel-2);color:#cdd6ee;font-weight:800;font-size:12px;text-transform:uppercase;border-right:1px solid var(--border);}
.sub-head .grid-cell:last-child{border-right:none;text-align:right;}
.sub-row .grid-cell{background:#0d131e;}
.sub-cell{color:#dce3f5;font-weight:700;}
.sub-name-cell{display:flex;align-items:center;gap:8px;}
.sub-arrow{opacity:.7;margin-right:2px;color:var(--muted)}
.sub-title .muted{font-weight:500}
.sub-arrow{opacity:.7;margin-right:2px;color:var(--muted)}

/* Status dots */
.status-dots{display:flex;gap:8px;align-items:center;justify-content:flex-start}
.dot{display:inline-block;width:12px;height:12px;border-radius:50%;background:#1f2633;box-shadow:0 0 0 1px rgba(255,255,255,.06) inset}
.dot-purple{background:var(--dot-purple)!important}
.dot-gold{background:var(--dot-gold)!important}
.dot-green{background:var(--dot-green)!important}

/* Modal / Camera */
.modal{position:fixed;inset:0;background:rgba(0,0,0,0.55);display:flex;align-items:center;justify-content:center;z-index:1000;}
.modal.hidden{display:none}
.modal-inner{background:var(--panel);border:1px solid var(--border);border-radius:12px;width: min(720px, 92vw);box-shadow:0 16px 42px rgba(0,0,0,0.45);display:flex;flex-direction:column;max-height:90vh;}
.modal-head{display:flex;align-items:center;justify-content:space-between;padding:12px 14px;border-bottom:1px solid var(--border);}
.modal-head h3{margin:0;font-size:18px}
.modal-close{background:none;border:none;color:#fff;font-size:22px;cursor:pointer}
.modal-body{padding:12px 14px;display:grid;grid-template-columns: 1fr 1fr;gap:14px;}
.cam-live,.cam-preview{position:relative;border:1px dashed var(--border);border-radius:12px;overflow:hidden;min-height:240px;background:#0b1017;display:flex;align-items:center;justify-content:center;}
.cam-live video,.cam-preview img{width:100%;height:100%;object-fit:cover;}
.cam-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:rgba(0,0,0,0.45);color:#cbd5e1;font-weight:600;}
.cam-overlay.hidden{display:none}
.cam-preview.hidden{display:none}
.cam-live.hidden{display:none}
.modal-foot{padding:12px 14px;border-top:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:10px;}
.modal-actions{display:flex;gap:10px;align-items:center}
body.modal-open{overflow:hidden}

@media (max-width: 900px){
  .sidebar{width:200px}
  .board-shell-head{align-items:flex-start}
  .title-cell{flex-wrap:wrap}
  .job-title{white-space:normal}
}
@media (max-width: 720px){
  .app-container{flex-direction:column}
  .sidebar{position:relative;height:auto;width:100%}
  .board-shell-head{flex-direction:column;align-items:flex-start}
  .data-table col.col-print{width:140px}
}
@media (max-width: 840px){
  .modal-body{grid-template-columns:1fr}
}

/* Badges & helpers */
.badge{display:inline-block;padding:4px 10px;border-radius:999px;background:#1e293b;color:#e2e8f0;font-size:12px;border:1px solid var(--border)}
.mt-8 { margin-top: 8px; }

/* Legacy helpers still used by scripts */
.scan-pill-text{margin-left:12px}
.grid-2{display:grid;grid-template-columns: 1.2fr 1fr;gap:18px;}
@media (max-width: 1000px){ .grid-2{ grid-template-columns: 1fr; } }
.form-grid{display:grid;grid-template-columns: 1fr 1fr;gap:12px 14px;}
.form-grid .form-row{ display:block; }
.form-grid .form-row.full{ grid-column: 1 / -1; }
.form-grid label{ display:block; font-weight:600; color:#cfe0ff; }
.form-grid input, .form-grid textarea{
  width:100%; margin-top:6px; padding:8px 10px; border-radius:8px;
  border:1px solid var(--border); background:#0b1017; color:#fff;
}
.combo{position: relative;display: grid;grid-template-columns: 1fr auto;gap: 8px;align-items: center;}
.combo .dd{position:absolute; left:0; right:0; top:100%; margin-top:6px; background:#0f131a; border:1px solid var(--border); border-radius:10px; max-height:240px; overflow:auto; display:none; z-index:10;}
.combo .dd.open{ display:block; }
.dd-item{ padding:10px 12px; cursor:pointer; }
.dd-item:hover{ background:#0b1017; }
.dd-title{ font-weight:600; color:#fff; }
.dd-sub{ font-size:12px; color:#9db0cc; margin-top:2px; }
.colour-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:12px}

/* Visual Approvals */
.va-controls { display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)) auto; gap: 14px; align-items: end; }
.va-actions { display: flex; gap: 10px; align-items: center; justify-content: flex-end; flex-wrap: wrap; }
.va-status { grid-column: 1 / -1; text-align: right; font-weight: 700; min-height: 18px; color: var(--muted); }
.va-status[data-tone="success"] { color: var(--ok); }
.va-status[data-tone="error"] { color: var(--danger); }
.va-status[data-tone="info"] { color: var(--muted); }
.va-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); gap: 16px; }
.va-panel { background: #0f1622; border: 1px solid var(--border); border-radius: 10px; padding: 12px; min-height: 320px; display: flex; flex-direction: column; gap: 8px; }
.va-img-wrap { position: relative; min-height: 260px; background: #0b1017; border-radius: 8px; border: 1px solid var(--border); overflow: hidden; display:flex; align-items:center; justify-content:center; }
.va-panel img { width: 100%; height: 100%; object-fit: contain; background: transparent; border-radius: 8px; display:block; }
.va-panel img.hidden { display:none; }
.va-placeholder { position:absolute; inset:0; display:flex; align-items:center; justify-content:center; color: #55607a; font-weight:700; font-size:14px; padding: 0 12px; text-align:center; background:#0b1017; }
.va-placeholder.hidden { display:none; }
.va-img-dim { filter: blur(2px) brightness(0.4); }
.hidden { display: none !important; }
.va-label { font-weight: 800; font-size: 14px; color: #e5edff; }
.va-confidence { font-weight: 800; margin-bottom: 6px; }
.va-findings { color: var(--muted); font-size: 14px; }
.va-findings ul { margin: 4px 0 0 18px; padding: 0; }

.va-select-group { display: flex; flex-direction: column; gap: 6px; }
.va-select-group.tight { max-width: 160px; }
.va-select { position: relative; }
.va-select select {
  width: 100%;
  appearance: none;
  background: #0b1017;
  color: #fff;
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 10px 12px;
  font-weight: 700;
}
.va-select-arrow {
  position: absolute;
  right: 12px;
  top: 50%;
  transform: translateY(-50%);
  color: var(--muted);
  pointer-events: none;
}

.va-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.6);
  display: none;
  align-items: center;
  justify-content: center;
  z-index: 2000;
  backdrop-filter: blur(6px);
}
.va-overlay.show { display: flex; }
.va-overlay-box {
  background: #0f1622;
  border: 1px solid var(--border);
  border-radius: 14px;
  padding: 18px 20px;
  width: min(420px, 92vw);
  box-shadow: 0 16px 40px rgba(0,0,0,0.45);
}
.va-progress {
  height: 12px;
  background: #0b1017;
  border: 1px solid var(--border);
  border-radius: 999px;
  overflow: hidden;
  margin-top: 12px;
}
.va-progress-bar {
  height: 100%;
  width: 0%;
  background: linear-gradient(90deg, var(--accent), #5f8dfd);
  transition: width 0.25s ease;
}
.va-progress-label { margin-top: 8px; color: #cfe0ff; font-weight: 700; }

.va-confidence { font-size: 18px; }
.va-confidence .va-confidence-number { font-size: 24px; font-weight: 800; color: #e5edff; }
.va-findings { font-size: 15px; }

.va-preview-card { position: relative; overflow: hidden; }
.va-result-float {
  position:absolute;
  left:50%;
  top:50%;
  transform: translate(-50%,-50%);
  min-width: 280px;
  max-width: 420px;
  padding: 14px 16px;
  background: rgba(15,22,34,0.92);
  border: 1px solid var(--border);
  border-radius: 12px;
  box-shadow: var(--shadow);
  backdrop-filter: blur(6px);
  z-index: 5;
}
.va-preview-card.dim .va-img-wrap img { filter: blur(3px) brightness(0.35); }
.va-preview-card.dim .va-placeholder { filter: blur(1px) brightness(0.4); }
@media (max-width: 900px){
  .va-result-float{ position:static; transform:none; margin:12px 0 0 0; }
}
@media (max-width: 720px){
  .va-controls { grid-template-columns: 1fr; }
  .va-actions { justify-content: flex-start; }
  .va-status { text-align: left; }
}
