/* Team & Permissions — Claude Design port (Session 18).
 *
 * Scope: page-only. Sidebar, top-strip, theme toggle, role pill, and
 * breadcrumb already come from `page_shell` — those rules from the
 * source HTML are intentionally not included here. All tokens come
 * from `tokens.css`.
 *
 * Source of truth: Haulbase_Claude_Design/assets/design/Team _ Permissions.html
 */

/* page wrapper ------------------------------------------------------ */
.tm-page { padding: 24px 28px 64px; max-width: 1400px; }

/* head ------------------------------------------------------------- */
.tm-head { display: flex; align-items: flex-end; justify-content: space-between; gap: 24px; margin-bottom: 22px; flex-wrap: wrap; }
.tm-head h1 { margin: 0; font: 700 28px/1.05 var(--font-display); letter-spacing: -0.015em; color: var(--fg-1); }
.tm-head .sub { color: var(--fg-3); font-size: 13.5px; margin-top: 6px; max-width: 660px; }
.tm-head .sub b { color: var(--fg-2); font-weight: 600; }

.tm-owner-banner {
  display: inline-flex; align-items: center; gap: 7px;
  margin-top: 10px;
  background: var(--bg-input); border: 1px solid var(--border-2); border-radius: var(--r-md);
  padding: 5px 9px;
  font: 500 11.5px/1 var(--font-body); color: var(--fg-3);
}
.tm-owner-banner svg { width: 13px; height: 13px; color: var(--accent-400); }
.tm-owner-banner b { color: var(--fg-1); font-weight: 600; }

.tm-actions { display: flex; gap: 8px; align-items: center; }
.tm-btn {
  height: 36px; padding: 0 14px; border-radius: var(--r-md);
  background: var(--bg-card); border: 1px solid var(--border-2); color: var(--fg-2);
  font: 600 12.5px/1 var(--font-display); display: inline-flex; align-items: center; gap: 6px; cursor: pointer;
}
.tm-btn:hover { color: var(--fg-1); border-color: var(--border-3); }
.tm-btn svg { width: 14px; height: 14px; }
.tm-btn.primary { background: var(--brand-cta); color: var(--brand-cta-fg); border-color: var(--brand-cta); box-shadow: var(--shadow-glow-amber); }
.tm-btn.primary:hover { background: var(--brand-cta-hover); border-color: var(--brand-cta-hover); }

/* card frame ------------------------------------------------------- */
.tm-card { background: var(--bg-card); border: 1px solid var(--border-1); border-radius: var(--r-lg); overflow: hidden; }
.tm-card + .tm-card { margin-top: 24px; }
.tm-card-head {
  display: flex; align-items: center; gap: 10px; flex-wrap: wrap;
  padding: 12px 18px; border-bottom: 1px solid var(--border-1); background: var(--bg-card-2);
}
.tm-card-head h3 { margin: 0; font: 700 13.5px/1 var(--font-display); color: var(--fg-1); letter-spacing: -0.005em; }
.tm-card-head .sub { font: 500 11.5px/1.4 var(--font-body); color: var(--fg-4); }
.tm-card-head .spacer { flex: 1; }
.tm-card-head .meta { font: 500 11.5px/1 var(--font-mono); color: var(--fg-4); }

