/* Footer component styles (builds on base.css) */
.site-footer {
  margin-top: var(--space-48);
  background: linear-gradient(180deg, rgba(31, 228, 228, 0.02), rgba(255, 209, 102, 0.02)), var(--color-surface);
  border-top: 1px solid var(--color-border);
}

.footer-grid {
  display: grid;
  grid-template-columns: 1.2fr 2fr;
  gap: var(--space-24);
  padding-block: var(--space-40);
}
.footer-brand .brand-link { display: inline-flex; align-items: center; gap: 12px; color: var(--gray-50); margin-bottom: var(--space-12); }
.footer-brand .brand-logo { width: 40px; height: 40px; border-radius: 10px; box-shadow: var(--shadow-glow-gold); }
.footer-brand .brand-text { font-family: var(--font-display); font-weight: 800; letter-spacing: 0.04em; text-transform: uppercase; }

.footer-nav { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: var(--space-24); }
.links-title { font-size: var(--text-lg); color: var(--gray-100); margin-bottom: var(--space-12); }
.links-list { display: grid; gap: 8px; }
.links-list a { color: var(--gray-200); }
.links-list a:hover { color: var(--color-text); text-decoration: underline; text-underline-offset: 2px; }
.links-list a:focus-visible { outline: 2px solid var(--color-primary); outline-offset: 2px; }

.footer-bottom { display: flex; align-items: center; justify-content: space-between; padding-block: var(--space-16); border-top: 1px solid var(--color-border); color: var(--gray-400); }

@media (max-width: 900px) {
  .footer-grid { grid-template-columns: 1fr; }
  .footer-nav { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 600px) {
  .footer-nav { grid-template-columns: 1fr; }
}

/* Cookie banner */
.cookie-banner {
  position: fixed;
  left: 0; right: 0; bottom: 0;
  z-index: 1100;
  background: linear-gradient(180deg, rgba(31, 228, 228, 0.06), rgba(0,0,0,0.6)), var(--color-elevated);
  border-top: 1px solid var(--color-border);
  transform: translateY(100%);
  opacity: 0;
  transition: transform var(--duration-slow) var(--ease-emphasized), opacity var(--duration-slow) var(--ease-emphasized);
  padding-bottom: max(env(safe-area-inset-bottom), 0px);
}
.cookie-banner.is-visible { transform: translateY(0); opacity: 1; }
.cookie-banner.is-hiding { transform: translateY(100%); opacity: 0; }

.cookie-inner { display: flex; gap: var(--space-24); align-items: flex-start; padding-block: var(--space-16); }
.cookie-text h2 { margin: 0 0 6px 0; font-size: var(--text-xl); }
.cookie-text p { margin: 0; color: var(--gray-200); }
.cookie-text a { color: var(--color-gold); text-decoration: underline; text-underline-offset: 2px; }
.cookie-actions { margin-left: auto; display: inline-flex; gap: var(--space-12); }

@media (max-width: 720px) {
  .cookie-inner { flex-direction: column; align-items: stretch; }
  .cookie-actions { margin-left: 0; justify-content: flex-start; }
}
