ul.article-list {
    width: 70rem;
    display: flex;
    flex-flow: column;
    justify-content: center;
    margin: 5rem auto;
    gap: 5rem;
}

/* Articles list items */
ul.article-list li {
    position: relative;
    list-style: none;
}

ul.article-list li a {
    display: block;
    padding: 1rem;
    text-decoration: none;
}

ul.article-list li .article-button {
    position: relative;
    display: grid;
    column-gap: 1rem;
    padding-block: 3rem 0;
    grid-template-areas:
        "title img"
        "tags  img"
        ".     img";
    grid-template-columns: 1fr 30rem;
    text-align: end;
}

ul.article-list li:nth-child(even) .article-button {
    padding-block: 0;
    grid-template-areas:
        "img .    "
        "img title"
        "img tags ";
    grid-template-columns: 30rem 1fr;
    margin-top: -22rem;
    text-align: start;
}

ul.article-list li .article-button .chevron {
    position: absolute;
    top: 0;
    left: 0;
    z-index: 0;
    transition: all 0.5s;
}

ul.article-list li:nth-child(even) .article-button .chevron {
    top: unset;
    left: unset;
    right: 0;
    bottom: 1rem;
    transform: scaleX(-1);
}
ul.article-list li a:before {
    content: '';
    position: absolute;
    width: 100%;
    height: 16rem;
    background-color: var(--current-highlight);
    border-radius: 2rem;
    transition: opacity 0.4s;
    opacity: 0;
}
ul.article-list li a:hover:before {
    opacity: 1;
}
ul.article-list li:nth-child(even) a:before {
    bottom: -1rem;
    left: 0;
}
ul.article-list li a:hover .article-button .chevron {
    transform: scale(2);
    opacity: 0;
}
ul.article-list li:nth-child(even) a:hover .article-button .chevron {
    transform: scale(-2,2);
    opacity: 0;
}

.article-button-title {
    grid-area: title;
    font-size: 2.5rem;
    line-height: 3.1rem;
    color: var(--primary);
    font-weight: bold;
    padding-left: 3rem;
}
li:nth-child(even) .article-button-title {
    padding-left: 0;
    padding-right: 3rem;
}

.article-button-tags {
    grid-area: tags;
    font-size: 1.25rem;
    color: var(--secondary);
    text-transform: uppercase;
}

.article-button img {
    grid-area: img;
    width: 100%;
    object-fit: cover;
    aspect-ratio: 1/1;
    justify-self: start;
    border-radius: 5rem;
    z-index: 10;
}

ul.article-list li:nth-child(even) .article-button img {
    justify-self: end;
}