:root{
  --red:#E0241C; --red-dark:#B81C16; --ink:#1A1A1A; --muted:#6F6E6A;
  --bg:#F6F5F2; --surface:#FFFFFF; --line:#E7E5E0;
  --ok:#1D9E75; --ok-bg:#E1F5EE; --warn:#BA7517; --warn-bg:#FAEEDA; --danger-bg:#FCEBEB;
  --radius:14px; --radius-sm:10px;
  --font:-apple-system,BlinkMacSystemFont,"Segoe UI","Sarabun","Noto Sans Thai",Roboto,sans-serif;
}
*{box-sizing:border-box}
html,body{margin:0}
body{font-family:var(--font);background:var(--bg);color:var(--ink);line-height:1.6;
  -webkit-font-smoothing:antialiased;padding:0 16px 48px}
.wrap{max-width:560px;margin:0 auto}
.wrap.wide{max-width:1000px}

header.bar{display:flex;align-items:center;justify-content:space-between;gap:12px;
  padding:18px 2px 22px}
header.bar img{height:30px;width:auto;display:block}
header.bar .tag{font-size:13px;color:var(--muted)}
a{color:var(--red);text-decoration:none}
a:hover{text-decoration:underline}

h1{font-size:24px;font-weight:600;margin:6px 0 4px}
h2{font-size:18px;font-weight:600;margin:0 0 14px}
.sub{color:var(--muted);margin:0 0 22px}

.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);
  padding:22px;margin-bottom:16px}

.actions{display:grid;gap:14px}
.tile{display:flex;align-items:center;gap:16px;background:var(--surface);border:1px solid var(--line);
  border-radius:var(--radius);padding:20px;cursor:pointer;text-decoration:none;color:var(--ink);
  transition:border-color .15s, transform .05s}
.tile:hover{border-color:var(--red);text-decoration:none}
.tile:active{transform:scale(.99)}
.tile .ic{width:46px;height:46px;flex:none;border-radius:12px;background:var(--danger-bg);
  display:grid;place-items:center;color:var(--red);font-size:24px;font-weight:700}
.tile .t{font-size:18px;font-weight:600}
.tile .d{font-size:14px;color:var(--muted)}

.btn{appearance:none;border:0;border-radius:var(--radius-sm);font:inherit;font-weight:600;
  padding:15px 18px;cursor:pointer;background:var(--red);color:#fff;font-size:17px;width:100%}
.btn:hover{background:var(--red-dark)}
.btn:disabled{opacity:.5;cursor:not-allowed}
.btn.ghost{background:transparent;color:var(--ink);border:1px solid var(--line)}
.btn.ghost:hover{background:#faf9f6;border-color:var(--red)}
.btn.sm{width:auto;padding:9px 13px;font-size:14px}
.row2{display:grid;grid-template-columns:1fr 1fr;gap:12px}

label{display:block;font-size:14px;font-weight:600;margin:0 0 6px}
input,select{width:100%;font:inherit;padding:13px 12px;border:1px solid var(--line);
  border-radius:var(--radius-sm);background:#fff;color:var(--ink)}
input:focus,select:focus{outline:2px solid var(--red);outline-offset:-1px;border-color:var(--red)}
.field{margin-bottom:16px}

.cam{position:relative;background:#111;border-radius:var(--radius);overflow:hidden;aspect-ratio:4/3;
  margin-bottom:16px;display:grid;place-items:center}
.cam video{width:100%;height:100%;object-fit:cover;transform:scaleX(-1)}
.cam .ring{position:absolute;inset:0;border:3px solid rgba(255,255,255,.0);border-radius:var(--radius);
  pointer-events:none;transition:border-color .2s}
.cam.scanning .ring{border-color:var(--red)}
.cam .hint{position:absolute;color:#fff;font-size:14px;opacity:.85}

.result{border-radius:var(--radius);padding:18px;margin-bottom:16px;border:1px solid var(--line)}
.result .who{font-size:22px;font-weight:700}
.result .meta{color:var(--muted);font-size:14px}
.result.ok{background:var(--ok-bg);border-color:#9FE1CB}
.result.ok .who{color:#0F6E56}
.result.late{background:var(--warn-bg);border-color:#FAC775}
.result.late .who{color:#854F0B}
.result.err{background:var(--danger-bg);border-color:#F7C1C1}
.result.err .who{color:#A32D2D;font-size:18px}

.pill{display:inline-block;font-size:12px;font-weight:600;padding:3px 10px;border-radius:999px;
  background:var(--bg);border:1px solid var(--line);color:var(--muted)}
.pill.green{background:var(--ok-bg);color:#0F6E56;border-color:#9FE1CB}
.pill.amber{background:var(--warn-bg);color:#854F0B;border-color:#FAC775}
.pill.red{background:var(--danger-bg);color:#A32D2D;border-color:#F7C1C1}

table{width:100%;border-collapse:collapse;font-size:14px}
th,td{text-align:left;padding:10px 8px;border-bottom:1px solid var(--line);white-space:nowrap}
th{font-weight:600;color:var(--muted);font-size:13px}
td.num{text-align:right;font-variant-numeric:tabular-nums}
.toolbar{display:flex;flex-wrap:wrap;gap:10px;align-items:end;margin-bottom:14px}
.toolbar .field{margin:0}
.scroll{overflow-x:auto}
.muted{color:var(--muted)}
.center{text-align:center}
.loading{color:var(--muted);font-size:14px;padding:6px 0}
.tabs{display:flex;gap:6px;margin-bottom:16px;flex-wrap:wrap}
.tab{padding:9px 14px;border:1px solid var(--line);border-radius:999px;background:#fff;cursor:pointer;font-size:14px;font-weight:600;color:var(--muted)}
.tab.on{background:var(--red);color:#fff;border-color:var(--red)}
.hide{display:none}
