.map-section {
    position: relative;
    height: 400px;
    overflow: hidden;
}

/* BG */
.map-section__bg {
    position: absolute;
    inset: 0;
}

.map-section__bg img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

/* OVERLAY */
.map-section__overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(
        to right,
        rgba(0,0,0,0.9) 30%,
        rgba(0,0,0,0.5) 65%,
        rgba(0,0,0,0.2)
    );
}

/* CONTENT */
.map-section__content {
    position: relative;
    z-index: 2;
    padding: var(--space-xl);
}

/* SUBTITLE */
.map-section__subtitle {
    color: var(--color-primary);
    font-size: var(--fs-sm);
    letter-spacing: 2px;
    display: inline-block;
}

.map-section__subtitle::after {
    content: "";
    display: block;
    width: 40px;
    height: 2px;
    background: var(--color-primary);
    margin-top: 6px;
}

/* CARD */
.map-card {
    margin-top: var(--space-md);
    max-width: 280px;

    padding: var(--space-md);

    background: rgba(0,0,0,0.75);
    border: 1px solid var(--color-border);

    display: flex;
    flex-direction: column;
    gap: var(--space-sm);
}

/* ICON */
.map-card__icon svg {
    width: 24px;
    height: 24px;
    stroke: var(--color-primary);
}

/* TEXT */
.map-card__text strong {
    display: block;
    font-size: var(--fs-sm);
    margin-bottom: 4px;
}

.map-card__text p {
    font-size: var(--fs-sm);
    color: var(--color-text-muted);
}

/* BUTTON */
.map-card__btn {
    margin-top: var(--space-sm);

    display: inline-flex;
    align-items: center;
    gap: 8px;

    padding: 8px 12px;

    border: 1px solid var(--color-primary);
    color: var(--color-primary);

    text-decoration: none;
    font-size: var(--fs-xs);
    letter-spacing: 1px;

    transition: var(--transition-fast);
}

.map-card__btn:hover {
    background: var(--color-primary);
    color: #000;
}

.map-card__btn svg {
    width: 14px;
    height: 14px;
    stroke: currentColor;
}

iframe

 {
    width: 100%;
}

/* ===== RESPONSIVE ===== */
@media (max-width: 768px) {

    .map-section {
        height: auto;
    }

    .map-section__content {
        padding: var(--space-lg);
    }

    .map-card {
        max-width: 100%;
    }
}