/* invite form ------------------------------------------------------ */
.tm-invite {
  padding: 16px 18px;
  border-bottom: 1px solid var(--border-1); background: var(--bg-card-2);
  display: grid; grid-template-columns: 1.1fr 1.3fr 0.9fr 0.8fr auto auto; gap: 10px;
  align-items: end;
}
.tm-invite-eyebrow {
  grid-column: 1 / -1;
  font: 600 9.5px/1 var(--font-body); text-transform: uppercase; letter-spacing: .14em; color: var(--accent-300);
  display: flex; align-items: center; gap: 6px; margin-bottom: 2px;
}
.tm-invite-eyebrow svg { width: 12px; height: 12px; }
.tm-field { display: flex; flex-direction: column; gap: 6px; min-width: 0; }
.tm-field label { font: 600 9.5px/1 var(--font-body); text-transform: uppercase; letter-spacing: .14em; color: var(--fg-4); }
.tm-input {
  height: 34px; padding: 0 12px;
  background: var(--bg-input); border: 1px solid var(--border-2); border-radius: var(--r-md);
  color: var(--fg-1); font: 500 13px/1 var(--font-body); outline: none;
  width: 100%;
}
.tm-input::placeholder { color: var(--fg-4); font-weight: 400; }
.tm-input:focus { border-color: var(--accent-500); }
.tm-select {
  height: 34px; padding: 0 28px 0 12px;
  background: var(--bg-input); border: 1px solid var(--border-2); border-radius: var(--r-md);
  color: var(--fg-1); font: 600 13px/1 var(--font-display); outline: none;
  appearance: none;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%2394a3b8' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><path d='m6 9 6 6 6-6'/></svg>");
  background-repeat: no-repeat; background-position: right 10px center;
  width: 100%;
}
.tm-cancel {
  height: 34px; padding: 0 12px; border-radius: var(--r-md);
  background: transparent; border: 1px solid var(--border-2); color: var(--fg-3);
  font: 600 12.5px/1 var(--font-display); cursor: pointer;
}
.tm-cancel:hover { color: var(--fg-1); border-color: var(--border-3); }
.tm-send {
  height: 34px; padding: 0 14px; border-radius: var(--r-md);
  background: var(--brand-cta); color: var(--brand-cta-fg); border: 1px solid var(--brand-cta);
  font: 700 12.5px/1 var(--font-display); cursor: pointer;
  display: inline-flex; align-items: center; gap: 6px;
}
.tm-send:hover { background: var(--brand-cta-hover); }
.tm-send svg { width: 13px; height: 13px; }

.tm-invite-error {
  grid-column: 1 / -1;
  font: 500 12px/1.4 var(--font-body); color: var(--status-issue-fg);
  background: var(--status-issue-bg); border: 1px solid var(--status-issue-bd);
  border-radius: var(--r-md); padding: 6px 10px;
}

/* table ------------------------------------------------------------ */
.tm-table { width: 100%; border-collapse: separate; border-spacing: 0; }
.tm-table thead th {
  text-align: left; padding: 10px 16px;
  background: var(--bg-card-2); border-bottom: 1px solid var(--border-1);
  font: 600 9.5px/1 var(--font-body); text-transform: uppercase; letter-spacing: .14em;
  color: var(--fg-4); white-space: nowrap;
}
.tm-table thead th.act { width: 36px; }
.tm-table tbody td { padding: 12px 16px; vertical-align: middle; font: 400 13px/1.4 var(--font-body); color: var(--fg-2); }
.tm-table tbody tr + tr td { border-top: 1px solid var(--border-1); }
.tm-table tbody tr:hover td { background: var(--bg-input); }
.tm-table tbody tr.disabled td { opacity: .55; }

