.cp_timeline04 {
position: relative;
width: 85%;
margin: 3em auto;
padding-bottom: 2em;
}
.cp_timeline04:before {
position: absolute;
top: 0px;
left: 45px;
width: 3px;
height: 100%;
content: '';
background: #8cd8db;
}
.cp_timeline04 .timeline_item {
margin: 100px 0px 0px 80px;
}
.cp_timeline04 .timeline_item .time_date .time {
font-family: ‘Noto Serif JP’, serif;
font-size: 5em;
font-weight: bold;
position: relative;
margin: 0;
letter-spacing: 3px;
color: rgba(31, 159, 165,0.2);
}
.cp_timeline04 .timeline_item .time_date .time:before {
position: absolute;
top: 50%;
left: -42px;
width: 10px;
height: 10px;
content: '';
border: 3px solid #8cd8db;
border-radius: 50%;	
background: #fff;
}
.cp_timeline04 .timeline_item .time_date .flag {
font-size: 1.5em;
font-weight: bold;
margin: 0;
margin-top: -60px;
color: #43c6cc;
}
.cp_timeline04 .timeline_item .desc {
font-size: 150%;
line-height: 100%;
padding-left: 20px;

}
@media only screen and (max-width: 480px) {
.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 {
font-size: 100%;
padding-left: 0px;

}
}