
:root {
	--primary-color: #bc13fe;
	--tertiary-color: #30004d;
	--brand-green: #79a948;
	--dark-green-color: #244205;
	--orange-color: #ff6a00;
	--dark-orange-color: #a34300;
	--text-color: #e0e0e0;
	--dark-bg: #1a1a1a;
	--footer-height: 65px;
	--section-text: #ffffff;
		--footer-height: 50px;
}



@font-face {
	font-family: "Orbitron";
	src: url("/fonts/rostex.regular.ttf") format("truetype");
	font-weight: 400;
}

@font-face {
	font-family: "Orbitron";
	src: url("/fonts/rostex.regular.ttf") format("truetype");
	font-weight: 700;
}

@font-face {
	font-family: "Poppins";
	src: url("/fonts/Poppins-Regular.ttf") format("truetype");
	font-weight: 400;
}

@font-face {
	font-family: "Bebas";
	src: url("/fonts/BebasNeue-Regular.ttf") format("truetype");
	font-weight: 400;
}

html,
body {
	background-color: #0d0d0d;
	color: var(--text-color);
	font-family: "Poppins", sans-serif;
	margin: 0;
	padding: 0;
	overflow-x: hidden;
	width: 100%;
	max-width: 100vw;
	overflow: hidden;
	height: -webkit-fill-available;
	min-height: 100vh;
	height: -webkit-fill-available;
	height: 100%;
}

h1,
h2,
h3,
h4,
.h1,
.h2 {
	font-family: "Orbitron", sans-serif;
	text-transform: uppercase;
}


@media (max-width: 768px) {
	.door {
		background: url("/img/main_smartphone.webp");
	}
}

.door {
	background-repeat: no-repeat;
	position: fixed;
	top: 0;
	width: 50vw;
	height: 100vh;
	z-index: 40;
	background-size: 100vw 100vh;

	transition: transform 1.2s cubic-bezier(0.645, 0.045, 0.355, 1);
}
#door-left {
	left: 0;
	background-position: left center;
	border-right: 2px solid var(--primary-color);
	box-shadow: 5px 0 25px rgba(0, 0, 0, 0.8);
}

#door-right {
	right: 0;
	background-position: right center;
	border-left: 2px solid var(--primary-color);
	box-shadow: -5px 0 25px rgba(0, 0, 0, 0.8);
}

#open-gates-btn {
	position: fixed;
	bottom: 33%;
	left: 50%;
	transform: translateX(-50%);
	z-index: 50;
	font-family: "Poppins", sans-serif;
	font-size: 0.8rem;
	font-weight: 600;
	color: #ffffff;
	text-transform: uppercase;
	letter-spacing: 1.5px;
	background: linear-gradient(135deg, #2a004d, #1a0030);
	border: 2px solid #bc13fe;
	border-radius: 8px;

	cursor: pointer;
	text-shadow:
		1px -1px 1px rgba(0, 0, 0, 2),
		-1px 1px -1px rgba(0, 0, 0, 2),
		-1px 1px -1px rgba(0, 0, 0, 2),
		1px -1px 1px rgba(0, 0, 0, 2),
		-1px -1px 1px rgba(0, 0, 0, 2),
		1px -1px -1px rgba(0, 0, 0, 2);
	transition: all 0.3s ease;
	overflow: hidden;
	padding: 10px 0;
	width: 200px;
	box-shadow: 0 0 27px rgba(0, 0, 0, 0.83);
}

#open-gates-btn::after {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background: radial-gradient(circle, rgba(234, 0, 255, 0.05) 40%, rgba(234, 0, 255, 0.96) 100%);
	pointer-events: none;
	animation: myAnim 4s ease-in-out 0s infinite alternate-reverse backwards;
}

#open-gates-btn.button-clicked {
	transform: translateX(-50%) scale(0.92);
}

#open-gates-btn:hover {
	box-shadow:
		0 0 15px rgba(188, 19, 254, 0.5),
		0 0 30px rgba(188, 19, 254, 0.3);
	background: linear-gradient(135deg, #3a0066, #220040);
	transform: translateX(-50%) translateY(-2px);
}

body.gates-open #content-hub {
	opacity: 1;
	transform: scale(1);
}

body.gates-open #door-left {
	animation: open-door-left 1.2s cubic-bezier(0.645, 0.045, 0.355, 1) forwards;
}

