/* ── FEAT-029 HiLabour v2 — Mechanic Dark Theme ─────────────────────── */

:root {
  --hlb-bg:          #0d1117;
  --hlb-card:        #161b22;
  --hlb-card-hi:     #1c2128;
  --hlb-border:      #30363d;
  --hlb-accent:      #f4a724;   /* HIConnect orange */
  --hlb-text:        #e6edf3;
  --hlb-muted:       #8b949e;
  --hlb-ok:          #238636;
  --hlb-ok-bg:       #0d2318;
  --hlb-mon:         #9e6a03;
  --hlb-mon-bg:      #271d04;
  --hlb-nok:         #da3633;
  --hlb-nok-bg:      #2d0f0e;
  --hlb-na:          #6e7681;
  --hlb-na-bg:       #161b22;
  --hlb-labour:      #1f6feb;
  --hlb-checklist:   #238636;
  --hlb-stock:       #9e6a03;
}

/* Page wrapper — mobile first, max 480px */
.hlb-page { background: var(--hlb-bg); min-height: 100vh; max-width: 480px; margin: 0 auto; color: var(--hlb-text); font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif; }

/* ── SCREEN 1: Setup ─────────────────────────────── */
.hlb-setup { padding: 24px 16px; display: flex; flex-direction: column; gap: 24px; }
.hlb-setup-title { text-align: center; font-size: 24px; font-weight: 700; color: var(--hlb-accent); }
.hlb-scan-label { font-size: 13px; color: var(--hlb-muted); text-transform: uppercase; letter-spacing: 0.08em; margin-bottom: 8px; }
.hlb-scan-input { width: 100%; background: var(--hlb-card); border: 2px solid var(--hlb-border); border-radius: 10px; padding: 18px 16px; font-size: 22px; font-weight: 700; color: var(--hlb-text); min-height: 64px; box-sizing: border-box; }
.hlb-scan-input:focus { border-color: var(--hlb-accent); outline: none; }
.hlb-validated { background: var(--hlb-ok-bg); border: 1px solid var(--hlb-ok); border-radius: 10px; padding: 12px 16px; }
.hlb-validated-name { font-size: 20px; font-weight: 700; color: var(--hlb-ok); }
.hlb-validated-sub { font-size: 13px; color: var(--hlb-muted); margin-top: 2px; }
.hlb-error-banner { background: var(--hlb-nok-bg); border: 1px solid var(--hlb-nok); border-radius: 10px; padding: 14px 16px; font-size: 14px; color: var(--hlb-nok); font-weight: 600; white-space: pre-line; line-height: 1.5; }
.hlb-card-error { font-size: 12px; font-weight: 600; color: var(--hlb-nok); padding: 4px 16px 8px; min-height: 0; }
.hlb-start-btn { background: var(--hlb-accent); color: #0d1117; border: none; border-radius: 12px; width: 100%; min-height: 68px; font-size: 18px; font-weight: 800; cursor: pointer; letter-spacing: 0.02em; }
.hlb-start-btn:disabled { opacity: 0.4; cursor: not-allowed; }

/* ── SCREEN 2: Main — Hero bar ───────────────────── */
.hlb-hero {
    background: linear-gradient(160deg, #161b22 0%, #0d1117 100%);
    padding: 16px 56px 14px;          /* side padding leaves room for Tukar btn */
    border-bottom: 1px solid var(--hlb-border);
}
.hlb-hero-center {
    display: flex; flex-direction: column;
    align-items: center; gap: 4px;
}
.hlb-plate {
    font-size: 34px; font-weight: 900;
    color: var(--hlb-accent);
    text-align: center; letter-spacing: 0.1em; line-height: 1.15;
}
.hlb-ro-line {
    font-size: 14px; font-weight: 600;
    color: var(--hlb-text); text-align: center;
    letter-spacing: 0.06em; opacity: 0.85;
}
.hlb-mech-line {
    font-size: 12px; font-weight: 500;
    color: var(--hlb-muted); text-align: center;
    letter-spacing: 0.03em;
}

/* Progress bar */
.hlb-progress { display: flex; gap: 4px; padding: 8px 16px; background: var(--hlb-card); border-bottom: 1px solid var(--hlb-border); }
.hlb-prog-seg { flex: 1; }
.hlb-prog-bar { height: 6px; border-radius: 3px; background: var(--hlb-border); overflow: hidden; }
.hlb-prog-fill-l { height: 100%; background: var(--hlb-labour); border-radius: 3px; transition: width 0.3s; }
.hlb-prog-fill-c { height: 100%; background: var(--hlb-checklist); border-radius: 3px; transition: width 0.3s; }
.hlb-prog-fill-s { height: 100%; background: var(--hlb-stock); border-radius: 3px; transition: width 0.3s; }
.hlb-prog-label { font-size: 11px; color: var(--hlb-muted); margin-top: 3px; display: flex; justify-content: space-between; }
.hlb-nok-badge { color: var(--hlb-nok); font-weight: 700; }

/* Tab bar */
.hlb-tabs { display: flex; border-bottom: 1px solid var(--hlb-border); background: var(--hlb-card); }
.hlb-tab { flex: 1; padding: 14px 8px; font-size: 14px; font-weight: 600; color: var(--hlb-muted); text-align: center; cursor: pointer; border-bottom: 2px solid transparent; background: transparent; border-top: none; border-left: none; border-right: none; }
.hlb-tab.active { color: var(--hlb-accent); border-bottom-color: var(--hlb-accent); }
.hlb-tab-content { padding: 12px 16px; overflow-y: auto; min-height: 200px; }

/* NOK strip */
.hlb-nok-strip { background: #271d04; border: 1px solid var(--hlb-mon); border-radius: 8px; padding: 10px 14px; margin-bottom: 12px; font-size: 14px; color: var(--hlb-mon); font-weight: 600; cursor: pointer; display: flex; align-items: center; gap: 8px; }

/* Section jump chips */
.hlb-jump-bar { display: flex; gap: 8px; overflow-x: auto; padding: 8px 0 4px; margin-bottom: 12px; scrollbar-width: none; }
.hlb-jump-bar::-webkit-scrollbar { display: none; }
.hlb-jump-chip { flex-shrink: 0; padding: 6px 14px; border-radius: 20px; background: var(--hlb-card-hi); border: 1px solid var(--hlb-border); font-size: 12px; color: var(--hlb-muted); cursor: pointer; white-space: nowrap; }
.hlb-jump-chip.active { background: var(--hlb-accent); color: #0d1117; border-color: var(--hlb-accent); font-weight: 700; }

/* ── CARDS ────────────────────────────────────────── */
.hlb-card { background: var(--hlb-card); border: 1px solid var(--hlb-border); border-radius: 12px; margin-bottom: 10px; overflow: hidden; }
.hlb-card-header { padding: 14px 16px 10px; }
.hlb-card-code { font-size: 13px; color: var(--hlb-muted); font-weight: 600; letter-spacing: 0.05em; }
.hlb-card-desc { font-size: 18px; font-weight: 700; color: var(--hlb-text); margin: 2px 0; }
.hlb-card-type { font-size: 13px; color: var(--hlb-muted); }
.hlb-card-status-row { padding: 0 16px 14px; display: flex; gap: 8px; }
.hlb-card-start-time { font-size: 11px; color: var(--hlb-accent); font-weight: 600; margin-top: 2px; }
.hlb-mandatory-badge { display: inline-flex; align-items: center; gap: 4px; font-size: 11px; color: var(--hlb-nok); font-weight: 600; margin-top: 4px; }

/* Labour status buttons */
.hlb-labour-btn { flex: 1; min-height: 56px; border: none; border-radius: 10px; font-size: 14px; font-weight: 800; cursor: pointer; letter-spacing: 0.03em; }
.hlb-btn-start    { background: var(--hlb-accent); color: #0d1117; }
.hlb-btn-done     { background: var(--hlb-ok); color: #fff; }
.hlb-btn-hold     { background: var(--hlb-mon-bg); color: var(--hlb-mon); border: 1px solid var(--hlb-mon); }
.hlb-btn-resume   { background: var(--hlb-labour); color: #fff; }
.hlb-status-done  { color: var(--hlb-ok); font-size: 13px; font-weight: 700; padding: 6px 16px 14px; }
.hlb-status-hold  { color: var(--hlb-mon); font-size: 13px; font-weight: 700; padding: 6px 16px 14px; }

/* Status pills (Checklist + Stock) */
.hlb-pills { display: flex; gap: 6px; padding: 0 16px 10px; }
.hlb-pill { flex: 1; min-height: 60px; border-radius: 10px; border: 2px solid; font-size: 13px; font-weight: 800; cursor: pointer; display: flex; align-items: center; justify-content: center; transition: opacity .15s; }

/* Default — each pill shows its own muted colour */
.hlb-pill-ok  { border-color: rgba(35,134,54,.45);  background: rgba(35,134,54,.08);  color: #3fb950; }
.hlb-pill-mon { border-color: rgba(158,106,3,.45);  background: rgba(158,106,3,.08);  color: #d29922; }
.hlb-pill-nok { border-color: rgba(218,54,51,.45);  background: rgba(218,54,51,.08);  color: #f85149; }
.hlb-pill-na  { border-color: rgba(110,118,129,.35); background: rgba(110,118,129,.08); color: #8b949e; }

/* Selected — full bright fill */
.hlb-pill-ok.selected  { background: var(--hlb-ok);  border-color: var(--hlb-ok);  color: #fff; }
.hlb-pill-mon.selected { background: var(--hlb-mon); border-color: var(--hlb-mon); color: #fff; }
.hlb-pill-nok.selected { background: var(--hlb-nok); border-color: var(--hlb-nok); color: #fff; }
.hlb-pill-na.selected  { background: #6e7681;        border-color: #6e7681;        color: #fff; }

/* Inactive — heavily dimmed when another pill in the group is selected */
.hlb-pill.inactive { opacity: 0.2; }

/* Immediate press feedback — compresses on tap so mechanic knows it registered */
.hlb-pill:active        { transform: scale(0.88); opacity: 0.8; }
.hlb-labour-btn:active  { transform: scale(0.97); filter: brightness(0.85); }
.hlb-qty-btn:active     { transform: scale(0.88); }

/* Remark input */
.hlb-remark { width: 100%; background: var(--hlb-card-hi); border: 1px solid var(--hlb-border); border-radius: 8px; padding: 12px 14px; font-size: 15px; color: var(--hlb-text); min-height: 48px; resize: none; margin: 0 16px 10px; width: calc(100% - 32px); box-sizing: border-box; }
.hlb-remark:focus { border-color: var(--hlb-accent); outline: none; }

/* Remark save button + saved tick */
.hlb-remark-save-row { display: flex; align-items: center; justify-content: flex-end; gap: 10px; padding: 0 16px 8px; margin-top: -4px; }
.hlb-remark-save-btn { background: transparent; border: 1px solid var(--hlb-border); border-radius: 8px; color: var(--hlb-muted); font-size: 12px; font-weight: 600; padding: 6px 14px; cursor: pointer; transition: all .2s; }
.hlb-remark-save-btn:active { background: var(--hlb-ok-bg); border-color: var(--hlb-ok); color: var(--hlb-ok); transform: scale(0.96); }
.hlb-remark-tick { font-size: 12px; font-weight: 600; color: transparent; transition: color .3s; }
.hlb-remark-tick-saved { color: #3fb950; }

/* Photo slots */
.hlb-photos { display: flex; gap: 10px; padding: 0 16px 14px; }
/* dcc.Upload and wrapper divs must also stretch to fill equal halves */
.hlb-photos > div { flex: 1; }
.hlb-photo-btn { flex: 1; min-height: 60px; background: var(--hlb-card-hi); border: 2px dashed var(--hlb-border); border-radius: 10px; color: var(--hlb-muted); font-size: 13px; font-weight: 600; cursor: pointer; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 4px; width: 100%; }
.hlb-photo-btn.has-photo { border-style: solid; border-color: var(--hlb-ok); }
.hlb-photo-btn.required { border-color: var(--hlb-nok); }
.hlb-photo-thumb { width: 100%; height: 60px; object-fit: cover; border-radius: 8px; }

/* Section headers */
.hlb-section { margin-bottom: 8px; }
.hlb-section-header { display: flex; align-items: center; justify-content: space-between; padding: 14px 16px; background: var(--hlb-card-hi); border-radius: 10px; cursor: pointer; min-height: 56px; }
.hlb-section-name { font-size: 15px; font-weight: 700; color: var(--hlb-text); }
.hlb-section-count { font-size: 12px; color: var(--hlb-muted); }
.hlb-section-nok { color: var(--hlb-nok); font-weight: 700; font-size: 12px; }
.hlb-sec-items { display: none; }
.hlb-sec-items.open { display: block; }

/* Quantity input (Stock) */
.hlb-qty-row { display: flex; align-items: center; gap: 12px; padding: 0 16px 10px; }
.hlb-qty-btn { width: 52px; height: 52px; border-radius: 10px; background: var(--hlb-card-hi); border: 1px solid var(--hlb-border); color: var(--hlb-text); font-size: 24px; font-weight: 700; cursor: pointer; display: flex; align-items: center; justify-content: center; }
.hlb-qty-val { flex: 1; text-align: center; font-size: 22px; font-weight: 700; color: var(--hlb-text); }
.hlb-qty-uom { font-size: 13px; color: var(--hlb-muted); }
.hlb-qty-issued { font-size: 12px; color: var(--hlb-muted); padding: 0 16px 6px; }

/* ── SCREEN 3: Sign-off ───────────────────────────── */
.hlb-signoff { padding: 16px; }
.hlb-signoff-title { font-size: 20px; font-weight: 800; color: var(--hlb-text); text-align: center; margin-bottom: 16px; }
.hlb-signoff-item { display: flex; align-items: center; justify-content: space-between; padding: 14px 16px; background: var(--hlb-card); border-radius: 10px; margin-bottom: 8px; }
.hlb-signoff-label { font-size: 16px; font-weight: 600; color: var(--hlb-text); }
.hlb-signoff-count { font-size: 15px; font-weight: 700; }
.hlb-signoff-ok { color: var(--hlb-ok); }
.hlb-signoff-warn { color: var(--hlb-mon); }
.hlb-signoff-divider { height: 1px; background: var(--hlb-border); margin: 16px 0; }
.hlb-signoff-info { padding: 14px 16px; background: var(--hlb-card); border-radius: 10px; margin-bottom: 16px; }
.hlb-signoff-row { display: flex; justify-content: space-between; font-size: 14px; margin-bottom: 4px; }
.hlb-signoff-key { color: var(--hlb-muted); }
.hlb-signoff-val { color: var(--hlb-text); font-weight: 600; }
.hlb-submit-btn { width: 100%; min-height: 68px; background: var(--hlb-ok); color: #fff; border: none; border-radius: 12px; font-size: 20px; font-weight: 800; cursor: pointer; }
.hlb-back-btn { width: 100%; min-height: 48px; background: transparent; border: 1px solid var(--hlb-border); border-radius: 14px; color: var(--hlb-muted); font-size: 15px; font-weight: 600; cursor: pointer; margin-bottom: 10px; transition: all .2s; }
.hlb-back-btn:hover { border-color: var(--hlb-accent); color: var(--hlb-accent); }

/* Confirm popup overlay */
.hlb-overlay { position: fixed; inset: 0; background: rgba(0,0,0,0.7); display: flex; align-items: flex-end; z-index: 9999; }
.hlb-popup { background: var(--hlb-card); border-radius: 20px 20px 0 0; padding: 24px 20px 32px; width: 100%; max-width: 480px; margin: 0 auto; }
.hlb-popup-title { font-size: 18px; font-weight: 800; color: var(--hlb-text); text-align: center; margin-bottom: 6px; }
.hlb-popup-sub { font-size: 14px; color: var(--hlb-muted); text-align: center; margin-bottom: 20px; }
.hlb-popup-yes { width: 100%; min-height: 60px; background: var(--hlb-ok); color: #fff; border: none; border-radius: 12px; font-size: 18px; font-weight: 800; cursor: pointer; margin-bottom: 10px; }
.hlb-popup-no  { width: 100%; min-height: 52px; background: transparent; border: 1px solid var(--hlb-border); border-radius: 12px; color: var(--hlb-muted); font-size: 16px; font-weight: 600; cursor: pointer; }

/* → Submit / Enter button */
.hlb-go-btn { flex-shrink: 0; width: 56px; min-height: 64px; background: var(--hlb-accent); border: none; border-radius: 14px; color: #000; font-size: 26px; font-weight: 900; cursor: pointer; transition: all .2s; display: flex; align-items: center; justify-content: center; }
.hlb-go-btn:hover          { background: #ff9500; transform: scale(1.04); }
.hlb-go-btn:active         { transform: scale(0.97); }
.hlb-go-btn:disabled,
.hlb-go-btn[disabled]      { background: var(--hlb-border); color: var(--hlb-muted); cursor: not-allowed; opacity: 0.5; transform: none; }

/* Camera scan button */
.hlb-cam-btn { flex-shrink: 0; width: 64px; min-height: 64px; background: var(--hlb-card-hi); border: 2px solid var(--hlb-accent); border-radius: 10px; display: flex; flex-direction: column; align-items: center; justify-content: center; cursor: pointer; font-size: 24px; color: var(--hlb-accent); user-select: none; -webkit-user-select: none; }
.hlb-cam-btn:active { background: var(--hlb-accent); color: #0d1117; }

/* Photo thumbnail inside upload button */
.hlb-photo-thumb { width: 100%; height: 52px; object-fit: cover; border-radius: 8px; display: block; }

/* Photo lightbox */
.hlb-lightbox { position: fixed; inset: 0; background: rgba(0,0,0,0.95); z-index: 9999; display: flex; flex-direction: column; }
.hlb-lightbox-img { flex: 1; object-fit: contain; width: 100%; }
.hlb-lightbox-bar { display: flex; gap: 12px; padding: 16px; background: var(--hlb-card); }
.hlb-lightbox-btn { flex: 1; min-height: 52px; border-radius: 10px; font-size: 15px; font-weight: 700; cursor: pointer; border: none; }
.hlb-lightbox-retake { background: var(--hlb-accent); color: #0d1117; }
.hlb-lightbox-delete { background: var(--hlb-nok-bg); border: 1px solid var(--hlb-nok); color: var(--hlb-nok); }
.hlb-lightbox-close  { background: var(--hlb-card-hi); color: var(--hlb-text); }

/* ── Sign-off Report ──────────────────────────────────── */
.hlb-report-wrap    { padding:12px; max-width:720px; margin:0 auto; }
.hlb-report-nok     { background:var(--hlb-nok-bg); border:1px solid rgba(239,68,68,.3); border-radius:14px; padding:14px 16px; margin-bottom:14px; display:flex; gap:12px; align-items:flex-start; animation:hlb-nok-pulse 2s ease-in-out infinite; }
.hlb-report-nok-title { font-size:14px; font-weight:700; color:var(--hlb-nok); }
.hlb-report-nok-sub   { font-size:12px; color:rgba(239,68,68,.7); margin-top:2px; }
.hlb-report-header  { background:linear-gradient(135deg,rgba(244,167,36,.1),rgba(244,167,36,.03)); border:1px solid rgba(244,167,36,.25); border-radius:16px; padding:18px 20px; margin-bottom:14px; }
.hlb-report-company { font-size:11px; color:var(--hlb-muted); text-transform:uppercase; letter-spacing:.08em; }
.hlb-report-title   { font-size:20px; font-weight:900; color:var(--hlb-accent); margin:4px 0 14px; }
.hlb-report-meta    { display:grid; grid-template-columns:1fr 1fr; gap:8px; }
.hlb-meta-label     { font-size:10px; color:var(--hlb-muted); text-transform:uppercase; letter-spacing:.06em; }
.hlb-meta-val       { font-size:14px; font-weight:700; margin-top:2px; }
.hlb-plate-accent   { color:var(--hlb-accent); }
.hlb-report-section { margin-bottom:14px; }
.hlb-report-sec-title { font-size:11px; font-weight:700; text-transform:uppercase; letter-spacing:.08em; color:var(--hlb-muted); padding:0 4px; margin-bottom:8px; display:flex; align-items:center; gap:8px; }
.hlb-report-sec-title::after { content:''; flex:1; height:1px; background:var(--hlb-border); }
.hlb-report-row     { background:var(--hlb-card); border:1px solid var(--hlb-border); border-radius:12px; padding:12px 14px; margin-bottom:6px; display:flex; align-items:flex-start; gap:10px; }
.hlb-report-row-icon { font-size:18px; flex-shrink:0; margin-top:1px; }
.hlb-report-row-body { flex:1; min-width:0; }
.hlb-report-row-name { font-size:14px; font-weight:600; }
.hlb-report-row-sub  { font-size:12px; color:var(--hlb-muted); margin-top:2px; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.hlb-report-status  { flex-shrink:0; padding:4px 10px; border-radius:20px; font-size:11px; font-weight:800; white-space:nowrap; }
.hlb-rs-completed, .hlb-rs-ok   { background:var(--hlb-ok-bg);  color:var(--hlb-ok); }
.hlb-rs-pending                  { background:rgba(59,130,246,.15); color:#60a5fa; }
.hlb-rs-hold, .hlb-rs-mon        { background:var(--hlb-mon-bg); color:var(--hlb-mon); }
.hlb-rs-nok                      { background:var(--hlb-nok-bg); color:var(--hlb-nok); }
.hlb-rs-na                       { background:rgba(107,114,128,.15); color:var(--hlb-na); }
.hlb-rs-none                     { background:rgba(255,255,255,.05); color:var(--hlb-muted); }
.hlb-report-empty   { padding:12px 14px; color:var(--hlb-muted); font-size:13px; font-style:italic; }
.hlb-report-sig     { display:grid; grid-template-columns:1fr 1fr; gap:12px; margin:16px 0 14px; }
.hlb-sig-box        { background:var(--hlb-card); border:1px solid var(--hlb-border); border-radius:14px; padding:14px; text-align:center; }
.hlb-sig-label      { font-size:10px; color:var(--hlb-muted); text-transform:uppercase; letter-spacing:.06em; }
.hlb-sig-line       { height:1px; background:var(--hlb-border); margin:28px 0 8px; }
.hlb-sig-name       { font-size:12px; color:var(--hlb-muted); }
.hlb-report-actions { display:block; }
.hlb-print-btn      { flex:1; min-height:56px; background:rgba(59,130,246,.15); border:1.5px solid rgba(59,130,246,.4); border-radius:14px; color:#60a5fa; font-size:15px; font-weight:700; cursor:pointer; transition:all .2s; }
.hlb-print-btn:hover { background:#1f6feb; color:#fff; border-color:#1f6feb; }
.hlb-submit-btn     { flex:1; min-height:56px; background:var(--hlb-ok); border:none; border-radius:14px; color:#fff; font-size:15px; font-weight:800; cursor:pointer; transition:all .2s; }
.hlb-submit-btn:hover { background:#16a34a; }

/* ── Photo capture review modal (shown after capture, before save) ─── */
.hlb-capture-overlay {
    position: fixed; inset: 0; z-index: 10001;
    background: rgba(0,0,0,0.95);
    display: flex; align-items: center; justify-content: center;
    padding: 16px;
}
.hlb-capture-card {
    background: var(--hlb-card); border-radius: 16px;
    width: 100%; max-width: 420px; overflow: hidden;
    display: flex; flex-direction: column;
}
.hlb-capture-title {
    padding: 12px 16px; font-size: 13px; font-weight: 700;
    color: var(--hlb-accent); text-align: center;
    background: var(--hlb-card-hi);
    text-transform: uppercase; letter-spacing: 0.05em;
}
.hlb-capture-img {
    width: 100%; max-height: 55vh; object-fit: contain; background: #000;
}
.hlb-capture-actions {
    display: flex; flex-direction: column; gap: 8px; padding: 12px 16px 16px;
}
.hlb-capture-save   { background: var(--hlb-ok); color: #fff; border: none; border-radius: 10px; padding: 15px; font-size: 16px; font-weight: 800; cursor: pointer; }
.hlb-capture-retake { background: var(--hlb-labour); color: #fff; border: none; border-radius: 10px; padding: 15px; font-size: 16px; font-weight: 700; cursor: pointer; }
.hlb-capture-cancel { background: transparent; color: var(--hlb-muted); border: 1px solid var(--hlb-border); border-radius: 10px; padding: 13px; font-size: 14px; font-weight: 600; cursor: pointer; }

/* Print styles */
@media print {
  /* Hide everything except the report */
  body > * { display: none !important; }
  #react-entry-point { display: block !important; }
  .hi-sidebar,
  [class*="hi-sidebar"],
  [id*="bulletin"],
  [class*="bulletin"],
  .hlb-no-print,
  .hlb-hero,
  .hlb-progress,
  .hlb-tabs,
  .tab-bar,
  .hlb-tab-bar { display: none !important; }

  /* Show only the report content */
  .hlb-page         { background: #fff !important; color: #000 !important; max-width: 100% !important; margin: 0 !important; }
  .hlb-report-wrap  { padding: 0 !important; max-width: 100% !important; }
  #tab-signoff      { display: block !important; padding: 0 !important; }

  /* History section — hide on print (KIV) */
  .hlb-hist-section,
  .hlb-history-tabs-wrapper,
  .hlb-hist-tabs { display: none !important; }

  /* Action buttons — hide on print */
  .hlb-report-actions { display: none !important; }

  /* Colour preservation */
  .hlb-report-header { background: #fff8e1 !important; -webkit-print-color-adjust: exact; print-color-adjust: exact; }
  .hlb-report-title  { color: #f4a724 !important; -webkit-print-color-adjust: exact; }
  .hlb-plate-accent  { color: #f4a724 !important; -webkit-print-color-adjust: exact; }
  .hlb-rs-completed, .hlb-rs-ok { background: #dcfce7 !important; color: #166534 !important; -webkit-print-color-adjust: exact; }
  .hlb-rs-nok  { background: #fee2e2 !important; color: #991b1b !important; -webkit-print-color-adjust: exact; }
  .hlb-rs-mon, .hlb-rs-hold { background: #fef3c7 !important; color: #92400e !important; -webkit-print-color-adjust: exact; }
  .hlb-rs-pending { background: #dbeafe !important; color: #1e40af !important; -webkit-print-color-adjust: exact; }
  .hlb-rs-none { background: #f3f4f6 !important; color: #6b7280 !important; -webkit-print-color-adjust: exact; }
  .hlb-report-row  { background: #f9f9f9 !important; border-color: #e5e7eb !important; -webkit-print-color-adjust: exact; }
  .hlb-report-nok  { background: #fee2e2 !important; -webkit-print-color-adjust: exact; }
  .hlb-sig-box     { background: #f9f9f9 !important; border-color: #e5e7eb !important; -webkit-print-color-adjust: exact; }
  .hlb-report-row-name, .hlb-meta-val, .hlb-report-sec-title { color: #111 !important; }
  .hlb-report-company, .hlb-meta-label, .hlb-sig-label, .hlb-sig-name, .hlb-report-row-sub { color: #555 !important; }
}

/* ── Photo preview popup ──────────────────────────────────── */
.hlb-preview-overlay { position:fixed; inset:0; background:rgba(0,0,0,0.93); z-index:9999; display:flex; flex-direction:column; align-items:center; justify-content:space-between; padding:16px; }
.hlb-preview-title   { width:100%; max-width:480px; font-size:13px; font-weight:600; color:var(--hlb-muted); text-align:center; padding-bottom:8px; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.hlb-preview-img     { flex:1; max-width:100%; max-height:calc(100vh - 180px); object-fit:contain; border-radius:10px; touch-action:pinch-zoom; cursor:zoom-in; }
.hlb-preview-actions { width:100%; display:flex; gap:10px; padding-top:12px; max-width:480px; }
.hlb-preview-btn     { flex:1; min-height:56px; border:none; border-radius:12px; font-size:14px; font-weight:700; cursor:pointer; transition:all .2s; }
.hlb-preview-replace { background:var(--hlb-accent); color:#000; }
.hlb-preview-delete  { background:var(--hlb-nok-bg); border:1.5px solid var(--hlb-nok); color:var(--hlb-nok); }
.hlb-preview-return  { background:var(--hlb-card-hi); border:1px solid var(--hlb-border); color:var(--hlb-muted); }

/* ── Responsive — tablet (768px+) ────────────────────────── */
@media (min-width: 768px) {
    .hlb-page         { max-width: 720px; }
    .hlb-hero         { padding: 20px 64px 16px; }
    .hlb-plate        { font-size: 44px; letter-spacing: 0.12em; }
    .hlb-ro-line      { font-size: 17px; }
    .hlb-mech-line    { font-size: 14px; }
    .hlb-scan-input   { font-size: 26px; min-height: 72px; }
    .hlb-start-btn    { min-height: 80px; font-size: 22px; }
    .hlb-pill         { min-height: 72px; font-size: 15px; }
    .hlb-photo-btn    { min-height: 72px; }
    .hlb-labour-btn   { min-height: 64px; font-size: 16px; }
    .hlb-qty-btn      { width: 64px; height: 64px; font-size: 28px; }
    .hlb-qty-val      { font-size: 26px; }
    .hlb-submit-btn   { min-height: 80px; font-size: 22px; }
    .hlb-cam-btn      { width: 72px; min-height: 72px; font-size: 28px; }
}

/* ── Responsive — desktop / web (1024px+) ─────────────────── */
@media (min-width: 1024px) {
    .hlb-page         { max-width: 860px; }
    .hlb-hero         { padding: 22px 72px 18px; }
    .hlb-plate        { font-size: 52px; }
    .hlb-ro-line      { font-size: 19px; }
    .hlb-mech-line    { font-size: 15px; }
    .hlb-pill         { min-height: 80px; font-size: 16px; }
    .hlb-card-desc    { font-size: 22px; }
    .hlb-labour-btn   { min-height: 72px; font-size: 18px; }
}

/* ── Live barcode scanner — full screen camera, minimal UI ───────── */
#hlb-scanner-modal {
    position: fixed; inset: 0; z-index: 20000; background: #000;
    flex-direction: column;
}
.hlb-scanner-video-full {
    width: 100%; height: 100%; object-fit: cover; flex: 1;
}
.hlb-scanner-bar {
    position: fixed; bottom: 0; left: 0; right: 0;
    padding: 16px 20px; background: rgba(0,0,0,0.7);
    display: flex; align-items: center; justify-content: space-between;
}
.hlb-scanner-status-txt { color: #fff; font-size: 14px; font-weight: 600; }
.hlb-scanner-cancel-btn {
    background: rgba(255,255,255,0.15); border: 1px solid rgba(255,255,255,0.3);
    color: #fff; border-radius: 8px; padding: 8px 20px;
    font-size: 14px; font-weight: 600; cursor: pointer;
}

/* ── Manual loading overlay (clientside — fires before API call) ─── */
#hlb-manual-loading {
    position: fixed; inset: 0; z-index: 19999;
    background: rgba(13,17,23,0.88); backdrop-filter: blur(3px);
    display: flex; align-items: center; justify-content: center;
    flex-direction: column; gap: 16px;
}
.hlb-manual-spinner {
    width: 44px; height: 44px; border-radius: 50%;
    border: 4px solid rgba(244,167,36,.2);
    border-top-color: var(--hlb-accent);
    animation: hlb-spin .8s linear infinite;
}
@keyframes hlb-spin { to { transform: rotate(360deg); } }
.hlb-manual-loading-text {
    color: var(--hlb-accent); font-size: 14px; font-weight: 700;
    letter-spacing: 0.06em;
}

/* ── Loading overlay — dark theme ────────────────────────────────── */
.hlb-page ._dash-loading,
.hlb-page [data-dash-is-loading="true"] > ._dash-loading-callback {
    background: rgba(13,17,23,0.88) !important;
    backdrop-filter: blur(3px);
}
/* Fullscreen overlay (when fullscreen=True) */
._dash-loading[style*="position: fixed"],
._dash-loading[style*="position:fixed"] {
    background: rgba(13,17,23,0.88) !important;
    backdrop-filter: blur(3px);
}
/* Spinner ring — orange */
.dash-spinner circle { stroke: var(--hlb-accent) !important; }
svg.dash-spinner path { fill: var(--hlb-accent) !important; }

/* Loading text label */
#hlb-loading-label {
    position: fixed; bottom: 40%; left: 50%; transform: translateX(-50%);
    color: var(--hlb-accent); font-size: 14px; font-weight: 600;
    letter-spacing: 0.05em; z-index: 9999; pointer-events: none;
    text-align: center; line-height: 1.5;
}

/* ── FEAT-034 Concurrency sync banner ───────────────────────────────── */
.hlb-sync-banner {
    background: #e67e22;
    color: #fff;
    padding: 10px 16px;
    border-radius: 6px;
    margin-bottom: 12px;
    display: flex;
    justify-content: space-between;
    align-items: center;
}
.hlb-sync-dismiss-btn {
    background: transparent;
    border: 1px solid rgba(255,255,255,0.5);
    color: #fff;
    border-radius: 4px;
    padding: 4px 10px;
    cursor: pointer;
    font-size: 14px;
    flex-shrink: 0;
    margin-left: 12px;
}

/* ── FEAT-036 History tabs + cards ──────────────────────────────────────── */
.hlb-hist-section { margin-top: 20px; padding: 0 4px; }

.hlb-hist-tabs .tab  { background: transparent !important; border: none !important; color: var(--hlb-muted) !important; font-size: 13px !important; font-weight: 600 !important; padding: 8px 14px !important; }
.hlb-hist-tabs .tab--selected { color: var(--hlb-accent) !important; border-bottom: 2px solid var(--hlb-accent) !important; }
.hlb-hist-tabs > div:first-child { background: var(--hlb-card) !important; border-bottom: 1px solid var(--hlb-border) !important; border-radius: 10px 10px 0 0; display: flex; }

.hlb-hist-tab      { padding: 8px 14px !important; color: var(--hlb-muted) !important; font-size: 13px !important; background: transparent !important; border: none !important; }
.hlb-hist-tab-active { color: var(--hlb-accent) !important; border-bottom: 2px solid var(--hlb-accent) !important; }

.hlb-hist-tab-body { padding: 10px 0; }

.hlb-hist-card {
    background: var(--hlb-card);
    border: 1px solid var(--hlb-border);
    border-radius: 12px;
    padding: 12px 14px;
    margin-bottom: 8px;
    position: relative;
}
.hlb-hist-card-top { display: flex; align-items: baseline; gap: 4px; margin-bottom: 4px; }
.hlb-hist-plate  { font-size: 15px; font-weight: 700; color: var(--hlb-text); }
.hlb-hist-date   { font-size: 12px; color: var(--hlb-muted); }
.hlb-hist-ro     { font-size: 12px; color: var(--hlb-muted); margin-bottom: 4px; }
.hlb-hist-svc    { font-size: 13px; color: var(--hlb-text); padding-right: 40px; }
.hlb-hist-btn {
    position: absolute; right: 12px; top: 50%; transform: translateY(-50%);
    background: #238636; color: #fff; border: none; border-radius: 20px;
    width: 34px; height: 34px; font-size: 16px; font-weight: 700;
    cursor: pointer; display: flex; align-items: center; justify-content: center;
}
.hlb-hist-empty {
    padding: 20px 14px; color: var(--hlb-muted); font-size: 13px;
    font-style: italic; text-align: center;
}

/* ── FEAT-036 History read-only modal ────────────────────────────────────── */
#hlb-history-modal {
    position: fixed; inset: 0; z-index: 15000;
    background: rgba(0,0,0,0.85);
    display: flex; align-items: flex-start; justify-content: center;
    overflow-y: auto;
}
.hlb-history-overlay {
    width: 100%; max-width: 480px; min-height: 100vh;
    display: flex; flex-direction: column;
}
.hlb-history-box {
    background: var(--hlb-bg);
    flex: 1; display: flex; flex-direction: column;
}
.hlb-history-modal-hdr {
    position: sticky; top: 0; z-index: 1;
    background: var(--hlb-card);
    border-bottom: 1px solid var(--hlb-border);
    padding: 12px 16px;
    display: flex; align-items: center; justify-content: space-between;
}
.hlb-history-modal-ttl {
    font-weight: 700; font-size: 13px;
    color: var(--hlb-muted); flex: 1;
}
.hlb-history-close-btn {
    background: var(--hlb-nok-bg);
    border: 1px solid var(--hlb-nok);
    color: var(--hlb-nok);
    border-radius: 8px;
    padding: 8px 14px;
    font-size: 13px; font-weight: 700;
    cursor: pointer; white-space: nowrap; flex-shrink: 0; margin-left: 12px;
}
.hlb-history-modal-body { flex: 1; overflow-y: auto; }
