/* Contenedor general de la vista */
.itinerario-timeline {
  position: relative;
  padding: 40px 0;
  max-width: 900px;
  margin: 0 auto;
}

/* La línea central vertical */
.itinerario-timeline::before {
  content: '';
  position: absolute;
  left: 120px; /* <--- VALOR X */
  top: 60px;
  bottom: 100px;
  width: 0;
  border-left: 2px dashed #ccc;
  z-index: 1; /* Por debajo */
}

/* Ítem individual */
.timeline-item {
  position: relative;
  display: flex;
  align-items: flex-start;
  margin-bottom: 60px;
  z-index: 2; /* Esto eleva el hito completo sobre la línea */
}

.timeline-date {
  flex: 0 0 80px;
  text-align: right;
  padding-right: 35px; /* Margen de seguridad */
  font-weight: bold;
  color: #c8102e;
  font-size: 1.1rem;
}


/* El punto de la línea */
.timeline-dot {
  position: absolute;
  left: 104px;
  transform: translateX(-50%);
  top: 3px;
  width: 9px;
  height: 9px;
  background: #fff; /* OBLIGATORIO: blanco sólido */
  border: 2px solid #c8102e; /* Tu rojo Cierzo */
  border-radius: 50%;
  z-index: 5;
}

/* Caja de contenido */
.timeline-content {
  flex: 1;
  margin-left: 35px; /* Espacio desde la línea hacia la derecha */
  display: flex;
  gap: 20px;
  background: #f9f9f9; /* Un tono sutil para que resalte el blanco del fondo si quieres */
  padding: 25px;
  border-radius: 12px;
  box-shadow: 0 4px 20px rgba(0,0,0,0.05);
}

.timeline-image {
  flex: 0 0 150px; /* Ancho fijo para la miniatura */
}

.timeline-image img {
  width: 100%;
  height: auto;
  border-radius: 4px;
  display: block;
}

.timeline-title {
  margin-top: 0;
  font-size: 1.25rem;
  color: #333;
}

.titulo-itinerario{
  text-align: center;
  font-size: 2rem;
  margin-bottom: 0px;
 color: #cc202c;
    font-weight: 500;
}

/* Responsive para móviles */
@media (max-width: 600px) {
  .timeline-item {
    flex-direction: column;
    align-items: flex-start;
    padding-left: 20px;
  }

  .timeline-date {
    flex: 0 0 auto;
    text-align: left;
    padding-right: 0;
    margin: 0 0 6px 10px;
    font-size: 0.9rem;
  }

  .itinerario-timeline::before { left: 10px; }
  .timeline-dot { left: -6px; }
  .timeline-content { margin-left: 0; flex-direction: column; }
  .timeline-image { flex: 0 0 auto; width: 100%; }
}
