@import url("https://fonts.googleapis.com/css2?family=Noto+Sans:ital,wght@0,600;1,600&display=swap");
@import url('https://fonts.googleapis.com/css2?family=Rubik:ital,wght@0,300..900;1,300..900&display=swap');

body {
    font-family: "Rubik", sans-serif;
    margin: 0;
    padding: 0;
    background-color: #fefefe;
}

.timeline {
    display: grid;
    grid-template-columns: 3rem 7fr;
}

.timeline-point {
    position: absolute;
    width: 2rem;
    height: 2rem;
    background-color: red;
    margin-left: 0.2rem;
    transform: translateX(-50%);
    border-radius: 50%;
    z-index: -1;
}

.timeline-end {
    position: absolute;
    background-color: red;
    width: 2rem;
    height: 0.4rem;
    margin-left: 0.2rem;
    transform: translateX(-50%);
    bottom: 0;
    z-index: -1;
}

.timeline-line {
    position: relative;
    background-color: red;
    padding-left: 1.3rem;
    padding-right: 1.3rem;
    background-clip: content-box;
}

.timeline-topic {
    display: flex; 
    flex-direction: row;
}

.timeline-topic > :nth-child(1) {
    margin: 0.3rem 0 0.3rem 0; 
    justify-content: left;
}

.timeline-topic > :nth-child(2) {
    margin: 0.3rem 0 0.3rem auto;
    text-align: right; 
    justify-content: flex-end; 
}