.block-timeline {
    position: relative;
    z-index: 2;
    color: var(--primary);
    margin-left: -12px;
    margin-right: -12px;
}
.block-events {
    position: relative;
    display: flex;
    flex-direction: column;
    justify-content: center;
}
.block-events .date {
    position: relative;
    flex-basis: 50%;
    flex-grow: 1;
    display: flex;
    align-items: flex-start;
}
.block-events .date.start {
    justify-content: center;
    margin-top: 12px;
}
.block-events::after {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    transform: translateX(-50%);
    width: 3px;
    height: calc( 100% + 64px );
    background-color: var(--primary);
}
.block-events:last-child::after {
    height: 50%;
}
.block-events:last-child::before {
    content: '';
    position: absolute;
    top: calc(50% + 3px);
    left: 0;
    transform: translateX(-50%);
    width: 0;
    height: 36px;
    border-left: dashed 3px var(--primary);
}
.block-events .date:not(.start)::before {
    content: '';
    position: absolute;
    top: 16px;
    left: -9px;
    width: 13px;
    height: 13px;
    background-color: var(--accent);
    border: solid 3px #FFFFFF;
    border-radius: 50%;
    box-shadow: 0 0 0 2px var(--primary);
    z-index: 1;
}
.block-events .date span {
    position: relative;
    background-color: #DEE4E9;
    display: block;
    border-radius: 8px;
    padding: 10px 32px;
    height: 50px;
    color: var(--primary);
    font-weight: 700;
}
.block-events .date.start-mobile span {
    height: auto;
    text-align: center;
}
.block-events .date:not(.start) span {
    margin-left: 44px;
    margin-bottom: 12px;
}
.block-events .date span::after {
    content: '';
    position: absolute;
    width: 0;
    height: 0;
    border: solid 9px transparent;
}
.block-events .date:not(.start) span::after {
    top: 50%;
    transform: translateY(-50%);
    right: 100%;
    border-left-width: 0;
    border-right: solid 15px #DEE4E9;
}
.block-events .date.start-mobile span::after {
    top: 16px;
    transform: translateY(0);
}
.block-events .date.start span::after {
    top: 100%;
    left: 50%;
    transform: translateX(-50%);
    border-bottom-width: 0;
    border-top: solid 15px #DEE4E9;
}
.block-events .events {
    flex-basis: 50%;
    flex-grow: 1;
}
.block-events .events.start {
    display: none;
}
.block-events .events.start {
    flex-basis: auto;
    flex-grow: 0;
    justify-self: center;
}
.block-events + .block-events {
    margin-top: 64px;
}
.block-events .event {
    position: relative;
    display: flex;
    flex-direction: column;
    align-items: center;
    background-color: #FFFFFF;
    border-radius: 8px;
    padding: 16px 16px;
    min-height: 90px;
    box-shadow: 0 4px 8px rgba(0,37,61,.08);
}
.block-events .event.start {
    justify-content: center;
}
.block-events .event:not(.start) {
    margin-left: 44px;
}
.block-events .event + .event {
    margin-top: 12px;
}
.block-events .event .image {
    flex-basis: 20%;
    flex-grow: 0;
    flex-shrink: 0;
    display: flex;
    justify-content: center;
    align-items: center;
}
.block-events .event .image span {
    display: block;
    flex-basis: 35%;
}
.block-events .event .image span img {
    display: block;
}
.block-events .image.start {
    display: flex;
    justify-content: center;
}
.block-events .image.start span {
    position: relative;
    display: block;
    flex-basis: 100px;
    flex-grow: 0;
    flex-shrink: 0;
    margin-top: 32px;
}
.block-events .image.start span::after {
    content: '';
    position: absolute;
    width: 3px;
    height: calc( 64px - 17px );
    background-color: var(--primary);
    top: calc( 100% + 17px );
    left: 50%;
    transform: translateX(-50%);
}
.block-events .event .description {
    padding: 12px 0;
}
.block-events .event.start .description {
    font-weight: 700;
}

.block-bg-sapps {
    position: absolute;
    top: 40px;
    left: 0;
    right: 0;
    bottom: 0;
}
.block-bg-sapps .bg-sapps {
    position: sticky;
    top: 40px;
}
.block-bg-sapps .bg-sapps img {
    display: block;
    margin: auto;
}

@media (min-width:576px){
    .block-timeline {
        margin-left: 0;
        margin-right: 0;
    }
    .block-events .event {
        flex-direction: row;
        padding: 16px 40px;
    }
    .block-events .event:not(.start) .description {
        padding-left: 40px;
    }
    .block-events .event .image span {
        flex-basis: 100%;
    }
}
@media (min-width:768px){
    .block-events {
        flex-direction: row;
    }
    .block-events .date {
        justify-content: flex-end;
        flex-basis: 25%;
        flex-grow: 0;
    }
    .block-events .date:not(.start) span {
        margin-left: initial;
        margin-right: 44px;
        margin-bottom: 0;
    }
    .block-events .date:not(.start) span::after {
        right: auto;
        left: 100%;
        border-right-width: 0;
        border-left: solid 15px #DEE4E9;
    }
    .block-events .event:not(.start):first-child::after {
        content: '';
        position: absolute;
        top: 16px;
        right: 100%;
        width: 0;
        height: 0;
        border: solid 9px transparent;
        border-left-width: 0;
        border-right: solid 15px #FFFFFF;
    }
    .block-events::after {
        display: none;
    }
    .block-events .date:not(.start)::after {
        content: '';
        position: absolute;
        top: 0;
        right: 0;
        transform: translateX(50%);
        width: 3px;
        height: calc( 100% + 64px );
        background-color: var(--primary);
    }
    .block-events:last-child .date::after {
        height: 50%;
    }
    .block-events .date:not(.start)::before {
        left: auto;
        right: -9px;
    }
    .block-events:last-child::before {
        display: none;
    }
    .block-events:last-child .events {
        position: relative;
    }
    .block-events:last-child .events::before {
        content: '';
        position: absolute;
        top: calc(50% + 3px);
        left: 0;
        transform: translateX(-50%);
        width: 0;
        height: 36px;
        border-left: dashed 3px var(--primary);
    }
}
@media (min-width:992px){
    .block-events .date {
        flex-basis: 50%;
        flex-grow: 1;
    }
    .block-bg-sapps .bg-sapps {
        top: -100px;
    }
    .block-events.odd {
        flex-direction: row-reverse;
    }
    .block-events.odd .date {
        justify-content: flex-start;
    }
    .block-events.odd .date::after {
        right: auto;
        left: 0;
        transform: translateX(-50%);
    }
    .block-events.odd .date::before {
        right: auto;
        left: -9px;
    }
    .block-events.odd .date:not(.start) span {
        margin-right: 0;
        margin-left: 44px;
    }
    .block-events.odd .date span::after {
        left: auto;
        right: 100%;
        border-left-width: 0;
        border-right: solid 15px #DEE4E9;
    }
    .block-events.odd .event:not(.start) {
        margin-left: 0;
        margin-right: 44px;
    }
    .block-events.odd .event:first-child::after {
        right: auto;
        left: 100%;
        border-right-width: 0;
        border-left: solid 15px #FFFFFF;
    }
    .block-events.odd:last-child .events::before {
        left: 100%;
        transform: translateX(-50%);
    }
    .block-events .start-mobile {
        display: none;
    }
    .block-events .events.start {
        display: block;
    }
}
@media (min-width:1200px){
    .block-bg-sapps .bg-sapps {
        top: -180px;
    }
}
@media (min-width:1400px){
    .block-events .event .image span {
        flex-basis: 100%;
    }
}