@import url('https://fonts.googleapis.com/css2?family=Cherry+Bomb+One&family=Kode+Mono:wght@400..700&family=Montserrat:ital,wght@0,100..900;1,100..900&display=swap');

:root {
    --color: black;   
}

html, body {
    min-height: 100dvh;
    color: var(--color);
    font-family: "Montserrat", serif;
    font-optical-sizing: auto;
    font-weight: 400;
    font-style: normal;
}

body {
    display: flex;
    flex-direction: column;
    justify-content: start;
    align-items: center;
    padding: 1rem;
}

footer {
    flex-grow: 2;
    width: 100%;
    display: flex;
    flex-direction: column;
    justify-content: end;
    align-items: center;
}

header {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    text-align: center;
    
    img {
        max-width: 10rem;
        border-radius: 100%;
        border: 0.4rem solid var(--color);
    }
}

main, nav {
    display: grid;
    place-items: center;
    max-width: 25rem;
    width: 100%;
}

ul {
    margin-top: 1.3rem;
    margin-bottom: 1.3rem;
    display: grid;
    gap: 1.3rem;
    width: 100%;
    
    list-style: none;
    padding-block-start: 0;
    padding-inline-start: 0;

    li {
        height: 4rem;
        width: 100%;

        a {
            display: flex;
            height: 100%;
            text-decoration: none;
            color: var(--color);
            flex-direction: row;
            justify-content: center;
            align-items: center;

            border: 0.4rem solid var(--color);

            &:hover, &:focus {
                min-width: 0;
            }

            i {
                align-self: flex-start;
                min-width: 0;
            }

            span {
                font-size: larger;
            }
        }
    }
}

.footer {
    text-align: center;
}