body.gates-open #door-right {
	animation: open-door-right 1.2s cubic-bezier(0.645, 0.045, 0.355, 1) forwards;
}

body.gates-open .hero-center {
	opacity: 0;
	transform: translate(-50%, -60%);
	pointer-events: none;
}

body.gates-open .mobile-list-container {
	opacity: 1;
	transform: translateY(0);
	transition-delay: 1.2s;
}

body.gates-open .mobile-nav-buttons {
	opacity: 1;
	transform: translateY(0);
	transition-delay: 1s;
}


body.gates-open .mobile-nav-buttons {
	opacity: 1;
	transform: translateY(0);
	transition-delay: 1s;
}

body.gates-open #open-gates-btn {
	opacity: 0;
	transform: translate(-50%, 20px);
	pointer-events: none;
}

main {
	position: fixed;
	top: 0;
	bottom: 0;
	height: 100%;
	padding-bottom: calc(var(--footer-height) + env(safe-area-inset-bottom));
	left: 0;
	right: 0;
	width: 100%;
	overflow: hidden;
	display: block;
	z-index: 10;
}

.main-title {
	font-size: 1.65em;
	letter-spacing: 0.08em;

	margin-bottom: 2.5rem;
	position: relative;
	padding-bottom: 5px;
	color: #ff4dff;
	z-index: 50;
	max-width: 100%;
	background: radial-gradient(circle, rgba(0, 0, 0, 0.6) 0%, rgba(0, 0, 0, 0) 70%);
	text-shadow:
		0 0 5px rgba(255, 80, 255, 1),
		0 0 2px rgba(212, 0, 255, 0.5),
		0 0 45px rgba(212, 0, 255, 0.4);
	transition:
		opacity 0.5s ease,
		transform 0.5s ease;
	text-align: center;
	font-family: "Orbitron";
	-webkit-font-smoothing: antialiased;
}

.main-title::after {
	content: "";
	position: absolute;
	left: 50%;
	bottom: 0;
	transform: translateY(-250%) translateX(-50%);
	text-shadow:
		0 0 5px rgba(255, 80, 255, 1),
		0 0 25px rgba(212, 0, 255, 0.8),
		0 0 45px rgba(212, 0, 255, 0.4);
	width: 180px;
	height: 2px;
	box-shadow: 0 0 45px #ff4dff;
}

.hero-center {
	position: fixed;
	top: 30%;
	left: 50%;
	transform: translateX(-50%);
	z-index: 50;
	max-width: 90%;
	transition:
		opacity 0.5s ease,
		transform 0.5s ease;
	white-space: nowrap;
	width: 100%;
	text-align: center;
	color: #ff4dff;
	padding-bottom: 5px;
	-webkit-font-smoothing: antialiased;
	font-size: 0.9rem;
	letter-spacing: 0.1em;
	padding: 0;
}

.hero-center::after {
	width: 60px;
	height: 3px;
	background-color: #ff4dff;
	box-shadow: 0 0 12px #ff4dff;
	left: 50%;
	transform: translateX(-50%);
}

.hero-genre-text {
	color: #fff;
	letter-spacing: 0.5px;
	opacity: 1;
	font-family: "Poppins";
	-webkit-font-smoothing: antialiased;
	text-shadow:
		5 4 5px rgb(0, 0, 0),
		0 0 25px rgba(69, 69, 69, 0.8),
		0 1 15px rgb(0, 0, 0);
	margin: 0 auto 1.5rem auto;
	font-size: 13px;
	max-width: 350px;
	font-weight: 640;
	background-color: rgba(0, 0, 0, 0.1);
}

.btn-go-dmt1,
.btn-go-dmt2 {
	border: 1.25px solid rgba(188, 19, 254, 0.6);
}

.btn-go-dmt1::after,
.btn-go-dmt2::after {
	background: radial-gradient(circle, rgba(190, 0, 241, 0.18) 24%, rgba(162, 0, 255, 0.5) 100%);
}

.btn-go-gigs {
	border: 1.25px solid #2aa600f1;
}

.btn-go-gigs::after {
	background: radial-gradient(circle, rgba(42, 241, 0, 0.18) 24%, rgba(0, 255, 34, 0.5) 100%);
}

.btn-go-midtempo {
	border: 1.25px solid rgb(255, 100, 5);
}

