:root{
    --lt-gray: #eaeaea;
    --med-gray: #555;
    --dk-gray: #222;
    --wht: #fff;
}

*{
    font-family: sans-serif;
    line-height: 1.5;
    box-sizing: border-box;
    color: var(--dk-gray);
}

body{
    margin: 0;
    background-color: var(--lt-gray);
}

header, main, footer{
    width: 100%;
    max-width: calc(900px - 32px);
    margin: 0 auto;
    background-color: var(--wht);
    padding: 32px 16px;
}

h1, h2, footer{
    text-align: center;
}

h3{
    margin: 0.5rem;
}

p{
    width: 100%;
    max-width: 65ch;
    margin: 1rem auto;
}

img{
    display: block;
    height: auto;
    margin: 0 auto;
}

div > section{
    max-width: 65ch;
    margin: 1rem auto;
}

#cats{
    display: flex;
    flex-wrap: wrap;
    gap: 1rem;
    justify-content: center;
}

#cats img{
    max-width: 350px;
    height: auto; 
}

#users{
    display: flex;
    flex-wrap: wrap;
    max-width: 615px;
    margin: 0 auto;
}

#users section{
    padding: 1rem;
    width: calc(300px - 2rem);
    display: flex;
    flex-direction: column;
    text-align: center;
    background-color: var(--lt-gray);
}
