.cp_timeline04 {
  position: relative;
  margin: 3em auto;
  padding-bottom: 2em;
}
.cp_timeline04:before {
  position: absolute;
  top: 0px;
  top: -30px;
  left: 45px;
  width: 3px;
  height: 100%;
  content: '';
  background: #e91e63;
}
.cp_timeline04 .timeline_item {
  margin: 0px 0px 0px 80px;
}
.cp_timeline04 .timeline_item .time_date .time {
  font-family: serif;
  font-size: 4em;
  font-weight: bold;
  position: relative;
  margin: 0;
  letter-spacing: 3px;
  line-height: 1em;
  color: rgba(255,159,173,1);
}
.cp_timeline04 .timeline_item .time_date .time:before {
  position: absolute;
  top: 50%;
  left: -42px;
  width: 10px;
  height: 10px;
  content: '';
  transform: rotate(45deg);
  border: 3px solid #e91e63;
  background: #fff;
}
.cp_timeline04 .timeline_item .time_date .flag {
  font-size: 2.5em;
  font-weight: bold;
  margin: 0;
  color: #880e4f;
}
.cp_timeline04 .timeline_item .desc {
  font-size: 1.4em;
  line-height: 1.1em;
  margin-top: 0px;
  padding-left: 20px;
  border-left: 1px solid #880e4f;
  margin-bottom: 30px;
}
@media only screen and (max-width: 767px) {
  .cp_timeline04:before {
    left: 15px;
  }
  .cp_timeline04 .timeline_item .time_date .time:before {
    left: -32px;
  }
  .cp_timeline04 .timeline_item {
    margin: 0px 0px 0px 40px;
  }
  .cp_timeline04 .timeline_item .desc {
    padding-left: 0px;
    border-top: 1px solid #880e4f;
    border-left: none;
  }
}