/* ―――――― [ SCHRIFTARTEN ] ―――――― */
@charset "UTF-8";

@font-face {
  font-family: "VIKING-N";
  src: url("webfonts/VIKING-N.woff2") format("woff2"),
    url("webfonts/VIKING-N.woff") format("woff");
  font-weight: bold;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: "Dungeon";
  src: url("webfonts/dungeon.woff2") format("woff2"),
    url("webfonts/dungeon.woff") format("woff");
  font-weight: bold;
  font-style: normal;
  font-display: swap;
}

/* ―――――― [ FARBEN ] ―――――― */
:root {
  /* HELL */
  --color1: #908C8C;
  --color2: #868282;
  --color3: #2B3237;
  --color4: #9a9696;
  --color5: #a3a0a0;
  --color6: #7d7878;

  --accent1: #484255;
  --accent2: #554F59;
  --accent3: #606744;
  --accent4: #5F5D66;

  --sparkle-color: #BDB28C;
  --scrollbar-bg: #908C8C;
  --scrollbar-thumb: #BDB28C;

  --header-bg: url("../img/design/header.jpg");
}

/* ―――――― [ RESET ] ―――――― */
html {
  scrollbar-width: thin;
  scrollbar-color: var(--scrollbar-thumb) var(--scrollbar-bg);
  transition: background 0.6s ease, color 0.6s ease, filter 0.6s ease;
}

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

body {
  background: var(--color1);
  font: 105% Calibri;
  text-align: justify;
  color: var(--color3);
  margin: 0px auto;
  scrollbar-width: thin;
  scrollbar-color: var(--scrollbar-thumb) var(--scrollbar-bg);
  transition: background 0.6s ease, color 0.6s ease, filter 0.6s ease;
}

::selection {
  color: var(--color5);
  background-color: var(--color1);
}

a {
  text-decoration: none;
  transition: all 0.5s ease-in-out;
}

p {
  margin: 0 auto 20px;
}

.left {
  float: left;
}

.right {
  float: right;
}

.spacer {
  clear: both;
}

b,
strong {
  color: var(--accent3);
}

i,
em {
  color: var(--accent2);
}

u {
  text-decoration: none;
  border-bottom: 2px solid var(--accent4);
}

/* ―――――― [ STANDARTGERÜST ] ―――――― */
#header {
  width: 50%;
  height: 100vh;
  margin: 0 auto;
  background-image: var(--header-bg);
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
  padding: 20px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  color: #ababab;
}

#container {
  display: flex;
  height: 100vh;
  min-width: 950px;
}

.content-wrapper {
  flex: 1;
  display: flex;
  flex-direction: column;
  height: 100vh;
  overflow-y: auto;
  scrollbar-width: thin;
}

#content {
  flex: 1;
  padding: 20px;
}

.page-nav-container {
  margin-top: 30px;
}

#sidebar {
  display: flex;
  justify-content: center;
  gap: 10px;
  background: linear-gradient(180deg, var(--color2) 0%, var(--color1) 100%);
}

#footer {
  position: absolute;
  font-size: 11pt;
  bottom: 0;
  left: 0;
  width: 900px;
  padding: 15px 20px;
  text-align: center;
  color: #ffffff;
  text-transform: uppercase;
  z-index: 2;
  text-shadow: 0 0 10px #ffffff, 2px 7px 4px rgba(255, 255, 255, 0);
}

/* ―――――― [ SPARKLE ETC ] ―――――― */
.sparkle-box {
  position: relative;
  display: inline-block;
}

body.dark .sparkle-canvas {
  opacity: 0;
}

.sparkle-canvas {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
  z-index: 5;
}

#bloodParticles {
  position: fixed;
  top: 0;
  left: 0;
  width: 900px;
  height: 100vh;
  pointer-events: none;
  z-index: 2;
  opacity: 0;
  transition: opacity 1.5s ease;
}

body.dark #bloodParticles {
  opacity: 1;
}

/* ―――――― [ ÜBERSCHRIFTEN ] ―――――― */
#content h1 {
  font-size: 25pt;
}

#sidebar h1,
#content h2 {
  font-size: 130%;
}

#content h3,
#sidebar h2 {
  font-size: 105%;
}

/* ―――――― [ LINKS ] ―――――― */
#content a {
  color: var(--accent2);
  transition: 0.3s ease;
}

#content a:hover {
  color: var(--accent1);
  text-shadow: 0 0 6px var(--sparkle-color);
}

#sidebar a {
  text-decoration: none;
  color: var(--accent3);
  text-transform: uppercase;
  display: block;
}

#sidebar a:hover {
  text-decoration: none;
  color: var(--accent1);
}

/* ―――――― [ LISTEN ] ―――――― */
#content ul {
  margin: 0 20px;
  padding: 0;
}

