.contact-map {
    position: relative;
    background: #25211b;
    padding: 56px 0 92px;
}

.contact-map__inner {
    width: min(1240px, calc(100% - 64px));
    margin: 0 auto;
}

.contact-map__grid {
    display: grid;
    grid-template-columns: 1.25fr 1fr 0.9fr;
    gap: 42px;
    align-items: start;
}

.contact-map__card {
    min-width: 0;
}

.contact-map__label {
    margin-bottom: 18px;
    font-size: 18px;
    line-height: 1;
    font-weight: 300;
    letter-spacing: -0.03em;
    text-transform: uppercase;
    color: rgba(255,255,255,0.7);
}

.contact-map__text,
.contact-map__phones a,
.contact-map__mail {
    font-size: clamp(22px, 2.15vw, 28px);
    line-height: 1.42;
    font-weight: 300;
    letter-spacing: -0.04em;
    color: rgba(255,255,255,0.95);
    text-decoration: none;
}

.contact-map__phones {
    display: grid;
    gap: 4px;
}

.contact-map__mail {
    display: inline-block;
    text-transform: uppercase;
}

.contact-map__divider {
    height: 1px;
    margin: 30px 0 36px;
    background: rgba(255,255,255,0.28);
}

.contact-map__map-shell {
    position: relative;
    overflow: hidden;
    min-height: 670px;
    background: #171614;
    border: 1px solid rgba(255,255,255,0.08);
}

.contact-map__map {
    position: relative;
    z-index: 1;
    width: 100%;
    min-height: 670px;
    filter: grayscale(1) saturate(0) contrast(1.18) brightness(0.72);
}

.contact-map__map iframe,
.contact-map__map > ymaps,
.contact-map__map [class*="ymaps"] {
    width: 100% !important;
}

.contact-map__map iframe {
    min-height: 670px;
}

.contact-map__overlay {
    position: absolute;
    inset: 0;
    z-index: 2;
    pointer-events: none;
    background:
        linear-gradient(180deg, rgba(12,12,12,0.22) 0%, rgba(12,12,12,0.08) 12%, rgba(12,12,12,0.08) 84%, rgba(12,12,12,0.26) 100%),
        linear-gradient(90deg, rgba(18,18,18,0.12) 0%, rgba(18,18,18,0) 12%, rgba(18,18,18,0) 88%, rgba(18,18,18,0.12) 100%);
    mix-blend-mode: multiply;
}

.contact-map__map-shell.is-ready .contact-map__map {
    animation: mapFadeIn 0.7s ease forwards;
}

@keyframes mapFadeIn {
    from {
        opacity: 0.78;
        transform: scale(1.01);
    }

    to {
        opacity: 1;
        transform: scale(1);
    }
}

@media (max-width: 980px) {
    .contact-map {
        padding: 40px 0 72px;
    }

    .contact-map__inner {
        width: calc(100% - 36px);
    }

    .contact-map__grid {
        grid-template-columns: 1fr;
        gap: 28px;
    }

    .contact-map__divider {
        margin: 24px 0 28px;
    }

    .contact-map__map-shell,
    .contact-map__map,
    .contact-map__map iframe {
        min-height: 520px;
    }
}

@media (max-width: 640px) {
    .contact-map__inner {
        width: calc(100% - 20px);
    }

    .contact-map__label {
        font-size: 16px;
        margin-bottom: 14px;
    }

    .contact-map__text,
    .contact-map__phones a,
    .contact-map__mail {
        font-size: 17px;
        line-height: 1.45;
    }

    .contact-map__map-shell,
    .contact-map__map,
    .contact-map__map iframe {
        min-height: 420px;
    }
}
