/**
 * Administration Pages Styles
 * Covers: Admin Passes page + Admin Workflows V2 page
 * Uses the app's CSS custom properties for dark-mode support.
 */

/* ================================================================== */
/*  ADMIN PASSES PAGE                                                  */
/* ================================================================== */

/* Stats row */
.ap-stats {
  display: flex;
  gap: 12px;
  margin-bottom: 16px;
  flex-wrap: wrap;
}
.ap-stat {
  flex: 1;
  min-width: 120px;
  padding: 16px;
  text-align: center;
}
.ap-stat-value {
  font-size: 28px;
  font-weight: 700;
  color: var(--text-primary);
}
.ap-stat-label {
  font-size: 12px;
  color: var(--text-secondary);
  text-transform: uppercase;
  letter-spacing: .5px;
  margin-top: 4px;
}

/* Actions bar */
.ap-actions {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 12px 16px;
  margin-bottom: 16px;
}
.ap-actions-left { flex: 1; }
.ap-actions-left .input { width: 100%; max-width: 320px; }
.ap-actions-right { display: flex; gap: 8px; }

/* Table tweaks */
.ap-member-name {
  font-weight: 500;
  color: var(--text-primary);
}
.ap-member-email {
  font-size: 12px;
  color: var(--text-secondary);
}
.ap-date {
  font-size: 13px;
  color: var(--text-secondary);
  white-space: nowrap;
}
.ap-row-actions {
  display: flex;
  gap: 4px;
  white-space: nowrap;
}

/* Badges */
.badge {
  display: inline-block;
  padding: 2px 8px;
  border-radius: 10px;
  font-size: 11px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .3px;
}
.badge-success {
  background: rgba(52, 199, 89, .15);
  color: #34c759;
}
.badge-danger {
  background: rgba(255, 59, 48, .15);
  color: #ff3b30;
}
.badge-muted {
  background: var(--bg-tertiary, rgba(128,128,128,.1));
  color: var(--text-secondary);
}

/* Clickable rows */
.ap-row-clickable { cursor: pointer; }
.ap-row-clickable:hover { background: var(--bg-hover, rgba(128,128,128,.05)); }
.ap-row-expanded { background: var(--bg-hover, rgba(128,128,128,.05)); }

/* Detail panel (expanded row) */
.ap-detail-row td { padding: 0 !important; }
.ap-detail-panel {
  padding: 16px 20px;
  background: var(--bg-secondary, rgba(0,0,0,.02));
  border-top: 1px solid var(--border-color, rgba(128,128,128,.15));
}
.ap-detail-loading {
  color: var(--text-secondary);
  font-size: 13px;
  padding: 8px 0;
}
.ap-detail-content {
  display: flex;
  gap: 32px;
  flex-wrap: wrap;
}
.ap-detail-section {
  flex: 1;
  min-width: 240px;
}
.ap-detail-section h4 {
  margin: 0 0 10px;
  font-size: 14px;
  font-weight: 600;
  color: var(--text-primary);
}
.ap-detail-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px 16px;
}
.ap-detail-item {
  display: flex;
  flex-direction: column;
  gap: 2px;
  font-size: 13px;
}
.ap-detail-label {
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: .4px;
  color: var(--text-secondary);
}
.ap-detail-mono {
  font-family: 'SF Mono', 'Roboto Mono', monospace;
  font-size: 11px;
  word-break: break-all;
}
.ap-detail-none {
  color: var(--text-secondary);
  font-size: 13px;
  font-style: italic;
  margin: 0;
}
.ap-detail-error {
  color: #ff3b30;
  font-size: 13px;
  padding: 8px 0;
}

