@import url(https://fonts.googleapis.com/css?family=Montserrat:100,200,300,regular,500,600,700,800,900,100italic,200italic,300italic,italic,500italic,600italic,700italic,800italic,900italic);

@import url(https://fonts.googleapis.com/css?family=Libre+Franklin:100,200,300,regular,500,600,700,800,900,100italic,200italic,300italic,italic,500italic,600italic,700italic,800italic,900italic);

/* Variables ------------------------------------------- */

:root {
	--yellow300: #eebb00;
	--yellow400: #f0cd50;
	--black100: #0d1320;
	--black200: #38382d;
	--white100: #faf9f6;
	--white200: #f3f3ef;
	--white300: #f7f6f4;
	--blue: #93a8ac;

	--bs01: 0 2px 30px 0 #0000000d;
	--bs02: 0 1px 50px rgba(0, 0, 0, 0.05), 0 1px 50px rgba(0, 0, 0, 0.05);
	--bs03: 0 0 1rem rgb(0 0 0 / 0.122), 0rem 0rem 0 0 rgb(0 0 0 / 0.122);

	--ff-base: "Libre Franklin", sans-serif;
	--ff-heading: "Montserrat", sans-serif;

	--fs-base: clamp(0.875rem, 0.855rem + 0.091vw, 1rem);
	--fs-h1: clamp(2rem, 1.836rem + 0.727vw, 3rem);
	--fs-h2: clamp(1.5rem, 1.377rem + 0.545vw, 2.25rem);
	--fs-h3: clamp(1.25rem, 1.209rem + 0.182vw, 1.5rem);
}

/* Reset ----------------------------------------------- */

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

img,
picture,
figure,
video,
canvas,
svg {
	max-width: 100%;
	height: auto;
	display: block;
}

input,
button,
textarea {
	font: inherit;
}

ul,
ol {
	list-style: none;
}

body {
	width: min(100%, 160rem);
	font-family: var(--ff-base);
	font-size: var(--fs-base);
	font-weight: 300;
	color: var(--black100);
	line-height: 1.8;
	-webkit-font-smoothing: antialiased;

	border-inline: clamp(0.5rem, 0.33643rem + 0.727vw, 1.5rem) solid var(--yellow300);
}

/* Typography ------------------------------------------ */

h1,
h2,
h3 {
	text-wrap: balance;
	font-family: var(--ff-heading);
	font-weight: 700;
	line-height: 1.1;
	letter-spacing: -1.25px;
	color: var(--black100);
	margin-block-end: 1.5rem;
}

h1 {
	font-size: var(--fs-h1);
}

h2 {
	font-size: var(--fs-h2);
}

h3 {
	font-size: var(--fs-h3);
}

p {
	display: inline-block;
	margin-block-end: 1rem;
}

a {
	text-decoration: none;
	color: var(--black100);
}

a:is(:hover, a.active) {
	color: var(--white100);
}

a.active {
	font-weight: 700;
}

strong {
	font-weight: 600;
}

/* Reusable classes ------------------------------------ */

.wrapper {
	padding-inline: 1rem;
}

address {
	margin-block-end: 2rem;
	font-style: normal;
}

span {
	margin-block-end: 0.5rem;
	font-weight: 300;
	text-transform: uppercase;
	letter-spacing: 8px;
	color: var(--blue);
}

figure,
picture {
	padding: 1rem;

	background-color: #ffffff;
	border: 1px solid #6e6d6d0d;
	border-radius: 3px;
	box-shadow: var(--bs01);
}

figure img {
	width: 100%;
}

picture {
	border-radius: 3px;
}

.xl,
.lg,
.md,
.sm {
	width: min(100%, 1800px);
	margin-inline: auto;
}

.lg {
	width: min(100%, 1600px);
}

.md {
	width: min(100%, 1400px);
}

.sm {
	width: min(100%, 1100px);
}

.grid,
.grid01 {
	display: grid;
	align-items: center;
	grid-template-columns: 2fr 1fr;
	gap: 5rem;
}

.grid01 {
	grid-template-columns: 1fr 2fr;
}

.start {
	align-items: start;
}

.start ul {
	margin-inline-start: 1rem;
	list-style: disc;
}

.start li {
	margin-block-end: 1rem;
}

.col {
	column-gap: 3rem;
}

.col {
	columns: 2 350px;
}

.col .title {
	column-span: all;
}

section {
	margin-block: clamp(4rem, 3.509rem + 2.182vw, 7rem);
}

.sub-title {
	margin-block: 2rem;
}

.title {
	margin-block-end: 2rem;
}

.title h2 {
	margin: 0;
}

.tags {
	width: 90%;
	margin-block-end: 1rem;

	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 0.5rem;
}

.tag {
	padding: 0.25rem 1rem;
	font-weight: 200;
	background-color: var(--white100);
	border: 1px solid #9695950d;
	border-radius: 3px;
	/* box-shadow: var(--bs01); */
}

.subpage-hero {
	margin-block: clamp(2rem, 1.673rem + 1.455vw, 4rem);
}

.subpage-hero-img {
	width: min(100%, 112.5rem);
	margin-inline: auto;
	height: clamp(21.875rem, 18.295rem + 15.909vw, 31.25rem);
}

.cta-banner {
	padding: 4rem;
	background-color: var(--white100);
	border: 1px solid #6e6d6d0d;
	border-radius: 3px;
	/* box-shadow: var(--bs01); */

	display: flex;
}

.cta-banner h2 {
	margin: 0;
}

.cta-banner-anfrage {
	display: flex;
	align-items: center;
	justify-content: end;
	gap: 2rem;

	flex: 1;
}

.cta-banner-anfrage .btn {
	margin: 0;
}

.btn {
	margin-block-start: 1rem;
	padding: 0.25rem 1rem;
	font-weight: 500;
	color: var(--white100);
	background-color: var(--black100);
	border: 1px solid var(--black100);
	border-radius: 3px;

	display: inline-block;
}

.event-btn {
	font-weight: 500;

	display: flex;
	align-items: center;
	gap: 0.5rem;
}

.event-btn:hover {
	color: var(--black200);
	text-decoration: underline;
}

.err,
.success {
	width: 100%;
	margin-block-start: 0.25rem;
	padding-inline: 0.5rem;
	font-size: 0.875rem;
	font-weight: 400;
	color: var(--yellow300);

	position: absolute;
	top: 100%;
	left: 0;
}

.success {
	margin-block-start: 1rem;
	padding-inline: 0;
	text-align: center;
}

/* Tabs ------------------------------------------------ */

.tab-wrapper {
	min-height: auto;
}

input[type="radio"] {
	display: none;
}

input[type="radio"]:checked + label {
	font-weight: 500;
	color: #ffffff;
	background-color: var(--black100);
}

label {
	margin: 0 0 2rem 0.5rem;
	cursor: pointer;
	transition: 0.4s;
}

label.tag {
	font-weight: 500;
	border: 1px solid #6e6d6d0d;

	display: inline-block;
}

.tab-content {
	margin-block: 5rem 20px;

	display: none;
}

#tab01:checked ~ #content01,
#tab02:checked ~ #content02,
#tab03:checked ~ #content03 {
	display: block;
}

/* Header & Navigation --------------------------------- */

header {
	padding: 1rem;
	background-color: var(--yellow300);

	position: sticky;
	top: 0;
	left: 0;
	z-index: 666;
}

header .mainNav {
	display: flex;
	align-items: end;
	gap: 2rem;
}

.logo svg {
	width: 7.5rem;
	height: 5rem;
	fill: var(--white100);
}

.nav {
	display: flex;
	align-items: center;
	gap: 1.5rem;
}

.nav02 a {
	font-size: 1.5rem;
	font-weight: 700;
	line-height: 39px;
}

.close,
.menu,
.nav p {
	cursor: pointer;
	display: none;
}

.nav03 {
	display: none;
}

.close {
	position: absolute;
	top: 1.5rem;
	right: 1.1rem;
}

/* Hero ------------------------------------------------ */

.hero-wrapper {
	padding: clamp(0.5rem, 0.418rem + 0.364vw, 1rem) clamp(0.5rem, 0.418rem + 0.364vw, 1rem) 0;
	display: grid;
	grid-template-columns: minmax(500px, 30%) auto;
}

.hero-img {
	height: clamp(21.875rem, 18.295rem + 15.909vw, 43.75rem);
	background: linear-gradient(to right, rgba(18, 18, 18, 0.25), rgba(18, 18, 18, 0.1)), url(../images/homepage/index.webp) no-repeat top 20% left 2.5% / cover;

	position: relative;
}

.event-img {
	background: url(/assets/images/eventcat/event02.webp) no-repeat center/cover;
}

.messe-img {
	background: url(/assets/images/homepage/messe01.webp) no-repeat center/cover;
}

.private-img {
	background: url(/assets/images/homepage/private01.webp) no-repeat center/cover;
}

.hero-img-ob {
	width: 7.5rem;
	height: 100%;
	background-color: var(--black100);
	clip-path: polygon(0 0, 0 100%, 60% 100%);

	position: absolute;
	left: 0;
	bottom: 0;
}

.hero-text {
	grid-area: 1 / 1;
	padding-inline: 3rem 1.5rem;
	background-color: var(--black100);
	color: var(--white100);

	display: flex;
	flex-direction: column;
	justify-content: center;
}

.hero-text h1 {
	color: var(--white100);
}

.hero-info {
	margin-block-end: 2rem;
}

.hero-icon {
	line-height: 50px;
	display: flex;
	align-items: center;
	gap: 0.5rem;
}

/* Intro ----------------------------------------------- */

.services a {
	margin-block-start: 1rem;
	justify-content: end;
}

.cards {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
	gap: 2rem;
}

.card {
	background-color: var(--white100);

	display: grid;
	grid-template-rows: 300px 1fr;
}

.card-img {
	overflow: hidden;
}

.card img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: 0.5s ease-in-out;
}

