@charset "utf-8";

:root {
	--bg-base: #085781;
	--bg-deep: #043957;
	--ink-dark: #0d2d43;
	--ink-soft: #26495f;
	--ink-light: #f3fbff;
	--glass-strong: rgba(255, 255, 255, 0.92);
	--border-soft: rgba(255, 255, 255, 0.32);
}

* {
	box-sizing: border-box;
}

html,
body {
	height: 100%;
}

body {
	margin: 0;
	font-family: 'Merriweather Sans', sans-serif;
	color: var(--ink-light);
	background:
		radial-gradient(circle at 18% 18%, rgba(86, 212, 255, 0.34), transparent 42%),
		radial-gradient(circle at 82% 0%, rgba(252, 202, 128, 0.42), transparent 38%),
		linear-gradient(145deg, var(--bg-base) 0%, var(--bg-deep) 64%, #022235 100%);
	display: flex;
	align-items: center;
	justify-content: center;
	overflow: hidden;
	position: relative;
}

body.theme-subpage.theme-about {
	background:
		radial-gradient(circle at 14% 16%, rgba(90, 216, 255, 0.34), transparent 42%),
		radial-gradient(circle at 84% 0%, rgba(176, 226, 255, 0.26), transparent 40%),
		linear-gradient(145deg, #0a5c88 0%, #07425f 60%, #03293f 100%);
}

body.theme-subpage.theme-ben {
	background:
		radial-gradient(circle at 14% 16%, rgba(90, 216, 255, 0.34), transparent 42%),
		radial-gradient(circle at 84% 0%, rgba(176, 226, 255, 0.26), transparent 40%),
		linear-gradient(145deg, #0a5c88 0%, #07425f 60%, #03293f 100%);
}

body.theme-subpage.theme-motorrad {
	background:
		radial-gradient(circle at 14% 16%, rgba(90, 216, 255, 0.34), transparent 42%),
		radial-gradient(circle at 84% 0%, rgba(176, 226, 255, 0.26), transparent 40%),
		linear-gradient(145deg, #0a5c88 0%, #07425f 60%, #03293f 100%);
}

body.theme-subpage.theme-gallery {
	background:
		radial-gradient(circle at 14% 16%, rgba(90, 216, 255, 0.34), transparent 42%),
		radial-gradient(circle at 84% 0%, rgba(176, 226, 255, 0.26), transparent 40%),
		linear-gradient(145deg, #0a5c88 0%, #07425f 60%, #03293f 100%);
}

body.theme-subpage.theme-links {
	background:
		radial-gradient(circle at 14% 16%, rgba(90, 216, 255, 0.34), transparent 42%),
		radial-gradient(circle at 84% 0%, rgba(176, 226, 255, 0.26), transparent 40%),
		linear-gradient(145deg, #0a5c88 0%, #07425f 60%, #03293f 100%);
}

body.theme-subpage.theme-informatiker {
	background:
		radial-gradient(circle at 14% 16%, rgba(90, 216, 255, 0.34), transparent 42%),
		radial-gradient(circle at 84% 0%, rgba(176, 226, 255, 0.26), transparent 40%),
		linear-gradient(145deg, #0a5c88 0%, #07425f 60%, #03293f 100%);
}

body.theme-subpage.theme-mediengestalter {
	background:
		radial-gradient(circle at 14% 16%, rgba(90, 216, 255, 0.34), transparent 42%),
		radial-gradient(circle at 84% 0%, rgba(176, 226, 255, 0.26), transparent 40%),
		linear-gradient(145deg, #0a5c88 0%, #07425f 60%, #03293f 100%);
}

body.theme-subpage.theme-tischler {
	background:
		radial-gradient(circle at 14% 16%, rgba(90, 216, 255, 0.34), transparent 42%),
		radial-gradient(circle at 84% 0%, rgba(176, 226, 255, 0.26), transparent 40%),
		linear-gradient(145deg, #0a5c88 0%, #07425f 60%, #03293f 100%);
}

body::before,
body::after {
	content: '';
	position: absolute;
	pointer-events: none;
	z-index: 0;
}

body::before {
	width: 48vmax;
	height: 48vmax;
	right: -18vmax;
	bottom: -20vmax;
	background: radial-gradient(circle, rgba(255, 255, 255, 0.14), transparent 60%);
}

body::after {
	width: 38vmax;
	height: 38vmax;
	left: -10vmax;
	top: 8vmax;
	background: radial-gradient(circle, rgba(94, 234, 212, 0.16), transparent 62%);
}

body.theme-subpage.theme-about::before {
	background: radial-gradient(circle, rgba(148, 228, 255, 0.18), transparent 60%);
}

body.theme-subpage.theme-about::after {
	background: radial-gradient(circle, rgba(118, 218, 255, 0.17), transparent 62%);
}

body.theme-subpage.theme-ben::before {
	background: radial-gradient(circle, rgba(148, 228, 255, 0.18), transparent 60%);
}

body.theme-subpage.theme-ben::after {
	background: radial-gradient(circle, rgba(118, 218, 255, 0.17), transparent 62%);
}

body.theme-subpage.theme-motorrad::before {
	background: radial-gradient(circle, rgba(148, 228, 255, 0.18), transparent 60%);
}

body.theme-subpage.theme-motorrad::after {
	background: radial-gradient(circle, rgba(118, 218, 255, 0.17), transparent 62%);
}

body.theme-subpage.theme-gallery::before {
	background: radial-gradient(circle, rgba(148, 228, 255, 0.18), transparent 60%);
}

body.theme-subpage.theme-gallery::after {
	background: radial-gradient(circle, rgba(118, 218, 255, 0.17), transparent 62%);
}

body.theme-subpage.theme-links::before {
	background: radial-gradient(circle, rgba(148, 228, 255, 0.18), transparent 60%);
}

body.theme-subpage.theme-links::after {
	background: radial-gradient(circle, rgba(118, 218, 255, 0.17), transparent 62%);
}

body.theme-subpage.theme-informatiker::before {
	background: radial-gradient(circle, rgba(148, 228, 255, 0.18), transparent 60%);
}

body.theme-subpage.theme-informatiker::after {
	background: radial-gradient(circle, rgba(118, 218, 255, 0.17), transparent 62%);
}

body.theme-subpage.theme-mediengestalter::before {
	background: radial-gradient(circle, rgba(148, 228, 255, 0.18), transparent 60%);
}

body.theme-subpage.theme-mediengestalter::after {
	background: radial-gradient(circle, rgba(118, 218, 255, 0.17), transparent 62%);
}

body.theme-subpage.theme-tischler::before {
	background: radial-gradient(circle, rgba(148, 228, 255, 0.18), transparent 60%);
}

body.theme-subpage.theme-tischler::after {
	background: radial-gradient(circle, rgba(118, 218, 255, 0.17), transparent 62%);
}

a {
	color: inherit;
}

#loading {
	font-size: clamp(1.1rem, 2.3vw, 1.55rem);
	font-weight: 300;
	display: none;
	justify-content: center;
	align-items: center;
	gap: 0.5rem;
	width: 100%;
	height: 100%;
	position: fixed;
	inset: 0;
	background: linear-gradient(140deg, #08608f 0%, #03283f 100%);
	z-index: 9999;
	letter-spacing: 0.02em;
}

#loading.is-visible {
	display: flex;
}

#menu {
	display: none;
	position: fixed;
	top: 20px;
	left: 20px;
	z-index: 100;
}

#menu.is-visible {
	display: block;
}

.burger-menu {
	font-size: 1.35rem;
	cursor: pointer;
	background: rgba(4, 33, 51, 0.54);
	border: 1px solid rgba(255, 255, 255, 0.5);
	color: #f7fdff;
	border-radius: 999px;
	width: 52px;
	height: 52px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	backdrop-filter: blur(6px);
	box-shadow: 0 10px 24px rgba(0, 0, 0, 0.24);
}

.burger-menu:hover {
	transform: translateY(-1px);
}

.burger-menu:focus-visible {
	outline: 2px solid rgba(255, 255, 255, 0.95);
	outline-offset: 4px;
}

.dropdown-content {
	display: none;
	position: absolute;
	top: 62px;
	left: 0;
	background: rgba(8, 40, 61, 0.96);
	min-width: 240px;
	border: 1px solid rgba(201, 239, 255, 0.28);
	border-radius: 16px;
	box-shadow: 0 18px 48px rgba(0, 0, 0, 0.36);
	overflow: hidden;
}

.dropdown-content a {
	color: #ecf9ff;
	padding: 0.72rem 0.96rem;
	text-decoration: none;
	display: block;
	white-space: nowrap;
	font-size: 0.95rem;
	letter-spacing: 0.01em;
}

.dropdown-content__section {
	margin: 0;
	padding: 0.62rem 0.96rem 0.3rem;
	font-size: 0.7rem;
	letter-spacing: 0.11em;
	text-transform: uppercase;
	color: rgba(156, 223, 252, 0.86);
	font-weight: 700;
}

.dropdown-content a:hover {
	background-color: rgba(110, 205, 255, 0.18);
}

.dropdown-content a.is-current {
	background: linear-gradient(90deg, rgba(48, 184, 243, 0.26), transparent);
	font-weight: 700;
}

.dropdown-content hr {
	margin: 0.3rem 0;
	border: 0;
	border-top: 1px solid rgba(255, 255, 255, 0.12);
}

.dropdown-content.show {
	display: block;
}

#content {
	display: none;
	width: 100%;
	height: 100%;
	align-items: center;
	justify-content: center;
	padding: clamp(0px, 2.8vw, 0px);
	position: relative;
	z-index: 1;
}

#content.is-visible {
	display: flex;
}

.page-home {
	padding: clamp(14px, 2vw, 22px) clamp(14px, 2.6vw, 28px);
}

#zoom-image {
	width: 100%;
	height: 100%;
	border-radius: 50%;
	object-fit: cover;
	border: 3px solid rgba(250, 254, 255, 0.84);
	box-shadow: 0 12px 28px rgba(0, 0, 0, 0.22);
	display: none;
}

#zoom-image.is-visible {
	display: block;
}

.image-empty-state {
	display: none;
	position: absolute;
	inset: 10px;
	border-radius: 50%;
	background: rgba(11, 52, 77, 0.78);
	color: #f3fbff;
	padding: 1.6rem;
	text-align: center;
	font-size: 0.95rem;
	line-height: 1.4;
	align-items: center;
	justify-content: center;
}

.image-empty-state.is-visible {
	display: flex;
}

code {
	background: rgba(31, 111, 154, 0.12);
	padding: 0.15rem 0.35rem;
	border-radius: 5px;
	font-size: 0.86em;
}

@media (max-width: 920px) {
	body {
		overflow: auto;
	}

	#content {
		height: auto;
		min-height: 100%;
	}
}

@media (max-width: 620px) {
	.dropdown-content {
		min-width: 210px;
	}
}
