/* General Styles */
body {
    background-color: #091b12;
    font-family: "IbmPlexMono-Medium", sans-serif;
    color: white;
    margin: 64px 0;
    font-size: 16px;
    line-height: 20px;
    font-weight: 400;
}

article {
    padding: 64px 0;
}

.mark {
    color: #3e7b27;
}

h1 {
    margin: 0;
    color: #3e7b27;
    font-size: 64px;
    line-height: 72px;
    font-weight: 400;
}

.mark-big {
    color: #3e7b27;
    font-size: 32px;
    line-height: 42px;
    font-weight: 500;
}

.article-1 {
    background: #123524;
    display: flex;
    flex-direction: column;
    gap: 128px;
    align-items: center;
    justify-content: center;
}

/* Styles for Header */
header {
    display: flex;
    flex-direction: row;
    justify-content: space-between;
    padding: 0 128px;
}

nav {
    display: flex;
    flex-direction: row;
    gap: 32px;
}

.logo {
    display: flex;
    flex-direction: row;
    gap: 8px;
    align-items: center;
}

.logo-text {
    text-align: left;
    font-size: 32px;
    line-height: 42px;
    font-weight: 500;
}

.logo-socials {
    display: flex;
    flex-direction: row;
    gap: 8px;
    align-items: center;
    text-decoration: none;
    color: inherit;
}

.logo-socials > img {
    width: 25px;
    height: 25px;
}

/* Styles for introduction section*/
.article-introduction {
    display: flex;
    flex-direction: column;
    gap: 0px;
    align-items: flex-start;
    align-self: stretch;
    flex-shrink: 0;
    position: relative;
    overflow: hidden;
}

.title {
    display: flex;
    color: #85a947;
    text-align: left;
    font-size: 117px;
    line-height: 134px;
    font-weight: 400;
    flex-direction: row;
    align-self: center;
    justify-content: center;
}

.introduction {
    margin-top: 64px;
    display: flex;
    flex-direction: row;
    gap: 128px;
    row-gap: 64px;
    align-items: center;
    justify-content: center;
    flex-wrap: wrap;
    align-content: center;
    align-self: stretch;
    flex-shrink: 0;
    position: relative;
}

.introduction-element {
    background: #091b12;
    border-radius: 160px 0px;
    border-style: solid;
    border-color: white;
    border-width: 4px;
    padding: 24px;
    display: flex;
    flex-direction: column;
    gap: 32px;
    align-items: center;
    justify-content: center;
    width: 270px;
    height: 520px;
    box-shadow: -4px -4px 2px 0px rgba(62, 123, 39, 1);
    overflow: hidden;
}

.nameplate {
    display: flex;
    flex-direction: column;
    gap: 32px;
    align-items: center;
    justify-content: flex-start;
    flex-shrink: 0;
    position: relative;
}

.photo-name {
    display: flex;
    flex-direction: column;
    gap: 16px;
    align-items: center;
}

.profile-photo {
    border-radius: 64px;
    border-style: solid;
    border-color: #3e7b27;
    border-width: 3px;
    display: flex;
    flex-direction: column;
    gap: 0px;
    width: 96px;
    height: 96px;
    overflow: hidden;
    object-fit: cover;
}

.name-section {
    display: flex;
    flex-direction: column;
    align-items: center;
}

.name {
    font-size: 32px;
    line-height: 42px;
    font-weight: 500;
}

.role {
    font-size: 14px;
    line-height: 18px;
    font-weight: 400;
}

.info {
    display: flex;
    flex-direction: column;
    gap: 16px;
    align-items: flex-start;
    justify-content: flex-start;
    flex-shrink: 0;
    position: relative;
}

.info-text {
    display: flex;
    flex-direction: column;
    gap: 16px;
    align-items: flex-start;
    justify-content: flex-start;
    flex-shrink: 0;
    position: relative;
}

.info-section {
    display: flex;
    flex-direction: row;
    gap: 16px;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    position: relative;
}

