:root{
    --between-algos-gap: 20px;
}

.algos-list{
    display: flex;
    flex-wrap: wrap;
    gap: var(--between-algos-gap);
}

.algo{
    display: flex;
    flex-direction: column;
    gap: 10px;
    width: calc((100% - 3 * var(--between-algos-gap)) / 4);
    color: black;
    text-decoration: none;
    padding: 5px;
    box-sizing: border-box;
    border: 1px solid black;
}

.algo:hover{
    background-color: whitesmoke;
    border-color: #e51c23;
}


.algo-name{
    font-size: 20px;
    font-family: var(--decorative-font);
    font-weight: bold;
    border-bottom: 2px solid #e51c23;
    text-align: center;
}

.algo-short-desc{
    font-family: var(--main-font);
    line-height: 20px;
}