.ocf-contact {
    background: var(--ocf-bg);
}

.contact-grid {
    display: grid;
    grid-template-columns: minmax(0, 0.85fr) minmax(320px, 0.75fr);
    gap: clamp(2rem, 6vw, 5rem);
    align-items: start;
}

.ocf-contact-heading { max-width: 620px; }
.ocf-contact-intro {
    max-width: 58ch;
    margin: 1rem 0 0;
    color: var(--ocf-body);
}

.ocf-contact-details {
    display: grid;
    gap: 0.85rem;
    margin-top: 2rem;
}

.ocf-contact-item {
    display: grid;
    grid-template-columns: 2.35rem minmax(0, 1fr);
    gap: 0.85rem;
    align-items: start;
    border-top: 1px solid var(--ocf-border-light);
    padding-top: 1rem;
}

.ocf-contact-icon {
    display: inline-flex;
    width: 2.25rem;
    height: 2.25rem;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    background: var(--ocf-bg-alt);
    color: var(--ocf-accent);
}

.ocf-contact-icon svg { width: 1rem; height: 1rem; }
.ocf-contact-item-body { display: grid; gap: 0.15rem; }
.ocf-contact-item-body strong { color: var(--ocf-heading); }
.ocf-contact-item-body span { color: var(--ocf-label); font-size: var(--text-sm); }

.ocf-contact-hours {
    margin-top: 2rem;
    border: 1px solid var(--ocf-border-light);
    border-radius: var(--card-radius);
    background: var(--ocf-bg-alt);
    padding: 1.25rem;
}

.ocf-contact-hours-label {
    display: flex;
    align-items: center;
    gap: 0.45rem;
    margin: 0 0 1rem;
}

.ocf-contact-hours-label svg { width: 1rem; height: 1rem; }
.ocf-hours-list {
    display: grid;
    gap: 0.5rem;
    margin: 0;
    padding: 0;
    list-style: none;
}
.ocf-hours-list li {
    display: flex;
    justify-content: space-between;
    gap: 1rem;
}

.ocf-contact .ocf-contact-form,
.ocf-contact .contact-form-wrapper {
    border-radius: var(--card-radius-lg);
}

@media (max-width: 860px) {
    .contact-grid { grid-template-columns: 1fr; }
}
