.field-timeline .field--name-field-row-details .field.field--name-field-title:before {
  content: "";
  position: absolute;
  background: #1476cc;
  width: 20px;
  height: 20px;
  border: 2px solid #fff;
  border-radius: 50%;
}

.field-timeline {
  position: relative;
  margin-left: 6px;
}
.field-timeline > .field--item {
  padding-bottom: 20px;
}
.field-timeline > .field--item:last-child {
  position: relative;
}
.field-timeline > .field--item:last-child:before {
  content: "";
  position: absolute;
  width: 6px;
  top: 5px;
  height: calc(100% - 5px);
  background: #ffffff;
  left: 0px;
}
.field-timeline:before {
  content: "";
  position: absolute;
  width: 4px;
  top: 5px;
  height: calc(100% - 5px);
  background: #1476cc;
}
.field-timeline .field--name-field-row-details {
  padding-left: 20px;
  position: relative;
}
.field-timeline .field--name-field-row-details .paragraph--timeline-detail {
  padding-bottom: 1px;
}
.field-timeline .field--name-field-row-details .field.field--name-field-title {
  font-weight: 600;
  margin-bottom: 15px;
  position: relative;
  overflow: visible !important;
}
.field-timeline .field--name-field-row-details .field.field--name-field-title:before {
  left: -18px;
  transform: translate(-50%, 0%);
}
@media only screen and (min-width: 768px) {
  .field-timeline {
    margin-left: 0px;
  }
  .field-timeline:before {
    left: 50%;
    transform: translateX(-50%);
  }
  .field-timeline > .field--item {
    position: relative;
  }
  .field-timeline > .field--item:last-child:before {
    left: 50%;
    transform: translateX(-50%);
  }
  .field-timeline .field--name-field-row-details {
    padding: 0;
    position: relative;
    z-index: 1;
  }
  .field-timeline .field--name-field-row-details .field.field--name-field-title {
    position: static;
    background: #fff;
    margin-left: -5px;
    padding-left: 5px;
    margin-right: -5px;
    padding-right: 5px;
  }
  .field-timeline .field--name-field-row-details .field.field--name-field-title:after {
    content: "";
    position: absolute;
    height: 4px;
    background: #1476cc;
    left: 0;
    right: 0;
    top: -2px;
    margin: 10.5px 0;
    z-index: -1;
  }
  .field-timeline .field--name-field-row-details .paragraph--timeline-direction-left--first .field.field--name-field-code-hole,
  .field-timeline .field--name-field-row-details .paragraph--timeline-direction-right--first .field.field--name-field-code-hole {
    padding-top: 35px;
  }
  .field-timeline .field--name-field-row-details .paragraph--timeline-direction-left--first .field.field--name-field-media,
  .field-timeline .field--name-field-row-details .paragraph--timeline-direction-right--first .field.field--name-field-media {
    padding-top: 15px;
  }
  .field-timeline .field--name-field-row-details .paragraph--timeline-direction-left {
    float: left;
    padding-right: 110px;
  }
  .field-timeline .field--name-field-row-details .paragraph--timeline-direction-left .field.field--name-field-title:before {
    left: initial;
    right: 0;
    transform: translateX(50%);
  }
  .field-timeline .field--name-field-row-details .paragraph--timeline-direction-left .field.field--name-field-title:after {
    left: 16px;
  }
  .field-timeline .field--name-field-row-details .paragraph--timeline-direction-right {
    float: right;
    padding-left: 110px;
  }
  .field-timeline .field--name-field-row-details .paragraph--timeline-direction-right .field.field--name-field-title:before {
    left: 0px;
  }
  .field-timeline .field--name-field-row-details .paragraph--timeline-direction-right .field.field--name-field-title:after {
    right: 16px;
  }
}
