@font-face {
	font-family: 'Raleway';
	src: url('../assets/fonts/raleway-regular-webfont.woff2') format('woff2'),
		url('../assets/fonts/raleway-regular-webfont.woff') format('woff');
	font-weight: 400;
	font-style: normal;
}

@font-face {
	font-family: 'Raleway';
	src: url('../assets/fonts/raleway-bold-webfont.woff2') format('woff2'),
		url('../assets/fonts/raleway-bold-webfont.woff') format('woff');
	font-weight: 700;
	font-style: normal;
}

:root {
	--base-font-size: 16px;
	--line-height: 1.6;
	--color-primary: #000;
	--color-secondary: #333;
	--color-text: #333;
	--color-accent: #d44d88;
	--color-links: #333;
	--color-links-hover: #d44d88;

	--border-radius: 1rem;

	/* =========================
       Spacing Scale
       ========================= */

	--s-0: 0;
	--s-1: 0.25rem;
	--s-2: 0.5rem;
	--s-3: 1rem;
	--s-4: 1.5rem;
	--s-5: 3rem;
	--s-6: 5rem;
}

*,
*::before,
*::after {
	box-sizing: border-box;
	margin: 0;
	padding: 0;
}

html {
	scroll-behavior: smooth;
	font-size: var(--base-font-size);
	height: 100%;
}

body {
	font-family: 'Raleway', sans-serif;
	color: var(--color-secondary);
	line-height: var(--line-height);
	background-color: #333;
	height: 100%;
	min-height: 100vh;
	min-height: 100dvh;
}

/* =========================
   Margin
========================= */

.m-0 {
	margin: var(--s-0);
}
.m-1 {
	margin: var(--s-1);
}
.m-2 {
	margin: var(--s-2);
}
.m-3 {
	margin: var(--s-3);
}
.m-4 {
	margin: var(--s-4);
}
.m-5 {
	margin: var(--s-5);
}
.m-6 {
	margin: var(--s-6);
}

.mt-0 {
	margin-top: var(--s-0);
}
.mt-1 {
	margin-top: var(--s-1);
}
.mt-2 {
	margin-top: var(--s-2);
}
.mt-3 {
	margin-top: var(--s-3);
}
.mt-4 {
	margin-top: var(--s-4);
}
.mt-5 {
	margin-top: var(--s-5);
}
.mt-6 {
	margin-top: var(--s-6);
}

.mb-0 {
	margin-bottom: var(--s-0);
}
.mb-1 {
	margin-bottom: var(--s-1);
}
.mb-2 {
	margin-bottom: var(--s-2);
}
.mb-3 {
	margin-bottom: var(--s-3);
}
.mb-4 {
	margin-bottom: var(--s-4);
}
.mb-5 {
	margin-bottom: var(--s-5);
}
.mb-6 {
	margin-bottom: var(--s-6);
}

.ms-0 {
	margin-left: var(--s-0);
}
.ms-1 {
	margin-left: var(--s-1);
}
.ms-2 {
	margin-left: var(--s-2);
}
.ms-3 {
	margin-left: var(--s-3);
}
.ms-4 {
	margin-left: var(--s-4);
}
.ms-5 {
	margin-left: var(--s-5);
}
.ms-6 {
	margin-left: var(--s-6);
}

.me-0 {
	margin-right: var(--s-0);
}
.me-1 {
	margin-right: var(--s-1);
}
.me-2 {
	margin-right: var(--s-2);
}
.me-3 {
	margin-right: var(--s-3);
}
.me-4 {
	margin-right: var(--s-4);
}
.me-5 {
	margin-right: var(--s-5);
}
.me-6 {
	margin-right: var(--s-6);
}

.mx-0 {
	margin-left: var(--s-0);
	margin-right: var(--s-0);
}
.mx-1 {
	margin-left: var(--s-1);
	margin-right: var(--s-1);
}
.mx-2 {
	margin-left: var(--s-2);
	margin-right: var(--s-2);
}
.mx-3 {
	margin-left: var(--s-3);
	margin-right: var(--s-3);
}
.mx-4 {
	margin-left: var(--s-4);
	margin-right: var(--s-4);
}
.mx-5 {
	margin-left: var(--s-5);
	margin-right: var(--s-5);
}
.mx-6 {
	margin-left: var(--s-6);
	margin-right: var(--s-6);
}

