@import url('https://fonts.googleapis.com/css2?family=Lora:ital,wght@0,400..700;1,400..700&family=DM+Sans:ital,wght@0,100..1000;1,200..1000&display=swap');

:root {
    --max-width: 1500px;
    --container-padding: 30px 50px 50px 50px;
    --spacing: 50px;
    --color-text: #585858;
    --color-headings: #71654b;
    --color-link: #557a72;
    --color-link-hover: #618a81;
}

html, body {
    text-align:center;
    padding:0;
    margin:0;
    font-size:16px;
    line-height:1.5;
    background-color:#f7f7f7;
    font-family: 'DM Sans';
    font-weight:300;
    color:var(--color-text);
}

h1, h2, h3 {
    font-family: 'Lora';
    color:var(--color-headings);
    font-weight: 500;
    text-transform: uppercase;
}

h1 {
    font-size:3rem;
    margin-bottom:1.5rem;
}

h2 {
    font-size:2rem;
    margin-bottom:1.5rem;
}

h3 {
    font-size:1.7rem;
    margin-bottom:1rem;
}

p {
    font-size:1.4rem;
}

.bold {
    font-weight:600;
}

a, a:visited, a:active {
    color:var(--color-link);
    font-weight:600;
}

a:hover {
    color:var(--color-link-hover);
}

#hero {
    margin: 0 auto;
    max-width: var(--max-width);
    min-height: 100vh;
    background-image: url('../images/hero.jpeg');
    background-size: cover;
    background-position: center 35%;
    background-repeat: no-repeat;
    position:relative;
}

    #hero .contact-icons {
        position: absolute;
        top:var(--spacing);
        right:var(--spacing);
    }

    #hero .contact-icons a {
        display:inline-block;
        margin-left:1rem;
    }

        #hero .contact-icons img {
            width: 24px;
            height: 24px;
        }

    #hero .text {
        text-align:left;
        position:absolute;
        top: var(--spacing);
        left:var(--spacing);
        width: 45%;
        /*padding: var(--spacing);*/
        /*background-color:#fff;*/
    }

    #hero .text h1 {
        margin-top:0;
    }

    #hero .text p {
        font-size:1.6rem;
    }

#content-container {
    margin: 0 auto;
    max-width: var(--max-width);
    background-color: #fff;
}

#content {
    text-align:left;
    padding: var(--container-padding);
    padding-bottom:calc(var(--spacing) * 2);
    display: flow-root;
}

.content-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
    gap: var(--spacing);
    margin-bottom: var(--spacing);
}

/*#intro {
    float:left;
}

.image.right {
    width:50%;
    float:right;
    margin: 0 0 var(--spacing) var(--spacing);
}
*/

.image img {
    width: 100%;
    height: auto;
}

.services-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
    gap: var(--spacing);
    margin-bottom: var(--spacing);
}

.services-grid .image {
    display: flex;
    justify-content: center;
    align-items: center;
    height:300px;
    overflow:hidden;
}

.services-grid .image img {
    object-fit:contain;
}

.image.about {
    text-align:center;
}

.image.about img {
    margin:0 auto;
    aspect-ratio: 1 / 1;
    width: 80%;       
    border-radius: 50%;
    object-fit: cover;
}

.contact-link {
    display: inline-block;
    padding-left: 30px;
    background-size: 18px 18px;
    background-position: left center;
    background-repeat: no-repeat;
    margin-right:2rem;
}

.contact-link.email {
    background-image: url('../images/email.png');
}

.contact-link.linkedin {
    background-image: url('../images/linkedin.png');
}

.contact-link.insta {
    background-image: url('../images/instagram.png');
}

.sep {
    margin: var(--spacing) 0;
    height:1px;
    background-color:#eee;
}

#subscribe {
    margin: var(--spacing) 0;
    background-color: #e9f3f1;
    color: var(--color-link);
    padding: 2rem var(--spacing);
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 2rem;
}

    #subscribe p {
        flex: 1;
        margin: 0;
        font-weight:500;
    }

    #subscribe a {
        flex-shrink: 0;
        display: block;
        background-color: var(--color-link);
        padding: 0.5rem 1rem;
        color: #fff;
        border-radius:8px;
        text-align:center;
        width:250px;
        text-decoration:none;
        font-size:1.5rem;
    }

    #subscribe a:hover {
        background-color: var(--color-link-hover);
    }


@media (max-width: 768px) {

    :root {
        --container-padding: 30px;
        --spacing: 30px;
    }

    html, body {
        font-size:13px;
    }

    h1 {
        font-size: 2.2rem;
    }

    #hero {
        background-size:180%;
        background-position:left top;
    }

    #hero .text {
        width:calc(100% - (var(--spacing) * 2));
    }

    #hero .contact-icons {
        margin-top:1rem;
    }

    #hero .contact-icons img {
        width: 18px;
        height: 18px;
    }

    .contact-link {
        display: block;
        margin-bottom: 1rem;
    }

    #subscribe {
        flex-direction: column;
        align-items: flex-start;
        gap: 2rem;
        margin-bottom: calc(var(--spacing) * 1.5);
    }

}