/* Footer styles scoped to .site-footer */
.site-footer { background: var(--color-bg-secondary); border-top: 1px solid var(--color-neutral-800); color: var(--color-text-secondary); }
.footer-upper { display: grid; grid-template-columns: 1.2fr 1fr; gap: var(--space-12); padding-top: var(--space-12); padding-bottom: var(--space-12); }

.footer-brand .brand-link { display: inline-flex; align-items: center; gap: var(--space-3); margin-bottom: var(--space-4); }
.footer-brand .brand-name { font-family: var(--font-heading); font-weight: var(--font-weight-extrabold); letter-spacing: 0.02em; text-transform: uppercase; color: var(--color-text-primary); }
.footer-tagline { max-width: 60ch; }
.footer-social { display: flex; gap: var(--space-4); margin-top: var(--space-4); }
.footer-social a { width: 40px; height: 40px; display: inline-flex; align-items: center; justify-content: center; border: 1px solid var(--color-neutral-800); border-radius: var(--radius-full); color: var(--color-text-primary); }
.footer-social a:hover { background: var(--color-bg-tertiary); }

.footer-links { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: var(--space-8); }
.links-title { font-size: var(--font-size-lg); color: var(--color-text-primary); margin-bottom: var(--space-4); }
.footer-links ul { display: grid; gap: var(--space-2); }
.footer-links a { color: var(--color-text-secondary); }
.footer-links a:hover { color: var(--color-text-primary); text-decoration: underline; text-underline-offset: 3px; }

.footer-lower { border-top: 1px solid var(--color-neutral-800); background: var(--color-bg-elevated); }
.footer-lower-inner { display: flex; align-items: center; justify-content: space-between; gap: var(--space-4); padding-top: var(--space-4); padding-bottom: var(--space-4); }
.footer-lower a { color: var(--color-accent-blue); }

@media (max-width: 960px) {
  .footer-upper { grid-template-columns: 1fr; }
  .footer-lower-inner { flex-direction: column; text-align: center; }
}

/* Cookie banner */
.cookie-banner { position: fixed; left: 0; right: 0; bottom: 0; z-index: var(--z-modal); padding: var(--space-4); pointer-events: none; }
.cookie-inner { max-width: 1280px; margin: 0 auto; background: var(--color-bg-elevated); border: 1px solid var(--color-neutral-800); box-shadow: var(--shadow-2xl); border-radius: var(--radius-2xl); padding: var(--space-6); display: grid; grid-template-columns: 1fr auto; gap: var(--space-6); transform: translateY(16px); opacity: 0; transition: transform var(--transition-base) var(--transition-ease), opacity var(--transition-base) var(--transition-ease); pointer-events: auto; }
.cookie-banner[data-visible="true"] .cookie-inner { transform: translateY(0); opacity: 1; }
.cookie-text h2 { font-size: var(--font-size-xl); margin-bottom: var(--space-2); }
.cookie-actions { display: flex; gap: var(--space-3); align-items: center; justify-content: flex-end; }

@media (max-width: 768px) {
  .cookie-inner { grid-template-columns: 1fr; }
  .cookie-actions { justify-content: stretch; }
  .cookie-actions .btn { width: 100%; }
}

/* Focus visibility inside banner */
.cookie-banner :focus-visible { outline: 2px solid var(--color-accent-blue); outline-offset: 4px; border-radius: var(--radius-lg); }