.my-0 {
	margin-top: var(--s-0);
	margin-bottom: var(--s-0);
}
.my-1 {
	margin-top: var(--s-1);
	margin-bottom: var(--s-1);
}
.my-2 {
	margin-top: var(--s-2);
	margin-bottom: var(--s-2);
}
.my-3 {
	margin-top: var(--s-3);
	margin-bottom: var(--s-3);
}
.my-4 {
	margin-top: var(--s-4);
	margin-bottom: var(--s-4);
}
.my-5 {
	margin-top: var(--s-5);
	margin-bottom: var(--s-5);
}
.my-6 {
	margin-top: var(--s-6);
	margin-bottom: var(--s-6);
}

/* =========================
   Padding
========================= */

.p-0 {
	padding: var(--s-0);
}
.p-1 {
	padding: var(--s-1);
}
.p-2 {
	padding: var(--s-2);
}
.p-3 {
	padding: var(--s-3);
}
.p-4 {
	padding: var(--s-4);
}
.p-5 {
	padding: var(--s-5);
}
.p-6 {
	padding: var(--s-6);
}

.pt-0 {
	padding-top: var(--s-0);
}
.pt-1 {
	padding-top: var(--s-1);
}
.pt-2 {
	padding-top: var(--s-2);
}
.pt-3 {
	padding-top: var(--s-3);
}
.pt-4 {
	padding-top: var(--s-4);
}
.pt-5 {
	padding-top: var(--s-5);
}
.pt-6 {
	padding-top: var(--s-6);
}

.pb-0 {
	padding-bottom: var(--s-0);
}
.pb-1 {
	padding-bottom: var(--s-1);
}
.pb-2 {
	padding-bottom: var(--s-2);
}
.pb-3 {
	padding-bottom: var(--s-3);
}
.pb-4 {
	padding-bottom: var(--s-4);
}
.pb-5 {
	padding-bottom: var(--s-5);
}
.pb-6 {
	padding-bottom: var(--s-6);
}

.ps-0 {
	padding-left: var(--s-0);
}
.ps-1 {
	padding-left: var(--s-1);
}
.ps-2 {
	padding-left: var(--s-2);
}
.ps-3 {
	padding-left: var(--s-3);
}
.ps-4 {
	padding-left: var(--s-4);
}
.ps-5 {
	padding-left: var(--s-5);
}
.ps-6 {
	padding-left: var(--s-6);
}

.pe-0 {
	padding-right: var(--s-0);
}
.pe-1 {
	padding-right: var(--s-1);
}
.pe-2 {
	padding-right: var(--s-2);
}
.pe-3 {
	padding-right: var(--s-3);
}
.pe-4 {
	padding-right: var(--s-4);
}
.pe-5 {
	padding-right: var(--s-5);
}
.pe-6 {
	padding-right: var(--s-6);
}

.px-0 {
	padding-left: var(--s-0);
	padding-right: var(--s-0);
}
.px-1 {
	padding-left: var(--s-1);
	padding-right: var(--s-1);
}
.px-2 {
	padding-left: var(--s-2);
	padding-right: var(--s-2);
}
.px-3 {
	padding-left: var(--s-3);
	padding-right: var(--s-3);
}
.px-4 {
	padding-left: var(--s-4);
	padding-right: var(--s-4);
}
.px-5 {
	padding-left: var(--s-5);
	padding-right: var(--s-5);
}
.px-6 {
	padding-left: var(--s-6);
	padding-right: var(--s-6);
}

