/* Admin portal — sits on top of the shared style.css. Compact, dense
   surface for reading the queue + acting on orders. */

.admin-topbar {
  display: flex; justify-content: space-between; align-items: center;
  gap: 16px; padding: 12px 22px; background: #14171c; color: #f3f1ea;
}
.admin-topbar .muted { color: #9a9ea7; }
.admin-topbar nav { display: flex; gap: 8px; align-items: center; }
.admin-topbar .navlink {
  font: inherit; padding: 6px 12px; border: 1px solid transparent;
  background: transparent; color: #cdd2dc; border-radius: 4px; cursor: pointer;
}
.admin-topbar .navlink:hover { border-color: #444a55; }
.admin-topbar .navlink.on { border-color: var(--accent); color: #fff; }

#app { padding: 18px 22px; }
#app h1 { margin: 0 0 12px; }
#app .panel {
  background: var(--card); border: 1px solid var(--line); border-radius: 6px;
  padding: 16px; margin-bottom: 14px;
}
#app table.grid {
  width: 100%; border-collapse: collapse; font-size: .9rem;
  font-variant-numeric: tabular-nums;
}
#app table.grid th, #app table.grid td {
  text-align: left; padding: 6px 10px; border-bottom: 1px solid var(--line);
}
#app table.grid th { color: var(--muted); font-weight: 500; font-size: .75rem; text-transform: uppercase; }
#app table.grid td.right { text-align: right; }
#app table.grid tr.clickable { cursor: pointer; }
#app table.grid tr.clickable:hover { background: #f6f2e6; }
#app .pill {
  display: inline-block; padding: 2px 8px; border-radius: 12px;
  font-size: .75rem; background: #e6e1d3; color: #444;
}
#app .pill.warn { background: #f0d9c5; color: #783a14; }
#app .pill.good { background: #cde6cd; color: #1e5128; }
#app .pill.info { background: #d4e1ef; color: #1d3e6d; }
#app .pill.bad  { background: #f0c5c5; color: #781414; }

#app .dash-cards { display: grid; grid-template-columns: repeat(4, 1fr); gap: 10px; margin-bottom: 14px; }
#app .dash-card { background: var(--card); border: 1px solid var(--line); border-radius: 6px; padding: 12px; }
#app .dash-card .dash-num { font-size: 1.6rem; font-weight: 700; font-variant-numeric: tabular-nums; }
#app .dash-card .dash-label { font-size: .8rem; color: var(--muted); }

#app .toolbar { display: flex; gap: 8px; margin-bottom: 12px; align-items: center; flex-wrap: wrap; }

#app .login {
  max-width: 360px; margin: 80px auto; padding: 24px;
  background: var(--card); border: 1px solid var(--line); border-radius: 6px;
}
#app .login label { display: block; margin: 8px 0; }
#app .login input { width: 100%; padding: 8px; border: 1px solid var(--line); border-radius: 4px; font: inherit; }
#app .login .err { color: #781414; margin-top: 8px; font-size: .85rem; }

#app .kanban { display: grid; grid-template-columns: repeat(4, 1fr); gap: 10px; }
#app .kanban .col { background: var(--card); border: 1px solid var(--line); border-radius: 6px; padding: 10px; min-height: 80px; }
#app .kanban .col h3 { font-size: .8rem; margin: 0 0 8px; color: var(--muted); text-transform: uppercase; }
#app .kanban .task { background: #fff; border: 1px solid var(--line); border-radius: 4px; padding: 8px; margin-bottom: 6px; }
#app .kanban .task .station { font-weight: 600; font-size: .85rem; }
#app .kanban .task .actions { display: flex; gap: 6px; margin-top: 6px; }
#app .kanban .task .actions button { font-size: .75rem; padding: 3px 8px; }

#app .actions-row { display: flex; gap: 8px; flex-wrap: wrap; margin: 8px 0 16px; }
#app .actions-row .btn { padding: 6px 12px; font-size: .85rem; }

#app .bom-row.make td:first-child { border-left: 3px solid var(--accent); }
#app .bom-row.buy  td:first-child { border-left: 3px solid #3d6dac; }

#app .po-card { border: 1px solid var(--line); border-radius: 4px; padding: 10px 12px; margin-bottom: 10px; }
#app .po-card + .po-card { margin-top: 6px; }
#app .po-head { display: flex; gap: 8px; align-items: center; margin-bottom: 6px; }
#app .po-card input.receive-qty { padding: 2px 4px; font: inherit; border: 1px solid var(--line); border-radius: 3px; }

#app .clock-running { text-align: center; padding: 24px; }
#app .clock-elapsed { font-size: 3.4rem; font-weight: 700; font-variant-numeric: tabular-nums; margin: 14px 0; }
#app .clock-meta { font-size: 1rem; margin: 6px 0; }
#app .clock-running .actions-row { justify-content: center; }

/* --- Mobile responsive --------------------------------------------------- */
/* Tables in admin panels are dense + wide. Let them scroll horizontally
   inside their panel rather than blowing out the page width. */
#app .panel { overflow-x: auto; }

@media (max-width: 800px) {
  .admin-topbar {
    padding: 10px 14px;
    flex-wrap: wrap;
    row-gap: 6px;
  }
  .admin-topbar nav {
    flex-wrap: wrap;
    width: 100%;
    justify-content: flex-start;
  }
  .admin-topbar #whoami { display: none; }   /* save space — email is in /me */
  .admin-topbar .navlink { padding: 6px 10px; font-size: .9rem; }

  #app { padding: 12px 14px; }
  #app .panel { padding: 12px; }
  #app h1 { font-size: 1.2rem; }
  #app .dash-cards { grid-template-columns: repeat(2, 1fr); }
  #app .kanban { grid-template-columns: 1fr; }
  #app .kanban .col { min-height: 0; }
  #app .actions-row { gap: 6px; }
  #app table.grid { font-size: .82rem; }
  #app table.grid th, #app table.grid td { padding: 5px 7px; }
  #app .clock-elapsed { font-size: 2.6rem; }
  #app .po-card { padding: 8px 10px; }
  #app .po-card input.receive-qty { width: 50px; }
}
@media (max-width: 480px) {
  #app .dash-cards { grid-template-columns: 1fr; }
  .admin-topbar .navlink { font-size: .85rem; padding: 5px 8px; }
}