.btn-go-midtempo::after {
	background: radial-gradient(circle, rgba(255, 83, 0, 0.18) 50%, rgba(255, 115, 0, 0.5) 100%);
}

.button-clicked {
	transform: scale(0.92);
	transition: all 0.1s ease;
}

.button-clicked::after {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	width: 300%;
	height: 100%;
	transform: skewX(-25deg) translateX(-200%);
	z-index: 30;
	filter: brightness(3) blur(2px);
	mix-blend-mode: screen;
	pointer-events: none;
}



.slider-track {
	display: flex;
	width: 300%;
	height: 100%;
	transition: transform 1.2s cubic-bezier(0.645, 0.045, 0.355, 1);
}
.content-panel {
	width: 33.3333%;
	height: 100%;
	position: relative;
	background-size: cover;
	background-position: top center;
	display: flex;
	flex-direction: column;
	justify-content: flex-end;
	padding-bottom: 0;
	padding: 0;
}

.content-panel::before {
	display: none;
}

#content-hub {
	position: relative;
	width: 100%;
	background-color: #050505;
	overflow: hidden;
	z-index: 10;
	opacity: 0;
	transform: scale(0.95);
	transition:
		opacity 0.8s ease 0.4s,
		transform 0.8s ease 0.4s;

	/*	width: 100vw;
	height: 100%;
	pointer-events: none;
	z-index: 90;*/
}

#content-hub::after {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	width: 100vw;
	height: 100%;
	pointer-events: none;
	z-index: 90;
}

#content-hub,
.content-slider-container,
.slider-track,
.content-panel {
	height: 100%;
	min-height: 100%;
}

#dmt-panel {
	background-image: url("/img/dmt_mobile_bg.webp");
}
#gigs-panel {
	background-image: url("/img/clubsets_mobile_bg.webp");
}
#midtempo-panel {
	background-image: url("/img/midtempo_mobile_bg.webp");
}

#content-hub.show-dmt1 .slider-track,
#content-hub.show-dmt2 .slider-track {
	transform: translateX(-33.3333%);
}

#content-hub.show-dmt1::after {
	animation: sweep-purple-r 0.8s ease forwards;
}

#content-hub.show-dmt2::after {
	animation: sweep-purple-l 0.8s ease forwards;
}

#content-hub.show-gigs .slider-track {
	transform: translateX(-66.6666%);
}

#content-hub.show-gigs::after {
	animation: sweep-green 0.8s ease forwards;
}

#content-hub.show-midtempo .slider-track {
	transform: translateX(0);
}

#content-hub.show-midtempo::after {
	animation: sweep-orange 0.8s ease forwards;
}

.mobile-list-container {
	background: rgba(8, 8, 8, 0.92);
	backdrop-filter: blur(15px);
	-webkit-backdrop-filter: blur(15px);
	border-radius: 12px;
	overflow-x: hidden;
	padding: 10px 0;
	flex: 1 1 0;
	min-height: 0;
	width: 95%;
	margin: 0 auto 15px auto;
	overflow-y: auto;
	display: block;
}

.mobile-nav-btn {
	position: relative;
	background: linear-gradient(135deg, rgba(30, 0, 50, 0.98), rgba(10, 0, 20, 0.98));
	border: 2px solid;
	border-radius: 8px;
	color: rgb(255, 255, 255);
	font-size: 0.8rem;
	padding: 10px 0;
	width: 125px;
	letter-spacing: 1.5px;
	font-weight: 600;
	cursor: pointer;
	text-transform: uppercase;
	overflow: hidden;
	text-shadow:
		1px -1px 1px rgba(0, 0, 0, 2),
		-1px 1px -1px rgba(0, 0, 0, 2),
		-1px 1px -1px rgba(0, 0, 0, 2),
		1px -1px 1px rgba(0, 0, 0, 2),
		-1px -1px 1px rgba(0, 0, 0, 2),
		1px -1px -1px rgba(0, 0, 0, 2);
}

.mobile-nav-btn::after {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	animation: myAnim 4s ease-in-out 0s infinite alternate-reverse backwards;
	pointer-events: none;
	z-index: 3;
}

.mobile-nav-buttons {
	display: flex;
	justify-content: center;
	gap: 73px;
	flex-shrink: 0;
	margin-top: 45vh;
	margin-bottom: 15px;
	z-index: 10;
}

.mobile-nav-buttons,
.mobile-list-container {
	opacity: 0;
	transform: translateY(20px);
	transition:
		opacity 0.6s ease,
		transform 0.6s ease;
}

