/**
 * Site footer — 4-column layout with copyright bar
 */

.site-footer {
    background-color: var(--color-primary-800);
    color: var(--color-primary-200);
    margin-top: auto;
}

/* ── Columns grid (mobile-first) ── */

.site-footer__columns {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--space-xl);
    width: 100%;
    max-width: var(--max-width);
    margin-inline: auto;
    padding-inline: var(--gutter);
    padding-block: clamp(2.5rem, 2rem + 2.5vw, 4rem) var(--space-xl);
}

/* ── Brand ── */

.site-footer__brand {
    display: flex;
    align-items: center;
    gap: var(--space-s);
    margin-bottom: var(--space-s);
}

.site-footer__logo {
    width: 2.75rem;
    height: auto;
    object-fit: contain;
}

/* ── Typography ── */

.site-footer__heading {
    font-size: var(--size-step-0);
    font-weight: 600;
    color: var(--color-bg);
    margin-bottom: 0;
    line-height: var(--leading-snug);
}

.site-footer__about {
    font-size: var(--size-step--2);
    line-height: var(--leading-relaxed);
    color: var(--color-primary-300);
}

/* ── Column titles ── */

.site-footer__col-title {
    font-size: var(--size-step--1);
    font-weight: 600;
    color: var(--color-bg);
    margin-bottom: var(--space-m);
    letter-spacing: 0.02em;
}

/* ── Lists ── */

.site-footer__list {
    list-style: none;
}

.site-footer__list li + li {
    margin-top: var(--space-xs);
}

.site-footer__col a {
    color: var(--color-primary-200);
    text-decoration: none;
    font-size: var(--size-step--2);
    transition: color var(--transition-base);
}

.site-footer__col a:hover {
    color: var(--color-bg);
}

/* ── Contact details ── */

.site-footer__list--contact li {
    display: flex;
    flex-direction: column;
    gap: 0.125rem;
}

.site-footer__list--contact li + li {
    margin-top: var(--space-s);
}

.site-footer__detail-label {
    font-size: var(--size-step--3);
    color: var(--color-primary-400);
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.site-footer__list--contact span:not(.site-footer__detail-label) {
    font-size: var(--size-step--2);
    color: var(--color-primary-200);
}

/* ── Office hours ── */

.site-footer__hours {
    display: flex;
    flex-direction: column;
    gap: var(--space-xs);
}

.site-footer__hours-row {
    display: flex;
    justify-content: space-between;
    gap: var(--space-s);
    font-size: var(--size-step--2);
}

.site-footer__hours dt {
    color: var(--color-primary-200);
}

.site-footer__hours dd {
    color: var(--color-primary-300);
    text-align: right;
}

/* ── Bottom bar ── */

.site-footer__bottom {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    gap: var(--space-xs);
    width: 100%;
    max-width: var(--max-width);
    margin-inline: auto;
    padding-inline: var(--gutter);
    padding-block: var(--space-m);
    border-top: 1px solid var(--color-primary-700);
}

@media (min-width: 36em) {
    .site-footer__bottom {
        flex-direction: row;
        justify-content: space-between;
        text-align: left;
    }
}

.site-footer__copy {
    font-size: var(--size-step--3);
    color: var(--color-primary-200);
}

.site-footer__credit {
    font-size: var(--size-step--3);
    color: var(--color-primary-200);
}

.site-footer__credit a {
    color: var(--color-bg);
    text-decoration: none;
    transition: color var(--transition-base);
}

.site-footer__credit a:hover {
    color: var(--color-bg);
}

/* ── Responsive ── */

@media (min-width: 36em) {
    .site-footer__columns {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (min-width: 62em) {
    .site-footer__columns {
        grid-template-columns: 1.2fr 1fr 1fr 1fr;
    }
}