.py-0 {
	padding-top: var(--s-0);
	padding-bottom: var(--s-0);
}
.py-1 {
	padding-top: var(--s-1);
	padding-bottom: var(--s-1);
}
.py-2 {
	padding-top: var(--s-2);
	padding-bottom: var(--s-2);
}
.py-3 {
	padding-top: var(--s-3);
	padding-bottom: var(--s-3);
}
.py-4 {
	padding-top: var(--s-4);
	padding-bottom: var(--s-4);
}
.py-5 {
	padding-top: var(--s-5);
	padding-bottom: var(--s-5);
}
.py-6 {
	padding-top: var(--s-6);
	padding-bottom: var(--s-6);
}

.container {
	width: 100%;
	max-width: 75rem;
	margin: 0 auto;
	padding: 0 2.5rem;
}

#heroBg {
	position: fixed;
	inset: 0;
	width: 100%;
	height: 100vh;
	height: 100dvh;
	overflow: hidden;
	z-index: -1;
	transform: translateZ(0);
	will-change: transform;
	max-width: 1920px;
	margin: 0 auto;
}

.bg-layer {
	position: absolute;
	z-index: -2;
	inset: 0;
	width: 100%;
	height: 110vh;
	height: 110dvh;
	background-size: cover;
	background-position: center;
	background-repeat: repeat-y;
	will-change: opacity;
}

.bg-default {
	background-image: url('../images/ades_zabel_2025_foto_joern_hartmann_430_ret_landscape.jpg');
	background-position: top right;
}

.bg-alt {
	background-image: url('../images/drei_drachen_vom_grill_pr_60x40cm_quer_rgb_square.jpg');
	background-position: center;
	opacity: 0;
}

@media (orientation: portrait) {
	.bg-default {
		background-image: url('../images/ades_zabel_2025_foto_joern_hartmann_430_ret_portrait.jpg');
		background-position: top right;
	}
}

main {
	position: relative;
	z-index: 2;
}

.bg-alt::after {
	content: '';
	position: absolute;
	inset: 0;
	pointer-events: none;
	/* background: radial-gradient(circle at center, rgba(0, 0, 0, 0) 50%, rgba(0, 0, 0, 0.25) 60%, rgba(0, 0, 0, 0.5) 70%); */
	background: radial-gradient(
		circle at center,
		rgba(0, 0, 0, 0) 50%,
		rgba(0, 0, 0, 0.125) 60%,
		rgba(0, 0, 0, 0.25) 70%
	);
	/* backdrop-filter: blur(1px); */
}

.content-box {
	width: 100%;
	padding: 1rem 3rem;
	border-radius: var(--border-radius);
	margin-bottom: 2rem;

	background: #ffffff;
	background: rgba(255, 255, 255, 0.85);
	backdrop-filter: blur(0.5rem) saturate(120%);
	border: 1px solid rgba(255, 255, 255, 0.4);
	box-shadow: 0 8px 32px rgba(0, 0, 0, 0.15), inset 0 1px 0 rgba(255, 255, 255, 0.6);
}
.content-box.imprint {
	padding-top: 2rem;
}

.transparent {
	background-color: unset;
	box-shadow: unset;
	background: unset;
	backdrop-filter: unset;
	border: unset;
}

.section {
	padding: 0;
	align-items: center;
}

.section h2 {
	font-size: 2rem;
	line-height: 1.2;
	font-weight: 700;
	color: var(--color-accent);
	text-wrap: balance;
	margin: 1rem 0;
	/* text-transform: uppercase; */
}

.page-title {
	font-size: 2.5rem;
	font-weight: 700;
	text-align: center;
	color: var(--color-accent);
}
.transparent .page-title {
	color: #fff;
	text-shadow: 0 0.125rem 0.25rem rgba(0, 0, 0, 0.33);
}

.section-title {
	font-size: 1.25rem;
	font-weight: 700;
	text-align: center;
}

a {
	color: var(--color-links);
	text-decoration: none;
	transition: all 0.3s ease;
	border-bottom: 1px dotted var(--color-links-hover);
}

a:hover {
	color: var(--color-links-hover);
	border-bottom: 1px solid var(--color-links-hover);
}

.datetime {
	display: flex;
	flex-direction: column;
	padding: 0.625rem 1.25rem;
}

.event-date {
	font-size: 1.125rem;
	color: var(--color-primary);
	font-weight: 600;
}

