.site-footer {
    border-top: 1px solid var(--ocf-border-light);
    background: var(--ocf-bg);
    color: var(--ocf-body);
}

.footer-grid {
    display: grid;
    grid-template-columns: 1.2fr repeat(4, minmax(0, 1fr));
    gap: 2rem;
}

.footer-logo-img { max-height: 2.5rem; width: auto; margin-bottom: 1rem; }
.footer-brand-name { display: block; color: var(--ocf-heading); font-weight: 700; }
.footer-brand-desc { margin: 0.75rem 0 0; max-width: 28ch; }
.footer-heading { margin: 0 0 0.75rem; color: var(--ocf-heading); font-weight: 700; }
.footer-link-list,
.footer-hours {
    display: grid;
    gap: 0.45rem;
    margin: 0;
    padding: 0;
    list-style: none;
    font-size: var(--text-sm);
}
.footer-hours li { display: flex; justify-content: space-between; gap: 1rem; }
.footer-contact-links { display: grid; gap: 0.5rem; margin-top: 1rem; font-size: var(--text-sm); }
.footer-contact-links a,
.footer-address { display: flex; gap: 0.5rem; align-items: start; }
.footer-bottom {
    display: flex;
    justify-content: space-between;
    gap: 1rem;
    margin-top: 2rem;
    padding-top: 1.25rem;
    border-top: 1px solid var(--ocf-border-light);
    color: var(--ocf-label);
    font-size: var(--text-sm);
}
.footer-bottom-links { display: flex; gap: 1rem; }

@media (max-width: 980px) {
    .footer-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}

@media (max-width: 640px) {
    .footer-grid,
    .footer-bottom { display: grid; grid-template-columns: 1fr; }
}
