.cookie-banner {
	--background-color: var(--blue-light);
	--text-color: var(--black);
	--outline-color: var(--sw-focus-color);
	--btn-background-color: var(--sw-button-primary-bg);
	--btn-background-color-hover: var(--sw-button-primary-bg-hover);
	--btn-text-color: var(--sw-button-primary-color);
	--btn-text-color-hover: var(--sw-button-primary-color-hover);

	position: relative;
	z-index: 200001;
	bottom: var(--space-3);
	top: auto;
	right: auto;
	left: 0;
	display: block;
	margin: 0 auto;
	padding: 0;
	width: calc(100% - var(--space-3));
	min-height: 0;
	border: none;
	border-radius: var(--rounded-xl);
	box-shadow: var(--shadow-xs), var(--shadow-xl);
	background-color: var(--background-color);
	transform: none;
	transition: transform 200ms ease-in-out;
	visibility: visible;
}

.cookie-banner.dismissed {
	transform: translateY(110%);
}

@media (min-width: 64em) {
	.cookie-banner {
		position: fixed;
		left: var(--space-5);
		bottom: var(--space-5);
		width: 100%;
		max-width: var(--width-comfortable);
	}
	.cookie-banner.dismissed { transform: translateX(-110%); }
}

.cookie-banner .banner-inner {
	display: flex;
	flex-direction: column;
	justify-content: center;
	padding: var(--space-4) var(--space-6);
}

@media (min-width: 40em) {
	.cookie-banner .banner-inner { flex-direction: row; }
}

.cookie-banner .banner-message {
	padding-right: var(--space-4);
}

.cookie-banner .banner-message h1 {
	font-family: var(--font-display-system);
}

.cookie-banner .banner-message p {
	margin-bottom: var(--space-4);
	color: var(--text-color);
}

@media (min-width: 40em) {
	.cookie-banner .banner-message p {
		margin-bottom: 0;
	}
}

.cookie-banner .banner-close {
	flex-shrink: 0;
	margin: 0;
	padding: 0;
}

.cookie-banner p, .cookie-banner a {
	margin: 0;
	font-size: var(--text-base);
	line-height: var(--leading-snug);
}

.cookie-banner .button {
	position: relative;
	z-index: 1;
	display: inline-block;
	font-size: var(--text-base);
	font-weight: var(--font-weight-bold);
	line-height: var(--leading-none);
	letter-spacing: var(--tracking-site-sm);
	color: var(--sw-button-primary-color);
	text-decoration: none;
	background: var(--sw-button-primary-bg);
	padding: 5px var(--space-6);
	border: 2px solid transparent;
	border-radius: var(--rounded-full);
	transition: color var(--transition-appendix), border-color var(--transition-appendix);
}

.cookie-banner .button::before {
	content: '';
	position: absolute;
	z-index: -1;
	top: 0;
	left: 0;
	height: 100%;
	width: 100%;
	background: var(--sw-button-primary-bg-hover);
	border-radius: var(--rounded-full);
	opacity: 0;
	transition: opacity var(--transition-appendix);
	pointer-events: none;
}

@media (hover: hover) {
	.cookie-banner .button:hover {
		border-color: var(--sw-button-primary-bg-hover);
	}

	.cookie-banner .button:hover::before {
		opacity: 1;
	}
}

@media (min-width: 64em) {
	.cookie-banner .button {
		font-size: var(--text-lg);
		letter-spacing: var(--tracking-site-lg);
	}
}

.cookie-banner .button:focus-visible {
	outline: var(--outline-color) solid 1px;
	outline-offset: 2px;
}