/* avatar/name cell ------------------------------------------------- */
.tm-who { display: flex; align-items: center; gap: 11px; }
.tm-av {
  width: 34px; height: 34px; border-radius: 50%;
  display: inline-grid; place-items: center;
  font: 700 12px/1 var(--font-display); color: #0f172a;
  flex-shrink: 0; border: 2px solid var(--bg-card);
  box-shadow: 0 0 0 1px var(--border-2);
}
.tm-av.amb { background: linear-gradient(135deg, #fbbf24, #d97706); }
.tm-av.blu { background: linear-gradient(135deg, #93c5fd, #3b82f6); color: #1e3a8a; }
.tm-av.grn { background: linear-gradient(135deg, #6ee7b7, #10b981); color: #064e3b; }
.tm-av.vlt { background: linear-gradient(135deg, #c4b5fd, #8b5cf6); color: #4c1d95; }
.tm-av.ros { background: linear-gradient(135deg, #fca5a5, #ef4444); color: #7f1d1d; }
.tm-av.gry { background: linear-gradient(135deg, #cbd5e1, #64748b); color: #0f172a; opacity: .8; }
.tm-av.invited { background: var(--bg-input); border: 2px dashed var(--border-3); color: var(--fg-3); box-shadow: none; font-weight: 500; }

.tm-name { display: flex; flex-direction: column; gap: 2px; min-width: 0; }
.tm-name b { font: 700 13.5px/1.2 var(--font-display); color: var(--fg-1); letter-spacing: -0.005em; }
.tm-name .you { font: 600 9px/1 var(--font-body); text-transform: uppercase; letter-spacing: .14em; color: var(--accent-300); background: rgba(245, 158, 11, 0.10); border: 1px solid rgba(245, 158, 11, 0.30); padding: 2px 5px; border-radius: 3px; margin-left: 6px; }
.tm-name .meta { font: 500 11px/1 var(--font-mono); color: var(--fg-4); }

.tm-mono { font: 500 12.5px/1 var(--font-mono); color: var(--fg-2); }
.tm-mono.muted { color: var(--fg-4); }

/* role pills ------------------------------------------------------- */
.tm-role {
  font: 600 10px/1 var(--font-body); text-transform: uppercase; letter-spacing: .10em;
  padding: 4px 8px; border-radius: var(--r-md);
  border: 1px solid transparent;
  display: inline-flex; align-items: center; gap: 5px;
  white-space: nowrap;
}
.tm-role::before { content: ""; width: 6px; height: 6px; border-radius: 50%; background: currentColor; }
.tm-role.owner      { color: var(--accent-300); background: rgba(245, 158, 11, 0.10); border-color: rgba(245, 158, 11, 0.30); }
.tm-role.manager    { color: var(--status-enroute-fg); background: var(--status-enroute-bg); border-color: var(--status-enroute-bd); }
.tm-role.dispatcher { color: var(--status-complete-fg); background: var(--status-complete-bg); border-color: var(--status-complete-bd); }
.tm-role.accounting { color: var(--status-invoiced-fg); background: var(--status-invoiced-bg); border-color: var(--status-invoiced-bd); }
.tm-role.driver     { color: var(--fg-3); background: var(--bg-input); border-color: var(--border-2); }

/* status pills ----------------------------------------------------- */
.tm-status {
  font: 600 10px/1 var(--font-body); text-transform: uppercase; letter-spacing: .10em;
  padding: 4px 8px; border-radius: var(--r-pill);
  display: inline-flex; align-items: center; gap: 6px;
  border: 1px solid transparent;
  white-space: nowrap;
}
.tm-status::before { content: ""; width: 6px; height: 6px; border-radius: 50%; background: currentColor; }
.tm-status.active   { color: var(--signal-active); background: rgba(34, 197, 94, 0.10); border-color: rgba(34, 197, 94, 0.30); }
.tm-status.offline  { color: var(--fg-3); background: var(--bg-input); border-color: var(--border-2); }
.tm-status.invited  { color: var(--accent-300); background: rgba(245, 158, 11, 0.10); border-color: rgba(245, 158, 11, 0.30); }
.tm-status.draft    { color: var(--fg-3); background: var(--bg-input); border-color: var(--border-2); }
.tm-status.disabled { color: var(--status-issue-fg); background: var(--status-issue-bg); border-color: var(--status-issue-bd); }

/* per-row expiration badge — secondary pill below status ---------- */
.tm-expires {
  display: inline-block; margin-top: 4px;
  font: 500 10px/1 var(--font-body); padding: 2px 6px; border-radius: 10px;
  white-space: nowrap; border: 1px solid transparent;
}
.tm-expires.fresh   { color: var(--fg-3); background: var(--bg-input); border-color: var(--border-2); }
.tm-expires.soon    { color: var(--accent-300); background: rgba(245, 158, 11, 0.12); border-color: rgba(245, 158, 11, 0.35); }
.tm-expires.expired { color: var(--status-issue-fg); background: var(--status-issue-bg); border-color: var(--status-issue-bd); }

/* row action cluster (icon buttons inline) ------------------------ */
.tm-act-cell { text-align: right; white-space: nowrap; }
.tm-icon-btn {
  width: 30px; height: 30px; border-radius: var(--r-md);
  background: transparent; border: 1px solid transparent;
  color: var(--fg-3); display: inline-grid; place-items: center; cursor: pointer;
  margin-left: 2px;
}
.tm-icon-btn:hover { background: var(--bg-card); border-color: var(--border-2); color: var(--fg-1); }
.tm-icon-btn svg { width: 14px; height: 14px; }
.tm-icon-btn.danger:hover { color: var(--status-issue-fg); border-color: var(--status-issue-bd); background: var(--status-issue-bg); }
.tm-icon-btn.accent { color: var(--accent-300); }
.tm-icon-btn.accent:hover { color: var(--accent-300); border-color: rgba(245, 158, 11, 0.35); background: rgba(245, 158, 11, 0.10); }

/* permissions matrix ---------------------------------------------- */
.tm-matrix-wrap { padding: 0; overflow-x: auto; }
.tm-mx { width: 100%; border-collapse: separate; border-spacing: 0; table-layout: fixed; }
.tm-mx th, .tm-mx td { border-right: 1px solid var(--border-1); }
.tm-mx th:last-child, .tm-mx td:last-child { border-right: 0; }

.tm-mx col.col-module { width: 240px; }
.tm-mx col.col-role   { width: auto; }

.tm-mx thead th {
  background: var(--bg-card-2); border-bottom: 1px solid var(--border-1);
  padding: 14px 12px; vertical-align: middle; height: 72px;
}
.tm-mx thead th.module-head {
  text-align: left; padding-left: 18px;
  font: 600 9.5px/1 var(--font-body); text-transform: uppercase; letter-spacing: .14em; color: var(--fg-4);
}
.tm-mx thead th.role-head { text-align: center; vertical-align: middle; }
.tm-rolehead { display: flex; align-items: center; gap: 10px; justify-content: center; }
.tm-rolehead .ic { width: 30px; height: 30px; border-radius: 50%; display: grid; place-items: center; flex-shrink: 0; }
.tm-rolehead .ic svg { width: 15px; height: 15px; }
.tm-rolehead .ic.amber  { background: rgba(245, 158, 11, 0.12); color: var(--accent-300); border: 1px solid rgba(245, 158, 11, 0.30); }
.tm-rolehead .ic.blue   { background: var(--status-enroute-bg); color: var(--status-enroute-fg); border: 1px solid var(--status-enroute-bd); }
.tm-rolehead .ic.green  { background: var(--status-complete-bg); color: var(--status-complete-fg); border: 1px solid var(--status-complete-bd); }
.tm-rolehead .ic.violet { background: var(--status-invoiced-bg); color: var(--status-invoiced-fg); border: 1px solid var(--status-invoiced-bd); }
.tm-rolehead .ic.gray   { background: var(--bg-input); color: var(--fg-4); border: 1px solid var(--border-2); }
.tm-rolehead .lbl  { display: flex; flex-direction: column; align-items: flex-start; gap: 3px; text-align: left; }
.tm-rolehead .name { font: 700 13px/1 var(--font-display); color: var(--fg-1); letter-spacing: -0.005em; }
.tm-rolehead .sub  { font: 500 10px/1 var(--font-body); color: var(--fg-4); text-transform: none; letter-spacing: 0; white-space: nowrap; }
.tm-mx thead th.role-head.implicit .name { color: var(--fg-3); }

.tm-mx tbody td { vertical-align: middle; padding: 0; }
.tm-mx tbody td.module-cell {
  padding: 12px 18px; background: var(--bg-card);
  font: 600 13.5px/1.2 var(--font-display); color: var(--fg-1); letter-spacing: -0.005em;
}
.tm-mx tbody tr + tr td { border-top: 1px solid var(--border-1); }
.tm-mx tbody tr:hover td { background: var(--bg-input); }
.tm-mx tbody td.implicit-col { background: var(--bg-card-2); }
.tm-mx tbody tr:hover td.implicit-col { background: var(--bg-card-2); }

/* tri-state pill button ------------------------------------------- */
.tm-cell { padding: 10px; text-align: center; height: 56px; }
.tm-pill {
  width: 100%; max-width: 150px;
  padding: 7px 12px; border-radius: var(--r-md);
  background: var(--bg-input); border: 1px solid var(--border-2);
  color: var(--fg-3); cursor: pointer;
  font: 600 11.5px/1 var(--font-display); letter-spacing: -0.005em;
  text-align: center; white-space: nowrap;
  transition: background 120ms ease, border-color 120ms ease, color 120ms ease;
}
.tm-pill:hover { border-color: var(--border-3); color: var(--fg-1); }
.tm-pill.read {
  background: rgba(30, 58, 138, 0.30); border-color: var(--status-enroute-bd); color: var(--status-enroute-fg);
}
.tm-pill.write {
  background: rgba(6, 78, 59, 0.35); border-color: var(--status-complete-bd); color: var(--status-complete-fg);
}
.tm-pill.implicit-allow {
  background: rgba(245, 158, 11, 0.12); border-color: rgba(245, 158, 11, 0.30); color: var(--accent-300);
  cursor: default; font-weight: 700;
}
.tm-pill.implicit-deny {
  background: var(--bg-input); border: 1px dashed var(--border-2); color: var(--fg-5);
  cursor: default;
}

/* legend strip ---------------------------------------------------- */
.tm-legend {
  display: flex; align-items: center; gap: 14px;
  padding: 11px 18px; border-top: 1px solid var(--border-1); background: var(--bg-card-2);
  font: 500 11.5px/1 var(--font-body); color: var(--fg-3);
  flex-wrap: wrap;
}
.tm-legend .li { display: inline-flex; align-items: center; gap: 6px; }
.tm-legend .sw {
  width: 22px; height: 22px; border-radius: 5px; display: inline-grid; place-items: center;
  border: 1px solid var(--border-2); background: var(--bg-input); color: var(--fg-4);
}
.tm-legend .sw svg { width: 12px; height: 12px; }
.tm-legend .sw.read  { background: rgba(30, 58, 138, 0.30); border-color: var(--status-enroute-bd); color: var(--status-enroute-fg); }
.tm-legend .sw.write { background: rgba(6, 78, 59, 0.35); border-color: var(--status-complete-bd); color: var(--status-complete-fg); }
.tm-legend .saved { margin-left: auto; display: inline-flex; align-items: center; gap: 6px; color: var(--status-complete-fg); font-weight: 600; }
.tm-legend .saved::before { content: ""; width: 6px; height: 6px; border-radius: 50%; background: currentColor; }

/* empty state for the roster card --------------------------------- */
.tm-empty {
  padding: 40px 20px; text-align: center;
  color: var(--fg-3);
}
.tm-empty .title { font: 600 14px/1.2 var(--font-display); color: var(--fg-2); margin-bottom: 4px; }
.tm-empty .body  { font: 400 12.5px/1.5 var(--font-body); color: var(--fg-4); }

/* responsive ------------------------------------------------------- */
@media (max-width: 1100px) {
  .tm-invite { grid-template-columns: 1fr 1fr; }
  .tm-invite .tm-cancel, .tm-invite .tm-send { grid-column: span 1; }
}
@media (max-width: 700px) {
  .tm-page { padding: 16px 12px 48px; }
  .tm-invite { grid-template-columns: 1fr; }
  .tm-table thead th { padding: 8px 10px; }
  .tm-table tbody td { padding: 10px; }
}