.card:hover img {
	transform: scale(105%);
}

.card-info {
	padding: 2rem clamp(1rem, 0.836rem + 0.727vw, 2rem);

	display: grid;
	grid-template-rows: span 3;
	align-self: start;
}

/* Slogan ---------------------------------------------- */

.slogan-wrapper {
	max-width: 1400px;
	margin-inline: auto;
	padding-inline: 1rem;

	display: grid;
	grid-template-columns: 1fr 1.5fr;
	align-items: center;
	gap: clamp(0rem, -0.327rem + 1.455vw, 2rem);
}

.note {
	padding: 4rem 2rem;
	text-align: center;
	background-color: var(--white100);
	border: 1px solid #6e6d6d0d;
	border-radius: 3px;
}

.note h2 {
	margin: 0;
}

/* Events ------------------------------------------ */

.events {
	width: min(100%, 95%);
	margin-inline: auto;
}

.event {
	margin-block-end: 2rem;
	background-color: var(--white100);

	display: grid;
	grid-template-columns: 40% 60%;
	grid-template-areas: "info image";
}

.reverse {
	grid-template-columns: 60% 40%;
	grid-template-areas: "image info";
}

.event-info {
	padding: clamp(1rem, 0.509rem + 2.182vw, 4rem);

	display: grid;
	align-items: center;
}