.info-section>img {
    width: 14px;
    height: 14px;
}

.info-section>div {
    font-size: 14px;
    line-height: 18px;
    font-weight: 400;
}

.info-languages {
    display: flex;
    flex-direction: row;
    gap: 16px;
    align-items: flex-start;
    justify-content: flex-start;
    flex-shrink: 0;
    position: relative;
}

.info-languages>div {
    background: #3e7b27;
    border-radius: 8px;
    padding: 0px 8px;
    display: flex;
    flex-direction: row;
    gap: 16px;
    color: #091b12;
    text-align: left;
    font-size: 14px;
    line-height: 18px;
    font-weight: 400;
}


.download-button {
    background: var(--white, #ffffff);
    border-radius: 32px;
    padding: 16px 32px 16px 32px;
    display: flex;
    flex-direction: row;
    gap: 16px;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    position: relative;
}

.button-text {
    color: black;
    font-size: 20px;
    line-height: 24px;
    font-weight: 400;
}

.icon-download {
    width: 24px;
    height: 24px;
}

.introduction-element2 {
    display: flex;
    flex-direction: row;
    align-items: center;
    justify-content: center;
}

.presentation {
    display: flex;
    flex-direction: column;
    gap: 32px;
    align-items: flex-start;
    justify-content: flex-start;
    flex-shrink: 0;
    position: relative;
}

.title2 {
    display: flex;
    flex-direction: column;
    font-size: 64px;
    line-height: 72px;
    font-weight: 400;
}

.introduction-paragraph {
    display: flex;
    flex-direction: column;
    gap: 16px;
    align-items: flex-start;
    justify-content: flex-start;
    align-self: stretch;
    flex-shrink: 0;
    position: relative;
}

.introduction-paragraph > p {
    padding: 0px 24px;
    display: flex;
    flex-direction: row;
}

.contact-me {
    padding: 0px 0px 0px 24px;
    display: flex;
    flex-direction: row;
    gap: 16px;
    align-items: center;
    justify-content: flex-start;
    flex-shrink: 0;
    position: relative;
}

.let-s-talk {
    color: #3e7b27;
    font-size: 32px;
    line-height: 42px;
    font-weight: 500;
}

.contact-button {
    background: var(--grey, #43454d);
    border-radius: 40px;
    padding: 8px;
    display: flex;
    flex-direction: row;
    gap: 0px;
    align-items: flex-start;
    justify-content: flex-start;
    flex-shrink: 0;
    position: relative;
}

.contact-button>img {
    width: 24px;
    height: 24px;
}

.highlights {
    background: var(--bg-2, #123524);
    border-radius: 80px;
    padding: 48px 32px 48px 32px;
    display: flex;
    flex-direction: column;
    gap: 48px;
    align-items: flex-start;
    justify-content: center;
    flex-shrink: 0;
    position: relative;
    box-shadow: 2px 2px 4px 0px rgba(0, 0, 0, 0.25);
}

.highlights-section {
    display: flex;
    flex-direction: row;
    gap: 16px;
    align-items: center;
    justify-content: flex-start;
    flex-shrink: 0;
    position: relative;
}

.highlights-number {
    color: var(--brand-1, #3e7b27);
    text-align: left;
    font-family: var(--number-m-font-family, "IbmPlexMono-Medium", sans-serif);
    font-size: var(--number-m-font-size, 48px);
    line-height: var(--number-m-line-height, 62px);
    font-weight: var(--number-m-font-weight, 500);
    position: relative;
}

.highlights-text {
    display: flex;
    flex-direction: column;
    gap: 0px;
    align-items: flex-start;
    justify-content: center;
    font-size: var(--para-m-font-size, 16px);
    line-height: var(--para-m-line-height, 20px);
    font-weight: var(--para-m-font-weight, 400);
    position: relative;
}

/* Styles for about me section */
.about-me-container {
    padding: 0px 64px 0px 128px;
    display: flex;
    flex-direction: row;
    gap: 64px;
    align-items: center;
    justify-content: center;
    flex-wrap: wrap;
    align-content: center;
}

.about-me-content {
    display: flex;
    flex-direction: column;
    gap: 64px;
    align-items: flex-start;
}

.about-me-title {
    background: #091b12;
    border-radius: 40px 0px;
    border-style: solid;
    border-color: #3e7b27;
    border-width: 4px;
    padding: 16px 40px;
    display: flex;
    flex-direction: row;
    font-size: 64px;
    line-height: 72px;
    font-weight: 400;
}

.about-me-text {
    background: #091b12;
    border-radius: 40px;
    padding: 24px 40px 24px 40px;
    gap: 16px;
    width: 800px;
}

.about-me-image {
    border-radius: 16px;
    flex-direction: column;
    width: 462px;
    height: 556px;
    position: relative;
    overflow: hidden;
    object-fit: cover;
}

/* styles for contacts section */
footer {
    background: #091b12;
    padding: 64px 0px 16px 0px;
    display: flex;
    flex-direction: column;
    gap: 64px;
    align-items: center;
}

.footer-top {
    display: flex;
    flex-direction: column;
    gap: 16px;
    align-items: center;
}

.footer-socials {
    display: flex;
    flex-direction: row;
    gap: 50px;
}

.footer-icon {
    background: var(--brand-2, #85a947);
    border-radius: 48px;
    padding: 8px;
    display: flex;
    flex-direction: row;
    align-items: center;
    justify-content: center;
    width: 82px;
    height: 82px;
}

.footer-icon > img {
    flex-shrink: 0;
    width: 60%;
    height: 60%;
    position: relative;
    overflow: visible;
}

@media only screen and (max-width: 600px) {
    /* General Styles */
    body {
        margin: 24px 0;
        font-size: 15px;
    }

    header {
        flex-direction: column;
        align-items: center;
        padding: 0 24px;
        gap: 16px;
    }

    nav {
        gap: 12px;
        flex-wrap: wrap;
        justify-content: center;
    }

    h1 {
        font-size: 52;
    }

    /* Header styles */
    .logo-text {
        font-size: 24px;
    }

    /* Inroduction section styles */
    .article-introduction {
        padding: 32px 16px;
    }

    .title {
        font-size: 48px;
        line-height: 56px;
        text-align: center;
    }

    .introduction {
        flex-direction: column;
        gap: 24px;
        padding: 0 16px;
    }

    .introduction-element {
        width: 90%;
        height: auto;
        border-radius: 100px 0;
        padding: 18px;
    }

    .introduction-element2 {
        padding: 20px 0;
        flex-direction: column;
        gap: 24px;
    }

    .introduction-paragraph > p {
        padding: 0px 8px;
        font-size: 14px;
        line-height: 20px;
        text-align: left;
    }

    .title2 {
        font-size: 36px;
        line-height: 44px;
        text-align: center;
    }

    .presentation {
        font-size: 36px;
        line-height: 44px;
        text-align: center;
    }

    .profile-photo {
        width: 72px;
        height: 72px;
    }

    .name {
        font-size: 24px;
    }

    .download-button {
        padding: 12px 20px;
        border-radius: 24px;
    }

    .info-languages > div {
        padding: 4px 8px;
        font-size: 13px;
    }

    .highlights {
        padding: 24px;
        border-radius: 24px;
    }

    /* About me section styles */
    .about-me-container {
        padding: 0 16px;
        flex-direction: column;
        gap: 24px;
        align-items: stretch;
    }

    .about-me-title {
        font-size: 52px;
    }

    .about-me-text {
        width: 75%;
        font-size: 14px;
        line-height: 20px;
    }

    .about-me-image {
        width: 100%;
        height: auto;
        max-width: 460px;
    }

    /* Footer styles */
    footer {
        padding: 32px 16px;
    }

    .footer-socials {
        gap: 20px;
    }

    .footer-icon {
        width: 30px;
        height: 30px;
    }

}