/* T0028 プラグイン UI モックアップ 共通スタイル */

:root {
  --bg: #f5f7f9;
  --card: #ffffff;
  --border: #e2e6e8;
  --border-strong: #cfd5da;
  --ink: #2a3340;
  --ink-dim: #6a7480;
  --ink-weak: #9aa4af;
  --brand: #2a7ae2;
  --brand-dark: #1d5bb3;
  --green: #3aa56a;
  --green-bg: #dff3ea;
  --yellow: #d8a12a;
  --yellow-bg: #fff6e0;
  --red: #b0413e;
  --red-bg: #fbeded;
  --purple: #7a3eb0;
  --purple-bg: #eee3ff;
}

* { box-sizing: border-box; }

body.plugin-ui {
  margin: 0;
  padding: 0;
  font-family: "Hiragino Kaku Gothic ProN", "Yu Gothic Medium", "Meiryo", system-ui, sans-serif;
  background: var(--bg);
  color: var(--ink);
  font-size: 13px;
  line-height: 1.5;
}

/* =========== header =========== */
.pu-header {
  display: flex;
  align-items: center;
  gap: 16px;
  padding: 10px 24px;
  background: #1f2d3d;
  color: #fff;
  position: sticky;
  top: 0;
  z-index: 100;
}
.pu-header .logo {
  width: 28px; height: 28px;
  background: #7ac143; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-weight: 700; border-radius: 6px;
  font-size: 15px;
}
.pu-header .title-wrap { display: flex; flex-direction: column; line-height: 1.2; }
.pu-header .title { font-size: 14px; font-weight: 700; }
.pu-header .sub { font-size: 11px; color: #a8b3bf; }
.pu-header .sys-chip {
  margin-left: auto;
  display: flex; gap: 6px;
}
.sys-chip .chip {
  display: inline-flex; align-items: center; gap: 4px;
  padding: 3px 8px; border-radius: 10px;
  background: rgba(255,255,255,.1);
  font-size: 11px; color: #cfd5da;
}
.chip .dot { width: 7px; height: 7px; border-radius: 50%; }
.chip.ok .dot { background: #3aa56a; }
.chip.warn .dot { background: #d8a12a; }
.chip.err .dot { background: #e06b6b; }

/* =========== user menu (header right) =========== */
.user-menu { position: relative; margin-left: 14px; }
.user-btn {
  display: flex; align-items: center; gap: 8px;
  padding: 4px 10px 4px 4px;
  background: rgba(255,255,255,.06);
  border-radius: 20px;
  cursor: pointer;
  transition: background .15s;
}
.user-btn:hover { background: rgba(255,255,255,.14); }
.avatar {
  width: 28px; height: 28px;
  border-radius: 50%;
  background: #7ac143;
  color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 700;
}
.user-info { display: flex; flex-direction: column; line-height: 1.2; }
.u-name { font-size: 12px; font-weight: 600; color: #fff; }
.u-role { font-size: 10px; color: #a8b3bf; }
.u-caret { color: #a8b3bf; font-size: 10px; }

.user-dropdown {
  display: none;
  position: absolute;
  top: calc(100% + 6px);
  right: 0;
  min-width: 220px;
  background: #fff;
  border: 1px solid var(--border);
  border-radius: 4px;
  box-shadow: 0 6px 20px rgba(0,0,0,.14);
  z-index: 200;
  padding: 6px 0;
}
.user-dropdown.open { display: block; }
.user-dropdown .ud-head {
  padding: 10px 14px;
  border-bottom: 1px solid var(--border);
  color: var(--ink);
  font-weight: 700;
}
.user-dropdown a {
  display: block;
  padding: 8px 14px;
  color: var(--ink);
  text-decoration: none;
  font-size: 12px;
}
.user-dropdown a:hover { background: #f5f7f8; }
.user-dropdown .ud-sep { height: 1px; background: var(--border); margin: 4px 0; }

/* =========== layout: sidebar + main =========== */
.pu-layout {
  display: grid;
  grid-template-columns: 220px 1fr;
  min-height: calc(100vh - 48px);
}
.pu-sidebar {
  background: #fff;
  border-right: 1px solid var(--border);
  padding: 14px 0 0;
  position: sticky;
  top: 48px;
  align-self: start;
  height: calc(100vh - 48px);
  overflow-y: auto;
  font-size: 12px;
}
.sb-group-label {
  font-size: 10px;
  text-transform: uppercase;
  color: var(--ink-weak);
  letter-spacing: 1px;
  padding: 12px 16px 6px;
  font-weight: 700;
}
.sb-item {
  display: flex;
  align-items: center;
  padding: 8px 14px;
  color: var(--ink-dim);
  font-weight: 500;
  border-left: 3px solid transparent;
  cursor: pointer;
  gap: 10px;
  white-space: nowrap;
}
.sb-item:hover { background: #f5f7f8; color: var(--ink); }
.sb-item.active {
  background: #eaf2f7;
  color: var(--brand);
  border-left-color: var(--brand);
  font-weight: 700;
}
.sb-ico { font-size: 14px; width: 18px; text-align: center; }
.sb-label { flex: 1; }
.sb-item .badge {
  display: inline-block;
  min-width: 18px;
  padding: 1px 6px;
  border-radius: 9px;
  background: var(--red);
  color: #fff;
  font-size: 10px;
  font-weight: 700;
  text-align: center;
}
.sb-item .badge.warn { background: var(--yellow); }
.sb-item .badge.ok { background: var(--green); }
.sb-footer { margin-top: auto; border-top: 1px solid var(--border); }

.pu-main { min-width: 0; }

/* =========== views =========== */
.pu-view { display: none; padding: 20px 24px; max-width: 1400px; }
.pu-view.active { display: block; }

/* =========== cards / panels =========== */
.panel {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 5px;
  margin-bottom: 16px;
  overflow: hidden;
}
.panel-head {
  padding: 10px 16px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  border-bottom: 1px solid var(--border);
  background: #fafbfc;
}
.panel-head h3 { margin: 0; font-size: 14px; font-weight: 700; }
.panel-head .meta { color: var(--ink-weak); font-size: 11px; }
.panel-body { padding: 14px 16px; }

/* =========== KPI cards (dashboard) =========== */
.kpi-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 12px;
  margin-bottom: 16px;
}
.kpi {
  background: var(--card);
  border: 1px solid var(--border);
  border-left: 4px solid var(--border-strong);
  padding: 12px 14px;
  border-radius: 4px;
}
.kpi .lbl { font-size: 11px; color: var(--ink-dim); }
.kpi .val { font-size: 22px; font-weight: 700; margin-top: 4px; font-variant-numeric: tabular-nums; }
.kpi .sub { font-size: 11px; color: var(--ink-weak); margin-top: 2px; }
.kpi.ok    { border-left-color: var(--green); }
.kpi.warn  { border-left-color: var(--yellow); }
.kpi.err   { border-left-color: var(--red); }
.kpi.brand { border-left-color: var(--brand); }

/* channel cards */
.ch-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); gap: 12px; }
.ch-card {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 5px;
  padding: 12px 14px;
}
.ch-card .row1 { display: flex; align-items: center; gap: 8px; }
.ch-card .ch-name { font-weight: 700; font-size: 14px; }
.ch-card .ch-body { margin-top: 8px; color: var(--ink-dim); font-size: 12px; }
.ch-card .ch-body div { display: flex; justify-content: space-between; margin: 3px 0; }
.ch-card.status-ok  { border-top: 3px solid var(--green); }
.ch-card.status-warn{ border-top: 3px solid var(--yellow); }
.ch-card.status-err { border-top: 3px solid var(--red); }

.status-pill {
  display: inline-block;
  padding: 1px 8px;
  border-radius: 10px;
  font-size: 10px;
  font-weight: 700;
}
.status-pill.ok   { background: var(--green-bg); color: #0d4d32; }
.status-pill.warn { background: var(--yellow-bg); color: #7a5a0f; }
.status-pill.err  { background: var(--red-bg); color: #6a1a1a; }
.status-pill.off  { background: #ecedef; color: #667; }

/* timeline */
.timeline { border-left: 2px solid var(--border); padding-left: 14px; margin-left: 6px; }
.tl-item { position: relative; padding-bottom: 12px; }
.tl-item::before {
  content: ""; width: 10px; height: 10px; border-radius: 50%;
  background: var(--ink-weak); position: absolute; left: -20px; top: 4px;
  border: 2px solid var(--card);
}
.tl-item.ok::before   { background: var(--green); }
.tl-item.warn::before { background: var(--yellow); }
.tl-item.err::before  { background: var(--red); }
.tl-head { display: flex; gap: 8px; font-size: 11px; color: var(--ink-weak); }
.tl-head b { color: var(--ink); }
.tl-msg { margin-top: 2px; font-size: 12px; }

/* =========== tables =========== */
.pu-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 12px;
}
.pu-table th, .pu-table td {
  padding: 7px 10px;
  text-align: left;
  border-bottom: 1px solid var(--border);
  vertical-align: middle;
}
.pu-table th {
  background: #f3f5f7;
  font-size: 11px;
  font-weight: 700;
  color: var(--ink-dim);
  text-transform: none;
  position: sticky;
  top: 0;
}
.pu-table tr:hover td { background: #f8f9fa; }
.pu-table td.num { font-variant-numeric: tabular-nums; color: var(--ink-dim); text-align: right; }
.pu-table td.ts { font-variant-numeric: tabular-nums; color: var(--ink-weak); white-space: nowrap; }
.pu-table td.sku { font-family: SFMono-Regular, Menlo, monospace; font-size: 11px; }
.pu-table td.diff { font-family: SFMono-Regular, Menlo, monospace; font-size: 11px; color: var(--ink-dim); }

/* =========== buttons =========== */
.btn {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 4px 10px;
  background: #fff;
  border: 1px solid var(--border-strong);
  border-radius: 3px;
  font-size: 11px;
  cursor: pointer;
  color: var(--ink);
  text-decoration: none;
  font-weight: 600;
}
.btn:hover { background: #f5f7f8; }
.btn.primary { background: var(--brand); color: #fff; border-color: var(--brand); }
.btn.primary:hover { background: var(--brand-dark); }
.btn.ok { background: var(--green); color: #fff; border-color: var(--green); }
.btn.ok:hover { filter: brightness(.92); }
.btn.danger { color: var(--red); border-color: #e0bcbc; }
.btn.danger:hover { background: var(--red-bg); }
.btn.small { padding: 2px 7px; font-size: 10px; }

/* =========== filters bar =========== */
.filters {
  display: flex; flex-wrap: wrap; gap: 8px;
  padding: 10px 14px;
  background: #fafbfc;
  border-bottom: 1px solid var(--border);
}
.filters select, .filters input {
  padding: 4px 8px;
  border: 1px solid var(--border-strong);
  border-radius: 3px;
  font-size: 12px;
  background: #fff;
  min-width: 120px;
}
.filters label { font-size: 11px; color: var(--ink-dim); display: flex; align-items: center; gap: 4px; }

/* =========== gray matrix =========== */
.gray-matrix {
  border-collapse: collapse;
  font-size: 11px;
}
.gray-matrix th, .gray-matrix td {
  border: 1px solid var(--border);
  padding: 4px 6px;
  text-align: center;
  min-width: 60px;
}
.gray-matrix th { background: #f3f5f7; font-weight: 600; }
.gray-matrix th.row-hdr, .gray-matrix td.row-hdr {
  text-align: left;
  background: #fafbfc;
  position: sticky; left: 0;
  font-weight: 600;
  min-width: 140px;
}
.gr-cell { cursor: pointer; transition: all .12s; }
.gr-cell.off { background: #fff; color: var(--ink-weak); }
.gr-cell.gray { background: var(--yellow-bg); color: #7a5a0f; font-weight: 700; }
.gr-cell.on { background: var(--green-bg); color: #0d4d32; font-weight: 700; }
.gr-cell.na { background: #ecedef; color: #aab; cursor: not-allowed; }
.gr-cell:hover:not(.na) { filter: brightness(.95); }

/* =========== diff bars =========== */
.diff-row { display: flex; align-items: center; gap: 10px; padding: 6px 0; }
.diff-row .lbl { min-width: 160px; font-weight: 600; }
.diff-row .bar-wrap { flex: 1; display: flex; height: 20px; background: #edf0f3; border-radius: 2px; overflow: hidden; font-size: 10px; color: #fff; font-weight: 600; }
.diff-row .seg { display: flex; align-items: center; justify-content: center; min-width: 0; }
.seg-ok   { background: var(--green); }
.seg-warn { background: var(--yellow); color: #5a4a0f; }
.seg-err  { background: var(--red); }
.seg-nil  { background: #bcc2c9; }

/* =========== history log table =========== */
.log-table tr.log-row { cursor: pointer; }
.log-table tr.log-row:hover td { background: #eef5fb; }
.log-table tr.log-row.expanded td { background: #eaf2f7; }
.log-table tr.log-row.expanded .chevron { transform: rotate(90deg); }
.chevron {
  display: inline-block;
  color: var(--ink-weak);
  margin-right: 4px;
  transition: transform .15s;
}
.scope-pill {
  display: inline-block;
  padding: 1px 7px;
  border-radius: 10px;
  font-size: 10px;
  font-weight: 700;
  margin-right: 4px;
}
.scope-pill.single  { background: #eef2f6; color: #556; }
.scope-pill.partial { background: #eaf4ff; color: #1f4a8a; }
.scope-pill.full    { background: #efe6fa; color: #5a2a8a; }
.fld-count { color: var(--ink-weak); font-size: 11px; font-variant-numeric: tabular-nums; }
.log-summary { color: var(--ink); font-family: SFMono-Regular, Menlo, monospace; font-size: 11px; }
.log-summary b { font-weight: 700; color: var(--ink); }
.log-err-msg {
  color: #8a2a2a;
  font-size: 11px;
  margin-top: 3px;
  background: #fbeded;
  padding: 2px 6px;
  border-radius: 2px;
  display: inline-block;
}

/* detail row (展開時) */
tr.log-detail td.detail-cell {
  background: #fafbfc !important;
  padding: 10px 16px 12px !important;
  border-bottom: 2px solid var(--border);
}
.detail-hdr {
  display: flex;
  align-items: center;
  font-size: 11px;
  font-weight: 700;
  color: var(--ink-dim);
  margin-bottom: 6px;
}
.detail-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 11px;
  background: #fff;
  border: 1px solid var(--border);
}
.detail-table th {
  background: #f3f5f7;
  text-align: left;
  padding: 5px 8px;
  font-weight: 600;
  color: var(--ink-dim);
  font-size: 10px;
  border-bottom: 1px solid var(--border);
}
.detail-table td {
  padding: 5px 8px;
  border-bottom: 1px solid var(--border);
  vertical-align: top;
}
.detail-table td code {
  background: #eef2f6;
  padding: 1px 5px;
  border-radius: 2px;
  font-size: 10px;
}
.detail-table td.old { color: var(--ink-weak); font-family: SFMono-Regular, Menlo, monospace; }
.detail-table td.new { color: var(--ink); font-weight: 600; font-family: SFMono-Regular, Menlo, monospace; }
.detail-actions {
  margin-top: 8px;
  display: flex;
  gap: 6px;
  justify-content: flex-end;
}

/* =========== queue items =========== */
.queue-item {
  border: 1px solid var(--border);
  border-left: 4px solid var(--yellow);
  border-radius: 4px;
  padding: 10px 14px;
  margin-bottom: 8px;
  background: #fff;
}
.queue-item.conflict { border-left-color: var(--red); }
.queue-item.exception { border-left-color: var(--yellow); }
.queue-item.approved { border-left-color: var(--green); opacity: .6; }
.qi-head { display: flex; justify-content: space-between; align-items: center; gap: 12px; }
.qi-head .typ {
  font-size: 10px; font-weight: 700; padding: 2px 7px; border-radius: 10px;
  background: var(--yellow-bg); color: #7a5a0f;
}
.qi-head .typ.conflict { background: var(--red-bg); color: #6a1a1a; }
.qi-head .sku { font-family: SFMono-Regular, Menlo, monospace; color: var(--ink-dim); font-size: 12px; }
.qi-head .time { color: var(--ink-weak); font-size: 11px; margin-left: auto; }
.qi-body { margin-top: 8px; display: grid; grid-template-columns: 1fr 1fr; gap: 10px; font-size: 12px; }
.qi-body .col { background: #fafbfc; padding: 8px 10px; border-radius: 3px; border: 1px dashed var(--border); }
.qi-body .col .h { font-size: 10px; color: var(--ink-weak); text-transform: uppercase; margin-bottom: 3px; }
.qi-body .col .v { font-family: SFMono-Regular, Menlo, monospace; font-size: 12px; word-break: break-all; }
.qi-actions { margin-top: 8px; display: flex; gap: 6px; justify-content: flex-end; }

/* =========== rule registry =========== */
.rules-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
  gap: 10px;
}
.rule-card {
  background: #fff;
  border: 1px solid var(--border);
  border-left: 4px solid var(--border-strong);
  border-radius: 4px;
  padding: 10px 12px;
}
.rule-card[data-status="v1"]     { border-left-color: var(--green); }
.rule-card[data-status="gray"]   { border-left-color: var(--yellow); }
.rule-card[data-status="off"]    { border-left-color: var(--border-strong); opacity: .6; }
.rule-card[data-status="delayed"]{ border-left-color: var(--purple); }
.rule-card .rc-head { display: flex; justify-content: space-between; align-items: center; }
.rule-card .rc-name { font-weight: 700; font-size: 13px; }
.rule-card .rc-body { margin-top: 6px; font-size: 11px; color: var(--ink-dim); }
.rule-card .rc-body div { margin: 2px 0; }
.rule-card .rc-body b { color: var(--ink); font-weight: 600; }
.rule-card .rc-actions { margin-top: 8px; display: flex; gap: 4px; justify-content: flex-end; }

/* =========== stat row =========== */
.stat-row { display: flex; gap: 16px; padding: 10px 16px; background: #fafbfc; border-bottom: 1px solid var(--border); }
.stat-row .item { font-size: 12px; color: var(--ink-dim); }
.stat-row .item b { color: var(--ink); font-weight: 700; font-variant-numeric: tabular-nums; }

/* =========== image_sync =========== */
.img-sync-layout {
  display: grid;
  grid-template-columns: 260px 1fr;
  gap: 12px;
  padding: 12px 16px 16px;
}
.img-tree {
  background: #fafbfc;
  border: 1px solid var(--border);
  border-radius: 4px;
  overflow: hidden;
  max-height: 620px;
  overflow-y: auto;
}
.tree-head {
  padding: 8px 12px;
  background: #fff;
  border-bottom: 1px solid var(--border);
  font-size: 11px;
  font-weight: 700;
  color: var(--ink-dim);
  display: flex; justify-content: space-between; align-items: center;
}
.tree-item {
  padding: 5px 12px;
  font-size: 12px;
  cursor: pointer;
  color: var(--ink);
}
.tree-item:hover { background: #eef2f6; }
.tree-item.sel { background: #dbeafe; color: #1f4a8a; font-weight: 600; border-left: 3px solid var(--brand); padding-left: 9px; }
.tree-item.warn { color: #8a6d1b; }
.tree-item.err { color: #8a2a2a; }
.tree-item.root { font-weight: 700; padding-left: 12px; background: #eef2f6; }
.t-count { color: var(--ink-weak); font-size: 10px; margin-left: 4px; }

.img-main {
  background: #fff;
  border: 1px solid var(--border);
  border-radius: 4px;
  padding: 12px;
}
.img-main-head {
  display: flex; justify-content: space-between; align-items: flex-start;
  margin-bottom: 10px;
}
.img-main-head code {
  background: #eef2f6; padding: 1px 5px; border-radius: 2px;
  font-size: 10px;
}
.img-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
  gap: 10px;
}
.img-card {
  border: 1px solid var(--border);
  border-radius: 4px;
  padding: 8px;
  background: #fff;
  transition: border-color .15s, background .15s;
}
.img-card:hover { border-color: var(--brand); }
.img-card.main {
  border: 2px solid var(--green);
  background: #f0f9f4;
}
.img-thumb {
  aspect-ratio: 1;
  background: #edf0f3;
  border-radius: 3px;
  display: flex; align-items: center; justify-content: center;
  position: relative;
  margin-bottom: 6px;
}
.img-placeholder {
  font-size: 28px; font-weight: 700; color: var(--ink-weak);
  font-family: SFMono-Regular, Menlo, monospace;
}
.img-num {
  position: absolute; top: 4px; left: 4px;
  background: rgba(0,0,0,.65); color: #fff;
  width: 20px; height: 20px;
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-size: 10px; font-weight: 700;
}
.img-meta { font-size: 11px; margin-bottom: 6px; }
.img-name {
  font-family: SFMono-Regular, Menlo, monospace;
  font-weight: 600;
  color: var(--ink);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.img-sub { color: var(--ink-weak); font-size: 10px; }
.img-badges { display: flex; gap: 3px; flex-wrap: wrap; margin-top: 4px; }
.img-badge {
  display: inline-block;
  padding: 1px 5px;
  border-radius: 8px;
  font-size: 9px;
  font-weight: 700;
}
.img-badge.main { background: #fef3c7; color: #7a5a0f; }
.img-badge.ok   { background: var(--green-bg); color: #0d4d32; }
.img-badge.warn { background: var(--yellow-bg); color: #7a5a0f; }
.img-actions { display: flex; gap: 3px; flex-wrap: wrap; }
.img-actions .btn { flex: 1 1 40%; justify-content: center; padding: 2px 5px; font-size: 10px; }

/* =========== settings general =========== */
.settings-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(340px, 1fr));
  gap: 16px 24px;
}
.setting-item label { display: block; font-size: 12px; font-weight: 700; color: var(--ink); margin-bottom: 6px; }
.setting-item > input, .setting-item > select, .setting-item textarea {
  padding: 6px 10px;
  font-size: 12px;
  border: 1px solid var(--border-strong);
  border-radius: 3px;
  background: #fff;
}
.setting-hint {
  margin-top: 4px;
  font-size: 11px;
  color: var(--ink-weak);
  line-height: 1.6;
}
.chk-list {
  display: flex; flex-direction: column;
  gap: 4px;
  padding: 4px 0;
}
.chk-list label {
  display: flex; align-items: center; gap: 6px;
  font-weight: 500 !important;
  font-size: 12px !important;
  margin: 0 !important;
  color: var(--ink-dim) !important;
  cursor: pointer;
}
.chk-list label b { color: var(--ink); }

.provider-row {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(150px, 1fr));
  gap: 8px;
}
.provider-card {
  display: block;
  padding: 10px;
  border: 2px solid var(--border);
  border-radius: 4px;
  cursor: pointer;
  background: #fff;
  font-weight: 500 !important;
  margin: 0 !important;
  font-size: 11px !important;
}
.provider-card input { display: none; }
.provider-card:has(input:checked) { border-color: var(--brand); background: #eff5fe; }
.provider-card b { display: block; font-size: 13px; color: var(--ink); margin-bottom: 4px; }
.p-hint { font-size: 10px; color: var(--ink-weak); line-height: 1.5; }

/* =========== connections =========== */
.conn-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(360px, 1fr));
  gap: 14px;
}
.conn-card {
  border: 1px solid var(--border);
  border-radius: 4px;
  padding: 14px;
  background: #fff;
}
.conn-head {
  display: flex; align-items: center; gap: 10px;
  padding-bottom: 10px; border-bottom: 1px solid var(--border);
  margin-bottom: 10px;
}
.conn-head b { font-size: 14px; }
.conn-row {
  display: grid; grid-template-columns: 130px 1fr;
  gap: 6px; margin-bottom: 6px; align-items: center;
}
.conn-row label { font-size: 11px; color: var(--ink-dim); font-weight: 600; }
.conn-row input {
  padding: 4px 8px; font-size: 11px;
  border: 1px solid var(--border); border-radius: 3px;
  background: #fafbfc; font-family: SFMono-Regular, Menlo, monospace;
}
.conn-actions { margin-top: 10px; display: flex; gap: 6px; }
.status-pill.off { background: #ecedef; color: #667; }

/* =========== users =========== */
.role-pill {
  display: inline-block;
  padding: 2px 9px;
  border-radius: 11px;
  font-size: 10px;
  font-weight: 700;
}
.role-admin      { background: #ffe3e3; color: #8a2a2a; }
.role-sync_admin { background: #eee3ff; color: #5a2a8a; }
.role-operator   { background: #e3eeff; color: #1f3f7a; }
.role-viewer     { background: #e3f3e3; color: #2a6a3a; }
tr.disabled { opacity: .5; }

/* =========== permissions matrix =========== */
.perm-matrix {
  width: 100%;
  border-collapse: collapse;
  font-size: 12px;
}
.perm-matrix th, .perm-matrix td {
  padding: 8px 10px;
  border-bottom: 1px solid var(--border);
  vertical-align: middle;
}
.perm-matrix th {
  background: #f3f5f7;
  text-align: center;
  font-weight: 700;
}
.perm-matrix th:first-child { text-align: left; background: #eff2f5; }
.perm-matrix tr.group-sep td {
  background: #edf2f7 !important;
  font-weight: 700;
  color: #2a5b7a;
  font-size: 11px;
  padding: 6px 10px;
  text-transform: uppercase;
  letter-spacing: .5px;
}
.perm-yes {
  display: inline-block;
  width: 22px; height: 22px;
  line-height: 22px;
  border-radius: 50%;
  background: var(--green-bg);
  color: #0d4d32;
  font-weight: 700;
}
.perm-no { color: #bcc2c9; }

/* =========== audit =========== */
.audit-act {
  display: inline-block;
  padding: 2px 8px;
  border-radius: 10px;
  font-size: 11px;
  font-weight: 600;
  background: #edf0f3;
  color: var(--ink-dim);
}
.audit-act.act-権限変更 { background: var(--red-bg); color: #6a1a1a; }
.audit-act.act-設定変更 { background: var(--yellow-bg); color: #7a5a0f; }
.audit-act.act-ユーザー招待 { background: var(--purple-bg); color: #5a2a8a; }
.audit-act.act-キュー承認 { background: var(--green-bg); color: #0d4d32; }
.audit-act.act-キュー却下 { background: #fff0ed; color: #8a4020; }
.audit-act.act-手動同期 { background: #e3eeff; color: #1f3f7a; }
.audit-act.act-接続テスト { background: #dbeafe; color: #1f4a8a; }
.audit-act.act-ログイン { background: #f3f5f7; color: #556; }
