/* =====================================================
   Web3 admin — design refresh inner styles
   Scoped to #admin-panel-web3 to avoid leaking
   ===================================================== */
body.page-admin #admin-panel-web3 {
  --w3-purple: #7e22ce;
  --w3-purple-2: #a855f7;
  --w3-purple-soft: #fae8ff;
  --w3-purple-ring: #e9d5ff;
  --w3-slate-900: #0f172a;
  --w3-slate-700: #334155;
  --w3-slate-600: #475569;
  --w3-slate-500: #64748b;
  --w3-slate-400: #94a3b8;
  --w3-slate-300: #cbd5e1;
  --w3-slate-200: #e2e8f0;
  --w3-slate-100: #f1f5f9;
  --w3-slate-50: #f8fafc;
  --w3-green-700: #166534;
  --w3-green-500: #10b981;
  --w3-green-100: #dcfce7;
  --w3-green-200: #bbf7d0;
  --w3-green-50: #f0fdf4;
  --w3-red-700: #b91c1c;
  --w3-red-500: #ef4444;
  --w3-red-100: #fee2e2;
  --w3-red-200: #fecaca;
  --w3-red-50: #fef2f2;
  --w3-amber-700: #92400e;
  --w3-amber-500: #f59e0b;
  --w3-amber-100: #fef3c7;
  --w3-amber-200: #fde68a;
  --w3-amber-50: #fffbeb;
  --w3-blue-700: #1d4ed8;
  --w3-blue-500: #3b82f6;
  --w3-blue-100: #dbeafe;
  --w3-cyan-700: #0369a1;
  --w3-cyan-100: #e0f2fe;
}

body.page-admin #admin-panel-web3 .w3-mono {
  font-family: "JetBrains Mono", "SF Mono", "Cascadia Code", "Fira Code", Consolas, monospace;
}

/* ---------- Section headers ---------- */
body.page-admin #admin-panel-web3 .w3-section-header {
  margin: 0 0 0.8rem 0;
  padding-left: 0.25rem;
}
body.page-admin #admin-panel-web3 .w3-section-header-title {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 0.95rem;
  font-weight: 700;
  color: var(--w3-slate-900);
  margin: 0;
}
body.page-admin #admin-panel-web3 .w3-section-header-title .w3-icon {
  color: var(--w3-purple);
  display: inline-flex;
}
body.page-admin #admin-panel-web3 .w3-section-header-title.is-warn .w3-icon { color: var(--w3-red-700); }
body.page-admin #admin-panel-web3 .w3-section-header-title.is-ok   .w3-icon { color: var(--w3-green-700); }
body.page-admin #admin-panel-web3 .w3-section-header-title.is-info .w3-icon { color: var(--w3-cyan-700); }
body.page-admin #admin-panel-web3 .w3-section-header-sub {
  margin: 0.25rem 0 0 1.4rem;
  font-size: 0.78rem;
  color: var(--w3-slate-500);
}

/* ---------- Pill filter groups ---------- */
body.page-admin #admin-panel-web3 .w3-pill-group {
  display: flex;
  flex-wrap: wrap;
  gap: 0.25rem;
}
body.page-admin #admin-panel-web3 .w3-pill {
  padding: 0.25rem 0.8rem;
  border-radius: 9999px;
  border: 1px solid var(--w3-slate-200);
  background: #fff;
  color: var(--w3-slate-500);
  font-family: inherit;
  font-size: 0.72rem;
  font-weight: 500;
  cursor: pointer;
}
body.page-admin #admin-panel-web3 .w3-pill.is-active {
  background: var(--w3-slate-900);
  color: #fff;
  border-color: transparent;
  font-weight: 600;
}
body.page-admin #admin-panel-web3 .w3-pill.is-purple.is-active {
  background: var(--w3-purple);
  color: #fff;
}
body.page-admin #admin-panel-web3 .w3-field-label {
  display: block;
  font-size: 0.65rem;
  font-weight: 700;
  color: var(--w3-slate-400);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  margin-bottom: 0.25rem;
}

/* ---------- Hero search input ---------- */
body.page-admin #admin-panel-web3 .w3-search-wrap {
  display: flex;
  align-items: center;
  gap: 0.55rem;
  padding: 0.5rem 0.75rem;
  background: var(--w3-slate-50);
  border: 1px solid var(--w3-slate-200);
  border-radius: 10px;
}
body.page-admin #admin-panel-web3 .w3-search-wrap input {
  flex: 1;
  border: none;
  outline: none;
  background: transparent;
  font-family: inherit;
  font-size: 0.85rem;
  color: var(--w3-slate-900);
}
body.page-admin #admin-panel-web3 .w3-search-wrap .w3-icon {
  color: var(--w3-slate-400);
  display: inline-flex;
}

