/* ============================= */
/* Logo                          */
/* ============================= */

.logo {
    display: inline-flex;
    flex-direction: column;
    align-items: center;
    text-decoration: none;
    color: var(--color-background);
}

.logo-icon {
    width: 48px;
    height: auto;
    display: block;
}

.logo-text {
    display: flex;
    flex-direction: column;
    align-items: center;
    line-height: 1;
    pointer-events: none;
}

.logo-name {
    margin-top: 1px;
    font-family: 'Anta', sans-serif;
    font-weight: var(--fw-regular);

    font-size: 16px;
    line-height: 120%;
    letter-spacing: 0%;
}

.logo-role {
    margin-top: 1px;
    font-family: 'Josefin Sans', sans-serif;
    font-weight: var(--fw-light);

    font-size: 16px;
    line-height: 120%;
    letter-spacing: 0%;
}

.logo--hero .logo-name {
    color: var(--color-secondary);
}

.logo--hero .logo-role {
    color: var(--color-primary);
}

.logo--hero .hero-logo-mark {
    height: 48px;

    display: inline-flex;
    justify-content: center;
    align-items: center;

    gap: 0;
}

.logo--hero .hero-logo-part {
    width: auto;
    display: block;
}

.hero-logo-brace-left {
    transform: translateX(22px);
}

.hero-logo-brace-right {
    transform: translateX(-22px);
}

.logo--hero .hero-logo-frame {
    height: 48px;
}

.logo--hero .hero-logo-brace-left,
.logo--hero .hero-logo-brace-right {
    height: 24px;
}

.logo--hero .hero-logo-frame {
    transform-origin: center;
    transition: transform 220ms ease-in-out;
}

.logo--hero:hover .hero-logo-frame {
    transform: scaleX(1.16);
}


/* ============================= */
/* Buttons                       */
/* ============================= */

.btn {
    display: inline-flex;
    justify-content: center;
    align-items: center;

    padding: 12px 40px;

    color: var(--color-primary);
    text-decoration: none;
    font-family: var(--font-body);
    font-weight: var(--fw-regular);
    font-size: 20px;
    line-height: 120%;

    border-radius: 999px;
}

.btn--outline {
    border: 1px solid var(--color-primary);
}

.btn--outline:hover {
    background-color: rgba(248, 245, 236, 0.12);
}


/* ============================= */
/* Section Layout                */
/* ============================= */

.section {
    padding: 96px 120px;
    max-width: 1440px;
    box-sizing: border-box;
}

.section-title {
    margin: 0 0 72px;

    color: var(--color-primary);
    font-family: var(--font-headline);
    font-weight: var(--fw-regular);
    font-size: 72px;
    line-height: 120%;
    text-align: center;
}

.section-content {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 96px;
}


/* ============================= */
/* Social-Links                  */
/* ============================= */

.social-link {
    width: 32px;
    height: 32px;

    display: inline-flex;
    justify-content: center;
    align-items: center;

    text-decoration: none;

    background-repeat: no-repeat;
    background-position: center;
    background-size: contain;
}

.social-link--email {
    background-image: url("../assets/icons/email-default.svg");
}

.social-link--github {
    background-image: url("../assets/icons/github-default.svg");
}

.social-link--linkedin {
    background-image: url("../assets/icons/linkedin-default.svg");
}

.social-link--email:hover {
    background-image: url("../assets/icons/email-hoverblue.svg");
}

.social-link--github:hover {
    background-image: url("../assets/icons/github-hoverblue.svg");
}

.social-link--linkedin:hover {
    background-image: url("../assets/icons/linkedin-hoverblue.svg");
}


/* ============================= */
/* Scroll-Down Button            */
/* ============================= */

.scroll-down {
    grid-row: 3;

    width: 40px;
    height: 94px;

    display: inline-flex;
    justify-content: center;
    align-items: center;
    align-self: center;

    border-radius: 999px;
    text-decoration: none;

    background-color: transparent;
    background-image: url("../assets/icons/arrow-down-default.svg");
    background-repeat: no-repeat;
    background-position: center;
    background-size: contain;

    transition: background-color 200ms ease-in-out;
}

.scroll-down:hover,
.scroll-down:focus-visible {
    background-color: rgba(248, 245, 236, 0.12);
}

.scroll-down:focus-visible {
    outline: 2px solid var(--color-primary);
    outline-offset: 8px;
}


/* ============================= */
/* Section Layout Tablet         */
/* ============================= */

@media (min-width: 768px) and (max-width: 1024px) {
    .section {
        padding: 96px 64px;
    }

    .section-title {
        margin: 0 0 56px;
        font-size: 64px;
    }

    .section-content {
        gap: 48px;
    }
}


/* ============================= */
/* Section Layout Small Desktop  */
/* ============================= */

@media (min-width: 1025px) and (max-width: 1199px) {
    .section {
        padding: 96px 64px;
    }

    .section-title {
        font-size: 64px;
    }

    .section-content {
        gap: 64px;
    }
}


/* ============================= */
/* Section Layout Mobile         */
/* ============================= */

@media (max-width: 767px) {
    .section {
        padding: 80px 24px 0;
    }

    .section-title {
        margin: 0 0 32px;
        font-size: 32px;
    }
}