/* Pipeline steps in left panel */
.pipeline-steps { display: flex; flex-direction: column; gap: 2px; }

.pipeline-step { display: flex; align-items: center; gap: 10px; padding: 8px 10px; border-radius: var(--radius-sm); cursor: pointer; transition: all var(--transition-fast); position: relative; }
.pipeline-step:hover { background: var(--bg-hover); }
.pipeline-step.active { background: var(--primary-light); }

.pipeline-step-icon { width: 28px; height: 28px; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 14px; flex-shrink: 0; border: 2px solid var(--border); background: var(--bg-card); }
.pipeline-step.completed .pipeline-step-icon { border-color: var(--success); background: var(--success); color: white; font-size: 12px; }
.pipeline-step.active .pipeline-step-icon { border-color: var(--primary); background: var(--primary-light); animation: pulse 2s infinite; }
.pipeline-step.pending .pipeline-step-icon { border-color: var(--border); color: var(--text-placeholder); }

.pipeline-step-info { flex: 1; min-width: 0; }
.pipeline-step-name { font-size: 13px; font-weight: 500; color: var(--text-body); }
.pipeline-step.completed .pipeline-step-name { color: var(--success); }
.pipeline-step.active .pipeline-step-name { color: var(--primary); font-weight: 600; }
.pipeline-step.pending .pipeline-step-name { color: var(--text-placeholder); }
.pipeline-step-desc { font-size: 11px; color: var(--text-placeholder); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }

/* Connector line between steps */
.pipeline-step::before { content: ''; position: absolute; left: 23px; top: -2px; width: 2px; height: 10px; background: var(--border); }
.pipeline-step:first-child::before { display: none; }
.pipeline-step.completed::before { background: var(--success); }
.pipeline-step.active::before { background: var(--primary); }

/* Pipeline Dashboard Modal */
.pipeline-dashboard { padding: 0; }

.pipeline-flow { display: flex; align-items: center; gap: 4px; padding: 24px 16px; overflow-x: auto; background: var(--bg-input); border-radius: var(--radius-md); margin-bottom: 24px; }

.pipeline-node { display: flex; flex-direction: column; align-items: center; gap: 6px; min-width: 80px; flex-shrink: 0; }
.pipeline-node-circle { width: 44px; height: 44px; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 20px; border: 3px solid var(--border); background: var(--bg-card); transition: all var(--transition-fast); }
.pipeline-node.completed .pipeline-node-circle { border-color: var(--success); background: #E8FFEA; }
.pipeline-node.active .pipeline-node-circle { border-color: var(--primary); background: var(--primary-light); animation: pulse 2s infinite; }
.pipeline-node.pending .pipeline-node-circle { opacity: .5; }
.pipeline-node-label { font-size: 11px; color: var(--text-secondary); text-align: center; max-width: 72px; }
.pipeline-node.completed .pipeline-node-label { color: var(--success); }
.pipeline-node.active .pipeline-node-label { color: var(--primary); font-weight: 600; }

.pipeline-arrow { color: var(--border); font-size: 16px; flex-shrink: 0; }
.pipeline-node.completed + .pipeline-arrow { color: var(--success); }

/* Pipeline detail content */
.pipeline-detail-content { padding: 24px 32px; }
.pipeline-detail-header { display: flex; align-items: center; gap: 12px; margin-bottom: 20px; padding-bottom: 16px; border-bottom: 1px solid var(--border-light); }
.pipeline-detail-header .module-icon { font-size: 28px; }
.pipeline-detail-header h2 { font-size: 18px; margin: 0; }
.pipeline-detail-header .module-status { margin-left: auto; }

.pipeline-output { font-size: 14px; line-height: 2; color: var(--text-body); white-space: pre-wrap; }
.pipeline-output h2 { font-size: 17px; margin: 20px 0 10px; color: var(--text-primary); }
.pipeline-output h3 { font-size: 15px; margin: 16px 0 8px; color: var(--primary); }
.pipeline-output table { width: 100%; border-collapse: collapse; margin: 12px 0; font-size: 13px; }
.pipeline-output th { background: var(--bg-input); padding: 8px 12px; text-align: left; font-weight: 600; }
.pipeline-output td { padding: 8px 12px; border-bottom: 1px solid var(--border-light); }
.pipeline-output strong { color: var(--text-primary); }

.pipeline-actions { display: flex; gap: 12px; margin-top: 24px; padding-top: 16px; border-top: 1px solid var(--border-light); }

/* Dashboard timeline */
.pipeline-timeline { margin-top: 20px; }
.timeline-item { display: flex; gap: 12px; padding: 10px 0; border-bottom: 1px solid var(--border-light); font-size: 13px; }
.timeline-item .timeline-time { width: 80px; flex-shrink: 0; color: var(--text-secondary); }
.timeline-item .timeline-module { font-weight: 500; }
.timeline-item .timeline-status { margin-left: auto; }