body.page-admin #admin-panel-web3 .w3-btn-primary {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  padding: 0.4rem 0.95rem;
  border-radius: 8px;
  border: 1px solid transparent;
  background: var(--w3-purple);
  color: #fff;
  font-family: inherit;
  font-size: 0.78rem;
  font-weight: 600;
  cursor: pointer;
}
body.page-admin #admin-panel-web3 .w3-btn-primary:hover { background: #6b21a8; }
body.page-admin #admin-panel-web3 .w3-btn-primary:disabled { opacity: 0.5; cursor: not-allowed; }
body.page-admin #admin-panel-web3 .w3-btn-secondary {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  padding: 0.4rem 0.95rem;
  border-radius: 8px;
  border: 1px solid var(--w3-slate-200);
  background: #fff;
  color: var(--w3-slate-600);
  font-family: inherit;
  font-size: 0.78rem;
  font-weight: 600;
  cursor: pointer;
}
body.page-admin #admin-panel-web3 .w3-btn-secondary.is-purple {
  color: var(--w3-purple);
  border-color: var(--w3-purple-ring);
}

/* ---------- Metric cards ---------- */
body.page-admin #admin-panel-web3 .w3-metrics-row {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
}
body.page-admin #admin-panel-web3 .w3-metric {
  flex: 1 1 120px;
  min-width: 120px;
  padding: 0.55rem 0.85rem;
  background: #fff;
  border: 1px solid var(--w3-slate-200);
  border-radius: 10px;
}
body.page-admin #admin-panel-web3 .w3-metric-label {
  font-size: 0.62rem;
  color: var(--w3-slate-400);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}
body.page-admin #admin-panel-web3 .w3-metric-value {
  font-size: 1.25rem;
  font-weight: 700;
  color: var(--w3-slate-900);
  margin-top: 0.1rem;
  font-variant-numeric: tabular-nums;
}
body.page-admin #admin-panel-web3 .w3-metric-value.is-zero { color: var(--w3-slate-300); }
body.page-admin #admin-panel-web3 .w3-metric-hint {
  font-size: 0.62rem;
  color: var(--w3-slate-500);
  margin-top: 0.1rem;
}

/* ---------- Empty state ---------- */
body.page-admin #admin-panel-web3 .w3-empty {
  padding: 2rem 1rem;
  text-align: center;
  color: var(--w3-slate-400);
  font-size: 0.85rem;
  background: #fff;
  border-radius: 12px;
  border: 1px dashed var(--w3-slate-200);
}
body.page-admin #admin-panel-web3 .w3-empty-icon {
  display: flex;
  justify-content: center;
  color: var(--w3-slate-300);
  margin-bottom: 0.5rem;
}

/* ---------- Flavor badge ---------- */
body.page-admin #admin-panel-web3 .w3-flavor {
  display: inline-flex;
  align-items: center;
  gap: 0.3rem;
  font-size: 0.7rem;
  font-weight: 600;
  padding: 0.1rem 0.55rem;
  border-radius: 9999px;
}
body.page-admin #admin-panel-web3 .w3-flavor::before {
  content: "";
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: currentColor;
  opacity: 0.85;
}
body.page-admin #admin-panel-web3 .w3-flavor.is-enabled  { background: var(--w3-green-100); color: var(--w3-green-700); }
body.page-admin #admin-panel-web3 .w3-flavor.is-disabled { background: var(--w3-red-100); color: var(--w3-red-700); }
body.page-admin #admin-panel-web3 .w3-flavor.is-preview  { background: var(--w3-purple-soft); color: var(--w3-purple); }
body.page-admin #admin-panel-web3 .w3-flavor.is-neutral  { background: var(--w3-slate-100); color: var(--w3-slate-500); }
body.page-admin #admin-panel-web3 .w3-flavor.is-warn     { background: var(--w3-amber-100); color: var(--w3-amber-700); }
body.page-admin #admin-panel-web3 .w3-flavor.is-info     { background: var(--w3-blue-100); color: var(--w3-blue-700); }
body.page-admin #admin-panel-web3 .w3-note {
  font-size: 0.72rem;
  color: var(--w3-slate-700);
  font-style: italic;
  line-height: 1.5;
}

