:root {
    font-family: 'Lato', san-serif;
}

@media screen, print and (min-width: 640px) {
    #resume {
        grid-template-areas:
        'header header header header header'
        'aside main main main main'
        'aside main main main main'
    }
}

@media screen and (max-width: 640px) {
    #resume {
        grid-template-areas:
        'header header header header header'
        'aside aside aside aside aside'
        'main main main main main'
    }
}

#resume h1 {
    text-align: center;
    font-family: 'Lato', san-serif;
    margin-bottom: 24px;
    letter-spacing: 6px;
    font-size: 40px;
}

#resume h2 {
    margin-top: 0;
    text-align: center;
    font-size: 20px;
    letter-spacing: 2px;
}

#resume h3 {
    margin: 0;
    margin-bottom: 12px;
    font-size: 16px;
}

#resume section {
    margin-bottom: 16px;
}

#resume article {
    margin-bottom: 36px;
}

#resume article > ul {
    margin: 0;
}

#resume article > p {
    margin: 0;
}

#resume {
    display: grid;
    width: 100%;
    height: 100%;
    max-width: 900px;
    margin: 0 auto;
    grid-gap: 4px;
}

#resume header.section {
    grid-area: header;
}

#resume aside.section {
    grid-area: aside;
}

#resume main.section {
    grid-area: main;
}

#resume header > p {
    text-align: center;
}

#resume #contact-info .item {
    display: flex;
    align-items: center;
    margin-bottom: 8px;
}

#resume #contact-info .item .icon {
    width: 24px;
    height: 24px;
    margin-right: 8px;
}

#resume .heading {
    margin-bottom: 0;
}

#resume .duration {
    display: block;
    margin-bottom: 8px;
}

#resume .links > a:link {
    text-decoration: none;
}

#resume .links .icon {
    width: 16px;
    height: 16px;
    margin: 4px;
    margin-right: 4px;
}
