/* Complianz cookie banner — overrides plugin defaults (load after Complianz CSS). */

/* Cookie banner */
.cmplz-cookiebanner {
  --cmplz_button_accept_background_color: transparent;
  --cmplz_button_accept_border_color: var(--color-black, #0f0101);
  --cmplz_button_accept_text_color: var(--color-black, #0f0101);
  --cmplz_button_deny_background_color: transparent;
  --cmplz_button_deny_border_color: var(--color-black, #0f0101);
  --cmplz_button_deny_text_color: var(--color-black, #0f0101);
  --cmplz_button_settings_background_color: transparent;
  --cmplz_button_settings_border_color: var(--color-black, #0f0101);
  --cmplz_button_settings_text_color: var(--color-black, #0f0101);
  position: fixed !important;
  top: auto !important;
  left: auto !important;
  right: 10px !important;
  bottom: 10px !important;
  transform: none !important;
  box-sizing: border-box;
  width: min(357px, calc(100vw - 48px));
  max-width: calc(100vw - 48px);
  max-height: calc(100vh - 20px);
  margin: 0;
  padding: 20px;
  flex-direction: column;
  gap: 20px;
  grid-template-columns: unset !important;
  grid-template-rows: unset !important;
  color: var(--color-black, #0f0101);
  background: var(--color-grey, #b5ae9b);
  border: 1px solid var(--color-black, #0f0101);
  border-radius: 10px;
  box-shadow: none;
  font-family: var(--font-sans, "Space Grotesk", system-ui, sans-serif);
}

.cmplz-cookiebanner * {
  box-sizing: border-box;
}

/*
 * Complianz controls visibility with `cmplz-show` / `cmplz-no-show`. Only force
 * `display: flex` once the plugin has added `cmplz-show`, otherwise our override
 * paints the banner during the pre-JS loading state and causes a flash before
 * the proper classes (and category visibility) are applied.
 */
.cmplz-cookiebanner.cmplz-show {
  display: flex !important;
}

.cmplz-cookiebanner.cmplz-no-show,
.cmplz-cookiebanner.cmplz-dismissed,
.cmplz-cookiebanner[hidden] {
  display: none !important;
}

#cmplz-cookiebanner-container {
  pointer-events: none;
}

.cmplz-cookiebanner.cmplz-show {
  pointer-events: auto;
}

.cmplz-cookiebanner .cmplz-header {
  display: flex !important;
  align-items: flex-end;
  gap: 20px;
  width: 100%;
  padding: 0;
  grid-column: unset !important;
  grid-template-columns: unset !important;
}

.cmplz-cookiebanner .cmplz-logo,
.cmplz-cookiebanner .cmplz-divider {
  display: none;
}

.cmplz-cookiebanner .cmplz-title {
  display: block !important;
  flex: 1 1 auto;
  min-width: 0;
  margin: 0;
  grid-column: unset !important;
  justify-self: unset !important;
  color: var(--color-black, #0f0101);
  font-family: var(--font-display, "Solaris", "Space Grotesk", sans-serif);
  font-size: 22px;
  font-weight: 400;
  line-height: 26.4px;
}

.cmplz-cookiebanner .cmplz-close {
  position: relative;
  flex: 0 0 40px;
  width: 40px;
  height: 40px;
  min-width: 40px;
  margin: 0;
  padding: 0;
  color: var(--color-black, #0f0101);
  background: transparent;
  border: 1px solid currentColor;
  border-radius: 999px;
  cursor: pointer;
  pointer-events: auto;
}

.cmplz-cookiebanner .cmplz-close svg,
.cmplz-cookiebanner .cmplz-close img {
  display: none;
}

.cmplz-cookiebanner .cmplz-close::before,
.cmplz-cookiebanner .cmplz-close::after {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  width: 20px;
  height: 1px;
  background: currentColor;
  transform-origin: center;
}

.cmplz-cookiebanner .cmplz-close::before {
  transform: translate(-50%, -50%) rotate(45deg);
}

.cmplz-cookiebanner .cmplz-close::after {
  transform: translate(-50%, -50%) rotate(-45deg);
}

.cmplz-cookiebanner .cmplz-body,
.cmplz-cookiebanner .cmplz-message {
  margin: 0;
  padding: 0;
}

.cmplz-cookiebanner .cmplz-message {
  color: var(--color-black, #0f0101);
  font-family: var(--font-sans, "Space Grotesk", system-ui, sans-serif);
  font-size: 12px;
  font-weight: 400;
  line-height: 16.8px;
}

.cmplz-cookiebanner .cmplz-message p {
  margin: 0;
}

.cmplz-cookiebanner .cmplz-buttons {
  display: grid !important;
  flex-direction: unset !important;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
  width: 100%;
  margin: 0;
  padding: 0;
  grid-column: unset !important;
}

.cmplz-cookiebanner .cmplz-buttons .cmplz-btn {
  width: 100%;
  min-width: 0;
  height: 40px;
  margin: 0;
  padding: 0 20px;
  color: var(--color-black, #0f0101);
  background: transparent;
  border: 1px solid currentColor;
  border-radius: 10px;
  font-family: var(--font-mono, "Space Mono", ui-monospace, monospace);
  font-size: 12px;
  font-weight: 400;
  line-height: 14.4px;
  text-align: center;
  text-transform: uppercase;
  cursor: pointer;
  pointer-events: auto;
}

.cmplz-cookiebanner.cmplz-show .cmplz-buttons .cmplz-btn:not(.cmplz-hidden) {
  align-items: center;
  justify-content: center;
}

.cmplz-cookiebanner .cmplz-buttons .cmplz-btn.cmplz-accept,
.cmplz-cookiebanner .cmplz-buttons .cmplz-btn.cmplz-deny,
.cmplz-cookiebanner .cmplz-buttons .cmplz-btn.cmplz-view-preferences,
.cmplz-cookiebanner .cmplz-buttons .cmplz-btn.cmplz-save-preferences,
.cmplz-cookiebanner .cmplz-buttons .cmplz-btn.cmplz-manage-options {
  color: var(--color-black, #0f0101);
  background: transparent;
  border-color: var(--color-black, #0f0101);
}

.cmplz-cookiebanner .cmplz-buttons .cmplz-view-preferences,
.cmplz-cookiebanner .cmplz-buttons .cmplz-save-preferences {
  grid-column: 1 / -1;
}

.cmplz-cookiebanner .cmplz-buttons .cmplz-btn:hover,
.cmplz-cookiebanner .cmplz-buttons .cmplz-btn:focus-visible,
.cmplz-cookiebanner .cmplz-close:hover,
.cmplz-cookiebanner .cmplz-close:focus-visible {
  background: color-mix(in srgb, var(--color-black, #0f0101) 8%, transparent);
}

.cmplz-cookiebanner .cmplz-buttons .cmplz-btn:focus-visible,
.cmplz-cookiebanner .cmplz-close:focus-visible {
  outline: 2px solid currentColor;
  outline-offset: 2px;
}

.cmplz-cookiebanner .cmplz-links,
.cmplz-cookiebanner .cmplz-documents {
  margin: 0;
  color: var(--color-black, #0f0101);
  font-size: 12px;
  line-height: 16.8px;
}

.cmplz-cookiebanner .cmplz-links a,
.cmplz-cookiebanner .cmplz-documents a {
  color: currentColor;
  text-decoration: underline;
  text-underline-offset: 0.2em;
}

.cmplz-cookiebanner .cmplz-categories {
  gap: 10px;
  margin: 0;
  padding: 0;
  margin-top: 12px;
}

.cmplz-cookiebanner .cmplz-category {
  margin: 0;
  padding: 0;
  background: transparent !important;
  border: 1px solid var(--color-black, #0f0101);
  border-radius: 10px;
}

.cmplz-cookiebanner .cmplz-category-header {
  display: grid !important;
  grid-template-columns: 1fr auto 15px !important;
  padding: 12px 14px;
}

.cmplz-cookiebanner .cmplz-category-title {
  color: var(--color-black, #0f0101);
  font-family: var(--font-mono, "Space Mono", ui-monospace, monospace);
  font-size: 12px;
  font-weight: 400;
  line-height: 14.4px;
  text-transform: uppercase;
}

/* Manage consent tab */
#cmplz-manage-consent .cmplz-manage-consent {
  color: var(--color-black, #0f0101);
  background: var(--color-grey, #b5ae9b);
  border: 1px solid var(--color-black, #0f0101);
  border-radius: 10px 10px 0 0;
  font-family: var(--font-mono, "Space Mono", ui-monospace, monospace);
  font-size: 12px;
  line-height: 14.4px;
  text-transform: uppercase;
}

/* Soft cookie wall */
.cmplz-soft-cookiewall {
  background: rgb(15 1 1 / 0.72);
}

/* Placeholder button - per category/service */
.cmplz-blocked-content-container .cmplz-blocked-content-notice,
.cmplz-blocked-content-notice,
button.cmplz-accept-service {
  color: var(--color-black, #0f0101);
  background: var(--color-grey, #b5ae9b);
  border: 1px solid var(--color-black, #0f0101);
  border-radius: 10px;
  font-family: var(--font-mono, "Space Mono", ui-monospace, monospace);
  font-size: 12px;
  line-height: 14.4px;
  text-transform: uppercase;
}

/* AMP notice */
#cmplz-consent-ui,
#cmplz-post-consent-ui {
  color: var(--color-black, #0f0101);
  background: var(--color-grey, #b5ae9b);
  border: 1px solid var(--color-black, #0f0101);
  border-radius: 10px;
  font-family: var(--font-sans, "Space Grotesk", system-ui, sans-serif);
}

#cmplz-consent-ui .cmplz-consent-message {
  font-size: 12px;
  line-height: 16.8px;
}

#cmplz-consent-ui button,
#cmplz-post-consent-ui button {
  height: 40px;
  padding: 0 20px;
  color: var(--color-black, #0f0101);
  background: transparent;
  border: 1px solid currentColor;
  border-radius: 10px;
  font-family: var(--font-mono, "Space Mono", ui-monospace, monospace);
  font-size: 12px;
  line-height: 14.4px;
  text-transform: uppercase;
}

/*
 * Mobile: full-width bottom bar only. Undo Complianz @media (max-width: 425px) /
 * (max-width: 768px) layout hacks (hidden title, stacked category headers, etc.).
 */
@media (max-width: 425px) {
  .cmplz-cookiebanner {
    inset: auto 0 0 0 !important;
    top: auto !important;
    left: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    transform: none !important;
    width: 100% !important;
    max-width: none !important;
    margin: 0 !important;
    border-radius: 10px 10px 0 0;
    border-bottom: none;
    max-height: min(100dvh, 100vh);
    padding-bottom: max(20px, env(safe-area-inset-bottom, 0px));
  }

  .cmplz-cookiebanner .cmplz-header .cmplz-title,
  .cmplz-cookiebanner .cmplz-title {
    display: block !important;
  }

  .cmplz-cookiebanner .cmplz-message {
    margin-right: 0 !important;
  }

  .cmplz-cookiebanner .cmplz-category .cmplz-category-header {
    grid-template-columns: 1fr auto 15px !important;
  }

  .cmplz-cookiebanner .cmplz-links.cmplz-information {
    display: none !important;
  }

  .cmplz-cookiebanner .cmplz-buttons {
    display: grid !important;
    flex-direction: unset !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }
}

/* Plugin stacks buttons in a column ≤768px; keep our 2-col grid until the bottom bar breakpoint. */
@media (max-width: 768px) and (min-width: 426px) {
  .cmplz-cookiebanner .cmplz-buttons {
    display: grid !important;
    flex-direction: unset !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }
}