/* ---------- User hero ---------- */
body.page-admin #admin-panel-web3 .w3-user-hero {
  background: #fff;
  border: 1px solid var(--w3-slate-200);
  border-radius: 12px;
  padding: 1rem 1.1rem;
  margin-bottom: 1rem;
}
body.page-admin #admin-panel-web3 .w3-user-hero-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  margin-bottom: 0.9rem;
}
body.page-admin #admin-panel-web3 .w3-user-hero-id {
  display: flex;
  align-items: center;
  gap: 0.75rem;
}
body.page-admin #admin-panel-web3 .w3-user-avatar {
  width: 44px;
  height: 44px;
  border-radius: 50%;
  background: linear-gradient(135deg, #a855f7, #6366f1);
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  font-weight: 700;
  font-size: 0.95rem;
}
body.page-admin #admin-panel-web3 .w3-user-name {
  font-size: 0.95rem;
  font-weight: 700;
  color: var(--w3-slate-900);
}
body.page-admin #admin-panel-web3 .w3-user-meta {
  font-size: 0.75rem;
  color: var(--w3-slate-500);
  font-family: "JetBrains Mono", monospace;
}
body.page-admin #admin-panel-web3 .w3-stat-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.5rem;
}
body.page-admin #admin-panel-web3 .w3-stat {
  background: var(--w3-slate-50);
  border: 1px solid var(--w3-slate-200);
  border-radius: 8px;
  padding: 0.5rem 0.65rem;
}
body.page-admin #admin-panel-web3 .w3-stat-label {
  display: flex;
  align-items: center;
  gap: 0.35rem;
  font-size: 0.62rem;
  color: var(--w3-slate-400);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}
body.page-admin #admin-panel-web3 .w3-stat-value {
  font-size: 0.85rem;
  font-weight: 600;
  color: var(--w3-slate-900);
  margin-top: 0.15rem;
}
body.page-admin #admin-panel-web3 .w3-stat-value.is-ok   { color: var(--w3-green-700); }
body.page-admin #admin-panel-web3 .w3-stat-value.is-warn { color: var(--w3-amber-700); }
body.page-admin #admin-panel-web3 .w3-stat-value.is-bad  { color: var(--w3-red-700); }

@media (max-width: 720px) {
  body.page-admin #admin-panel-web3 .w3-stat-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}

/* ---------- Config card (collapsible) ---------- */
body.page-admin #admin-panel-web3 .w3-config-card {
  background: #fff;
  border: 1px solid var(--w3-slate-200);
  border-radius: 12px;
  overflow: hidden;
  margin-bottom: 0.5rem;
}
body.page-admin #admin-panel-web3 .w3-config-card details > summary {
  list-style: none;
  cursor: pointer;
  display: flex;
  align-items: center;
  gap: 0.6rem;
  padding: 0.75rem 1rem;
  background: transparent;
}
body.page-admin #admin-panel-web3 .w3-config-card details > summary::-webkit-details-marker { display: none; }
body.page-admin #admin-panel-web3 .w3-config-card details[open] > summary { background: var(--w3-slate-50); }
body.page-admin #admin-panel-web3 .w3-config-card .w3-chev {
  color: var(--w3-slate-400);
  transition: transform 0.15s;
  display: inline-flex;
}
body.page-admin #admin-panel-web3 .w3-config-card details[open] .w3-chev { transform: rotate(90deg); }
body.page-admin #admin-panel-web3 .w3-config-card .w3-config-icon { color: var(--w3-purple); display: inline-flex; }
body.page-admin #admin-panel-web3 .w3-config-card .w3-config-title {
  font-size: 0.85rem;
  font-weight: 700;
  color: var(--w3-slate-900);
}
body.page-admin #admin-panel-web3 .w3-config-card .w3-config-summary {
  font-size: 0.72rem;
  color: var(--w3-slate-500);
  margin-top: 0.1rem;
}
body.page-admin #admin-panel-web3 .w3-config-card .w3-config-count {
  font-size: 0.65rem;
  color: var(--w3-slate-400);
  font-weight: 700;
  background: var(--w3-slate-100);
  padding: 0.1rem 0.55rem;
  border-radius: 9999px;
}
body.page-admin #admin-panel-web3 .w3-config-card .w3-config-body {
  border-top: 1px solid var(--w3-slate-100);
}
body.page-admin #admin-panel-web3 .w3-config-row {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  padding: 0.55rem 1rem 0.55rem 2.4rem;
  border-bottom: 1px solid var(--w3-slate-50);
  gap: 1rem;
}
body.page-admin #admin-panel-web3 .w3-config-row:last-child { border-bottom: none; }
body.page-admin #admin-panel-web3 .w3-config-row-label {
  font-size: 0.75rem;
  color: var(--w3-slate-700);
  line-height: 1.5;
  flex: 1;
}
body.page-admin #admin-panel-web3 .w3-config-row-value {
  text-align: right;
  max-width: 60%;
}

