.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: 3rem; 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-social-links {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    margin-top: 1rem;
}
.footer-social-link {
    display: inline-grid;
    place-items: center;
    width: 2.25rem;
    height: 2.25rem;
    border: 1px solid var(--ocf-border);
    border-radius: 999px;
    color: var(--ocf-heading);
    background: color-mix(in srgb, var(--ocf-bg-alt) 62%, transparent);
    transition: background 160ms ease, border-color 160ms ease, color 160ms ease, transform 160ms ease;
}
.footer-social-link:hover,
.footer-social-link:focus-visible {
    border-color: color-mix(in srgb, var(--ocf-heading) 34%, var(--ocf-border));
    color: var(--ocf-heading);
    background: color-mix(in srgb, var(--ocf-heading) 8%, var(--ocf-bg-alt));
    transform: translateY(-1px);
}
.footer-social-link svg {
    width: 1.05rem;
    height: 1.05rem;
    fill: currentColor;
    stroke: none;
}
.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: grid;
    grid-template-columns: 1.1rem minmax(0, 1fr);
    gap: 0.55rem;
    align-items: start;
}
.footer-contact-links svg,
.footer-address svg {
    width: 1.05rem;
    height: 1.05rem;
    margin-top: 0.16em;
    flex: 0 0 auto;
}
.footer-address svg {
    width: 1.16rem;
    height: 1.16rem;
    margin-left: -0.03rem;
    margin-top: 0.08em;
}
.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; }
}

/* Forge footer: dense utility directory. */
.site-footer {
    border-top: 0;
    background: var(--ocf-bg-dark);
    color: var(--ocf-body-alt);
}

.site-footer .section-padding {
    padding-block: clamp(2.5rem, 6vw, 4.5rem);
}

.footer-grid {
    grid-template-columns: minmax(16rem, 1.35fr) repeat(4, minmax(0, 1fr));
    gap: 0;
    border-top: 1px solid color-mix(in srgb, #fff 18%, transparent);
    border-left: 1px solid color-mix(in srgb, #fff 18%, transparent);
}

.footer-grid > div {
    min-width: 0;
    border-right: 1px solid color-mix(in srgb, #fff 18%, transparent);
    border-bottom: 1px solid color-mix(in srgb, #fff 18%, transparent);
    padding: 1rem;
}

.footer-brand-name,
.footer-heading {
    color: var(--ocf-heading-alt);
}

.footer-heading {
    color: var(--ocf-accent);
    font-size: 11px;
    letter-spacing: 0.06em;
    text-transform: uppercase;
}

.footer-brand-desc,
.footer-link-list,
.footer-hours,
.footer-contact-links,
.footer-bottom {
    color: color-mix(in srgb, var(--ocf-body-alt) 82%, transparent);
}

.footer-social-link {
    border-color: color-mix(in srgb, #fff 18%, transparent);
    background: transparent;
    color: var(--ocf-heading-alt);
}

.footer-bottom {
    border-top-color: color-mix(in srgb, #fff 18%, transparent);
}

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

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