/**
 * Footer — index.tsx
 */

.site-footer {
	margin-top: auto;
	overflow-x: clip;
	background: var(--wc-color-bg-dark);
	color: var(--wc-color-text-inverse);
}

/* Bündig mit .site-header: Inhaltsbreite = --wc-container-max,
 * Padding kommt ZUSÄTZLICH dazu (Header: Padding außen, Bar innen zentriert).
 * Daher hier max-width um das Padding erweitern — sonst ist der
 * Footer-Inhalt auf breiten Screens um 2× Padding schmaler als der Header. */
.site-footer__main,
.site-footer__bar {
	width: 100%;
	max-width: calc(var(--wc-container-max) + 2 * var(--wc-section-padding-x));
	margin-inline: auto;
	padding-inline: var(--wc-section-padding-x);
	box-sizing: border-box;
}

.site-footer__bar {
	padding-block: 4rem 0;
}

.site-footer__inner {
	max-width: var(--wc-container-max);
}

.site-footer__grid {
	display: grid;
	gap: var(--wc-gap-section);
	margin-bottom: var(--wc-gap-section);
	align-items: start;
}

.site-footer__grid--cols-3 {
	grid-template-columns: minmax(0, 1.15fr) minmax(0, 1fr) minmax(0, 1fr);
}

.site-footer__grid--cols-4 {
	grid-template-columns: minmax(0, 1.15fr) minmax(0, 1fr) minmax(0, 1fr) minmax(0, 1fr);
}

.site-footer__col--address {
	justify-self: start;
	text-align: left;
}

.site-footer__col--contact {
	justify-self: start;
	text-align: left;
}

.site-footer__col--menu {
	justify-self: start;
	text-align: left;
}

.site-footer__col--legal {
	justify-self: end;
	text-align: right;
}

.site-footer__menu {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	align-items: flex-end;
	gap: 0.5rem;
}

.site-footer__menu a {
	color: var(--wc-color-gray-400);
	text-decoration: none;
	font-size: var(--wc-font-size-sm);
	line-height: var(--wc-line-height-normal);
	transition: color var(--wc-transition);
}

.site-footer__menu a:hover,
.site-footer__menu a:focus {
	color: var(--wc-color-text-inverse);
}

.site-footer__text {
	margin: 0;
	font-family: var(--wc-font-body);
	font-size: var(--wc-font-size-sm);
	line-height: var(--wc-line-height-normal);
	color: var(--wc-color-gray-400);
}

.site-footer__col--contact a,
.site-footer__menu--legal a {
	color: var(--wc-color-gray-400);
	text-decoration: none;
	font-size: var(--wc-font-size-sm);
	line-height: var(--wc-line-height-normal);
	transition: color var(--wc-transition);
}

.site-footer__col--contact a:hover,
.site-footer__menu--legal a:hover {
	color: var(--wc-color-text-inverse);
}

.site-footer__copyright {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: space-between;
	gap: 1rem 2rem;
	border-top: 1px solid rgba(255, 255, 255, 0.12);
	padding: 2rem 0;
}

.site-footer__copy,
.site-footer__made {
	margin: 0;
	font-size: var(--wc-font-size-sm);
	color: var(--wc-color-gray-400);
}

.site-footer__made {
	display: inline-flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: flex-end;
	gap: 0.35rem;
}

.site-footer__heart {
	display: inline-flex;
	align-items: center;
	line-height: 1;
}

.site-footer__heart-icon {
	display: block;
	color: var(--wc-color-brand);
}

.site-footer__made-link {
	color: var(--wc-color-gray-400);
	text-decoration: none;
	transition: color var(--wc-transition);
}

.site-footer__made-link:hover,
.site-footer__made-link:focus {
	color: var(--wc-color-brand);
}

.site-footer__made-name {
	color: var(--wc-color-gray-400);
}

.site-footer__watermark {
	--watermark-ch-ratio: 0.64;
	--watermark-track: min(100vw - 2 * var(--wc-section-padding-x), var(--wc-container-max));
	position: relative;
	display: flex;
	justify-content: center;
	width: 100%;
	padding: clamp(1.5rem, 4vw, 2.5rem) var(--wc-section-padding-x);
	box-sizing: border-box;
	background: var(--wc-color-bg-darker);
}