/* ---------- Go/no-go panel ---------- */
body.page-admin #admin-panel-web3 .w3-gonogo {
  background: #fff;
  border: 1px solid var(--w3-red-200);
  border-radius: 12px;
  overflow: hidden;
}
body.page-admin #admin-panel-web3 .w3-gonogo-header {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.85rem 1rem;
  background: var(--w3-red-50);
  border-bottom: 1px solid var(--w3-red-200);
}
body.page-admin #admin-panel-web3 .w3-gonogo-icon { color: var(--w3-red-700); display: inline-flex; }
body.page-admin #admin-panel-web3 .w3-gonogo-status {
  font-size: 0.82rem;
  font-weight: 700;
  color: var(--w3-red-700);
}
body.page-admin #admin-panel-web3 .w3-gonogo-mode {
  font-size: 0.68rem;
  color: #991b1b;
}
body.page-admin #admin-panel-web3 .w3-gonogo-blocker-badge {
  margin-left: auto;
  font-size: 0.62rem;
  font-weight: 700;
  color: #fff;
  background: #dc2626;
  padding: 0.2rem 0.65rem;
  border-radius: 9999px;
}
body.page-admin #admin-panel-web3 .w3-gonogo-tabs {
  display: flex;
  padding: 0 1rem;
  border-bottom: 1px solid var(--w3-slate-100);
}
body.page-admin #admin-panel-web3 .w3-gonogo-tab {
  padding: 0.5rem 0.75rem;
  border: none;
  border-bottom: 2px solid transparent;
  background: transparent;
  cursor: pointer;
  font-family: inherit;
  font-size: 0.75rem;
  font-weight: 500;
  color: var(--w3-slate-500);
}
body.page-admin #admin-panel-web3 .w3-gonogo-tab.is-active {
  color: var(--w3-red-700);
  font-weight: 600;
  border-bottom-color: var(--w3-red-700);
}
body.page-admin #admin-panel-web3 .w3-gonogo-body { padding: 0.85rem; }
body.page-admin #admin-panel-web3 .w3-gonogo-pane { display: none; }
body.page-admin #admin-panel-web3 .w3-gonogo-pane.is-active { display: grid; }
body.page-admin #admin-panel-web3 .w3-gonogo-rows {
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: 0.25rem;
}
body.page-admin #admin-panel-web3 .w3-gonogo-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0.3rem 0.65rem;
  background: var(--w3-slate-50);
  border: 1px solid var(--w3-slate-100);
  border-radius: 6px;
}
body.page-admin #admin-panel-web3 .w3-gonogo-row.is-positive {
  background: var(--w3-green-50);
  border-color: var(--w3-green-200);
}
body.page-admin #admin-panel-web3 .w3-gonogo-row-label {
  font-size: 0.7rem;
  color: var(--w3-slate-600);
}
body.page-admin #admin-panel-web3 .w3-gonogo-row-val {
  font-size: 0.6rem;
  font-weight: 700;
  padding: 0.05rem 0.55rem;
  border-radius: 9999px;
  background: var(--w3-red-100);
  color: var(--w3-red-700);
}
body.page-admin #admin-panel-web3 .w3-gonogo-row.is-positive .w3-gonogo-row-val {
  background: var(--w3-green-100);
  color: var(--w3-green-700);
}
body.page-admin #admin-panel-web3 .w3-gonogo-blockers,
body.page-admin #admin-panel-web3 .w3-gonogo-forbidden {
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 0.3rem;
}
body.page-admin #admin-panel-web3 .w3-gonogo-blocker {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.35rem 0.75rem;
  background: var(--w3-red-50);
  border: 1px solid var(--w3-red-200);
  border-radius: 6px;
  font-size: 0.7rem;
  color: #991b1b;
}
body.page-admin #admin-panel-web3 .w3-gonogo-blocker svg { color: #dc2626; flex-shrink: 0; }
body.page-admin #admin-panel-web3 .w3-gonogo-forbidden-item {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.35rem 0.75rem;
  background: var(--w3-slate-50);
  border: 1px solid var(--w3-slate-200);
  border-radius: 6px;
  font-size: 0.7rem;
  color: var(--w3-slate-600);
  font-family: "JetBrains Mono", monospace;
}
body.page-admin #admin-panel-web3 .w3-gonogo-forbidden-item svg { color: var(--w3-slate-400); flex-shrink: 0; }