.event-info h2 {
	margin-block-end: 1rem;
}

.event-image,
.messe-image,
.private-image {
	grid-area: image;
	min-height: 200px;
	background: url(/assets/images/homepage/event01.webp) no-repeat center/cover;
}

.messe-image {
	background: url(/assets/images/homepage/messe01.webp) no-repeat center/cover;
}

.private-image {
	background: url(/assets/images/homepage/private01.webp) no-repeat center/cover;
}

/* Kontakt ------------------------------------------*/

.kontakt-boxes p {
	margin: 0;
}

.kontakt-boxes {
	display: grid;
	grid-template-columns: 250px 1fr 250px;
	gap: 2rem;

	grid-template-areas:
		"anschrift form email"
		"telefon form soziale"
		". form .";
}

.kontakt-box,
form {
	padding: 2rem;
	background-color: #ffffff;
	box-shadow: var(--bs01);
}

.pot {
	display: none;
}

.anschrift {
	grid-area: anschrift;
}

.email {
	grid-area: email;
}

.soziale {
	grid-area: soziale;
}

form {
	grid-area: form;

	display: flex;
	flex-direction: column;
	flex: 1;
}

.rows {
	display: flex;
	flex-wrap: wrap;
	gap: 2rem;
}

.row {
	margin-bottom: 2rem;

	display: flex;
	flex-direction: column;
	flex: 1;

	position: relative;
}

