.site-footer {
    background-color: var(--color-bg-dark);
    color: var(--color-text-light);
    padding: var(--space-2xl) 0 var(--space-lg);
    position: relative;
    overflow: hidden;
}

.footer__grid {
    display: grid;
    grid-template-columns: 1.2fr 1fr 0.8fr;
    gap: var(--space-2xl);
    margin-bottom: var(--space-2xl);
}

.footer__logo {
    height: 50px;
    width: auto;
    margin-bottom: var(--space-md);
}

.footer__text {
    color: var(--color-text-muted);
    font-size: var(--text-sm);
    margin-bottom: var(--space-xs);
}

.footer__address {
    color: var(--color-text-muted);
    font-size: var(--text-sm);
}

.footer__heading {
    font-size: var(--text-xl);
    font-weight: var(--font-weight-semibold);
    margin-bottom: var(--space-md);
    color: var(--color-accent);
}

.footer__social {
    display: flex;
    flex-direction: column;
    gap: var(--space-sm);
}

.footer__social-link {
    display: flex;
    align-items: center;
    gap: var(--space-xs);
    color: var(--color-text-muted);
    font-size: var(--text-sm);
    transition: color var(--transition-base), transform var(--transition-base);
}

.footer__social-link:hover {
    color: var(--color-accent);
    transform: translateX(5px);
}

.footer__nav li {
    margin-bottom: var(--space-xs);
}

.footer__nav a {
    color: var(--color-text-muted);
    font-size: var(--text-sm);
    transition: color var(--transition-base), padding-left var(--transition-base);
}

.footer__nav a:hover {
    color: var(--color-accent);
    padding-left: 5px;
}

.footer__bottom {
    border-top: 1px solid var(--color-border);
    padding-top: var(--space-md);
    text-align: center;
}

.footer__bottom p {
    color: var(--color-text-muted);
    font-size: var(--text-sm);
    margin: 0;
}

/* Mascot peeking in footer */
.footer__mascot {
    position: absolute;
    bottom: 0;
    right: -20px;
    height: 120px;
    width: auto;
    opacity: 0.3;
    transform: rotate(-10deg);
    pointer-events: none;
}

@media (max-width: 768px) {
    .footer__grid {
        grid-template-columns: 1fr;
        gap: var(--space-xl);
        text-align: center;
    }

    .footer__social {
        align-items: center;
    }

    .footer__mascot {
        display: none;
    }
}