/* ---------- Contract gates ---------- */
body.page-admin #admin-panel-web3 .w3-contract-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 0.35rem;
  margin-bottom: 0.75rem;
}
body.page-admin #admin-panel-web3 .w3-contract-chip {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  padding: 0.25rem 0.8rem;
  border-radius: 9999px;
  border: 1px solid var(--w3-slate-200);
  background: #fff;
  font-family: inherit;
  font-size: 0.7rem;
  font-weight: 500;
  color: var(--w3-slate-500);
  cursor: pointer;
}
body.page-admin #admin-panel-web3 .w3-contract-chip.is-active {
  background: var(--w3-slate-900);
  color: #fff;
  border-color: transparent;
  font-weight: 600;
}
body.page-admin #admin-panel-web3 .w3-contract-chip[data-group="decision"].is-active { background: #7e22ce; }
body.page-admin #admin-panel-web3 .w3-contract-chip[data-group="design"].is-active   { background: #1d4ed8; }
body.page-admin #admin-panel-web3 .w3-contract-chip[data-group="approval"].is-active { background: #92400e; }
body.page-admin #admin-panel-web3 .w3-contract-chip[data-group="evidence"].is-active { background: #0369a1; }
body.page-admin #admin-panel-web3 .w3-contract-chip[data-group="policy"].is-active   { background: #b91c1c; }
body.page-admin #admin-panel-web3 .w3-contract-chip[data-group="guard"].is-active    { background: #166534; }

body.page-admin #admin-panel-web3 .w3-contract-chip-count {
  font-size: 0.62rem;
  font-weight: 700;
  padding: 0.05rem 0.45rem;
  border-radius: 9999px;
  background: var(--w3-slate-100);
  color: var(--w3-slate-600);
}
body.page-admin #admin-panel-web3 .w3-contract-chip.is-active .w3-contract-chip-count {
  background: rgba(255,255,255,0.25);
  color: #fff;
}

body.page-admin #admin-panel-web3 .w3-contract-list {
  display: grid;
  grid-template-columns: 1fr;
  gap: 0.35rem;
}
body.page-admin #admin-panel-web3 .w3-contract-row {
  background: #fff;
  border: 1px solid var(--w3-slate-200);
  border-radius: 8px;
}
body.page-admin #admin-panel-web3 .w3-contract-row summary {
  list-style: none;
  cursor: pointer;
  display: flex;
  align-items: center;
  gap: 0.6rem;
  padding: 0.55rem 0.8rem;
}
body.page-admin #admin-panel-web3 .w3-contract-row summary::-webkit-details-marker { display: none; }
body.page-admin #admin-panel-web3 .w3-contract-row .w3-chev { color: var(--w3-slate-400); transition: transform 0.15s; }
body.page-admin #admin-panel-web3 .w3-contract-row[open] .w3-chev { transform: rotate(90deg); }
body.page-admin #admin-panel-web3 .w3-contract-feature {
  font-size: 0.6rem;
  font-weight: 700;
  color: var(--w3-slate-600);
  background: var(--w3-slate-100);
  padding: 0.1rem 0.45rem;
  border-radius: 4px;
  font-family: "JetBrains Mono", monospace;
  flex-shrink: 0;
}
body.page-admin #admin-panel-web3 .w3-contract-title {
  flex: 1;
  font-size: 0.78rem;
  color: var(--w3-slate-900);
  font-weight: 500;
}
body.page-admin #admin-panel-web3 .w3-contract-group {
  font-size: 0.6rem;
  font-weight: 600;
  padding: 0.1rem 0.6rem;
  border-radius: 9999px;
  flex-shrink: 0;
}
body.page-admin #admin-panel-web3 .w3-contract-group.is-decision { background: #fae8ff; color: #7e22ce; }
body.page-admin #admin-panel-web3 .w3-contract-group.is-design   { background: #dbeafe; color: #1d4ed8; }
body.page-admin #admin-panel-web3 .w3-contract-group.is-approval { background: #fef3c7; color: #92400e; }
body.page-admin #admin-panel-web3 .w3-contract-group.is-evidence { background: #e0f2fe; color: #0369a1; }
body.page-admin #admin-panel-web3 .w3-contract-group.is-policy   { background: #fee2e2; color: #b91c1c; }
body.page-admin #admin-panel-web3 .w3-contract-group.is-guard    { background: #dcfce7; color: #166534; }

