/* ============================================================
   kiosk.css — Gold / Dark Navy touch kiosk theme
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Barlow+Condensed:wght@400;600;700;800&family=JetBrains+Mono:wght@400;500&display=swap');

:root {
  --bg0:    #000000;
  --bg1:    #0a0e14;
  --bg2:    #111720;
  --bg3:    #1a2235;
  --border: #253045;
  --text:   #e2e8f0;
  --muted:  #6b7280;
  --gold:   #f5c400;
  --gold2:  #d4a800;
  --blue:   #3b82f6;
  --green:  #22c55e;
  --amber:  #f59e0b;
  --red:    #ef4444;
  --purple: #8b5cf6;
  --teal:   #0891b2;
}

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

html, body {
  height: 100%;
  background: var(--bg0);
  color: var(--text);
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 18px;
  overflow-x: hidden;
  -webkit-tap-highlight-color: transparent;
  user-select: none;
}

/* ── Header ──────────────────────────────────────────────── */
.kiosk-header {
  display: flex; justify-content: space-between; align-items: center;
  padding: 0 24px; height: 64px;
  background: var(--bg1); border-bottom: 2px solid var(--gold);
  position: sticky; top: 0; z-index: 100; flex-shrink: 0;
}
.kiosk-header-left { display: flex; align-items: center; gap: 12px; }
.kiosk-logo-icon   { font-size: 32px; }
.kiosk-appname     { font-size: 20px; font-weight: 800; color: var(--gold); letter-spacing: 1px; line-height: 1; }
.kiosk-appsub      { font-size: 12px; color: var(--muted); letter-spacing: 2px; text-transform: uppercase; }
.kiosk-header-right{ display: flex; align-items: center; gap: 20px; }
.kiosk-clock       { text-align: right; }
.clock-time        { display: block; font-size: 22px; font-weight: 700; color: #fff; line-height: 1; }
.clock-date        { display: block; font-size: 12px; color: var(--muted); }
.kiosk-user        { text-align: right; }
.hdr-role          { display: block; font-size: 10px; font-weight: 800; letter-spacing: 3px; color: var(--gold); }
.hdr-name          { display: block; font-size: 14px; font-weight: 700; color: #fff; }
.hdr-logout        {
  background: none; border: 1px solid var(--muted); color: var(--muted);
  padding: 4px 10px; border-radius: 4px; cursor: pointer; font-size: 16px;
  font-family: 'Barlow Condensed', sans-serif; margin-left: 8px;
}
.hdr-logout:hover { border-color: var(--red); color: var(--red); }

/* ── Main area ───────────────────────────────────────────── */
#kiosk-root {
  min-height: calc(100vh - 64px);
  display: flex; flex-direction: column;
}

/* ── Flash messages ──────────────────────────────────────── */
.flash {
  padding: 14px 20px; font-size: 17px; font-weight: 600; text-align: center;
  border-radius: 8px; margin: 12px 20px 0;
}
.flash-ok   { background: rgba(34,197,94,.15);  color: var(--green); border: 1px solid rgba(34,197,94,.3); }
.flash-err  { background: rgba(239,68,68,.15);  color: var(--red);   border: 1px solid rgba(239,68,68,.3); }
.flash-warn { background: rgba(245,196,0,.15);  color: var(--gold);  border: 1px solid rgba(245,196,0,.3); }

/* ── Centered screen ─────────────────────────────────────── */
.center-screen {
  flex: 1; display: flex; flex-direction: column;
  align-items: center; justify-content: center;
  padding: 40px 24px; text-align: center;
}
.login-icon  { font-size: 72px; margin-bottom: 16px; }
.screen-title{ font-size: 36px; font-weight: 800; color: #fff; letter-spacing: 2px; margin-bottom: 8px; }
.screen-sub  { font-size: 18px; color: var(--muted); margin-bottom: 28px; }

/* ── Scan indicator ──────────────────────────────────────── */
.scan-indicator {
  border: 2px solid var(--gold); border-radius: 12px;
  padding: 16px 40px; font-size: 20px; font-weight: 700;
  color: var(--gold); letter-spacing: 3px; text-transform: uppercase;
  background: rgba(245,196,0,.05);
}
@keyframes pulse-gold {
  0%, 100% { box-shadow: 0 0 0 0 rgba(245,196,0,.4); }
  50%       { box-shadow: 0 0 0 12px rgba(245,196,0,0); }
}
.pulse { animation: pulse-gold 2s infinite; }

/* ── Manual ID entry ─────────────────────────────────────── */
.login-divider {
  display: flex; align-items: center; gap: 12px;
  margin: 20px 0; width: 100%; max-width: 360px;
}
.login-divider::before, .login-divider::after {
  content: ''; flex: 1; height: 1px; background: var(--border);
}
.login-divider span { color: var(--muted); font-size: 14px; letter-spacing: 2px; }
.manual-id-wrap {
  display: flex; gap: 8px; width: 100%; max-width: 360px;
}
.manual-id-input {
  flex: 1; background: var(--bg2); border: 1px solid var(--border);
  color: var(--text); padding: 12px 16px; border-radius: 8px;
  font-size: 18px; font-family: 'Barlow Condensed', sans-serif;
  text-transform: uppercase; letter-spacing: 1px;
}
.manual-id-input:focus { outline: none; border-color: var(--gold); }
.manual-id-input::placeholder { color: var(--muted); text-transform: none; letter-spacing: 0; }

/* ── PIN screen ──────────────────────────────────────────── */
.pin-header   { text-align: center; margin-bottom: 24px; }
.pin-emp-id   { font-size: 20px; font-weight: 700; color: var(--gold); letter-spacing: 2px; }
.pin-label    { font-size: 14px; color: var(--muted); margin: 4px 0 12px; text-transform: uppercase; letter-spacing: 3px; }
.pin-dots     { font-size: 28px; color: var(--gold); letter-spacing: 12px; }

.numpad {
  display: grid; grid-template-columns: repeat(3, 90px);
  gap: 12px; margin: 0 auto;
}
.numpad-btn {
  width: 90px; height: 90px; border-radius: 12px;
  background: var(--bg2); border: 1px solid var(--border);
  color: #fff; font-size: 32px; font-weight: 700; cursor: pointer;
  font-family: 'Barlow Condensed', sans-serif;
  transition: background .1s, border-color .1s;
}
.numpad-btn:active, .numpad-btn:hover { background: var(--bg3); border-color: var(--gold); color: var(--gold); }
.numpad-blank { width: 90px; height: 90px; }
.pin-actions  { display: flex; gap: 12px; margin-top: 20px; justify-content: center; }

/* ── Kiosk buttons ───────────────────────────────────────── */
.kbtn {
  padding: 14px 28px; border-radius: 10px; font-size: 19px; font-weight: 700;
  cursor: pointer; border: none; font-family: 'Barlow Condensed', sans-serif;
  text-decoration: none; transition: filter .1s, transform .08s;
  display: inline-flex; align-items: center; gap: 8px; letter-spacing: 1px;
}
.kbtn:active { transform: scale(.97); }
.kbtn-primary  { background: var(--gold); color: #000; }
.kbtn-secondary{ background: var(--bg3); border: 1px solid var(--border); color: var(--text); }
.kbtn-cancel   { background: rgba(239,68,68,.15); border: 1px solid rgba(239,68,68,.3); color: var(--red); }
.kbtn-confirm  { background: var(--gold); color: #000; }
.kbtn-logout   { background: rgba(239,68,68,.1); border: 1px solid rgba(239,68,68,.2); color: var(--red); }
.kbtn:hover    { filter: brightness(1.1); }

/* ── Menu ────────────────────────────────────────────────── */
.menu-screen {
  flex: 1; display: flex; flex-direction: column;
  align-items: center; padding: 32px 20px;
}
.menu-greeting  { font-size: 28px; font-weight: 700; color: #fff; margin-bottom: 4px; }
.menu-role-badge{
  font-size: 12px; font-weight: 800; letter-spacing: 3px; text-transform: uppercase;
  padding: 3px 12px; border-radius: 20px; margin-bottom: 28px;
}
.menu-role-badge.crew   { background: rgba(59,130,246,.15); color: var(--blue); }
.menu-role-badge.bintech{ background: rgba(34,197,94,.15);  color: var(--green); }
.menu-role-badge.admin  { background: rgba(245,196,0,.15);  color: var(--gold); }

.menu-grid {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
  gap: 16px; width: 100%; max-width: 700px; margin-bottom: 28px;
}
.menu-btn {
  padding: 24px 16px; border-radius: 14px; border: none; cursor: pointer;
  font-family: 'Barlow Condensed', sans-serif; font-size: 21px; font-weight: 700;
  color: #fff; text-align: center; letter-spacing: 1px;
  display: flex; flex-direction: column; align-items: center; gap: 10px;
  transition: filter .1s, transform .08s;
  text-shadow: 0 1px 3px rgba(0,0,0,.4);
}
.menu-btn:active { transform: scale(.97); filter: brightness(1.1); }
.menu-icon { font-size: 36px; }
.menu-btn.blue   { background: linear-gradient(135deg,#1d4ed8,#3b82f6); }
.menu-btn.amber  { background: linear-gradient(135deg,#92400e,#d97706); }
.menu-btn.gray   { background: linear-gradient(135deg,#374151,#6b7280); }
.menu-btn.green  { background: linear-gradient(135deg,#065f46,#16a34a); }
.menu-btn.gold   { background: linear-gradient(135deg,#92700a,#f5c400); color: #000; text-shadow: none; }
.menu-btn.purple { background: linear-gradient(135deg,#4c1d95,#7c3aed); }
.menu-btn.teal   { background: linear-gradient(135deg,#0f4c5c,#0891b2); }
.menu-btn.orange { background: linear-gradient(135deg,#9a3412,#ea580c); }

/* ── Flow screens ────────────────────────────────────────── */
.flow-screen { flex: 1; display: flex; flex-direction: column; padding: 20px; }
.flow-header {
  display: flex; align-items: center; gap: 16px; margin-bottom: 16px;
  padding-bottom: 12px; border-bottom: 1px solid var(--border);
}
.flow-header h2 {
  font-size: 26px; font-weight: 800; color: #fff;
  letter-spacing: 2px; text-transform: uppercase;
}
.flow-sub { font-size: 17px; color: var(--muted); margin-bottom: 20px; }
.back-btn {
  background: var(--bg2); border: 1px solid var(--border); color: var(--muted);
  padding: 8px 16px; border-radius: 8px; cursor: pointer;
  font-size: 16px; font-family: 'Barlow Condensed', sans-serif; font-weight: 700;
  white-space: nowrap;
}
.back-btn:hover { border-color: var(--gold); color: var(--gold); }

/* ── Unit grid ───────────────────────────────────────────── */
.unit-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(110px, 1fr)); gap: 12px; }
.unit-btn {
  padding: 24px 12px; border-radius: 10px; background: var(--bg2);
  border: 1px solid var(--border); color: #fff; font-size: 22px; font-weight: 700;
  cursor: pointer; font-family: 'Barlow Condensed', sans-serif; letter-spacing: 1px;
  transition: border-color .1s, background .1s;
}
.unit-btn:hover, .unit-btn:active { border-color: var(--gold); background: var(--bg3); color: var(--gold); }

/* ── Confirm box ─────────────────────────────────────────── */
.confirm-box {
  background: var(--bg1); border: 1px solid var(--border);
  border-radius: 12px; padding: 16px 20px; max-width: 520px; width: 100%;
}
.confirm-detail {
  display: flex; justify-content: space-between; align-items: center;
  padding: 10px 0; border-bottom: 1px solid var(--border); font-size: 18px;
}
.confirm-detail:last-child { border-bottom: none; }
.confirm-detail span   { color: var(--muted); font-size: 15px; }
.confirm-detail strong { color: #fff; }
.confirm-actions { display: flex; gap: 14px; justify-content: center; margin-top: 20px; flex-wrap: wrap; }

/* ── Bin type badge ──────────────────────────────────────── */
.bin-type-badge {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 6px 16px; border-radius: 20px; font-size: 16px; font-weight: 700;
  background: var(--bg2); border: 1px solid var(--border);
}
.bin-type-dot { width: 12px; height: 12px; border-radius: 50%; }

/* ── Restock / checklist ─────────────────────────────────── */
.checklist-grid { display: flex; flex-direction: column; gap: 8px; margin-top: 8px; }
.checklist-row {
  display: flex; align-items: center; gap: 12px;
  background: var(--bg1); border: 1px solid var(--border);
  border-radius: 8px; padding: 10px 14px; font-size: 17px;
}
.checklist-row.done    { border-color: rgba(34,197,94,.4); background: rgba(34,197,94,.05); }
.checklist-row.over    { border-color: rgba(245,196,0,.4); background: rgba(245,196,0,.05); }
.checklist-row.missing { border-color: rgba(239,68,68,.4); background: rgba(239,68,68,.05); }
.check-icon   { font-size: 22px; flex-shrink: 0; }
.check-name   { flex: 1; font-weight: 700; }
.check-qty    { color: var(--muted); font-size: 15px; }
.check-qty strong { color: #fff; }
.check-lot    { font-family: 'JetBrains Mono', monospace; font-size: 13px; color: var(--muted); }

/* ── Manual input ────────────────────────────────────────── */
.manual-input {
  background: var(--bg2); border: 1px solid var(--border); color: var(--text);
  padding: 12px 16px; border-radius: 8px; font-size: 18px;
  font-family: 'Barlow Condensed', sans-serif; width: 100%;
  transition: border-color .12s;
}
.manual-input:focus { outline: none; border-color: var(--gold); }
.date-input {
  background: var(--bg2); border: 1px solid var(--border); color: var(--text);
  padding: 10px 14px; border-radius: 8px; font-size: 18px;
  font-family: 'Barlow Condensed', sans-serif; width: 100%;
}
.date-input:focus { outline: none; border-color: var(--gold); }

.field-label { font-size: 14px; color: var(--muted); letter-spacing: 2px; text-transform: uppercase; display: block; margin-bottom: 4px; }
.expiry-row  { margin-bottom: 12px; }

/* ── Qty control ─────────────────────────────────────────── */
.qty-btn {
  width: 48px; height: 48px; border-radius: 8px;
  background: var(--bg2); border: 1px solid var(--border);
  color: var(--gold); font-size: 28px; font-weight: 700; cursor: pointer;
  font-family: 'Barlow Condensed', sans-serif;
}
.qty-btn:hover { background: var(--bg3); border-color: var(--gold); }
.section-label { font-size: 11px; color: var(--muted); letter-spacing: 3px; font-weight: 700; text-transform: uppercase; }

/* ── History ─────────────────────────────────────────────── */
.history-table { width: 100%; border-collapse: collapse; font-size: 16px; }
.history-table th {
  background: var(--bg0); padding: 8px 12px; text-align: left;
  font-size: 11px; font-weight: 700; letter-spacing: 2px; text-transform: uppercase;
  color: var(--muted); border-bottom: 1px solid var(--border);
}
.history-table td { padding: 10px 12px; border-bottom: 1px solid var(--border); }
.history-table tr:last-child td { border-bottom: none; }

/* ── Loading ─────────────────────────────────────────────── */
.loading-screen {
  flex: 1; display: flex; flex-direction: column;
  align-items: center; justify-content: center; gap: 20px; color: var(--muted);
}
@keyframes spin { to { transform: rotate(360deg); } }
.spinner {
  width: 52px; height: 52px; border: 4px solid var(--border);
  border-top-color: var(--gold); border-radius: 50%;
  animation: spin .8s linear infinite;
}
.empty-msg { text-align: center; color: var(--muted); font-size: 18px; padding: 32px; }

/* ── Search results (pickup) ─────────────────────────────── */
.search-result-item {
  display: flex; justify-content: space-between; align-items: center;
  padding: 12px 16px; background: var(--bg1); border: 1px solid var(--border);
  border-radius: 8px; margin-bottom: 8px; cursor: pointer;
  transition: border-color .1s;
}
.search-result-item:hover { border-color: var(--gold); }
.search-result-name  { font-size: 18px; font-weight: 700; }
.search-result-stock { font-size: 14px; color: var(--muted); }

/* ── Scrollbar ───────────────────────────────────────────── */
::-webkit-scrollbar       { width: 4px; }
::-webkit-scrollbar-thumb { background: var(--gold2); border-radius: 2px; }
::-webkit-scrollbar-track { background: var(--bg1); }
