:root{
    --roadmap_colour: var(--accent);
    --roadmap_goal_padding: 20px;
}

.roadmap{
    width: 800px;
    background-color: var(--secondary);
    min-height: 400px;
    position: relative;
}

.roadmap .road{
    position: absolute;
    top: 50%;
    left: 50%;
    translate: -50% -50%;
    width: 5px;
    background-color: var(--roadmap_colour);
    height: 100%;
    z-index: 1000;
}

.goal{
    display: flex;
    padding: 10px;
    flex: 1;
    position: relative;
}

.goal.left{
    justify-content: left;

    & .content{
        padding-right: calc(10px + var(--roadmap_goal_padding));
    }
}



.goal .content{
    display: flex;
    flex-direction: column;
    width: fit-content;
    max-width: 50%;
    background: var(--primary);
    padding: var(--roadmap_goal_padding);
}

.goal.right{
    justify-content: right;

    & .content{
        padding-left: calc(10px + var(--roadmap_goal_padding));
    }
}

.goal::after{
    content: '';
    position: absolute;
    border-radius: 50%;
    width: 10px;
    height: 10px;
    background-color: var(--roadmap_colour);
    left: 50%;
    top: 50%;
    translate: -50% -50%;
}


.goal .content .text{
    text-align: justify;
}
.goal .content .date{
    font-size: 2rem;
}