body.page-admin #admin-panel-web3 .w3-contract-blocked {
  display: inline-flex;
  align-items: center;
  gap: 0.25rem;
  font-size: 0.6rem;
  font-weight: 700;
  padding: 0.1rem 0.55rem;
  border-radius: 9999px;
  background: #fee2e2;
  color: #b91c1c;
  flex-shrink: 0;
}
body.page-admin #admin-panel-web3 .w3-contract-blocked::before {
  content: "";
  width: 5px;
  height: 5px;
  border-radius: 50%;
  background: #ef4444;
}
body.page-admin #admin-panel-web3 .w3-contract-detail {
  padding: 0 0.8rem 0.7rem 2.4rem;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 0.25rem;
}
body.page-admin #admin-panel-web3 .w3-detail-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0.2rem 0.55rem;
  background: var(--w3-slate-50);
  border-radius: 4px;
  gap: 0.5rem;
}
body.page-admin #admin-panel-web3 .w3-detail-row-label { font-size: 0.62rem; color: var(--w3-slate-400); }
body.page-admin #admin-panel-web3 .w3-detail-row-val   { font-size: 0.72rem; color: var(--w3-slate-900); font-weight: 500; text-align: right; }
body.page-admin #admin-panel-web3 .w3-detail-row-val.is-mono { font-family: "JetBrains Mono", monospace; }
body.page-admin #admin-panel-web3 .w3-detail-row-val.is-ok  { color: var(--w3-green-700); }
body.page-admin #admin-panel-web3 .w3-detail-row-val.is-bad { color: var(--w3-red-700); }

/* ---------- Sandbox preview cards ---------- */
body.page-admin #admin-panel-web3 .w3-sandbox-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 0.6rem;
}
body.page-admin #admin-panel-web3 .w3-sandbox-card {
  background: #fff;
  border: 1px solid var(--w3-slate-200);
  border-radius: 10px;
  overflow: hidden;
}
body.page-admin #admin-panel-web3 .w3-sandbox-card-head {
  padding: 0.75rem 0.85rem;
}
body.page-admin #admin-panel-web3 .w3-sandbox-title {
  font-size: 0.82rem;
  font-weight: 700;
  color: var(--w3-slate-900);
  margin-bottom: 0.3rem;
}
body.page-admin #admin-panel-web3 .w3-sandbox-status {
  display: inline-flex;
  align-items: center;
  gap: 0.3rem;
  font-size: 0.62rem;
  font-weight: 600;
  padding: 0.1rem 0.55rem;
  border-radius: 9999px;
  background: var(--w3-amber-100);
  color: var(--w3-amber-700);
  margin-bottom: 0.5rem;
}
body.page-admin #admin-panel-web3 .w3-sandbox-status::before {
  content: "";
  width: 5px;
  height: 5px;
  border-radius: 50%;
  background: var(--w3-amber-500);
}
body.page-admin #admin-panel-web3 .w3-sandbox-summary {
  font-size: 0.7rem;
  color: var(--w3-slate-500);
  line-height: 1.5;
  margin: 0;
}
body.page-admin #admin-panel-web3 .w3-sandbox-candidates {
  display: flex;
  gap: 0.3rem;
  margin-top: 0.5rem;
  flex-wrap: wrap;
}
body.page-admin #admin-panel-web3 .w3-sandbox-candidate {
  font-size: 0.62rem;
  font-weight: 600;
  padding: 0.1rem 0.55rem;
  border-radius: 4px;
}
body.page-admin #admin-panel-web3 .w3-sandbox-candidate.is-primary { background: var(--w3-blue-100); color: var(--w3-blue-700); }
body.page-admin #admin-panel-web3 .w3-sandbox-candidate.is-backup  { background: var(--w3-slate-100); color: var(--w3-slate-600); }
body.page-admin #admin-panel-web3 .w3-sandbox-account {
  margin-top: 0.5rem;
  padding: 0.5rem;
  background: var(--w3-slate-50);
  border-radius: 6px;
  font-size: 0.7rem;
}
body.page-admin #admin-panel-web3 .w3-sandbox-account-label { color: var(--w3-slate-500); }
body.page-admin #admin-panel-web3 .w3-sandbox-account-val   { color: var(--w3-slate-900); font-family: "JetBrains Mono", monospace; }
body.page-admin #admin-panel-web3 .w3-sandbox-toggle {
  margin-top: 0.5rem;
  display: inline-flex;
  align-items: center;
  gap: 0.3rem;
  padding: 0.25rem 0.6rem;
  border-radius: 6px;
  border: 1px solid var(--w3-slate-200);
  background: #fff;
  font-family: inherit;
  font-size: 0.7rem;
  font-weight: 500;
  color: var(--w3-slate-600);
  cursor: pointer;
}
body.page-admin #admin-panel-web3 .w3-sandbox-body {
  padding: 0.6rem;
  display: flex;
  flex-direction: column;
  gap: 0.2rem;
  background: #fafbfc;
  border-top: 1px solid var(--w3-slate-100);
}

