.events li {
    display: flex;
}

.events bullet {
    position: relative;
    color: #ccc;
    padding: 0 1.5em;
}

.events bullet::after {
    content: "";
    position: absolute;
    z-index: 2;
    right: 0;
    top: 9px;
    transform: translateX(50%);
    border-radius: 50%;
    background: #fff;
    border: 2px #ccc solid;
    width: 40px;
    height: 40px;
}

.events bullet span {
    font-size: 25px;
    z-index: 3;
    position: absolute;
    transform: translateX(50%);
    margin-left: 13px;
    margin-top: 10px;
}

.events bullet span.onefix {
    margin-left: 12px;
}


.events li > span {
    padding: 0 1.5em 0.5em 3em;
    position: relative;
}

.events li > span::before {
    content: "";
    position: absolute;
    z-index: 1;
    left: 0;
    height: 100%;
    border-left: 2px #ccc solid;
}



.events h4 {
    display: block;
    margin-top: 15px;
    margin-bottom: 15px;
    font-size: 21px;
}

.events span.shout {
    font-style: italic;
    font-weight: bolder;
}

.events {
    margin: 1em 0 0 0;
    width: 100%;
    padding: 0;
}

.events,
.events *::before,
.events *::after { box-sizing: border-box; font-family: arial; }