.site-footer__watermark-text {
	margin: 0;
	width: 100%;
	max-width: var(--wc-container-max);
	box-sizing: border-box;
	font-family: var(--wc-font-heading);
	/* Gleiche Breite wie Footer-Inhalt — nicht volle Viewport-Breite */
	font-size: clamp(
		2.75rem,
		calc(var(--watermark-track) / (var(--watermark-chars, 7) * var(--watermark-ch-ratio))),
		20rem
	);
	font-weight: var(--wc-font-weight-bold);
	line-height: 0.95;
	letter-spacing: -0.02em;
	text-align: center;
	text-transform: uppercase;
	color: #e7e1e11c;
	user-select: none;
	white-space: nowrap;
}

/* —— Variante 1: Edge-to-Edge ——
 * Text sitzt direkt auf der Unterkante der Seite und wirkt,
 * als würde er aus dem Seitenende herauswachsen. */
.site-footer__watermark--edge {
	padding-bottom: 0;
	overflow: hidden;
}

.site-footer__watermark--edge .site-footer__watermark-text {
	/* Descent-Raum der Schrift unter der Baseline aus der Kante schieben —
	 * Großbuchstaben bleiben voll lesbar, kein horizontaler Overflow */
	margin-bottom: -0.22em;
}

/* —— Variante 2: Vertikaler Verlauf ——
 * Position unverändert; Deckkraft läuft von 100 % (oben)
 * auf 10 % (unten) der Watermark-Farbe aus. */
.site-footer__watermark--fade .site-footer__watermark-text {
	-webkit-mask-image: linear-gradient(to bottom, rgb(0 0 0 / 100%) 0%, rgb(0 0 0 / 10%) 100%);
	mask-image: linear-gradient(to bottom, rgb(0 0 0 / 100%) 0%, rgb(0 0 0 / 10%) 100%);
}

/* Desktop — gleiche rechte Spalte wie Header-Navigation */
@media (min-width: 1024px) {
	.site-footer__grid--cols-3 {
		grid-template-columns: minmax(0, 1.15fr) minmax(0, 1fr) var(--wc-nav-slot-width);
	}

	.site-footer__grid--cols-4 {
		grid-template-columns: minmax(0, 1fr) minmax(0, 1fr) minmax(0, 1fr) var(--wc-nav-slot-width);
	}

	.site-footer__col--legal {
		justify-self: end;
		text-align: right;
	}

	.site-footer__copyright {
		display: grid;
		grid-template-columns: minmax(0, 1fr) var(--wc-nav-slot-width);
		align-items: center;
		justify-content: stretch;
	}

	.site-footer__copy {
		grid-column: 1;
	}

	.site-footer__made {
		grid-column: 2;
		justify-self: end;
		width: 100%;
	}
}

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

	.site-footer__col--legal {
		justify-self: start;
		text-align: left;
	}

}

/* Mobil: Adresse + Kontakt nebeneinander (je 50 %),
 * weitere Spalten volle Breite darunter, alles linksbündig */
@media (max-width: 768px) {
	.site-footer__bar {
		padding-block: var(--wc-gap-section) 0;
	}

	.site-footer__grid,
	.site-footer__grid--cols-3,
	.site-footer__grid--cols-4 {
		grid-template-columns: repeat(2, minmax(0, 1fr));
		gap: var(--wc-gap-cards-lg) var(--wc-gap-cards);
	}

	.site-footer__col--address,
	.site-footer__col--contact,
	.site-footer__col--menu,
	.site-footer__col--legal {
		justify-self: stretch;
		text-align: left;
	}

	.site-footer__col--address {
		grid-column: 1;
		grid-row: 1;
	}

	.site-footer__col--contact {
		grid-column: 2;
		grid-row: 1;
		text-align: right;
	}

	.site-footer__col--menu,
	.site-footer__col--legal {
		grid-column: 1 / -1;
	}

	/* Linklisten linksbündig statt rechtsbündig */
	.site-footer__menu {
		align-items: flex-start;
	}

	.site-footer__copyright {
		flex-direction: column;
		align-items: flex-start;
		text-align: left;
	}

	.site-footer__made {
		align-self: flex-start;
		justify-content: flex-start;
	}
}
