.cbp_tmtimeline { margin: 0; padding: 0; list-style: none; position: relative; }
.cbp_tmtimeline:before { content: ''; position: absolute; top: 0; bottom: 0; width: 10px; background: #fff; left: 20%; margin-left: -10px; }
.cbp_tmtimeline > li { position: relative; }
.cbp_tmtimeline > li .cbp_tmtime { display: block; width: 24%; padding-right: 100px; position: absolute; }
.cbp_tmtimeline > li .cbp_tmtime span { display: block; text-align: right; color: #fff; opacity: 0.7; -webkit-transition: 0.25s; -moz-transition: 0.25s; -o-transition: 0.25s; transition: 0.25s; }
.cbp_tmtimeline > li .cbp_tmtime span:first-child { font-size: 0.9em;  }
.cbp_tmtimeline > li .cbp_tmtime span:last-child { font-size: 1.9em; }
.cbp_tmtimeline > li .cbp_tmlabel { margin: 0 0 15px 25%; background: #fff; opacity: 0.7; padding: 1.2em; position: relative; border-radius: 5px; -webkit-transition: 0.25s; -moz-transition: 0.25s; -o-transition: 0.25s; transition: 0.25s; }
.cbp_tmtimeline > li .cbp_tmlabel h3 { color: #333; margin-top: 0px; }
.cbp_tmtimeline > li .cbp_tmlabel:after { right: 100%; border: solid transparent; content: " "; height: 0; width: 0; position: absolute; pointer-events: none; border-right-color: #fff; border-width: 10px; top: 10px; }
.cbp_tmtimeline > li .cbp_tmicon { width: 40px; height: 40px; speak: none; font-style: normal; font-weight: normal; font-variant: normal; text-transform: none; font-size: 1.68em; line-height: 43px; -webkit-font-smoothing: antialiased; position: absolute; color: #fff; background: #fff; border-radius: 50%; text-align: center; left: 20%; top: -1px; margin: 0 0 0 -25px; -webkit-transition: 0.25s; -moz-transition: 0.25s; -o-transition: 0.25s; transition: 0.25s; }
.cbp_tmtimeline > li:hover .cbp_tmlabel, .cbp_tmtimeline > li:hover .cbp_tmtime span { opacity: 1.0; }
.cbp_tmtimeline > li:hover .cbp_tmicon { background: #1AB4DA; }


@media screen and (max-width: 65.375em) {
.cbp_tmtimeline > li .cbp_tmtime span:last-child { font-size: 1.2em; }
}

@media screen and (max-width: 47.2em) {
.cbp_tmtimeline:before { display: none; }
.cbp_tmtimeline > li .cbp_tmtime { width: 100%; position: relative; padding: 0 0 20px 0; }
.cbp_tmtimeline > li .cbp_tmtime span { text-align: left; }
.cbp_tmtimeline > li .cbp_tmlabel { margin: 0 0 30px 0; padding: 1em; font-weight: 400; font-size: 95%; }
.cbp_tmtimeline > li .cbp_tmlabel:after { right: auto; left: 20px; border-right-color: transparent; border-bottom-color: #fff; top: -20px; }
.cbp_tmtimeline > li .cbp_tmicon { position: relative; float: right; left: auto; margin: -60px 5px 0 0px; background: #1AB4DA; }
} 
