.contact {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    gap: 4rem;
    width: 100%;
    min-height: 98rem;
    position: relative;
    border: 1px solid var(--color-primary-dark);
    border-radius: var(--border-radius);
    padding: 24rem;
}

.contact:has(.contact__icon) {
    padding-left: 96rem;
}

.contact__icon {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    width: 48rem;
    height: 48rem;
    background-color: var(--color-primary-10);
    border-radius: var(--border-radius);
}

.contact > .contact__icon {
    position: absolute;
    top: 50%;
    left: 24rem;
    -webkit-transform: translateY(-50%);
        -ms-transform: translateY(-50%);
            transform: translateY(-50%);
}

.contact__icon img {
    width: 32rem;
    height: 32rem;
    -o-object-fit: contain;
       object-fit: contain;
    opacity: 0.5;
}

.contact__title {
    font-size: 18rem;
    line-height: 24rem;
}

a.contact {
    -webkit-transition:
        border-color var(--transition-duration),
        -webkit-transform var(--transition-duration),
        -webkit-box-shadow var(--transition-duration);
    transition:
        border-color var(--transition-duration),
        -webkit-transform var(--transition-duration),
        -webkit-box-shadow var(--transition-duration);
    transition:
        transform var(--transition-duration),
        border-color var(--transition-duration),
        box-shadow var(--transition-duration);
    transition:
        transform var(--transition-duration),
        border-color var(--transition-duration),
        box-shadow var(--transition-duration),
        -webkit-transform var(--transition-duration),
        -webkit-box-shadow var(--transition-duration);
}

a.contact:after {
    content: '';
    width: 16rem;
    height: 16rem;
    position: absolute;
    top: 10rem;
    right: 10rem;
    background: url('../../img/icons/hand-pointer-primary.svg') center/contain no-repeat;
    -webkit-transition: -webkit-transform var(--transition-duration);
    transition: -webkit-transform var(--transition-duration);
    transition: transform var(--transition-duration);
    transition: transform var(--transition-duration), -webkit-transform var(--transition-duration);
}

a.contact .contact__icon img {
    -webkit-transition: opacity var(--transition-duration);
    transition: opacity var(--transition-duration);
}

a.contact .contact__text {
    -webkit-transition: color var(--transition-duration);
    transition: color var(--transition-duration);
}

.contacts {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    gap: 24rem;
    width: 100%;
}

.contact-row {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    gap: 32rem;
}

.contact-row:not(:first-child) {
    margin-top: 48rem;
}

@media screen and (min-width: 1024px) and (orientation: landscape) {
    .contacts {
        -webkit-box-pack: justify;
            -ms-flex-pack: justify;
                justify-content: flex-start;
    }

    .contact-row > * {
        max-width: calc(50% - 16rem);
    }
}

@media (hover: hover) {
    a.contact:hover {
        -webkit-transform: translateY(-8rem);
            -ms-transform: translateY(-8rem);
                transform: translateY(-8rem);
        border-color: var(--color-primary);
        -webkit-box-shadow: 0 0 15rem var(--color-primary-30);
                box-shadow: 0 0 15rem var(--color-primary-30);
    }

    a.contact:hover:after {
        -webkit-transform: translate3d(-2rem, 4rem, 0) scale(0.9) rotate(-8deg);
                transform: translate3d(-2rem, 4rem, 0) scale(0.9) rotate(-8deg);
    }

    a.contact:hover .contact__icon img {
        opacity: 1;
    }

    a.contact:hover .contact__text {
        color: var(--color-primary);
    }
}
