.vof-contact-map {
    padding: 0 0 120px;
    background: var(--bg);
}

.vof-contact-map__header {
    text-align: center;
    margin-bottom: 40px;
    padding-top: 120px;
}

.vof-contact-map__header .label-caps {
    display: block;
    text-align: center;
}

.vof-contact-map__header h2 {
    margin-bottom: 12px;
}

.vof-contact-map__header p {
    font-size: 0.9375rem;
    color: var(--muted);
    line-height: 1.6;
}

.vof-contact-map__embed {
    border-radius: var(--radius-xl);
    overflow: hidden;
    border: 1px solid var(--border-light);
    box-shadow: 0 8px 32px rgba(0,0,0,0.06);
}

.vof-contact-map__embed iframe {
    display: block;
    width: 100%;
    height: 480px;
}

.vof-contact-map__placeholder {
    width: 100%;
    height: 480px;
    background: var(--surface-alt);
    display: flex;
    align-items: center;
    justify-content: center;
}

.vof-contact-map__placeholder span {
    font-family: var(--font-mono);
    font-size: 0.75rem;
    color: var(--muted);
    letter-spacing: 0.5px;
}

@media (max-width: 768px) {
    .vof-contact-map { padding: 0 0 80px; }
    .vof-contact-map__header { padding-top: 80px; }
    .vof-contact-map__embed iframe { height: 320px; }
    .vof-contact-map__placeholder { height: 320px; }
}
