.cookie-banner {
  position: fixed;
  bottom: var(--s-4);
  left: var(--s-4);
  right: var(--s-4);
  z-index: var(--z-overlay);
  max-width: 720px;
  margin: 0 auto;
  background: var(--bg-2);
  border: 1px solid var(--line-strong);
  border-radius: var(--r-lg);
  box-shadow: var(--sh-raised);
  padding: var(--s-5);
  display: flex;
  align-items: center;
  gap: var(--s-5);
  transform: translateY(calc(100% + 20px));
  transition: transform var(--d-slow) var(--ease-spring);
}

.cookie-banner.is-open { transform: none; }

.cookie-banner__icon {
  flex-shrink: 0;
  width: 44px; height: 44px;
  border-radius: 50%;
  background: var(--accent);
  color: var(--ink-on-accent);
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.cookie-banner__body { flex: 1; min-width: 0; }

.cookie-banner__title {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: var(--t-md);
  text-transform: uppercase;
  letter-spacing: var(--tr-snug);
  margin-bottom: 4px;
}

.cookie-banner__text {
  font-size: var(--t-xs);
  color: var(--ink-2);
  line-height: var(--lh-loose);
}

.cookie-banner__text a { color: var(--accent); text-decoration: underline; text-underline-offset: 2px; }

.cookie-banner__actions {
  display: flex;
  gap: var(--s-2);
  flex-shrink: 0;
}

@media (max-width: 720px) {
  .cookie-banner { flex-direction: column; align-items: stretch; gap: var(--s-3); padding: var(--s-4); }
  .cookie-banner__actions { flex-direction: row; justify-content: flex-end; flex-wrap: wrap; }
}

.cookie-prefs__row {
  display: flex; align-items: center; justify-content: space-between;
  padding: var(--s-3) 0;
  border-bottom: 1px solid var(--line-soft);
  gap: var(--s-3);
}

.cookie-prefs__row:last-child { border-bottom: 0; }

.cookie-prefs__name {
  font-weight: 600;
  color: var(--ink-1);
  font-size: var(--t-sm);
}

.cookie-prefs__desc {
  font-size: var(--t-xs);
  color: var(--ink-3);
  line-height: var(--lh-base);
  margin-top: 2px;
  max-width: 320px;
}

.cookie-prefs__locked {
  font-size: var(--t-xs);
  color: var(--ink-3);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: var(--tr-wide);
}
