:root {
  --bg: #1b1b1b;
  --fg: #f5f5f5;
  --muted: #a8a8a8;
  --accent: #b58b00;
  --err: #d35400;
  --ok: #2ecc71;
  --card: #252525;
  --border: #3a3a3a;
  --uncertain: #3a3418;
}

* { box-sizing: border-box; margin: 0; padding: 0; }

html, body {
  background: var(--bg);
  color: var(--fg);
  font-family: system-ui, -apple-system, "Segoe UI", sans-serif;
  height: 100%;
  overflow-x: hidden;
}

#app { min-height: 100vh; padding: 16px; }

button {
  background: var(--accent);
  color: #000;
  border: none;
  padding: 14px 20px;
  border-radius: 8px;
  font-size: 16px;
  font-weight: 600;
  cursor: pointer;
  touch-action: manipulation;
}

button.secondary { background: var(--card); color: var(--fg); }
button.danger { background: var(--err); color: #fff; }
button:disabled { opacity: .5; }

input, select, textarea {
  background: var(--card);
  color: var(--fg);
  border: 1px solid var(--border);
  padding: 10px;
  border-radius: 6px;
  font-size: 16px;
  width: 100%;
}

.field.uncertain input, .field.uncertain select { background: var(--uncertain); }

.row { padding: 12px; border-bottom: 1px solid var(--border); }
.row.flagged { border-left: 3px solid var(--accent); }
.toast {
  position: fixed; bottom: 24px; left: 50%; transform: translateX(-50%);
  background: var(--card); color: var(--fg); padding: 12px 20px;
  border-radius: 24px; border: 1px solid var(--border);
  transition: opacity .3s;
}
.toast.ok { border-color: var(--ok); }
.toast.err { border-color: var(--err); }

.home-buttons { display: flex; flex-direction: column; gap: 16px; margin-top: 40px; }
.home-buttons button { padding: 24px; font-size: 20px; }

.camera-screen {
  position: fixed; inset: 0; background: #000;
  display: flex; flex-direction: column;
}
.camera-screen video { flex: 1; object-fit: cover; }
.camera-controls {
  display: flex; justify-content: space-between; align-items: center;
  padding: 16px 20px; background: rgba(0,0,0,.8);
}
.shutter {
  width: 72px; height: 72px; border-radius: 50%;
  background: #fff; border: 4px solid rgba(0,0,0,.3);
}
.shutter:disabled { opacity: .4; }
.status-chip {
  padding: 6px 12px; border-radius: 12px; font-size: 14px;
  background: var(--card);
}
.status-chip.ok { color: var(--ok); }
.status-chip.err { color: var(--err); }

.photo-viewport {
  width: 100%; aspect-ratio: 1 / 1; overflow: hidden;
  background: #000; position: relative;
  touch-action: none;
}
.photo-viewport img {
  position: absolute; left: 0; top: 0;
  width: 100%; height: 100%; object-fit: contain;
  transform-origin: 0 0;
  transition: transform .3s ease;
  user-select: none; -webkit-user-drag: none;
}
.field {
  display: flex; justify-content: space-between; align-items: center;
  padding: 12px; border-bottom: 1px solid var(--border); gap: 12px;
}
.field label { color: var(--muted); min-width: 110px; font-size: 14px; }
.field input, .field select { flex: 1; }
.action-row { display: flex; gap: 12px; padding: 16px; }
.action-row button { flex: 1; }

.admin-layout { display: grid; grid-template-columns: 220px 1fr; min-height: 100vh; }
.admin-sidebar { background: #111; border-right: 1px solid var(--border); padding: 24px 0; }
.admin-sidebar a {
  display: block; padding: 12px 24px; color: var(--fg);
  text-decoration: none;
}
.admin-sidebar a.active { background: var(--card); color: var(--accent); }
.admin-main { padding: 24px 32px; }
.admin-main table { width: 100%; border-collapse: collapse; }
.admin-main th, .admin-main td {
  text-align: left; padding: 8px 12px; border-bottom: 1px solid var(--border);
  font-size: 14px;
}
