@media only screen and (max-width: 768px) {
    .body {
        flex-direction: column;
    }
    .card>.image>img {
        height: 10rem;
    }
}
@media only screen and (max-width: 1200px) {
    .card {
        flex-direction: row;
    }
}
.body {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: center;
    max-width: 100vw;
    padding: auto 12px;
}
.card {
    flex-basis: 32%;
    padding: 12px;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    margin: 12px 30px;
    background: transparent;
    box-shadow: 5px 10px 10px #0000002c;
}
.card:hover {
    background:#FFB20F;
    padding: 30px;
    transition: 1s ease-out;
    border-radius: 0 5px 0 5px;
}
.card>.title, .card>.topic {
    text-align: center;
    padding: 5px 0;
    margin: 10px 0;
}
.card>.title>h2, .card>.title>p, .card>.topic>p, .footer>p  {
    font-family: Verdana, Geneva, Tahoma, sans-serif;
    color: rgb(3, 3, 41);
}
.card>.image {
    width: 100%;
    height: 30%;
    margin: 10px 0;
}
.card>.image>img {
    width: 100%;
    height: 30rem;
}
.footer {
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 50px;
}