.event-time {
	color: var(--color-text);
}

.event-name {
	font-size: 1.1rem;
	font-weight: 700;
	color: var(--color-primary);
	text-wrap: balance;
}

.event-location {
	display: inline-block;
	padding: 0.625rem 1.25rem;
	text-wrap: balance;
	text-align: right;
}

.contact-info {
	display: flex;
	flex-wrap: wrap;
	gap: 2.5rem;
	margin-top: 1.875rem;
}

.contact-item {
	flex: 1;
	text-align: center;
	text-wrap: balance;
}

.contact-item h3 {
	font-size: 1.25rem;
	margin-bottom: 0.9375rem;
	color: var(--color-primary);
}

.social-icons {
	display: flex;
	justify-content: center;
	align-items: center;
	flex-direction: row;
	gap: 2.5rem;
}
footer .social-icons {
	margin-top: 1.5rem;
}
.social-icons a {
	border: none;
}
.social-icon {
	width: 3.75rem;
	height: 3.75rem;
	display: flex;
	justify-content: center;
	align-items: center;
	transition: transform 0.3s ease;
}

.social-icon:hover {
	transform: scale(1.1);
}

.tooltip {
	cursor: pointer;
}
.tooltip::before {
	content: attr(aria-label);
	position: absolute;
	top: -90%;
	padding: 0.5em 1em;
	background-color: var(--color-accent);
	color: #fff;
	font-weight: 700;
	border-radius: var(--border-radius);
	scale: 0;
	opacity: 0;
	transition: 200ms ease;
	translate: -15%;
}
.tooltip::after {
	/* content: ''; */
	position: absolute;
	top: -30%;
	border-top: 0.7em solid var(--color-accent);
	border-left: 0.5em solid transparent;
	border-right: 0.5em solid transparent;
	scale: 0;
	opacity: 0;
	transition: scale 200ms ease 0.2s;
	transform-origin: top;
}
.tooltip:hover::before,
.tooltip:hover::after {
	scale: 1;
	opacity: 1;
}

footer {
	color: #fff;
	text-align: center;
	padding: 0 0 2.5rem 0;
}

footer-content {
	background-color: var(--color-primary);
	max-width: 75rem;
	margin: 0 auto;
	padding: 0 2.5rem;
}

.footer-links {
	display: flex;
	justify-content: center;
	flex-wrap: wrap;
	gap: 1.5rem;
	margin-top: 1.25rem;
	font-size: 1.5rem;
	font-weight: 700;
	text-shadow: 0 0.125rem 0.25rem rgba(0, 0, 0, 0.33);
}
.footer-links > * {
	padding: 0.25rem 0.5rem 0;
	border-radius: var(--border-radius);
}
.footer-links a {
	color: white;
	border-bottom: 2px dotted white;
}
.footer-links a:hover {
	color: var(--color-links-hover);
	text-shadow: 0 0 1px white;
	background-color: white;
}

.social-icons svg {
	color: white;
}
.social-icons a:hover svg {
	color: var(--color-links-hover);
	fill: white;
}

.white-line {
	width: 50vw;
	height: 0.1rem;
	background-color: #fff;
}

.welcome-text {
	font-size: 1.125rem;
	line-height: 2;
	color: var(--color-primary);
}

.events-list {
	list-style: none;
}

.events-list li {
	padding: 1rem 0;
	display: flex;
	align-items: start;
	gap: 0.5rem 5rem;
	border-top: 1px solid rgba(255, 255, 255, 0.5);
	border-bottom: 1px solid rgba(0, 0, 0, 0.05);
}

.events-list li:first-child {
	border-top: none;
}
.events-list li:last-child {
	border-bottom: none;
}

.events-list li .event-item {
	display: flex;
	gap: 1.5rem;
	width: 100%;
}

.events-list li .event-date-column {
	display: flex;
	flex-direction: column;
	flex-shrink: 0;
	justify-content: start;
	width: 6.25rem;
}

.events-list li .event-date {
	font-size: 1.125rem;
	color: var(--color-primary);
	font-weight: 600;
}

