.speaker {
    position: relative;
}

.speaker .speaker__wrapper {
    --img-width: 620px;
    --overhang: 40px;
    display: grid;
    grid-template-columns: 1fr var(--img-width);
    align-items: center;
}

.speaker .speaker__wrapper.mirrored {
    grid-template-columns: var(--img-width) 1fr;
}

.speaker .speaker__block {
    padding: 40px;
    width: calc(100% + var(--overhang));
    background-color: #1F1F1F;
    border-radius: 40px;
    border: 1px solid #2B2B2B;
    position: relative;
}

.speaker .speaker__wrapper:last-child .speaker__block {
    right: var(--overhang);
}

.speaker .speaker__name {
    width: fit-content;
    font-weight: 700;
    font-size: 29px;
    line-height: 140%;
    letter-spacing: 0%;
    text-transform: uppercase;
}

.speaker .speaker__points {
    display: flex;
    flex-direction: column;
    gap: 1em;
    list-style: disc;
    margin-left: 1em;
    margin-top: 24px;
}

.speaker .speaker__point {
    font-weight: 400;
    font-size: 18px;
    line-height: 150%;
    letter-spacing: 0%;
}

.speaker .speaker__picture {
    width: 100%;
    flex-shrink: 0;
    display: flex;
}

.speaker .speaker__img {
    width: 100%;
    height: auto;
    border-radius: 40px;
    border: 1px solid #2B2B2B;
}

.speaker .speaker__speakers {
    display: flex;
    flex-direction: column;
    gap: 40px;
    margin-top: 40px;
}

.speaker .bg-grid-img {
    top: -895px;
}

@media screen and (max-width: 1200px) {
    .speaker .speaker__wrapper {
        --img-width: 500px;
    }    

    .speaker .speaker__block {
        padding: 25px;
        border-radius: 20px;
    }
}

@media screen and (max-width: 980px) {
    .speaker .speaker__wrapper {
        --horizontal-offset: 50px;
        --overhang: 100px;
    }

    .speaker .speaker__wrapper {
        flex-direction: column-reverse;
        display: flex;
    }

    .speaker .speaker__wrapper.mirrored {
        flex-direction: column;
    }

    .speaker .speaker__wrapper:last-child .speaker__block {
        right: unset;
    }

    .speaker .speaker__block {
        width: 100%;
    }

    .speaker .speaker__wrapper .speaker__picture {
        padding-left: var(--horizontal-offset);
    }

    .speaker .speaker__wrapper .speaker__block {
        margin-right: var(--horizontal-offset);
        width: calc(100% - var(--horizontal-offset));
        margin-top: calc(-1 * var(--overhang));
    }

    .speaker .speaker__wrapper .speaker__picture {
        max-width: 650px;
        margin-left: auto;
    }
}

@media screen and (max-width: 670px) {
    .speaker .speaker__wrapper {
        --horizontal-offset: 0px;
        --overhang: 50px;
    }


    .speaker .speaker__name {
        font-size: 24px;
    }

    .speaker .speaker__point {
        font-size: 14px;
    }

    .speaker .speaker__wrapper .speaker__block {
        padding: 20px;
    }

    .speaker .speaker__speakers {
        margin-top: 20px;
    }
}