label {
	margin-block-end: 0.5rem;
}

span.req {
	color: var(--yellow300);
}

input,
textarea {
	padding: 1rem;
	border: 1px solid var(--white200);
	border-radius: 3px;
	outline: 0;
}

textarea {
	min-height: 100px;
	resize: vertical;
}

input[type="submit"] {
	background-color: var(--black100);
	border: 0;
	cursor: pointer;
	color: var(--white100);
	font-weight: 700;
	margin-block-start: 1rem;
}

/* Datenschutz ----------------------------------------- */

.daten :is(h2, h3) {
	margin-block-start: 1rem;
}

.daten a {
	text-decoration: underline;
}

.daten a:hover {
	color: var(--black200);
}

/* FAQ ------------------------------------------------- */

.faqs-wrapper .content {
	padding-inline: 10px;
	max-height: 0;
	overflow: hidden;
	transition: max-height 1s;
}

.faqs-wrapper input[type="radio"]:checked + label + .content {
	max-height: 400px;
}

.faq {
	margin-block-end: 20px;
	padding: 0px;
	border-radius: 3px;
	box-shadow: var(--bs01);
}

.faq label {
	margin: 1rem 0;
	padding: 20px;

	font-family: var(--ff-heading);
	font-size: var(--fs-h3);
	font-weight: 500;
	color: var(--black100);
	line-height: 1.1;
	letter-spacing: -1.25px;
	border-radius: 3px;

	display: flex;
	justify-content: space-between;
	align-items: center;
}

/* Footer ---------------------------------------------- */

footer {
	background-color: var(--yellow300);
}

.footer-wrapper {
	display: grid;
	grid-template-columns: 2fr repeat(3, 1fr);
	gap: 2rem;

	padding: 4rem 0.5rem 2.5rem;
	border-bottom: 1px dashed var(--yellow400);
}

.footer-wrapper svg {
	margin-block-end: 1.5rem;
}

.footer-wrapper ul {
	justify-self: center;
	margin-block-start: 2rem;
}

.footer-wrapper li {
	margin-block-start: 0.5rem;
}

footer ul p {
	margin-block: 0;
	font-family: var(--ff-heading);
	font-size: clamp(1.1rem, 0.918rem + 0.364vw, 1.5rem);
	letter-spacing: -1px;
	font-weight: 700;
}

/* Copyright ------------------------------------------- */

.copyright {
	padding: 1.5rem 0.5rem;
	font-size: 0.8125rem;

	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	align-items: center;
}

.copy {
	margin-inline-end: 2rem;
}

/* MediaQueries ---------------------------------------- */