.gig-clicked-flash {
	transform: scale(0.96);
	transition: all 0.15s ease;
	border-radius: 8px;
}

.gig-clicked-flash .gig-image {
	filter: saturate(1.5) brightness(1.2);
}

.gig-date {
	font-family: "Orbitron", sans-serif;
	font-size: 0.65rem;
	color: #aaa;
	margin-bottom: 2px;
}


.gig-grid {
	width: 100%;
	max-width: 100%;
	margin: 0;
	padding: 0;
	box-sizing: border-box;
}

.gig-info {
	display: flex;
	flex-direction: column;
	justify-content: center;
}

.gig-item.card-layout {
	background: transparent;
	border: none;
	border-bottom: 1px solid rgba(255, 255, 255, 0.05);

	padding: 10px 15px;
	border-radius: 0;
	text-decoration: none;
}

.gig-item.card-layout .gig-image {
	width: 40px;
	height: 40px;
	border-radius: 4px;
	margin-right: 15px;
	filter: saturate(0.5) brightness(0.7);
	transition: all 0.3s ease;
}

.gig-item.card-layout .gig-link-image {
	display: flex;
	flex-direction: row;
	align-items: center;
	text-decoration: none;
}

.gig-title {
	font-size: 0.8rem;
	font-weight: 500;
	color: #fff;
	transition: all 0.3s ease;
}
	.col-green .gig-clicked-flash {
		background-color: rgba(0, 79, 1, 0.25);
	}

	.col-green .gig-clicked-flash .gig-title {
		color: var(--brand-green);
		text-shadow: 0 0 15px var(--brand-green);
	}

	.col-orange .gig-clicked-flash {
		background-color: rgba(202, 120, 0, 0.25);
	}

	.col-orange .gig-clicked-flash .gig-title {
		color: var(--orange-color);
		text-shadow: 0 0 15px var(--orange-color);
	}

	.col-purple .gig-clicked-flash {
		background-color: rgba(101, 0, 181, 0.25);
	}

	.col-purple .gig-clicked-flash .gig-title {
		color: #ff4dff;
		text-shadow: 0 0 15px #ff4dff;
	}

.text-section {
	font-size: 14px;
}

.text-primary-accent {
	color: var(--primary-color);
	font-size: 13px;
}
.section-title {
	font-size: 1.3rem;
	position: relative;
	text-align: center;
	color: var(--primary-color);
}

.section-title::after {
	content: "";
	position: absolute;
	left: 50%;
	bottom: 0;
	transform: translateX(-50%);
	width: 40px;
	height: 2px;
	background-color: var(--primary-color);
}

.overlay-content {
	position: relative;
	border-radius: 12px;
	padding: 80px 40px 60px;
	max-width: 800px;
	width: 95%;
	box-shadow: 0 0 30px rgba(188, 19, 254, 0.2);
	overflow: hidden;
	border: 1px solid rgba(188, 19, 254, 0.3);
	z-index: 2;
}

.overlay-content::before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background: linear-gradient(rgba(18, 16, 16, 0) 50%, rgba(0, 0, 0, 0.1) 50%),
		linear-gradient(90deg, rgba(255, 0, 0, 0.03), rgba(0, 255, 0, 0.01), rgba(0, 0, 255, 0.03));
	background-size:
		100% 3px,
		3px 100%;
	z-index: 1;
	pointer-events: none;
}

/* ► min-width: 768px */
.overlay-content {
	padding: 40px 15px 30px;
	width: 90%;
}

.overlay-h4-style {
	color: var(--primary-color);
	font-size: 1.3rem;
	margin-top: 2rem;
	-webkit-font-smoothing: antialiased;
}


.overlay-h4-style {
	font-size: 1.2rem;
}

.glass-overlay {
	position: fixed;
	top: 0;
	left: 0;
	width: 100vw;
	height: 100vh;
	background: rgba(5, 5, 5, 0.85);
	backdrop-filter: blur(20px);
	-webkit-backdrop-filter: blur(20px);
	z-index: 9999;
	display: flex;
	align-items: center;
	justify-content: center;
	opacity: 0;
	pointer-events: none;
	transition: opacity 0.4s ease;
}

.glass-overlay.active {
	opacity: 1;
	pointer-events: all;
}

