/* Users & roles — Day 7
   Staff cards + role grid + audit log. All copy plain English. */

.usr-staff-list { display: flex; flex-direction: column; gap: 8px; margin-bottom: 16px; }
.usr-staff-row {
  display: grid;
  grid-template-columns: 1fr 120px 200px 120px;
  align-items: center;
  gap: 14px;
  padding: 14px 16px;
  background: var(--bg-elevated, #fff);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
}
.usr-staff-row__person { display: flex; flex-direction: column; gap: 3px; }
.usr-staff-row__name { font-weight: 600; font-size: 15px; color: var(--fg); }
.usr-staff-row__email { font-size: 13px; color: var(--muted); }
.usr-role-chip {
  display: inline-block;
  padding: 4px 12px;
  border-radius: var(--radius-full);
  font-size: 12px;
  font-weight: 600;
  text-transform: capitalize;
}
.usr-role-chip--admin   { background: color-mix(in srgb, var(--red) 14%, transparent);   color: var(--red-ink);}
.usr-role-chip--manager { background: color-mix(in srgb, var(--amber) 18%, transparent); color: var(--amber-ink);}
.usr-role-chip--cashier { background: color-mix(in srgb, var(--green) 14%, transparent); color: var(--green-ink);}
.usr-role-chip--clerk   { background: color-mix(in srgb, var(--blue) 14%, transparent);  color: var(--blue); }
.usr-role-chip--viewer  { background: var(--bg-subtle); color: var(--muted); }
.usr-staff-row__last-active { font-size: 12px; color: var(--muted); }
.usr-staff-row__actions { display: flex; gap: 4px; justify-content: flex-end; }

.usr-invites { display: flex; flex-direction: column; gap: 6px; margin-bottom: 16px; }
.usr-invite-row {
  display: grid;
  grid-template-columns: 1fr 120px 180px 120px;
  align-items: center;
  gap: 14px;
  padding: 12px 16px;
  background: color-mix(in srgb, var(--amber) 6%, var(--bg-elevated, #fff));
  border: 1px solid color-mix(in srgb, var(--amber) 25%, var(--border));
  border-radius: var(--radius-md);
  font-size: 14px;
}
.usr-invite-row__pill {
  display: inline-block;
  padding: 2px 8px;
  border-radius: var(--radius-full);
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  background: var(--amber);
  color: #fff;
}

.usr-invite-callout {
  margin-top: 18px;
  padding: 20px 22px;
  background: color-mix(in srgb, var(--fg) 4%, var(--bg-elevated, #fff));
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
}
.usr-invite-callout strong { font-family: var(--font-heading); font-size: 16px; color: var(--fg); display: block; margin-bottom: 4px; }
.usr-invite-form {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  align-items: flex-end;
  margin-top: 12px;
}
.usr-invite-form .pos-pay-field { flex: 1 1 160px; }
.usr-invite-form select, .usr-invite-form input {
  padding: 10px 12px;
  border: 1px solid var(--border-strong);
  border-radius: var(--radius-sm);
  font-size: 14px;
}
/* Mobile: the invite row (Email + Name + Role + Send) squeezes the Name
   and Role fields to ~60-70px — unusable. The inline style="flex:1.5/1"
   on each field beats the .pos-pay-field flex-basis, so override with
   !important and force one field per row (full-width stack). */
@media (max-width: 640px) {
  .usr-invite-form .pos-pay-field { flex: 1 1 100% !important; }
  .usr-invite-form .pos-btn { width: 100%; }
}

/* Roles grid */
.usr-roles-list { display: flex; flex-direction: column; gap: 12px; }
.usr-role-card {
  background: var(--bg-elevated, #fff);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  padding: 18px 20px;
}
.usr-role-card__head {
  display: flex;
  align-items: center;
  gap: 14px;
  margin-bottom: 8px;
}
.usr-role-card__title { font-family: var(--font-heading); font-size: 18px; }
.usr-role-card__blurb { color: var(--muted); font-size: 14px; line-height: 1.5; margin: 6px 0 14px; }
.usr-role-perms {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 6px 16px;
  font-size: 13px;
}
.usr-role-perm { display: flex; gap: 8px; align-items: flex-start; padding: 4px 0; }
.usr-role-perm__check { color: var(--green-ink);font-weight: 700; flex-shrink: 0; }
.usr-role-perm__x     { color: var(--muted); flex-shrink: 0; }
.usr-role-perm__label--off { color: var(--muted); text-decoration: line-through; text-decoration-color: rgba(0,0,0,0.2); }
.usr-role-perm__threshold { font-family: var(--font-tabular); color: var(--amber-ink);font-weight: 600; font-size: 12px; }
.usr-role-section { margin-top: 12px; font-size: 11px; text-transform: uppercase; letter-spacing: 0.04em; color: var(--muted); font-weight: 600; }

/* Audit log */
.usr-audit-list { display: flex; flex-direction: column; gap: 6px; }
.usr-audit-row {
  display: grid;
  grid-template-columns: 130px 140px 1fr 130px;
  gap: 14px;
  align-items: center;
  padding: 10px 14px;
  border-bottom: 1px solid var(--border);
  font-size: 13px;
}
.usr-audit-row:hover { background: var(--bg-subtle); }
.usr-audit-row__kind {
  display: inline-block;
  padding: 2px 8px;
  border-radius: var(--radius-full);
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  background: var(--bg-subtle);
  color: var(--muted);
}
.usr-audit-row__kind--role_change   { background: color-mix(in srgb, var(--amber) 14%, transparent); color: var(--amber-ink);}
.usr-audit-row__kind--refund        { background: color-mix(in srgb, var(--red) 12%, transparent); color: var(--red-ink);}
.usr-audit-row__kind--invite_sent   { background: color-mix(in srgb, var(--blue) 14%, transparent); color: var(--blue); }
.usr-audit-row__kind--price_change  { background: color-mix(in srgb, var(--amber) 14%, transparent); color: var(--amber-ink);}
.usr-audit-row__kind--invoice_void  { background: color-mix(in srgb, var(--red) 14%, transparent); color: var(--red-ink);}

.usr-roles-nav {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 12px 14px;
  margin-bottom: 16px;
  background: var(--bg-subtle);
  border-radius: var(--radius-md);
  flex-wrap: wrap;
}

.usr-status-badge {
  display: inline-block;
  margin-left: 8px;
  padding: 2px 8px;
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  font-weight: 600;
  border-radius: var(--radius-full);
  vertical-align: middle;
}
.usr-status-badge--active   { background: color-mix(in srgb, var(--green) 16%, transparent); color: var(--green-ink);}
.usr-status-badge--pending  { background: color-mix(in srgb, var(--amber) 18%, transparent); color: var(--amber-ink);}
.usr-status-badge--disabled { background: color-mix(in srgb, var(--muted) 18%, transparent); color: var(--muted); }

/* Phone: audit-log row (130px 140px 1fr 130px) clips its trailing
   timestamp column off-screen — stack to one column. MUST be end-of-file:
   the base .usr-audit-row rule (line ~123) comes AFTER the invite-form
   @media block at line 83, so the stacking override has to live below it
   to win on equal specificity. */
@media (max-width: 640px) {
  .usr-audit-row { grid-template-columns: 1fr; gap: 4px; }
  .usr-audit-row__kind { justify-self: start; }
}
