.consent-banner[hidden] {
  display: none;
}

.consent-banner {
  position: fixed;
  inset: auto clamp(1rem, 3vw, 2rem) clamp(1rem, 3vw, 2rem);
  z-index: 1000;
  display: flex;
  justify-content: center;
  pointer-events: none;
}

.consent-banner__panel {
  width: min(980px, 100%);
  padding: clamp(1rem, 2vw, 1.35rem);
  border: 1px solid var(--line, #d9e1ea);
  background: rgba(255, 255, 255, .98);
  box-shadow: 0 22px 70px rgba(12, 42, 69, .18);
  color: var(--ink, #0c2a45);
  pointer-events: auto;
}

.consent-banner__copy {
  max-width: 760px;
}

.consent-banner__eyebrow {
  margin: 0 0 .35rem;
  color: var(--muted, #5f7186);
  font-size: .72rem;
  font-weight: 900;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.consent-banner h2 {
  margin: 0 0 .45rem;
  font-size: clamp(1.15rem, 2vw, 1.45rem);
  line-height: 1.15;
}

.consent-banner p {
  margin: 0;
  color: var(--muted, #5f7186);
  font-size: .95rem;
}

.consent-banner a {
  color: var(--ink, #0c2a45);
  font-weight: 800;
  text-decoration-color: var(--red, #d50b2f);
  text-underline-offset: .18em;
}

.consent-banner__settings {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: .75rem;
  margin-top: 1rem;
}

.consent-banner__settings[hidden] {
  display: none;
}

.consent-option {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: .7rem;
  min-height: 100%;
  padding: .85rem;
  border: 1px solid var(--line, #d9e1ea);
  background: var(--paper, #f3f6f9);
}

.consent-option input {
  width: 1.05rem;
  height: 1.05rem;
  margin: .15rem 0 0;
  accent-color: var(--red, #d50b2f);
}

.consent-option strong,
.consent-option small {
  display: block;
}

.consent-option strong {
  margin-bottom: .25rem;
  font-size: .9rem;
}

.consent-option small {
  color: var(--muted, #5f7186);
  font-size: .78rem;
  line-height: 1.45;
}

.consent-option--disabled {
  color: var(--muted, #5f7186);
}

.consent-banner__actions {
  display: flex;
  justify-content: flex-end;
  gap: .55rem;
  margin-top: 1rem;
  flex-wrap: wrap;
}

.consent-button,
.footer-cookie-link {
  font: inherit;
}

.consent-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 44px;
  padding: .72rem 1rem;
  border: 1px solid var(--line, #d9e1ea);
  border-radius: 0;
  background: #fff;
  color: var(--ink, #0c2a45);
  cursor: pointer;
  font-weight: 850;
  text-align: center;
}

.consent-button:hover,
.consent-button:focus-visible {
  border-color: var(--ink, #0c2a45);
}

.consent-button--primary {
  border-color: var(--red, #d50b2f);
  background: var(--red, #d50b2f);
  color: #fff;
}

.consent-button--primary:hover,
.consent-button--primary:focus-visible {
  border-color: var(--red-dark, #b90728);
  background: var(--red-dark, #b90728);
}

.footer-cookie-link {
  margin: .4rem 0 0;
  padding: 0;
  border: 0;
  background: transparent;
  color: inherit;
  cursor: pointer;
  font-weight: 800;
  text-decoration: underline;
  text-decoration-color: var(--red, #d50b2f);
  text-underline-offset: .18em;
}

.footer-cookie-link:hover,
.footer-cookie-link:focus-visible {
  color: var(--red, #d50b2f);
}

@media (max-width: 720px) {
  .consent-banner {
    inset: auto 0 0;
  }

  .consent-banner__panel {
    width: 100%;
    max-height: min(88vh, 720px);
    overflow: auto;
    border-right: 0;
    border-bottom: 0;
    border-left: 0;
  }

  .consent-banner__settings {
    grid-template-columns: 1fr;
  }

  .consent-banner__actions {
    display: grid;
    grid-template-columns: 1fr;
  }

  .consent-button {
    width: 100%;
  }
}
