.hero{
    width: 100vw;
    height: 200px;
    display: grid;
}
.hero img{
    width: 100vw;
    height: 200px;
    grid-column: 1;
    grid-row: 1;
    z-index: 1;
    object-fit: cover;
    object-position: top;
}
.hero figcaption{
    grid-column: 1;
    grid-row: 1;
    z-index: 2;
    align-self: center;
    justify-self: center;
}
.hero span{
    display: block;
    font-size: 2.5rem;
    background: var(--clear-color);
    padding: 1rem 5rem;
}


article{
    display: grid;
    gap: 5rem;
}
@media (max-width: 768px){
    article{
        gap: 3rem;
    }
}


article section{
    max-width: 1200px;
    width: 90%;
    margin: 0 auto;
    display: grid;
    grid-template-columns: 1fr 20rem;
    gap: 5rem;
}
@media (max-width: 768px){
    article section{
        display: block;
    }
}
.info{
    position: relative;
    display: grid;
    gap: 3.125rem;
}
.info::before{
    content: "";
    position: absolute;
    right: -2.5rem;
    top: 0;
    background: var(--main-color);
    width: 1px;
    height: 100%;
}
@media (max-width: 768px){
    .info{
        margin-bottom: 5rem;
    }
    .info::before{
        display: none;
    }
}
.news__list{
    display: flex;
    align-items: center;
    gap: 1.5rem;
}
.news__list time{
    font-size: .9rem;
}
.news__list span{
    border: 1px solid var(--main-color);
    font-size: .8rem;
    padding: .5rem 1rem;
    white-space: nowrap;
}
.news__list a{
    color: var(--text-color);
}



.info div{
    min-height: 20rem;
}

.side-box h3{
    text-align: center;
    font-weight: normal;
    background: var(--main-color);
    color: var(--clear-color);
    padding: .75rem 0;
}
.side-box ul{
    margin: 1rem auto;
    list-style-type: disc;
    list-style-position: inside;
}
.side-box li{
    list-style-type: disc;  
}
.side-box a{
    color: var(--text-color);
    display: inline;
}

article footer{
    background: var(--accent-color) !important;
    padding: 2rem 0 !important;
    display: flex !important;
    justify-content: center !important;
}