body.page-admin #admin-panel-web3 .w3-cap-pill {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0.3rem 0.6rem;
  background: #fff;
  border: 1px solid var(--w3-slate-100);
  border-radius: 6px;
}
body.page-admin #admin-panel-web3 .w3-cap-pill-label {
  font-size: 0.68rem;
  color: var(--w3-slate-600);
  font-family: "JetBrains Mono", monospace;
}
body.page-admin #admin-panel-web3 .w3-cap-pill-state {
  display: inline-flex;
  align-items: center;
  gap: 0.25rem;
  font-size: 0.6rem;
  font-weight: 700;
  padding: 0.05rem 0.55rem;
  border-radius: 9999px;
  background: var(--w3-red-100);
  color: var(--w3-red-700);
}
body.page-admin #admin-panel-web3 .w3-cap-pill-state.is-on {
  background: var(--w3-green-100);
  color: var(--w3-green-700);
}
body.page-admin #admin-panel-web3 .w3-cap-pill-state::before {
  content: "";
  width: 5px;
  height: 5px;
  border-radius: 50%;
  background: var(--w3-red-500);
}
body.page-admin #admin-panel-web3 .w3-cap-pill-state.is-on::before { background: var(--w3-green-500); }

body.page-admin #admin-panel-web3 .w3-stage-chips,
body.page-admin #admin-panel-web3 .w3-method-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 0.2rem;
  margin-top: 0.3rem;
}
body.page-admin #admin-panel-web3 .w3-stage-chip {
  font-size: 0.58rem;
  font-family: "JetBrains Mono", monospace;
  color: var(--w3-slate-600);
  background: #fff;
  padding: 0.1rem 0.4rem;
  border-radius: 4px;
  border: 1px solid var(--w3-slate-200);
}
body.page-admin #admin-panel-web3 .w3-method-chip {
  font-size: 0.58rem;
  font-family: "JetBrains Mono", monospace;
  color: var(--w3-purple);
  background: var(--w3-purple-soft);
  padding: 0.1rem 0.4rem;
  border-radius: 4px;
}
body.page-admin #admin-panel-web3 .w3-subhead {
  font-size: 0.62rem;
  color: var(--w3-slate-400);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  margin-top: 0.55rem;
  margin-bottom: 0.25rem;
}

/* ---------- Safety posture ---------- */
body.page-admin #admin-panel-web3 .w3-safety {
  background: var(--w3-green-50);
  border: 1px solid var(--w3-green-200);
  border-radius: 12px;
  padding: 0.85rem 1rem;
}
body.page-admin #admin-panel-web3 .w3-safety-head {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 0.78rem;
  font-weight: 600;
  color: var(--w3-green-700);
  margin-bottom: 0.65rem;
}
body.page-admin #admin-panel-web3 .w3-safety-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 0.25rem;
}
body.page-admin #admin-panel-web3 .w3-safety-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0.3rem 0.7rem;
  background: #fff;
  border: 1px solid var(--w3-green-200);
  border-radius: 6px;
  font-family: "JetBrains Mono", monospace;
}
body.page-admin #admin-panel-web3 .w3-safety-row-label {
  font-size: 0.65rem;
  color: var(--w3-green-700);
}
body.page-admin #admin-panel-web3 .w3-safety-row-pill {
  font-size: 0.58rem;
  font-weight: 700;
  color: var(--w3-green-700);
  background: var(--w3-green-100);
  padding: 0.05rem 0.5rem;
  border-radius: 9999px;
}

/* ---------- Redemption ---------- */
body.page-admin #admin-panel-web3 .w3-redemption-tip {
  background: var(--w3-green-50);
  border: 1px solid var(--w3-green-200);
  border-radius: 10px;
  padding: 0.55rem 0.85rem;
  margin: 0.5rem 0 0.9rem;
  font-size: 0.75rem;
  color: var(--w3-green-700);
}

/* ---------- Logistics 4-step ---------- */
body.page-admin #admin-panel-web3 .w3-flag-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
  gap: 0.35rem;
  margin-bottom: 1rem;
}
body.page-admin #admin-panel-web3 .w3-flag {
  padding: 0.4rem 0.75rem;
  border-radius: 8px;
  border: 1px solid var(--w3-green-200);
  background: var(--w3-green-50);
}
body.page-admin #admin-panel-web3 .w3-flag-label {
  font-size: 0.58rem;
  color: var(--w3-green-700);
  opacity: 0.85;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}
