/* Bloqio — cookie consent banner (pairs with scripts/cookie-consent.js) */

.cookie-banner {
  position: fixed;
  inset-inline: var(--space-4);
  bottom: var(--space-4);
  z-index: 100;
  box-sizing: border-box;
  max-width: 36rem;
  margin-inline: auto;
  padding: var(--space-4);
  border-radius: 1.25rem;
  border: 1px solid color-mix(in srgb, var(--bhf-glass-border) 42%, #fff 58%);
  background:
    linear-gradient(
      168deg,
      rgba(255, 255, 255, 0.96) 0%,
      rgba(255, 255, 255, 0.88) 100%
    );
  backdrop-filter: blur(28px) saturate(1.12);
  -webkit-backdrop-filter: blur(28px) saturate(1.12);
  box-shadow:
    0 24px 64px rgba(17, 24, 39, 0.14),
    0 8px 20px rgba(17, 24, 39, 0.08),
    inset 0 1px 0 rgba(255, 255, 255, 0.95);
  transform: translateY(110%);
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition:
    transform var(--holo-motion-duration-fast) var(--holo-motion-ease),
    opacity var(--holo-motion-duration-fast) var(--holo-motion-ease),
    visibility 0s linear var(--holo-motion-duration-fast);
}

.cookie-banner.is-visible {
  transform: translateY(0);
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  transition:
    transform var(--holo-motion-duration-fast) var(--holo-motion-ease),
    opacity var(--holo-motion-duration-fast) var(--holo-motion-ease),
    visibility 0s;
}

.cookie-banner__title {
  margin: 0 0 var(--space-2);
  font-size: var(--text-base);
  font-weight: 700;
  line-height: var(--leading-snug);
  color: var(--color-text);
}

.cookie-banner__text {
  margin: 0 0 var(--space-4);
  font-size: var(--text-sm);
  line-height: var(--leading-relaxed);
  color: var(--color-text-muted);
}

.cookie-banner__text a {
  color: var(--color-identity);
  text-decoration: underline;
  text-underline-offset: 0.15em;
}

.cookie-banner__actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
}

.cookie-banner__actions .button {
  flex: 1 1 auto;
  min-width: min(100%, 9rem);
  font-size: var(--text-xs);
  padding: var(--space-2) var(--space-3);
}

.cookie-banner__actions .button--secondary {
  flex: 1 1 auto;
}

@media (min-width: 40rem) {
  .cookie-banner {
    inset-inline: auto;
    right: var(--space-5);
    left: auto;
    margin-inline: 0;
  }

  .cookie-banner__actions .button {
    flex: 0 1 auto;
    min-width: 0;
  }
}

@media (prefers-reduced-motion: reduce) {
  .cookie-banner,
  .cookie-banner.is-visible {
    transform: none;
    transition: opacity var(--holo-motion-duration-fast) var(--holo-motion-ease);
  }
}