.events-list li .event-time {
	color: var(--color-text);
}

.events-list li .event-info-column {
	flex-grow: 1;
	display: flex;
	flex-direction: column;
	justify-content: start;
}

.events-list li .event-location-column {
	display: flex;
	justify-content: start;
}

.events-list li .event-name {
	font-size: 1.1rem;
	font-weight: 700;
	color: var(--color-primary);
}

.events-list li .event-description {
	color: var(--color-text);
	text-wrap: balance;
}

.events-list li .event-location-link {
	display: inline-block;
	align-self: flex-start;
	text-align: right;
	text-wrap: balance;
}

.hero-container {
	min-height: 100vh;
	height: 100%;
	display: flex;
	flex-direction: column;
	justify-content: end;
	align-items: center;
	text-align: center;
	gap: 2rem;
	padding-bottom: 3rem;
}

.hero-container .hero-title {
	font-size: 5rem;
	font-size: clamp(3rem, calc(8vw + 2rem), 8rem);
	font-weight: 700;
	letter-spacing: 8%;
	line-height: 1.1;
	color: #fff;
	text-shadow: 0 0.125rem 0.25rem rgba(0, 0, 0, 0.33);
	padding-top: 7.5rem;
}

.hero-container .social-icons {
	padding-right: 1.25rem;
}

.welcome-container {
	text-align: center;
}

.welcome-container nav {
	margin-top: 1rem;
	padding: 1rem 0 0.5rem;
	/* border-top: 1px solid #ddd; */
	display: flex;
	gap: 1rem;
	justify-content: center;
}

.welcome-container h3 {
	font-size: 1.875rem;
	font-weight: 700;
	margin-bottom: 1.875rem;
}

.welcome-container p {
	font-size: 1.25rem;
	margin-bottom: 1.25rem;
	line-height: 1.8;
}

.booking-contact-container {
	text-align: center;
}

.booking-contact-container h3 {
	font-size: 1.875rem;
	font-weight: 700;
	margin-bottom: 1.875rem;
}

.booking-contact-container p {
	font-size: 1.25rem;
	line-height: 1.8;
	margin-bottom: 1.25rem;
}

.booking-contact-info {
	display: flex;
	justify-content: center;
	flex-wrap: wrap;
	gap: 2.5rem;
	margin-top: 1.875rem;
}

.booking-contact-item {
	padding: 1.875rem 2.5rem;
	min-width: 18.75rem;
}

.booking-contact-item h3 {
	font-size: 1.25rem;
	margin-bottom: 0.9375rem;
	color: var(--color-primary);
}

.divider {
	display: flex;
	align-items: center;
	gap: 1rem;
	margin: 2.5rem 0 0 0;
}

.divider hr {
	flex: 1;
	border: none;
	border-top: 1px solid #ccc;
	margin: 0;
}

.divider span {
	white-space: nowrap;
}

.imprint div p,
.datenschutz div p {
	margin-bottom: 1rem;
}
.imprint div ul,
.datenschutz div ul {
	margin-left: 1rem;
}

@media (max-width: 768px) {
	.container {
		padding: 0 0.5rem;
	}
	.content-box {
		padding: 1rem 1rem;
	}
	.hero-container {
		gap: 1.5rem;
		padding-bottom: 1rem;
	}
	.events-list li {
		justify-content: center;
		flex-direction: column;
		padding: 1.5rem 0;
	}
	.events-list li .event-date-column {
		width: 100%;
		flex-direction: row;
		justify-content: center;
		gap: 1rem;
	}
	.events-list li .event-date-column > * {
		align-self: center;
	}
	.events-list li .event-info-column {
		width: 100%;
		justify-content: center;
	}
	.events-list li .event-info-column > * {
		align-self: center;
		text-align: center;
	}
	.events-list li .event-location-column {
		width: 100%;
		justify-content: center;
	}
	.events-list li .event-location-column > * {
		align-self: center;
		text-align: center;
	}
	.contact-info {
		flex-direction: column;
		gap: 1rem;
	}
}
