/* Education section */
#education_body {
    display: grid;
    justify-content: center;
    align-content: start;
    color: var(--accent-text);
    padding: 28px 20px;
    height: 640px;
    background: var(--bg-card);
    border-top: 1px solid var(--border-primary);
    border-bottom: 1px solid var(--border-primary);
    box-shadow: 0 5px 10px var(--shadow-primary);
    position: relative;
    overflow: hidden;
}

#education_body h2 {
    text-align: center;
    font-size: 2.4em;
    margin-bottom: 70px;
    color: var(--text-primary);
    font-weight: 700;
    position: relative;
    z-index: 10;
}

/* education content container */
.education_content {
    display: flex;
    gap: 24px;
    align-items: flex-start;
    justify-content: flex-start;
    width: min(100%, 1100px);
    margin: 0 auto;
    padding-right: clamp(0px, 50vw, 380px);
    position: relative;
    z-index: 10;
}

/* grid of education */
.education_grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 20px;
}

/* background image positioned absolutely */
.education_background_image {
    height: 900px;
    width: 900px;
    position: absolute;
    top: 50%;
    left: calc(50% - 150px);
    transform: translateY(-50%);
    z-index: 0;
    pointer-events: none;
}

.education_bg_img {
    opacity: 0.7;
}

/* education image */
.education_image {
    flex: 0 0 auto;
    max-width: 400px;
}

.education_img {
    width: 100%;
    height: auto;
    transform: skew(-3deg) rotate(1deg);
}

.education_pin_icon {
    z-index: 10;
    position: absolute;
    height: 32px;
    filter: grayscale(100%) brightness(80%);
    transition: height 0.2s ease, filter 0.2s ease;
}

#pin_icon_orebro {
    top: 404px;
    left: 547px;
    transform: translate(-100%, -100%);
}

#pin_icon_augsburg {
    top: 647px;
    left: 489px;
    transform: translate(-100%, -100%);
}

#pin_icon_vasteras {
    top: 393px;
    left: 566px;
    /* Uses reverse pin image, must be flipped */
    transform: translate(0%, -100%);
}

/* Hover effect for #pin_icon_orebro when the third education card is hovered */
#education_body:has(.education_content .education_grid .education_card:nth-child(3):hover) #pin_icon_orebro,
#education_body:has(.education_content .education_grid .education_card:nth-child(2):hover) #pin_icon_augsburg,
#education_body:has(.education_content .education_grid .education_card:nth-child(1):hover) #pin_icon_vasteras {
    filter: grayscale(20%) brightness(80%);
    height: 46px;
}


/* single education card */
.education_card {
    background: var(--bg-card);
    padding: 20px 24px;
    border-radius: 10px;
    display: flex;
    flex-direction: column;
    gap: 10px;
    box-shadow: 0 5px 10px var(--shadow-primary);
    transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.education_card:hover {
    transform: translateY(-2px);
    box-shadow: 0 8px 20px var(--shadow-primary);
}

.education_degree {
    font-weight: 600;
    color: var(--accent-text);
    font-size: 1.1rem;
}

.education_institution {
    color: var(--text-secondary);
    font-size: 0.95rem;
}

.education_location {
    color: var(--text-muted);
    font-size: 0.9rem;
}

@media (max-width: 900px) {
    #education_body {
        height: 75vh;
        padding: 28px 16px 32px;
    }

    #education_body h2 {
        margin-bottom: 28px;
    }

    .education_content {
        width: 100%;
    }

        .education_background_image {
        height: 900px;
        width: 900px;
        position: absolute;
        top: 70%;
        left: calc(20% - 200px);
        transform: translateY(-50%);
        z-index: 0;
        pointer-events: none;
    }
}

