div.timeline {
	padding: 0 0 3rem 0;
	background-image: url(../img/timeline-single.png);
	background-repeat: repeat-y;
	background-position: center;
}

div.timeline.start {
	margin-top: 3rem;
}

div.timeline.end {
	padding-bottom: 0;
}

div.timeline.gap {

}

div.timeline.gap div.contents {
	display: none;
}

div.timeline div.contents {
	padding: 1rem 2rem;
	border: 2px solid rgb(226, 226, 226);
	border-radius: 0.5rem;
	margin: 0 auto;
	max-width: 80ch;
	background-color: rgb(247, 245, 241);
}

div.timeline p, div.timeline h4, div.timeline h5 {
	margin: 0 0 1rem 0;
	padding: 0;
	text-align: left;
}

div.timeline h5 {
	font-size: 1.1rem;
	font-weight: 600;
	text-align: center;
	margin-bottom: 0.5rem;
    text-transform: none;
}

div.timeline h4 {
	font-size: 1.3rem;
	text-align: center;
	margin: 0 0 1rem 0;
}

div.timeline h4 + p {
	margin-top: 1rem;
}

div.timeline div.contents ul, div.timeline div.contents ol {
	margin: 0 0 1rem 0;
}

div.timeline.counter {
}

div.timeline.counter div.contents {
	max-width: 30ch;
    border-radius: 2rem;
}

div.timeline.counter p {
    text-align: center;
    font-weight: 600;
    font-style: italic;
    margin: 0;
}

div.timeline div.contents ul ul {
    margin-top: 0.5rem;
}

div.timeline blockquote {
    margin-left: 2rem;
    margin-right: 2rem;
}

div.timeline img {
    float: right;
    margin: 0 0 1rem 1rem;
    border-radius: 0.5rem;
    width: 200px;
    height: 200px;
    background-color: rgb(124, 124, 124);
}

div.timeline h4 {
    clear: both;
}

div.timeline h4 {
    padding-top: 0.5rem;
}

div.timeline h4:nth-of-type(1) {
    padding-top: 0;
}

span.clear {
    clear: both;
    display: block;
    overflow: hidden;
    visibility: hidden;
    width: 0;
    height: 0;
}