.sg-consent-banner,
.sg-consent-banner *,
.sg-consent-reopen,
.sg-consent-embed,
.sg-consent-embed * {
	box-sizing: border-box;
}

.sg-alt-homepage .sg-alt-platter__footer .material-symbols-outlined {
	display: inline-grid !important;
	place-items: center !important;
	align-items: center !important;
	justify-content: center !important;
	width: 52px !important;
	height: 52px !important;
	flex: 0 0 52px !important;
	border-radius: 50% !important;
	background: rgba(255, 246, 241, 0.14);
	font-size: 1.35rem !important;
	line-height: 1 !important;
	text-align: center !important;
}

.sg-consent-banner[hidden],
.sg-consent-reopen[hidden] {
	display: none !important;
}

.sg-consent-banner {
	position: fixed;
	left: 18px;
	right: 18px;
	bottom: 18px;
	z-index: 9998;
	color: #fff7ef;
	font-family: "Be Vietnam Pro", Arial, sans-serif;
}

.sg-consent-banner__inner {
	display: grid;
	grid-template-columns: minmax(0, 1fr) auto;
	gap: 18px;
	align-items: end;
	width: min(920px, 100%);
	margin: 0 auto;
	padding: 18px;
	border: 1px solid rgba(255, 247, 239, 0.14);
	border-radius: 8px;
	background:
		linear-gradient(135deg, rgba(229, 188, 88, 0.09), transparent 36%),
		rgba(18, 11, 9, 0.94);
	box-shadow: 0 24px 80px rgba(0, 0, 0, 0.36);
	backdrop-filter: blur(14px);
}

.sg-consent-banner__copy {
	display: grid;
	gap: 8px;
}

.sg-consent-banner__kicker {
	margin: 0;
	color: #e5bc58;
	font-size: 0.72rem;
	font-weight: 800;
	letter-spacing: 0.22em;
	text-transform: uppercase;
}

.sg-consent-banner h2 {
	margin: 0;
	color: #fff7ef;
	font-family: "Noto Serif", Georgia, serif;
	font-size: 1.55rem;
	line-height: 1.1;
	letter-spacing: 0;
}

.sg-consent-banner p {
	margin: 0;
	max-width: 640px;
	color: rgba(255, 247, 239, 0.72);
	font-size: 0.92rem;
	line-height: 1.6;
}

.sg-consent-banner a {
	width: fit-content;
	color: rgba(255, 247, 239, 0.82);
	font-size: 0.78rem;
	font-weight: 800;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	text-decoration: none;
	border-bottom: 1px solid rgba(229, 188, 88, 0.62);
}

.sg-consent-banner__actions {
	display: flex;
	flex-wrap: wrap;
	justify-content: flex-end;
	gap: 10px;
}

.sg-consent-button,
.sg-consent-embed__actions button,
.sg-consent-reopen {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 44px;
	padding: 0 16px;
	border-radius: 8px;
	font-size: 0.76rem;
	font-weight: 800;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	cursor: pointer;
	transition: transform 0.18s ease, background-color 0.18s ease, border-color 0.18s ease;
}

.sg-consent-button:hover,
.sg-consent-embed__actions button:hover,
.sg-consent-reopen:hover {
	transform: translateY(-1px);
}

.sg-consent-button--quiet {
	border: 1px solid rgba(255, 247, 239, 0.18);
	background: rgba(255, 255, 255, 0.04);
	color: rgba(255, 247, 239, 0.82);
}

.sg-consent-button--primary,
.sg-consent-embed__actions button {
	border: 1px solid rgba(229, 188, 88, 0.34);
	background: linear-gradient(135deg, #c6452d, #db7340);
	color: #fff7ef;
}

.sg-consent-reopen {
	position: fixed;
	left: 18px;
	bottom: 18px;
	z-index: 9997;
	border: 1px solid rgba(255, 247, 239, 0.14);
	background: rgba(18, 11, 9, 0.88);
	color: rgba(255, 247, 239, 0.84);
	box-shadow: 0 18px 48px rgba(0, 0, 0, 0.28);
	backdrop-filter: blur(10px);
}

.sg-consent-embed {
	position: relative;
	display: grid;
	min-height: 320px;
	width: 100%;
	overflow: hidden;
	border-radius: 8px;
	background:
		linear-gradient(135deg, rgba(29, 117, 95, 0.12), transparent 38%),
		linear-gradient(180deg, rgba(17, 20, 22, 0.98), rgba(12, 14, 16, 0.98));
}

.sg-consent-embed[data-sg-consent-embed] iframe {
	display: none;
	width: 100%;
	min-height: inherit;
	height: 100%;
	border: 0;
}

.sg-consent-embed[data-sg-consent-embed].is-loaded iframe {
	display: block;
}

.sg-consent-embed.is-loaded .sg-consent-embed__notice {
	display: none;
}

.sg-consent-embed__notice {
	display: grid;
	align-content: center;
	justify-items: start;
	gap: 10px;
	min-height: inherit;
	padding: 28px;
	color: #fff7ef;
}

.sg-consent-embed__kicker {
	margin: 0;
	color: #e5bc58;
	font-size: 0.72rem;
	font-weight: 800;
	letter-spacing: 0.2em;
	text-transform: uppercase;
}

.sg-consent-embed h3 {
	margin: 0;
	font-family: "Noto Serif", Georgia, serif;
	font-size: 1.9rem;
	line-height: 1.08;
	letter-spacing: 0;
}

.sg-consent-embed p {
	margin: 0;
	max-width: 480px;
	color: rgba(255, 247, 239, 0.7);
	font-size: 0.95rem;
	line-height: 1.65;
}

.sg-consent-embed__actions {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
	margin-top: 6px;
}

.sg-consent-embed__actions a {
	display: inline-flex;
	align-items: center;
	min-height: 44px;
	padding: 0 16px;
	border: 1px solid rgba(255, 247, 239, 0.16);
	border-radius: 8px;
	color: rgba(255, 247, 239, 0.84);
	font-size: 0.76rem;
	font-weight: 800;
	letter-spacing: 0.12em;
	text-decoration: none;
	text-transform: uppercase;
	background: rgba(255, 255, 255, 0.04);
}

.sg-consent-banner button:focus-visible,
.sg-consent-reopen:focus-visible,
.sg-consent-embed button:focus-visible,
.sg-consent-embed a:focus-visible,
.sg-consent-banner a:focus-visible {
	outline: 2px solid #e5bc58;
	outline-offset: 3px;
}

@media (max-width: 760px) {
	.sg-consent-banner {
		left: 12px;
		right: 12px;
		bottom: 12px;
	}

	.sg-consent-banner__inner {
		grid-template-columns: 1fr;
		align-items: start;
	}

	.sg-consent-banner__actions {
		justify-content: stretch;
	}

	.sg-consent-button,
	.sg-consent-banner__actions {
		width: 100%;
	}
}

@media (max-width: 520px) {
	.sg-consent-embed__actions,
	.sg-consent-embed__actions a,
	.sg-consent-embed__actions button {
		width: 100%;
	}

	.sg-consent-reopen {
		left: 12px;
		bottom: 12px;
	}
}

@media (prefers-reduced-motion: reduce) {
	.sg-consent-button,
	.sg-consent-embed__actions button,
	.sg-consent-reopen {
		transition: none;
	}
}