/* Small buttons */
.btn-sm {
  padding: 4px 8px;
  font-size: 12px;
  min-width: auto;
}
.btn-danger {
  background: #ff3b30;
  color: #fff;
  border: none;
}
.btn-danger:hover { background: #e0342b; }
.btn-success {
  background: #34c759;
  color: #fff;
  border: none;
}
.btn-success:hover { background: #2db84e; }

/* Dialog overlay */
.ap-dialog-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,.5);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 1000;
}
.ap-dialog {
  width: 90%;
  max-width: 480px;
  padding: 24px;
}
.ap-dialog h3 {
  margin: 0 0 16px;
  font-size: 18px;
  color: var(--text-primary);
}
.ap-dialog-body {
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.ap-dialog-body label {
  font-size: 13px;
  font-weight: 500;
  color: var(--text-secondary);
}
.ap-dialog-body .input {
  width: 100%;
}
.ap-dialog-body textarea.input {
  resize: vertical;
  font-family: inherit;
}
.ap-checkbox-label {
  display: flex;
  align-items: center;
  gap: 6px;
  cursor: pointer;
}
.ap-dialog-actions {
  display: flex;
  justify-content: flex-end;
  gap: 8px;
  margin-top: 16px;
}

/* ================================================================== */
/*  ADMIN WORKFLOWS V2 PAGE                                            */
/* ================================================================== */

.admin-workflows { max-width: none; }

.aw-list {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

/* Workflow card */
.aw-card { padding: 0; overflow: hidden; }
.aw-card-header {
  display: flex;
  align-items: center;
  gap: 16px;
  padding: 16px 20px;
  flex-wrap: wrap;
}
.aw-card-info { flex: 1; min-width: 200px; }
.aw-card-title {
  font-size: 16px;
  font-weight: 600;
  color: var(--text-primary);
}
.aw-card-desc {
  font-size: 13px;
  color: var(--text-secondary);
  margin-top: 2px;
}

/* Meta items */
.aw-card-meta {
  display: flex;
  gap: 20px;
  flex-wrap: wrap;
}
.aw-meta-item {
  display: flex;
  flex-direction: column;
  align-items: center;
  min-width: 80px;
}
.aw-meta-label {
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: .5px;
  color: var(--text-secondary);
}
.aw-meta-value {
  font-size: 13px;
  color: var(--text-primary);
  font-weight: 500;
}

/* Status badges */
.aw-status-badge {
  display: inline-block;
  padding: 2px 8px;
  border-radius: 10px;
  font-size: 11px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .3px;
}
.aw-status-completed {
  background: rgba(52, 199, 89, .15);
  color: #34c759;
}
.aw-status-in_progress, .aw-status-running {
  background: rgba(0, 122, 255, .15);
  color: #007aff;
}
.aw-status-failed {
  background: rgba(255, 59, 48, .15);
  color: #ff3b30;
}
.aw-status-paused, .aw-status-blocked {
  background: rgba(255, 159, 10, .15);
  color: #ff9f0a;
}
.aw-status-unknown {
  background: var(--bg-tertiary, rgba(128,128,128,.1));
  color: var(--text-secondary);
}

/* Card actions */
.aw-card-actions {
  display: flex;
  gap: 6px;
}

/* Runs section */
.aw-card-runs {
  border-top: 1px solid var(--border-color, rgba(128,128,128,.2));
  padding: 12px 20px;
  background: var(--bg-secondary, rgba(0,0,0,.02));
  max-height: 400px;
  overflow-y: auto;
}
.aw-hidden { display: none; }
.aw-no-runs {
  text-align: center;
  padding: 16px;
  color: var(--text-secondary);
  font-size: 13px;
}

/* Runs table */
.aw-runs-table { font-size: 13px; }
.aw-run-id {
  font-family: 'SF Mono', 'Roboto Mono', monospace;
  font-size: 12px;
  color: var(--text-secondary);
}
.aw-run-row { cursor: pointer; }
.aw-run-row:hover { background: var(--bg-hover, rgba(128,128,128,.05)); }

/* Run detail dialog */
.aw-run-detail-dialog {
  max-width: 640px;
  max-height: 80vh;
  overflow-y: auto;
}
.aw-run-detail-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 16px;
}
.aw-run-detail-header h3 { margin: 0; }
.aw-run-detail-body { font-size: 14px; }

.aw-detail-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
  margin-bottom: 16px;
}
.aw-detail-item {
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.aw-detail-label {
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: .4px;
  color: var(--text-secondary);
}
.aw-detail-error { color: #ff3b30; }

/* Stages */
.aw-stages {
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin-bottom: 16px;
}
.aw-stage {
  border: 1px solid var(--border-color, rgba(128,128,128,.2));
  border-radius: 8px;
  padding: 10px 12px;
}
.aw-stage-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.aw-stage-name {
  font-weight: 500;
  font-size: 13px;
}
.aw-stage-data {
  margin-top: 8px;
  padding: 8px;
  background: var(--bg-tertiary, rgba(0,0,0,.03));
  border-radius: 4px;
  font-size: 11px;
  overflow-x: auto;
  max-height: 150px;
}
.aw-stage-blocker {
  margin-top: 6px;
  color: #ff9f0a;
  font-size: 12px;
}

/* Raw JSON */
.aw-raw-json {
  margin-top: 12px;
}
.aw-raw-json summary {
  cursor: pointer;
  font-size: 13px;
  color: var(--text-secondary);
}
.aw-raw-json pre {
  margin-top: 8px;
  padding: 12px;
  background: var(--bg-tertiary, rgba(0,0,0,.03));
  border-radius: 6px;
  font-size: 11px;
  overflow-x: auto;
  max-height: 300px;
}

/* Spinner small */
.spinner-sm {
  display: inline-block;
  width: 16px;
  height: 16px;
  border: 2px solid var(--text-secondary);
  border-top-color: transparent;
  border-radius: 50%;
  animation: spin 0.6s linear infinite;
  vertical-align: middle;
  margin-right: 6px;
}

/* ================================================================== */
/*  Responsive                                                         */
/* ================================================================== */
@media (max-width: 768px) {
  .ap-stats { flex-direction: column; }
  .ap-actions { flex-direction: column; }
  .ap-actions-left .input { max-width: 100%; }
  .aw-card-header { flex-direction: column; align-items: flex-start; }
  .aw-card-meta { width: 100%; }
  .aw-detail-grid { grid-template-columns: 1fr; }
}
