/* ===================================================================================== */
/* TIMELINE - PROCESO DE TRABAJO                                                         */
/* ===================================================================================== */

.timeline {
  position: relative;
}

.timeline-card {
  transition: transform var(--transition-base), box-shadow var(--transition-base);
  border: 1px solid var(--glass-light-border);
  overflow: hidden;
  background: white;
  border-radius: var(--radius-lg);
  box-shadow: var(--glass-light-shadow);
}

.timeline-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 12px 40px rgba(0, 0, 0, 0.10);
}

/* Timeline icon circles */
.timeline-icon {
  width: 56px;
  height: 56px;
  min-width: 56px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  color: #fff;
  font-size: 1.5rem;
  transition: transform var(--transition-base);
}

.timeline-card:hover .timeline-icon {
  transform: scale(1.05);
}

/* Icon color variants */
.timeline-icon.icon-purple {
  background: linear-gradient(135deg, #6f42c1, #8b5a9d);
  box-shadow: 0 4px 15px rgba(111, 66, 193, 0.25);
}

.timeline-icon.icon-blue {
  background: linear-gradient(135deg, #0d6efd, #0056b3);
  box-shadow: 0 4px 15px rgba(13, 110, 253, 0.25);
}

.timeline-icon.icon-green {
  background: linear-gradient(135deg, #28a745, #1e7e34);
  box-shadow: 0 4px 15px rgba(40, 167, 69, 0.25);
}

.timeline-icon.icon-yellow {
  background: linear-gradient(135deg, #ffc107, #e0a800);
  box-shadow: 0 4px 15px rgba(255, 193, 7, 0.25);
}

.timeline-icon.icon-cyan {
  background: linear-gradient(135deg, #17a2b8, #138496);
  box-shadow: 0 4px 15px rgba(23, 162, 184, 0.25);
}

.timeline-icon.icon-indigo {
  background: linear-gradient(135deg, #6f42c1, #563d7c);
  box-shadow: 0 4px 15px rgba(111, 66, 193, 0.25);
}

.timeline-icon i {
  color: #fff;
}

/* Timeline center line */
.timeline-line {
  width: 4px;
  background: linear-gradient(180deg, var(--rse-teal), var(--rse-cyan));
  border-radius: 2px;
}

/* Badges */
.step-details .badge {
  font-size: 0.8rem;
  font-weight: 600;
}

/* Responsive */
@media (max-width: 768px) {
  .timeline-card {
    margin: 0 !important;
  }
}