body.page-admin #admin-panel-web3 .w3-flag-val {
  display: flex;
  align-items: center;
  gap: 0.3rem;
  margin-top: 0.15rem;
  font-size: 0.72rem;
  font-weight: 600;
  color: var(--w3-green-700);
}
body.page-admin #admin-panel-web3 .w3-flag-val::before {
  content: "";
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--w3-green-500);
}
body.page-admin #admin-panel-web3 .w3-flag.is-preview { background: var(--w3-purple-soft); border-color: var(--w3-purple-ring); }
body.page-admin #admin-panel-web3 .w3-flag.is-preview .w3-flag-label,
body.page-admin #admin-panel-web3 .w3-flag.is-preview .w3-flag-val { color: var(--w3-purple); }
body.page-admin #admin-panel-web3 .w3-flag.is-preview .w3-flag-val::before { background: var(--w3-purple-2); }
body.page-admin #admin-panel-web3 .w3-flag-val.is-mono { font-family: "JetBrains Mono", monospace; }

body.page-admin #admin-panel-web3 .w3-steps {
  display: flex;
  align-items: center;
  gap: 0.25rem;
  padding: 0.6rem;
  background: #fff;
  border: 1px solid var(--w3-slate-200);
  border-radius: 10px;
  margin-bottom: 0.9rem;
}
body.page-admin #admin-panel-web3 .w3-step {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.35rem 0.85rem;
  border: 1px solid transparent;
  background: transparent;
  color: var(--w3-slate-400);
  border-radius: 8px;
  cursor: pointer;
  font-family: inherit;
  font-size: 0.75rem;
  font-weight: 600;
}
body.page-admin #admin-panel-web3 .w3-step.is-active {
  background: var(--w3-purple);
  color: #fff;
}
body.page-admin #admin-panel-web3 .w3-step.is-done {
  background: var(--w3-green-100);
  color: var(--w3-green-700);
}
body.page-admin #admin-panel-web3 .w3-step-num {
  width: 18px;
  height: 18px;
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: var(--w3-slate-100);
  color: var(--w3-slate-400);
  font-size: 0.62rem;
}
body.page-admin #admin-panel-web3 .w3-step.is-active .w3-step-num {
  background: rgba(255,255,255,0.25);
  color: #fff;
}
body.page-admin #admin-panel-web3 .w3-step.is-done .w3-step-num {
  background: var(--w3-green-500);
  color: #fff;
}
body.page-admin #admin-panel-web3 .w3-step-line {
  flex: 1;
  height: 1px;
  background: var(--w3-slate-200);
}

body.page-admin #admin-panel-web3 .w3-form-card {
  background: #fff;
  border: 1px solid var(--w3-slate-200);
  border-radius: 12px;
  padding: 1.1rem;
  margin-bottom: 1rem;
}
body.page-admin #admin-panel-web3 .w3-form-card h3 {
  font-size: 0.88rem;
  font-weight: 700;
  color: var(--w3-slate-900);
  margin: 0 0 0.25rem;
}
body.page-admin #admin-panel-web3 .w3-form-card p {
  font-size: 0.75rem;
  color: var(--w3-slate-500);
  margin: 0 0 0.85rem;
}
body.page-admin #admin-panel-web3 .w3-form-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
  gap: 0.5rem;
}
body.page-admin #admin-panel-web3 .w3-form-grid input {
  width: 100%;
  padding: 0.35rem 0.6rem;
  background: var(--w3-slate-50);
  border: 1px solid var(--w3-slate-200);
  border-radius: 8px;
  font-family: inherit;
  font-size: 0.78rem;
  color: var(--w3-slate-900);
}
body.page-admin #admin-panel-web3 .w3-form-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  margin-top: 0.85rem;
}
body.page-admin #admin-panel-web3 .w3-form-empty {
  margin-top: 0.85rem;
  padding: 0.75rem;
  background: var(--w3-slate-50);
  border-radius: 8px;
  font-size: 0.75rem;
  color: var(--w3-slate-400);
  font-style: italic;
}

/* Compact pill button row for actions */
body.page-admin #admin-panel-web3 .w3-action-row {
  display: flex;
  flex-wrap: wrap;
  gap: 0.4rem;
  align-items: center;
}

/* Hide native overlays inside web3 panel that we replace with pills */
body.page-admin #admin-panel-web3 .w3-hidden-control {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0,0,0,0);
  border: 0;
}
