footer {
    background-color: var(--bg-nav);
    padding: 28px 0;
    flex-shrink: 0;
}

.footer-inner {
    max-width: 1160px;
    margin: 0 auto;
    padding: 0 var(--container-padding) 28px;
    box-sizing: border-box;
    display: flex;
    align-items: flex-end;
    gap: 80px;
}

.footer-col {
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.footer-heading {
    font-family: var(--font);
    font-size: var(--fs-nav);
    font-weight: 700;
    color: var(--color-primary);
}

.footer-links {
    display: flex;
    gap: 28px;
}

.footer-links a,
.footer-email {
    font-family: var(--font);
    font-size: var(--fs-base);
    color: var(--color-primary);
    text-decoration: none;
}

.footer-links a:hover,
.footer-email:hover {
    font-weight: bold;
}

.footer-copy {
    font-family: var(--font);
    font-size: var(--fs-sm);
    color: var(--color-primary);
    margin-left: auto;
    padding-bottom: 2px;
}

.footer-rule {
    max-width: 1160px;
    margin: 0 auto;
    padding: 0 var(--container-padding);
    box-sizing: border-box;
}

.footer-rule::before {
    content: '';
    display: block;
    height: 1px;
    background-color: var(--color-primary);
}

@media (max-width: 700px) {
    .footer-inner {
        flex-direction: column;
        align-items: flex-start;
        gap: 24px;
    }
    .footer-copy { margin-left: 0; }
    .footer-links { flex-direction: column; gap: 10px; }
}
