/* --- PERFORMANCE-FIRST FOOTER --- */
.footer-glass {
    /* Solid background from your File 1 variables */
    background: var(--header-accent) !important;
    border-top: 1px solid var(--glass-border);
    color: var(--text);
    padding: 2rem 0;
    /* Layer promotion to keep footer sticky/scroll smooth */
    transform: translateZ(0);
}

.footer-logo {
    filter: none; 
    transition: transform 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    will-change: transform;
}

.footer-logo:hover {
    transform: scale(1.05);
}

.provider-logo, .developer-logo {
    max-width: 100px;
    height: auto;
    object-fit: contain;
    opacity: 0.8;
    transition: opacity 0.3s ease, transform 0.3s ease;
    will-change: transform, opacity;
}

.provider-logo:hover, .developer-logo:hover {
    opacity: 1;
    /* Uses GPU instead of CPU-heavy filters */
    transform: translate3d(0, -2px, 0); 
}

body.dark-mode .developer-logo {
    filter: brightness(0.9);
}

.notice-text {
    font-size: 0.75rem;
    line-height: 1.6;
    color: var(--dim);
    margin: 0;
}

.footer-links a {
    color: var(--blue);
    text-decoration: none;
    font-size: 0.9rem;
    margin-left: 15px;
    transition: color 0.2s ease;
}

.footer-links a:hover {
    color: var(--blue-2);
    text-decoration: underline;
}

/* Tiny labels for Powered By / Built By */
.label-tiny {
    text-transform: uppercase;
    font-weight: 800;
    font-size: 0.55rem;
    color: var(--dim);
    letter-spacing: 0.5px;
    margin-bottom: 2px;
}

/* Solid Performance Divider */
.shadow-vr {
    height: 35px;
    width: 1px;
    background-color: var(--dim);
    opacity: 0.2;
    display: inline-block;
    vertical-align: middle;
}

/* Responsiveness & Layout Fixes */
@media (max-width: 991px) {
    .footer-logo { margin-bottom: 5px; }
    .shadow-vr { height: 25px; }
}

@media (max-width: 767px) {
    /* Hide specific vertical rules on mobile to prevent horizontal overflow */
    .vr, .shadow-vr { display: none; }
    .footer-links a { margin: 0 10px; }
}