@media (width < 1100px) {
	.cta-banner {
		padding: 4rem 0;
		text-align: center;
		flex-direction: column;
		justify-content: center;
		gap: 2rem;
	}

	.cta-banner-anfrage {
		justify-content: center;
		gap: 1rem;
	}

	.grid,
	.grid01 {
		grid-template-columns: repeat(2, 1fr);
		align-items: start;
		gap: 3rem;
	}

	/* Header & Navigation ------------------------------ */

	header {
		padding: 0 0.5rem;
	}

	.logo svg {
		width: 5rem;
	}

	header .mainNav {
		justify-content: space-between;
		align-items: center;
	}

	.mainNav .menuList {
		width: 100%;
		height: 100vh;
		padding-inline: 3rem;
		background-color: var(--yellow300);
		transition: left 0.2s ease;

		position: fixed;
		top: 0;
		left: -100%;

		display: flex;
		flex-direction: column;
		justify-content: center;
	}

	.nav {
		display: flex;
		flex-direction: column;
		align-items: start;
		gap: 0.5rem;
	}

	.nav {
		padding-block-start: 1.5rem;
	}

	.nav p {
		width: 100%;
		padding-block-end: 0.5rem;
		margin-block-end: 0;
		font-family: var(--ff-heading);
		font-size: 1.25rem;
		font-weight: 700;
		letter-spacing: -1px;
		border-bottom: 1px dashed var(--yellow400);
	}

	.nav a {
		font-size: 1rem;
		font-weight: 200;
	}

	.nav a.active {
		font-weight: 600;
	}

	.close,
	.menu,
	.nav p {
		display: block;
	}

	header.showMenu::before {
		content: "";
		width: 100%;
		height: 100vh;
		backdrop-filter: blur(2px);

		position: fixed;
		top: 0;
		left: 0;
	}

	header.showMenu .mainNav .menuList {
		left: 0;
	}

	/* Hero --------------------------------------------- */

	.hero-wrapper {
		grid-template-columns: 1fr;
		grid-template-rows: 1fr auto;
	}

	.hero-text {
		grid-area: 2 / 1;
		padding: 3rem 1rem;
		text-align: end;
		background-color: var(--black100);
	}

	.hero-text p {
		align-self: end;
	}

	.hero-icon {
		align-self: end;
	}

	.hero-img-ob {
		width: 100%;
		clip-path: polygon(100% 100%, 100% 85%, 0% 100%);

		bottom: -1px;
	}

	.event {
		grid-template-columns: 1fr;
		grid-template-areas:
			"image"
			"info";
	}

	/* Kontakt ------------------------------------------ */

	.kontakt-boxes {
		grid-template-columns: repeat(2, 1fr);
		grid-template-areas:
			"anschrift telefon"
			"email soziale"
			"form form";
	}

	.kontakt-box,
	form {
		padding: 2rem 1rem;
	}

	/* Slogan ------------------------------------------- */

	.slogan-wrapper {
		grid-template-columns: 1fr;
	}

	/* Footer ------------------------------------------- */

	.footer-wrapper {
		padding-top: 2rem;
		grid-template-columns: repeat(2, 1fr);
		gap: 1rem;
	}

	.footer-wrapper svg {
		margin-block-end: 1rem;
	}

	.info {
		grid-area: 1 / span 3;
	}

	.footer-wrapper ul {
		justify-self: start;
	}

	footer ul:last-of-type {
		grid-area: 3 / span 2;
	}

	.webinfo-flex {
		display: flex;
		gap: 1rem;
	}
}

@media (width < 750px) {
	.grid,
	.grid01 {
		grid-template-columns: 1fr;
	}

	.grid {
		grid-template-areas: "image" "text";
	}

	.image {
		grid-area: image;
	}

	.text {
		grid-area: text;
	}

	input,
	textarea {
		padding: 0.5rem;
	}

	.kontakt-boxes {
		grid-template-columns: 1fr;
		grid-template-areas:
			"form"
			"anschrift"
			"telefon"
			"email"
			"soziale";
	}
}

@media (width < 560px) {
	.rows {
		gap: 0;
	}
}
