*{
    margin: 0;
    padding: 0;
    text-align: justify;
}

.heading{
    background-color: indigo;
}

.heading-text{
    padding: 30px;
    margin-left: 20px;
    font-size: 40px;
    font-family: 'Lato';
    color: white;
}

main{
    width: 80%;
    margin: auto;
}

main h1{
    font-size: 40px;
    color: purple;
    text-align: center;
    margin-top: 20px;
    margin-bottom: -20px;
    font-family: 'Roboto Slab';
}

main h2{
    font-size: 30px;
    margin-top: 50px;
    padding: 10px;
    color: indigo;
    font-family: 'Sofia';
}

p{
    padding: 10px;
    font-size: 18px;
    line-height: 1.5em;
    font-family: 'Roboto Slab';
}

img{
    /* width: 100%; */
    background-position: center;
    padding: 10px;
    float: right;
    width: 30%;
    /* height: 100vh; */
}

.event::after{
    content: '';
    clear: both;
    display: block;
}

@media(max-width: 900px){
    img{
        width: 40%;
    }
    main{
        width: 90%;
    }
}
@media(max-width: 700px){
    main{
        width: 90%;
    }
    img{
        float: none;
        width: 100%;
        padding: 0;
    }
}
