/* ── Approval Dashboard Styles ─────────────────────────────────────────────── */

.apv-header { display: flex; justify-content: space-between; align-items: center; margin-bottom: 1rem; }
.apv-header h2 { margin: 0; font-size: 1.25rem; }
.apv-actions { display: flex; gap: 0.5rem; }
.btn-danger { background: rgba(255, 77, 106, 0.15); color: var(--danger, #ff4d6a); border: 1px solid rgba(255, 77, 106, 0.3); border-radius: 6px; padding: 0.35rem 0.75rem; cursor: pointer; font-size: 0.8rem; }
.btn-danger:hover { background: rgba(255, 77, 106, 0.25); }

.apv-filter-row { display: flex; gap: 0.5rem; margin-bottom: 1rem; align-items: center; }

/* Approval Cards */
.apv-queue { display: flex; flex-direction: column; gap: 0.5rem; margin-bottom: 1.5rem; }
.apv-card { background: var(--card-bg, #1a1d23); border: 1px solid var(--border, #2a2d35); border-radius: 10px; padding: 0.75rem 1rem; transition: border-color 0.15s; }
.apv-card:hover { border-color: rgba(124, 92, 252, 0.3); }
.apv-card-processed { opacity: 0.6; }
.apv-card-header { display: flex; align-items: center; gap: 0.5rem; margin-bottom: 0.35rem; }
.apv-risk { font-size: 0.75rem; text-transform: uppercase; }
.apv-type { font-size: 0.75rem; color: var(--text-secondary, #8a8f98); background: rgba(255,255,255,0.04); padding: 0.1rem 0.5rem; border-radius: 4px; }
.apv-title { margin: 0.25rem 0; font-size: 0.9rem; }
.apv-desc { font-size: 0.8rem; color: var(--text-secondary, #8a8f98); margin: 0.25rem 0; }
.apv-meta { display: flex; gap: 1rem; font-size: 0.72rem; color: var(--text-secondary, #8a8f98); margin-top: 0.25rem; }
.apv-card-actions { display: flex; gap: 0.5rem; margin-top: 0.5rem; }

/* Rules */
.apv-rules-section { margin-top: 1.5rem; }
.apv-rule-form { display: flex; gap: 0.5rem; flex-wrap: wrap; align-items: center; margin-bottom: 0.75rem; }
.apv-rule-card { background: var(--card-bg, #1a1d23); border: 1px solid var(--border, #2a2d35); border-radius: 8px; padding: 0.5rem 0.75rem; font-size: 0.82rem; margin-bottom: 0.35rem; }
