@import url('https://fonts.googleapis.com/css2?family=Major+Mono+Display&family=Montserrat&display=swap');

:root {
    --headline-font: 'Major Mono Display', monospace;
    --body-font: 'Montserrat', sans-serif;

    --background-color: #3c887eff;
    --headline-color: #a17c6b;
    --header-color: #e0f2e9;
    --anchor-color: #ceb5a7;
    --body-color: #e0f2e9;
    --transition-color: #A9DBC3;
}

html {
    text-align: center;
    width: 100%;
    height: 100%;
}

/* default css for mobile */
body {
    display: flex;
    flex-direction: column;
    width: 100%;
    height: 100%;
    margin: 0;
    padding: 0;
    background-color: var(--background-color);
    font-family: var(--body-font);
}

header, footer {
    padding: 1rem 0;
    background-color: var( --header-color);
    font-family: var(--headline-font);
    clear: both;
}

body * {
    color: var(--body-color);
}

h1, h2, h3 {
    color: var(--headline-color);
    font-family: var(--headline-font);
}

nav * {
    margin: 0 2rem;
}

a {
    color: var(--anchor-color);
    text-decoration: none;
}

header a:hover, article a:hover {
    text-decoration: revert;
}

.card {
    background-color: var(--header-color);
    height: 10rem;
    padding: 1rem;
    border-radius: .5rem;
    transition: background-color .5s;
    border-color: var(--background-color);
    border: solid;
}

.card h2, .card p {
    padding: 0;
    margin: 0;
    color: var(--headline-color);
}

/* .container * {
    text-align: center;
} */

a:hover {
    text-decoration: none;
}

article {
    text-align: left;
}

p {
    margin: 1rem 2rem;
    text-indent: 2rem;
}

img {
    margin: 1rem;
    width: 20rem;
    width: -moz-available;
}

/* default desktop */
@media screen and (min-width: 600px) {
    nav {
        display: block;
    }

    .container {
        display: flex;
        justify-content: space-around;
    }

    .card {
        width: 15rem;
        height: auto;
    }

    .card:hover {
        background-color: var(--transition-color);
    }

    .img-left {
        float: left;
        padding-left: 2rem;
    }

    .img-right {
        float: right;
        padding-right: 2rem;
    }

    footer {
        width: 100%;
        position: relative;
        bottom: 0;
    }

    article {
        width: 80%;
        align-self: center;
    }
    
    img {
        margin-top: 0;
        height: 16rem;
        width: auto;
    }
}

/* printing */
@media print {
    html {
        text-align: left;
    }

    html * {
        font-family: var(--body-font);
        color: black !important; 
    }

    .card {
        border-style: none;
    }

    .card {
        height: auto;
    }
}