/* Footer specific styles for OSK SIGMA ANDRZEJ SZCZECIŃSKI */

.site-footer {
	border-top: 1px solid var(--color-border-subtle);
	background:
		radial-gradient(
			circle at top left,
			rgba(76, 111, 255, 0.14),
			transparent 55%
		),
		radial-gradient(
			circle at bottom right,
			rgba(255, 20, 81, 0.16),
			transparent 55%
		),
		var(--color-background-elevated);
	margin-top: var(--space-16);
	color: var(--color-text-muted);
}

.site-footer__top {
	padding-block: var(--space-12);
}

.site-footer__brand {
	display: flex;
	align-items: center;
	gap: var(--space-3);
	margin-bottom: var(--space-8);
}

.site-footer__logo-mark {
	width: 40px;
	height: 40px;
	border-radius: 999px;
	background:
		radial-gradient(
			circle at 30% 20%,
			rgba(255, 255, 255, 0.4),
			transparent 60%
		),
		conic-gradient(
			from 200deg,
			var(--color-primary),
			var(--color-accent-purple),
			var(--color-accent-red),
			var(--color-primary)
		);
	box-shadow: var(--shadow-glow-primary);
}

.site-footer__brand-text {
	display: flex;
	flex-direction: column;
	gap: 2px;
}

.site-footer__brand-main {
	font-family: var(--font-display);
	font-size: var(--font-size-xl);
}

.site-footer__brand-sub {
	font-size: var(--font-size-xs);
	text-transform: uppercase;
	letter-spacing: 0.16em;
	color: var(--color-text-soft);
}

.site-footer__grid {
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: var(--space-8);
}

.site-footer__heading {
	font-size: var(--font-size-sm);
	text-transform: uppercase;
	letter-spacing: 0.18em;
	color: var(--color-silver);
	margin-bottom: var(--space-3);
}

.site-footer__links {
	list-style: none;
	display: flex;
	flex-direction: column;
	gap: var(--space-2);
}

.site-footer__links a {
	font-size: var(--font-size-sm);
	color: var(--color-text-muted);
}

.site-footer__links a:hover,
.site-footer__links a:focus-visible {
	color: var(--color-text);
}

.site-footer__text {
	font-size: var(--font-size-sm);
	color: var(--color-text-soft);
	margin-bottom: var(--space-3);
}

.site-footer__social {
	display: flex;
	align-items: center;
	gap: var(--space-3);
}

.site-footer__social a {
	width: 32px;
	height: 32px;
	border-radius: 999px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	border: 1px solid rgba(255, 255, 255, 0.16);
	background: rgba(10, 10, 20, 0.9);
	color: var(--color-silver);
	font-size: 0.875rem;
	transition:
		background var(--transition-normal),
		color var(--transition-normal),
		transform var(--transition-fast),
		box-shadow var(--transition-normal);
}

.site-footer__social a:hover,
.site-footer__social a:focus-visible {
	background: linear-gradient(
		135deg,
		var(--color-primary),
		var(--color-accent-purple)
	);
	color: #050509;
	box-shadow: var(--shadow-soft);
	transform: translateY(-1px);
}

.site-footer__bottom {
	border-top: 1px solid var(--color-border-subtle);
	background: rgba(5, 5, 10, 0.96);
}

.site-footer__bottom-inner {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: space-between;
	gap: var(--space-3);
	padding-block: var(--space-4);
}

.site-footer__copyright {
	font-size: var(--font-size-xs);
	color: var(--color-text-soft);
}

.site-footer__meta {
	font-size: var(--font-size-xs);
	color: var(--color-text-soft);
}

@media (max-width: 960px) {
	.site-footer__grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}

@media (max-width: 640px) {
	.site-footer__grid {
		grid-template-columns: minmax(0, 1fr);
	}

	.site-footer__bottom-inner {
		flex-direction: column;
		align-items: flex-start;
	}
}

/* Cookie banner */

.cookie-banner {
	position: fixed;
	inset-inline: 0;
	bottom: 0;
	z-index: 50;
	transform: translateY(100%);
	opacity: 0;
	pointer-events: none;
	transition:
		transform var(--transition-slow),
		opacity var(--transition-slow);
}

.cookie-banner.is-visible {
	transform: translateY(0);
	opacity: 1;
	pointer-events: auto;
}

.cookie-banner.is-hidden {
	transform: translateY(100%);
	opacity: 0;
	pointer-events: none;
}

.cookie-banner__inner {
	max-width: var(--container-wide-max-width);
	margin-inline: auto;
	margin-bottom: var(--space-4);
	border-radius: var(--radius-xl);
	border: 1px solid rgba(255, 255, 255, 0.16);
	padding: var(--space-4) var(--space-5);
	background:
		radial-gradient(
			circle at top left,
			rgba(76, 111, 255, 0.2),
			transparent 55%
		),
		radial-gradient(
			circle at bottom right,
			rgba(255, 20, 81, 0.18),
			transparent 55%
		),
		rgba(5, 5, 10, 0.98);
	box-shadow: var(--shadow-strong);
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: var(--space-5);
}

.cookie-banner__text {
	flex: 1 1 60%;
}

.cookie-banner__title {
	font-size: var(--font-size-md);
	margin-bottom: var(--space-2);
}

.cookie-banner__desc {
	font-size: var(--font-size-sm);
	color: var(--color-text-muted);
	margin-bottom: var(--space-2);
}

.cookie-banner__link {
	background: none;
	border: none;
	padding: 0;
	font-size: var(--font-size-xs);
	color: var(--color-primary);
	text-decoration: underline;
	text-underline-offset: 0.12em;
	cursor: pointer;
}

.cookie-banner__actions {
	flex: 0 0 auto;
	display: flex;
	flex-direction: column;
	gap: var(--space-2);
}

.cookie-banner__btn {
	width: 100%;
	white-space: nowrap;
}

@media (max-width: 768px) {
	.cookie-banner__inner {
		margin-inline: var(--space-4);
		padding: var(--space-4);
		flex-direction: column;
		align-items: stretch;
	}

	.cookie-banner__actions {
		flex-direction: column-reverse;
	}
}

@media (max-width: 480px) {
	.cookie-banner__inner {
		margin-inline: var(--space-3);
	}
}
