.cbp_tmtimeline {
	margin: 3em 0 0 0;
	padding: 0;
	list-style: none;
	position: relative;
	height:100%;
} 

/* The line */
.cbp_line {
	content: '';
	position: absolute;
	top: 10px;
	bottom: 0;
	width: 3px;
	height:calc(100% + 20px);
	background: #999999;
	left: 20%;
	margin-left: -27px;
} 

.cbp_tmtimeline li {
	position: relative;
} 

.cbp_tmtimeline > li .cbp_tmtime {
	display: block;
	width: 20%;
	top:-1.0em;
	left:-3.5em;
	position: absolute;
}
.cbp_tmtimeline > li .cbp_tmtime_after {
	display: block;
	width: 20%;
	top:0.7em;
	left:-2.8em;
	position: absolute;
}

.cbp_tmtimeline > li .cbp_tmtime span {
	display: block;
	text-align: right;
}
.cbp_tmtimeline > li .cbp_tmtime_after span {
	display: block;
	text-align: right;
}

.cbp_tmtimeline > li .cbp_tmtime span:last-child,
.cbp_tmtimeline > li .cbp_tmtime_after span:last-child {
	font-size: 1.6em;
}

/* Right content */
.cbp_tmtimeline > li .cbp_tmlabel {
	margin: 0 0 20px 20%;
	padding: 0 0.0 0.5em 0;
	font-size: 1.2em;
	font-weight: 300;
	line-height: 1.4;
	position: relative;
}

.cbp_tmtimeline > li .cbp_tmlabel h2 {
	margin-bottom: 0.5em;
	padding: 0.2em 0;
	font-weight: 600;
	border-top: 1px solid #999999;
}
.cbp_tmtimeline > li .cbp_tmlabel h3 { 
	margin: 0.5em 0;
  padding: 0 0 0.2em 0;
	font-weight: 500;
	border-bottom: 1px solid rgba(255,255,255,0.4);
}
.cbp_tmtimeline > li .cbp_tmlabel p,
.cbp_tmtimeline > li .cbp_tmlabel img,
.cbp_tmtimeline > li .cbp_tmlabel ul{
	margin-left:0.5em;
}


.flexBox{
	display: -webkit-flex;
	display: -moz-flex;
	display: -ms-flex;
	display: -o-flex;
	display: flex;
}

/* The icons */
.cbp_tmtimeline > li .cbp_tmicon {
	width: 10px;
	height: 10px;
	font-family: 'ecoico';
	speak: none;
	font-style: normal;
	font-weight: normal;
	font-variant: normal;
	text-transform: none;
	font-size: 1.4em;
	line-height: 20px;
	-webkit-font-smoothing: antialiased;
	position: absolute;
	color: #fff;
	background: #999999;
	box-shadow: 0 0 0 3px #cccccc;
	text-align: center;
	left: 20%;
	top: -3px;
	margin: 0 0 0 -30px;
}



/* Example Media Queries */
@media screen and (max-width: 65.375em) {

	.cbp_tmtimeline > li .cbp_tmtime span:last-child {
		font-size: 1.5em;
	}
}

@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: #3594cb;
		top: -20px;
	}

	.cbp_tmtimeline > li:nth-child(odd) .cbp_tmlabel:after {
		border-right-color: transparent;
		border-bottom-color: #6cbfee;
	}

	.cbp_tmtimeline > li .cbp_tmicon {
		position: relative;
		float: right;
		left: auto;
		margin: -55px 5px 0 0px;
	}	
}