#artist-overlay .overlay-content {
	background:
		linear-gradient(rgba(10, 10, 10, 0.55), rgba(10, 10, 10, 0.7)),
		url("/img/artist3.webp") center/cover no-repeat;
}

.artist-subtitle-style {
	color: var(--primary-color);
	letter-spacing: 3px;
	text-transform: uppercase;
}

.artist-subtitle {
	font-size: 0.8rem;
}

.social-icon-box {
	position: relative;
	display: flex;
	justify-content: center;
	align-items: center;
	width: 50px;
	height: 50px;
	background: linear-gradient(135deg, rgba(60, 10, 100, 0.9), rgba(20, 0, 40, 0.9));
	border: 2px solid var(--primary-color);
	border-radius: 16px;
	overflow: hidden;
	transition: all 0.3s ease;
	text-decoration: none;
}

.social-icon-box::after {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	width: 60%;
	height: 100%;
	background: linear-gradient(
		to right,
		rgba(255, 255, 255, 0) 0%,
		rgba(220, 130, 255, 0.5) 50%,
		rgba(255, 255, 255, 0) 100%
	);
	transform: skewX(-25deg) translateX(-300%);
	animation: shine-sweep-main 3.5s infinite;
	pointer-events: none;
	z-index: 3;
}

.close-btn {
		-webkit-appearance: none;
	position: absolute;
	background: linear-gradient(135deg, rgba(60, 10, 100, 0.9), rgba(20, 0, 40, 0.9));
	border: 2px solid var(--primary-color);
	border-radius: 12px;
	color: #ffffff;
	font-size: 1.2rem;
	display: flex;
	align-items: center;
	justify-content: center;
	line-height: 0;
	cursor: pointer;
	overflow: hidden;
	transition: all 0.3s ease;
	top: 10px;
	right: 15px;
	width: 35px;
	height: 30px;
}

.close-btn::after {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	width: 60%;
	height: 100%;
	background: linear-gradient(
		to right,
		rgba(255, 255, 255, 0) 0%,
		rgba(220, 130, 255, 0.5) 50%,
		rgba(255, 255, 255, 0) 100%
	);
	transform: skewX(-25deg) translateX(-300%);
	animation: shine-sweep-rare 6s infinite;
	pointer-events: none;
}

.close-btn:hover {

	transform: scale(1.2);
	background: linear-gradient(135deg, rgba(80, 15, 130, 1), rgba(30, 0, 60, 1));
	box-shadow: 0 0 20px rgba(188, 19, 254, 0.6);
}
.social-icon-box:hover {
	transform: translateY(-5px);
	background: linear-gradient(135deg, rgba(80, 15, 130, 1), rgba(30, 0, 60, 1));
	box-shadow: 0 0 20px rgba(188, 19, 254, 0.6);
}


.social-icon-img {
	width: 25px;
	height: 25px;
		object-fit: contain;
		z-index: 2;
}

.social-icons-grid {
	display: flex;
	justify-content: center;
	gap: 20px;
	flex-wrap: wrap;
}

#social-overlay .overlay-content {
	background:
		linear-gradient(rgba(10, 10, 10, 0.6), rgba(10, 10, 10, 0.75)),
		url("/img/social.webp") center/cover no-repeat;
}

#impressum-overlay .overlay-content {
	background:
		linear-gradient(rgba(10, 10, 10, 0.65), rgba(10, 10, 10, 0.8)),
		url("/img/impressum_smartphone.webp") center/cover no-repeat;
}

.footer {
	position: fixed;
	bottom: 0;
	left: 0;
	width: 100%;
	height: calc(50px + env(safe-area-inset-bottom));
	padding-bottom: env(safe-area-inset-bottom);
	box-sizing: border-box;
	background: #000000;
	border-top: 1px solid rgba(255, 255, 255, 0.1);
	display: flex;
	align-items: center;
	justify-content: center;
	z-index: 1000;
}

.nav-link {
	color: var(--text-color);
	text-transform: uppercase;
	font-weight: 600;
	text-decoration: none;
	transition:
		color 0.3s,
		text-shadow 0.3s;
	font-family: "Poppins", sans-serif;
	letter-spacing: 1.5px;
	font-size: 0.7rem;
	padding: 0.5rem 0.8rem;
}

.nav-link:hover {
	color: var(--primary-color);
	text-shadow: 0 0 10px rgba(188, 19, 254, 0.5);
}