#content ol {
  margin: 0 20px;
  padding: 0;
}

#content ul li ul {
  margin: 0 15px;
  padding: 0 5px;
}

#content ul li::marker {
  content: "› ";
  color: var(--accent4);
}

#content ul li ul li::marker {
  content: "⤑ ";
  color: var(--accent1);
}

.tabs {
  display: flex;
  list-style: none;
  padding: 0;
  margin: 0 auto;
  justify-content: center;
}

.tabs li {
  margin: 0 5px;
}

.tabs li {
  display: block;
  padding: 10px 20px;
  text-decoration: none;
  border-bottom: none;
  background: var(--color2);
  color: var(--color3);
  cursor: pointer;
}

.tabs li:hover {
  background: var(--color4);
}

.tab-content {
  display: none;
  padding: 15px;
}

.tab-content.current {
  display: block;
}

.kv {
  display: grid;
  grid-template-columns: 350px 1fr;
  gap: 0.25rem 0.75rem;
}

.kv dt {
  font-weight: normal;
}

.kv dt:before {
  content: "› ";
  color: var(--accent4);
}

.kv dd {
  margin: 0;
}

/* ―――――― [ HR + TOOLTIP ] ―――――― */
hr {
  padding: 10px 0;
  border: none;
  border-top: none;
  text-align: center;
}

hr:after {
  content: "──────────── ▪ ✦ ▪ ────────────";
  font-size: 10pt;
  display: inline-block;
  position: relative;
  font-weight: thin;
  background: linear-gradient(to right,
      transparent,
      var(--color1),
      var(--accent2),
      var(--color1),
      transparent);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}

.tooltip {
  position: relative;
}

.tooltip::after {
  content: attr(data-title);
  position: absolute;
  bottom: 100%;
  left: 50%;
  transform: translateX(-50%);
  white-space: nowrap;

  background: var(--color2);
  color: var(--color3);
  padding: 6px 10px;
  border-radius: 6px;
  font-size: 0.85rem;
  line-height: 1.2;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.2s ease-in-out;
  z-index: 999;
}

.tooltip:hover::after,
.tooltip:hover::before {
  opacity: 1;
}

/* ―――――― [ SONSTIGES ] ―――――― */
.co1 {
  column-count: 2;
  column-gap: 30px;
}

.co2 {
  column-count: 3;
  column-gap: 30px;
}

.theme-icon {
  display: inline-block;
  cursor: pointer;
}

a.theme-icon::before {
  content: "";
}

/* ―――――― [ PAGINATION ] ―――――― */
#pagenavi {
  clear: both;
  margin: 0 auto;
  padding: 10px;
  text-align: center;
}

#pagenavi a {
  margin: 1px 20px;
  font-size: 12pt;
  text-decoration: none;
  text-transform: uppercase;
  word-spacing: 5px;
  color: var(--accent4);
}

#pagenavi .current {
  padding: 10px;
  font-size: 12pt;
  margin: 1px auto;
  text-transform: uppercase;
  background: var(--color1);
  color: var(--accent1);
}

#pagenavi .pages {
  color: var(--color3);
  padding: 10px;
  margin: 5px;
  font-size: 12pt;
}

#pagenavi .pages::before {
  content: "|";
  color: var(--color5);
  margin: 5px 20px 5px 5px;
}

#pagenavi .disabled {
  margin: 1px 20px;
  font-size: 12pt;
  text-decoration: none;
  text-transform: uppercase;
  word-spacing: 5px;
  color: var(--color5);
}

/* ―――――― [ BILDER ] ―――――― */
.img {
  object-fit: cover;
  width: 100%;
  height: 150px;
  margin: 5px;
  padding: 10px;
  border: 1px solid var(--color2);
  background: var(--color2);
  image-rendering: pixelated;
}

.img.top {
  object-fit: cover;
  width: 100%;
  height: 250px;
  margin: 10px auto;
  padding: 10px;
  border: 1px solid var(--color2);
  background: var(--color2);
  display: block;
  image-rendering: pixelated;
}

.img.left {
  object-fit: cover;
  width: 200px;
  height: 350px;
  margin: 10px 10px 0;
  padding: 10px;
  float: inline-start;
  border: 1px solid var(--color2);
  background: var(--color2);
  image-rendering: pixelated;
}

/* Lightbox Overlay */
#lightbox {
	position: fixed;
	inset: 0;
	background: rgba(0, 0, 0, 0.85);
	display: none;
	justify-content: center;
	align-items: center;
	z-index: 9999;
}

#lightbox img {
	max-width: 90%;
	max-height: 90%;
	box-shadow: 0 0 25px rgba(0, 0, 0, 0.7);
}

#lightbox-close {
	position: absolute;
	top: 20px;
	right: 30px;
	color: #fff;
	font-size: 40px;
	cursor: pointer;
	user-select: none;
}