/* ========== COOKIE BANNER ==========
   Black surface, mustard hairline, slide-up entrance, slide-up button
   fills (same translateY(101%) → 0 pattern as .way__link / .tier__cta).
   Hidden by default; analytics.js flips .visible after a 1.8s delay so
   the loader and hero have settled.

   Loaded as <link rel="stylesheet" href="/assets/analytics.css?v=1">
   from each page after that page's inline <style> block. Uses the
   :root tokens (--black, --mustard, --cream, --sans, --display, --ease)
   defined by the page itself. */

.cookie-banner {
  position: fixed;
  left: 0; right: 0; bottom: 0;
  z-index: 300;
  background: var(--black);
  color: var(--cream);
  border-top: 1px solid var(--mustard);
  padding: 32px 32px 28px;
  transform: translateY(100%);
  transition: transform 0.6s var(--ease);
  visibility: hidden;
}
.cookie-banner.visible { transform: translateY(0); visibility: visible; }
.cookie-banner__inner {
  max-width: 1400px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 32px;
  align-items: center;
}
.cookie-banner__copy { max-width: 60ch; }
.cookie-banner__eyebrow {
  font-family: var(--sans);
  font-size: 11px;
  letter-spacing: 0.32em;
  text-transform: uppercase;
  color: var(--mustard);
  margin-bottom: 14px;
}
.cookie-banner__prompt {
  font-family: var(--display);
  font-size: clamp(20px, 2.2vw, 28px);
  font-weight: 400;
  line-height: 1.35;
  letter-spacing: -0.005em;
  color: var(--cream);
}
.cookie-banner__prompt em {
  font-style: italic;
  color: var(--mustard);
}
.cookie-banner__actions { display: flex; gap: 14px; }
.cookie-btn {
  font-family: var(--sans);
  font-size: 11px;
  letter-spacing: 0.26em;
  text-transform: uppercase;
  color: var(--cream);
  background: transparent;
  border: 1px solid var(--cream);
  padding: 14px 26px;
  cursor: pointer;
  position: relative;
  overflow: hidden;
  transition: color 0.4s var(--ease);
}
.cookie-btn::before {
  content: "";
  position: absolute; inset: 0;
  background: var(--cream);
  transform: translateY(101%);
  transition: transform 0.45s var(--ease);
  z-index: 0;
}
.cookie-btn:hover::before { transform: translateY(0); }
.cookie-btn:hover { color: var(--black); }
.cookie-btn > * { position: relative; z-index: 1; }
.cookie-btn--accept {
  background: var(--mustard);
  color: var(--black);
  border-color: var(--mustard);
}
.cookie-btn--accept::before { background: var(--cream); }
.cookie-btn--accept:hover { color: var(--black); }
@media (max-width: 600px) {
  .cookie-banner { padding: 24px 20px 22px; }
  .cookie-banner__inner { grid-template-columns: 1fr; gap: 22px; }
  .cookie-banner__actions { flex-direction: column-reverse; }
  .cookie-btn { width: 100%; text-align: center; }
}
