:root {
    --purple100: hsl(254, 88%, 90%);
    --purple500: hsl(256, 67%, 59%);
    --yellow100: hsl(31, 66%, 93%);
    --yellow500: hsl(39, 100%, 71%);

    --white: hsl(0, 0%, 100%);
    --black: hsl(0, 0%, 7%);

    --font: "DM Sans", sans-serif;
}

body {
    background-color: #f5f5f5;
    margin: 0;

    display: flex;
    justify-content: center;
    align-items: center;
    min-height: 100vh;
    padding: 3rem;
}

.box {
    padding: 2rem;
    border-radius: 12px;
    font-family: var(--font);
    background-color: green;
    overflow: hidden;
    box-sizing: border-box;
    width: 100%;
    height: 100%;
}

.grid-container {
    display: grid;
    grid-template-columns: 220px 1fr 1fr 260px;
    grid-template-rows: repeat(6, 115px);
    gap: 1.5rem;
    max-width: 1120px;
    width: 100%;

    grid-template-areas:
        "box-7 box-1 box-1 box-4"
        "box-7 box-1 box-1 box-4"
        "box-7 box-2 box-3 box-4"
        "box-8 box-2 box-3 box-4"
        "box-8 box-6 box-5 box-5"
        "box-8 box-6 box-5 box-5"
}



#box-1 {
    grid-area: box-1;
    background-color: var(--purple500);
}

#box-1 h1 {
    color: var(--white);
    font-weight: 500;
    font-size: 2rem;
    text-align: center;
    margin-top: .5rem;
}

#box-1 #h1-top {
    margin-bottom: -1rem;
    font-size: 3.2rem;
}

#box-1 #h1-bottom {
    margin-top: 0;
    font-size: 3.2rem;
    margin-bottom: 0;
}

#box-1 #num {
    color: var(--yellow500);
}

#box-1 #faster {
    font-style: italic;
}

#box-1 img {
    width: 40%;
    margin: 0 auto;
}

#box-1 p {
    text-align: center;
    color: var(--purple100);
    margin-top: 0.5rem;
}

#box-2 {
    grid-area: box-2;
    background-color: var(--white);
}

#box-2 img {
    max-width: 160%;
}

#box-2 h2 {
    font-size: 1.8rem;
    font-weight: 500;
    max-width: 10ch;
    line-height: 1;
}

#box-3 {
    grid-area: box-3;
    background-color: var(--yellow500);
}

#box-3 h2 {
    margin-top: -.5rem;
    margin-left: -.5rem;
    font-weight: 600;
    font-size: 1.6rem;
    margin-bottom: 0.5rem;
}

#box-4 {
    grid-area: box-4;
    background-color: var(--purple100);
}

#box-4 h2 {
    margin-top: -.5rem;
    font-size: 1.8rem;
    font-weight: 600;
    margin-bottom: .5rem;
}

#box-4 img {
    max-width: 160%;
    display: flex;
    align-self: self-end;
}

#box-4 p {
    color: var(--black);
    font-size: 1.2rem;
}

#box-5 {
    grid-area: box-5;
    background-color: var(--purple500);
    display: flex;
    gap: 1rem;
    font-weight: 500;
}

#box-5 span {
    color: var(--white);
    font-size: 2.2rem;
    display: flex;
    align-items: center;
}





#box-6 {
    grid-area: box-6;
    background-color: var(--white);
}

#box-6 h2 {
    margin-top: -.5rem;
    font-size: 4rem;
    font-weight: 500;
    margin-bottom: -1.5rem;
}

#box-6 p {
    font-size: 18px;
    font-weight: 500;
    margin-bottom: 2rem;
}

#box-6 img {
    width: 80%;
}

#box-7 {
    grid-area: box-7;
    background-color: var(--yellow100);
}

#box-7 h2 {
    font-weight: 500;
    color: var(--black);
    font-size: 1.7rem;
    margin-bottom: 2rem;
}

#box-7 span {
    color: var(--purple500);
    font-style: italic;
    font-weight: 600;
}

#box-7 img {
    max-width: 120%;
    display: flex;
    justify-self: center;
}

#box-8 {
    grid-area: box-8;
    background-color: var(--yellow500);
    
}

#box-8 h2 {
    font-size: 1.7rem;
    font-weight: 500;
    margin-top: -1rem;
    margin-left: -.5rem;
    margin-bottom: 3rem;
}

#box-8 img {
    max-width: 120%;
    display: flex;
    justify-self: center;
    object-fit: cover;
    
}

img {
    max-width: 100%;
    display: block;
}




/*

- Font size (paragraph): 18px

### Font

- Family: [DM Sans]
- Weights: 400, 500
*/ 

@media (max-width: 768px) {
    body {
        display: block;
        padding: 2rem 1rem;
    }

    .grid-container {
        display: grid;
        grid-template-columns: 1fr;
        grid-template-rows: auto;
        gap: 2rem;
        max-width: 375px;
        margin: 0 auto;

        grid-template-areas:
            "box-1"
            "box-2"
            "box-3"
            "box-4"
            "box-5"
            "box-6"
            "box-7"
            "box-8";
    }

    .box {
        width: 100%;
        height: auto;
    }

    #box-1 h1,
    #box-1 #h1-top,
    #box-1 #h1-bottom {
        font-size: 2.6rem;
        line-height: 1;
    }

    #box-1 img {
        width: 60%;
    }

    #box-2 img,
    #box-4 img,
    #box-7 img,
    #box-8 img {
        max-width: 100%;
        width: 100%;
        transform: none;
    }

    #box-3 img {
        width: 75%;
    }

    #box-4 {
        text-align: center;
    }

    #box-4 p {
        font-size: 1rem;
    }

    #box-5 {
        flex-direction: column;
        text-align: center;
        align-items: center;
    }

    #box-5 span {
        font-size: 2rem;
        line-height: 1;
    }

    #box-6 h2 {
        font-size: 3rem;
    }
}