/* Footer styles (builds on base.css) */
.site-footer { border-top: 1px solid var(--divider-color); background: var(--color-surface); color: var(--color-text); }
.footer__grid { display: grid; grid-template-columns: repeat(12, 1fr); gap: var(--space-24); padding-block: var(--space-32); }

.footer__brand { grid-column: span 5; display: grid; gap: var(--space-16); }
.footer__logo { display: inline-flex; align-items: center; gap: var(--space-12); color: var(--color-text); text-decoration: none; }
.footer__name { font-family: var(--font-display); font-weight: 800; letter-spacing: 0.08em; text-transform: uppercase; font-size: 22px; background: linear-gradient(180deg, var(--color-primary), var(--color-accent)); -webkit-background-clip: text; background-clip: text; color: transparent; }
.footer__tagline { max-width: 56ch; color: var(--color-text-muted); }
.footer__social { display: flex; gap: var(--space-12); }
.footer__social-link { display: inline-flex; align-items: center; justify-content: center; width: 40px; height: 40px; border: 1px solid var(--divider-color); border-radius: var(--radius-md); color: var(--gray-100); background: var(--color-elevated); box-shadow: var(--shadow-sm); transition: transform var(--duration-fast) var(--ease-standard), color var(--duration-normal) var(--ease-standard), border-color var(--duration-normal) var(--ease-standard); }
.footer__social-link:hover { transform: translateY(-1px); color: var(--color-accent); border-color: color-mix(in oklab, var(--color-primary) 50%, var(--divider-color)); }

.footer__links { grid-column: span 4; }
.links__grid { display: grid; grid-template-columns: repeat(2, minmax(140px, 1fr)); gap: var(--space-8) var(--space-24); list-style: none; margin: 0; padding: 0; }
.links__grid a { color: var(--color-text); text-decoration: none; }
.links__grid a:hover { color: var(--color-accent); }
.links__grid a:focus-visible { outline: 2px solid var(--color-focus); outline-offset: 2px; border-radius: 2px; }

.footer__cta { grid-column: span 3; display: grid; gap: var(--space-12); align-content: start; }
.footer__cta-title { font-size: var(--fs-2xl); text-transform: uppercase; letter-spacing: 0.06em; }
.footer__cta-text { color: var(--color-text-muted); }

.footer__bottom { border-top: 1px solid var(--divider-color); background: var(--color-elevated); }
.footer__bottom-inner { display: flex; align-items: center; justify-content: space-between; gap: var(--space-16); padding-block: var(--space-16); }
.footer__copy { font-size: var(--fs-sm); }
.footer__legal { font-size: var(--fs-sm); }

@media (max-width: 980px) {
  .footer__grid { grid-template-columns: 1fr; }
  .footer__brand, .footer__links, .footer__cta { grid-column: span 12; }
  .footer__bottom-inner { flex-direction: column; align-items: flex-start; }
}

/* Cookie consent banner */
.cookie-consent { position: fixed; inset: auto 0 0 0; z-index: 1100; background: color-mix(in oklab, var(--color-elevated) 95%, black); border-top: 1px solid var(--divider-color); box-shadow: var(--shadow-lg); transform: translateY(100%); opacity: 0; visibility: hidden; transition: transform var(--duration-slow) var(--ease-standard), opacity var(--duration-slow) var(--ease-standard), visibility var(--duration-slow) step-end; }
.cookie-consent.is-visible { transform: translateY(0); opacity: 1; visibility: visible; transition: transform var(--duration-slow) var(--ease-standard), opacity var(--duration-slow) var(--ease-standard), visibility 0s step-start; }
.cookie-consent.is-hiding { transform: translateY(100%); opacity: 0; visibility: hidden; }
.cookie-consent__inner { display: flex; align-items: flex-start; justify-content: space-between; gap: var(--space-24); padding-block: var(--space-16); }
.cookie-consent__content { max-width: 72ch; }
.cookie-consent__title { font-size: var(--fs-xl); margin: 0; }
.cookie-consent__text { color: var(--color-text-muted); margin: 6px 0 0; }
.cookie-consent__text a { color: var(--color-accent); }
.cookie-consent__actions { display: flex; gap: var(--space-12); flex-wrap: wrap; }
.cookie-btn { min-width: 160px; }

@media (max-width: 720px) {
  .cookie-consent__inner { flex-direction: column; align-items: stretch; }
  .cookie-btn { width: 100%; }
}
