.sports {
    display: grid;
    height: 100%;
    grid-template-rows: auto 1fr
}

.sports__nav {
    margin-bottom: .75rem
}

.sports__nav ul {
    display: grid;
    grid-gap: .5rem;
    grid-template-columns: repeat(4,minmax(0,1fr))
}

@media(min-width: 1024px) {
    .sports__nav ul {
        grid-gap:.75rem
    }
}

.sports__nav li .app-link--exact-active {
    background-color: #faa611
}

.sports--d {
    display: block;
    height: auto;
    margin-top: .5rem
}

.sports-grid {
    display: grid;
    grid-gap: .75rem;
    align-items: start;
    margin-bottom: 1rem;
    grid-template-columns: repeat(2,minmax(0,1fr))
}

@media(min-width: 1024px) {
    .sports-grid {
        grid-template-columns:repeat(4,minmax(0,1fr))
    }
}

.sports-grid button:first-child {
    position: relative;
    display: block;
    height: 0;
    width: 100%;
    overflow: hidden;
    padding-bottom: 100%;
    border-radius: 10px
}

.sports-grid button:first-child img {
    position: absolute;
    display: block;
    width: 100%;
    height: 100%;
    -o-object-fit: cover;
    object-fit: cover
}

.sports-grid button:first-child>span {
    position: absolute;
    z-index: 2;
    left: .375rem;
    bottom: .375rem;
    color: #fff;
    font-weight: 700
}

.sports-grid button:first-child:after {
    position: absolute;
    left: 0;
    bottom: 0;
    width: 100%;
    height: 100%;
    content: "";
    background: linear-gradient(0deg,#000,transparent 30%,transparent)
}

.sports-grid button:last-child {
    width: 100%;
    max-width: 20rem;
    margin: .75rem auto 0
}