.contacts-list {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: calc(var(--spacing) * 8);
    margin-top: calc(var(--spacing) * 8);
    --color-lighter-gray: #f6f7f7;
    --color-primary-lighter: #f4f8f8;

    @media screen and (max-width: 1280px) {
        grid-template-columns: repeat(2, 1fr);
    }

    @media screen and (max-width: 767px) {
        grid-template-columns: 1fr;
    }

    .contact {
        position: relative;
        padding: calc(var(--spacing) * 8);
        transition: all .3s;

        &::after {
            content: "";
            position: absolute;
            top: 0;
            left: 0;
            right: 0;
            bottom: 0;
            border-radius: var(--radius-semilarge);
            padding: 3px;
            background: linear-gradient(90deg, var(--color-primary-dark) 50%, transparent 50%);
            background-size: 200% 100%;
            background-position: 100% 0;
            -webkit-mask: linear-gradient(#fff 0 0) content-box,
            linear-gradient(#fff 0 0);
            -webkit-mask-composite: xor;
            mask-composite: exclude;
            pointer-events: none;
            transition: background-position 800ms linear;
            z-index: 3;
        }

        &:hover::after {
            background-position: 0% 0;
        }

        .contact-body {
            position: relative;
            display: flex;
            justify-content: space-between;
            align-items: start;
            gap: calc(var(--spacing) * 8);
            z-index: 2;

            .contact-photo-container {
                position: relative;
                aspect-ratio: 1/1;
                width: 90px;
                height: 90px;

                .contact-photo {
                    border-radius: 50%;
                    margin: 0;
                    width: 100%;
                    height: 100%;
                    object-fit: cover;
                }


                div.contact-photo {
                    mask-size: contain;
                    mask-position: center;
                    mask-repeat: no-repeat;
                    background: var(--color-primary-light);
                    transition: all .3s;
                }

                &::before {
                    content: '';
                    position: absolute;
                    width: 100%;
                    height: 100%;
                    z-index: 1;
                    border-radius: 50%;
                    transition: all .3s;

                    background-color: var(--color-lighter-gray);
                }
            }


            h3 {
                margin-top: 0 !important;
                margin-bottom: calc(var(--spacing) * 2) !important;
            }

            a {
                transition: all .3s;

                &:hover {
                    text-decoration: underline;
                }
            }

            .contact-ways {
                display: flex;
                flex-direction: column;
                gap: calc(var(--spacing) * 2);
            }

            .contact-emails {
                a {
                    display: block;
                    font-size: .8rem;
                }
            }

            .contact-phones {
                span {
                    display: block;
                    font-size: .8rem;
                }
            }

            .contact-websites {
                a {
                    display: block;
                    font-size: .8rem;
                }
            }
        }

        &::before {
            z-index: 1;
            content: "";
            position: absolute;
            inset: 0;
            background-color: var(--color-lighter-gray);
            border-radius: var(--radius-semilarge);
            border: 1px solid var(--color-lighter-gray);
            /*opacity: .5;*/
            transition: all .3s;
        }

        &:hover {
            scale: 1.05;

            &::before {
                background-color: var(--color-green-lighter);
            }

            div.contact-photo {
                background: var(--color-primary) !important;
            }

            .contact-photo-container::before {
                background-color: var(--color-green-lighter);
            }
        }
    }
}
