

.cookie-banner {
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  background-color: var(--c-dark-bg);
  color: var(--c-dark-fg);
  padding: var(--space-3);
  border-top: 1px solid var(--c-accent);
  box-shadow: 0 -4px 12px rgba(21, 33, 32, 0.15);
  z-index: 1000;
  font-family: var(--font-body);
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

.cookie-banner.hidden {
  display: none;
}

.cookie-banner__container {
  max-width: 1200px;
  margin: 0 auto;
  width: 100%;
}

.cookie-banner__content {
  display: flex;
  gap: var(--space-3);
  align-items: flex-start;
  margin-bottom: var(--space-2);
}

.cookie-banner__text {
  flex: 1;
}

.cookie-banner__title {
  font-size: 1rem;
  font-weight: 600;
  margin-bottom: var(--space-1);
  color: var(--c-dark-fg);
}

.cookie-banner__desc {
  font-size: 0.875rem;
  line-height: 1.6;
  color: var(--c-dark-muted);
  margin-bottom: var(--space-2);
}

.cookie-banner__policy-link {
  font-size: 0.875rem;
  color: var(--c-accent-2);
  text-decoration: underline;
}

.cookie-banner__policy-link:hover {
  color: var(--c-dark-fg);
}

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

.cookie-banner__btn {
  padding: var(--space-1) var(--space-3);
  border: none;
  border-radius: var(--radius-md);
  font-size: 0.875rem;
  font-weight: 600;
  cursor: pointer;
  transition: all 0.2s ease;
  font-family: var(--font-body);
}

.cookie-banner__btn--accept {
  background-color: var(--c-accent-2);
  color: var(--c-dark-fg);
}

.cookie-banner__btn--accept:hover {
  background-color: var(--c-accent);
}

.cookie-banner__btn--reject {
  background-color: transparent;
  color: var(--c-dark-fg);
  border: 1px solid var(--c-dark-muted);
}

.cookie-banner__btn--reject:hover {
  border-color: var(--c-dark-fg);
  background-color: rgba(232, 242, 238, 0.05);
}

.cookie-banner__btn--customize {
  background-color: transparent;
  color: var(--c-accent-2);
  border: 1px solid var(--c-accent-2);
}

.cookie-banner__btn--customize:hover {
  background-color: rgba(46, 140, 116, 0.1);
  border-color: var(--c-dark-fg);
  color: var(--c-dark-fg);
}

.cookie-banner__customize-panel {
  background-color: var(--c-dark-surface);
  border: 1px solid var(--c-accent);
  border-radius: var(--radius-md);
  padding: var(--space-3);
  margin-top: var(--space-2);
  display: none;
}

.cookie-banner__customize-panel.visible {
  display: block;
}

.cookie-banner__category {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  margin-bottom: var(--space-2);
  padding-bottom: var(--space-2);
  border-bottom: 1px solid var(--c-accent);
}

.cookie-banner__category:last-child {
  border-bottom: none;
  margin-bottom: 0;
  padding-bottom: 0;
}

.cookie-banner__category-label {
  display: flex;
  align-items: center;
  flex: 1;
  cursor: pointer;
  gap: var(--space-2);
}

.cookie-banner__checkbox {
  width: 18px;
  height: 18px;
  cursor: pointer;
  accent-color: var(--c-accent-2);
}

.cookie-banner__category-name {
  font-weight: 600;
  color: var(--c-dark-fg);
  font-size: 0.875rem;
}

.cookie-banner__category-desc {
  font-size: 0.75rem;
  color: var(--c-dark-muted);
  display: block;
  margin-top: var(--space-1);
}

.cookie-banner__customize-actions {
  display: flex;
  gap: var(--space-2);
  margin-top: var(--space-3);
  border-top: 1px solid var(--c-accent);
  padding-top: var(--space-3);
}

.cookie-banner__btn--save {
  background-color: var(--c-accent-2);
  color: var(--c-dark-fg);
  padding: var(--space-1) var(--space-3);
  border-radius: var(--radius-md);
  border: none;
  font-weight: 600;
  cursor: pointer;
  font-size: 0.875rem;
  font-family: var(--font-body);
  transition: all 0.2s ease;
}

.cookie-banner__btn--save:hover {
  background-color: var(--c-accent);
}

@media (max-width: 640px) {
  .cookie-banner {
    padding: var(--space-2);
  }

  .cookie-banner__content {
    flex-direction: column;
    gap: var(--space-2);
    align-items: stretch;
  }

  .cookie-banner__buttons {
    flex-direction: column;
  }

  .cookie-banner__btn {
    width: 100%;
    text-align: center;
  }

  .cookie-banner__customize-panel {
    padding: var(--space-2);
  }
}

.cookie-banner__btn--accept { color: #ffffff !important; }
.cookie-banner__btn--reject:hover { color: #111111 !important; }
.cookie-banner__btn--customize:hover { color: #ffffff !important; }
.cookie-banner__btn--save { color: #ffffff !important; }


/* wh-contrast-fix */
/* Auto-injected: text color did not meet 4.5:1 against declared background. */
.cookie-banner__btn--accept { color: #ffffff !important; }
.cookie-banner__btn--reject:hover { color: #111111 !important; }
.cookie-banner__btn--customize:hover { color: #ffffff !important; }
.cookie-banner__btn--save { color: #ffffff !important; }
