/* NewPath – Echoes of the Wild Custom Styling */

:root {
  --np-bg-main: #0f2028;
  --np-bg-deep: #0c1114;

  --np-bg-content: #15384a;
  --np-bg-panel: #183f53;

  --np-bg-card: #184154;
  --np-bg-card-hover: #21556d;

  --np-stone: #20292d;
  --np-stone-light: #303b40;

  --np-neutral-bg: #15191c;
  --np-neutral-bg-light: #1b2024;
  --np-neutral-panel: #171f24;

  --np-border: rgba(72, 122, 146, 0.78);
  --np-border-soft: rgba(72, 122, 146, 0.38);

  --np-text: #f5eadc;
  --np-text-muted: #d8ddd6;

  --np-gold: #ecb76e;
  --np-gold-soft: #f4cf7f;

  --np-cyan: #00e6f6;
  --np-cyan-soft: rgba(0, 230, 246, 0.18);

  --np-moss: #6f824b;
  --np-moss-soft: rgba(111, 130, 75, 0.22);

  --np-petrol: #15384a;
  --np-petrol-light: #35657d;
  --np-petrol-soft: rgba(21, 56, 74, 0.55);
}

/* Gesamtfläche */

body {
  background:
    linear-gradient(
      180deg,
      rgba(8, 10, 11, 0.30) 0%,
      rgba(8, 10, 11, 0.40) 46%,
      rgba(6, 8, 9, 0.56) 100%
    ),
    radial-gradient(circle at 18% 16%, rgba(255, 255, 255, 0.012), transparent 34rem),
    radial-gradient(circle at 84% 22%, rgba(0, 230, 246, 0.018), transparent 36rem),
    url("../images/background-site.webp"),
    linear-gradient(180deg, #181b1d 0%, #121516 48%, #0b0d0e 100%);
  background-size: cover, auto, auto, cover, auto;
  background-position: center top, center, center, center top, center;
  background-repeat: no-repeat, no-repeat, no-repeat, no-repeat, no-repeat;
  background-attachment: fixed;
  color: var(--np-text);
}

/* Hauptbereich */

.main {
  min-height: 100vh;
  position: relative;
  background: transparent !important;
  box-shadow: none !important;
}

.main-content-wrap {
  max-width: 1120px;
  min-height: calc(100vh - 4.45rem);
  background:
    radial-gradient(circle at 100% 12%, rgba(53, 101, 125, 0.13), transparent 24rem),
    radial-gradient(circle at 50% 100%, rgba(53, 101, 125, 0.09), transparent 34rem),
    linear-gradient(180deg, rgba(20, 52, 67, 0.88), rgba(14, 34, 43, 0.90) 68%, rgba(12, 28, 35, 0.90));
  border-left: 1px solid rgba(72, 122, 146, 0.12);
  border-right: 1px solid rgba(72, 122, 146, 0.14);
  box-shadow:
    24px 0 46px rgba(5, 11, 14, 0.24),
    -24px 0 46px rgba(5, 11, 14, 0.22),
    0 22px 42px rgba(0, 0, 0, 0.16);
}

.main-content {
  position: relative;
  padding-top: 1.65rem;
  padding-bottom: 4rem;
  line-height: 1.65;
  color: var(--np-text);
}

/* Layout-Zentrierung für große Bildschirme */

@media (min-width: 66.5rem) {
  .side-bar {
    display: none !important;
  }

  .main {
    width: 100% !important;
    max-width: none !important;
    margin-left: 0 !important;
    background: transparent !important;
  }

  .main-header {
    position: sticky !important;
    top: 0 !important;
    left: 0 !important;
    right: 0 !important;
    z-index: 50 !important;
    width: 100% !important;
    max-width: none !important;
    min-height: 5rem !important;
    height: 5rem !important;
    max-height: 5rem !important;
    padding: 0 2rem !important;
    display: flex !important;
    align-items: center !important;
    gap: 1rem !important;
    overflow: visible !important;
    background:
      linear-gradient(180deg, rgba(0, 9, 15, 0.96), rgba(0, 18, 33, 0.91)) !important;
    border-bottom: 1px solid rgba(0, 230, 246, 0.16) !important;
    border-radius: 0 !important;
    box-shadow: 0 14px 36px rgba(0, 0, 0, 0.34) !important;
  }

  .main-content-wrap {
    width: 100% !important;
    max-width: none !important;
    min-height: calc(100vh - 5rem);
    border-left: 0;
    border-right: 0;
    border-radius: 0 !important;
    box-shadow: none;
  }

  .main-content {
    width: min(1400px, calc(100% - 5.2rem)) !important;
    max-width: 1400px !important;
    margin: 0 auto !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
    border-radius: 0 !important;
  }
}

/* Desktop-Topbar Navigation */

.np-topbar-brand,
.np-top-nav {
  display: none;
}

@media (min-width: 66.5rem) {
  .np-topbar-brand {
    display: inline-flex;
    align-items: center;
    gap: 0.75rem;
    flex: 0 0 auto;
    color: var(--np-gold);
    font-weight: 900;
    letter-spacing: 0.01em;
    text-decoration: none;
    white-space: nowrap;
  }

  .np-topbar-brand:hover {
    color: var(--np-gold-soft);
    text-decoration: none;
    background: transparent;
  }

  .np-topbar-logo {
    width: 3.15rem;
    height: 3.15rem;
    object-fit: contain;
    filter:
      drop-shadow(0 0 10px rgba(0, 230, 246, 0.18))
      drop-shadow(0 8px 14px rgba(0, 0, 0, 0.24));
  }

  .np-topbar-title {
    display: inline-flex;
    flex-direction: column;
    line-height: 1.05;
  }

  .np-topbar-title span:first-child {
    font-size: 1.18rem;
  }

  .np-topbar-title span:last-child {
    margin-top: 0.12rem;
    color: rgba(0, 230, 246, 0.78);
    font-size: 0.70rem;
    font-weight: 850;
    letter-spacing: 0.12em;
    text-transform: uppercase;
  }

  .np-top-nav {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.25rem;
    flex: 1 1 auto;
    min-width: 0;
  }

  .np-top-nav a {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 2.3rem;
    padding: 0.45rem 0.72rem;
    border: 1px solid transparent;
    border-radius: 999px;
    color: var(--np-text-muted);
    font-size: 0.86rem;
    font-weight: 800;
    line-height: 1;
    text-decoration: none;
    white-space: nowrap;
    transition:
      color 0.15s ease,
      border-color 0.15s ease,
      background 0.15s ease,
      box-shadow 0.15s ease;
  }

  .np-top-nav a:hover {
    color: var(--np-cyan);
    border-color: rgba(0, 230, 246, 0.25);
    background: rgba(0, 230, 246, 0.065);
    text-decoration: none;
  }

  .np-top-nav a.active {
    color: var(--np-gold);
    border-color: rgba(236, 183, 110, 0.30);
    background:
      radial-gradient(circle at top left, rgba(236, 183, 110, 0.10), transparent 58%),
      linear-gradient(180deg, rgba(21, 56, 74, 0.70), rgba(11, 24, 30, 0.62));
    box-shadow: 0 0 16px rgba(236, 183, 110, 0.08);
  }
}

/* Sidebar */

.side-bar {
  background:
    linear-gradient(
      180deg,
      transparent 0,
      transparent 4.25rem,
      rgba(19, 41, 50, 0.82) 4.25rem,
      rgba(17, 35, 43, 0.82) 54%,
      rgba(12, 27, 34, 0.86) 100%
    ),
    radial-gradient(circle at 18% 18%, rgba(53, 101, 125, 0.12), transparent 18rem),
    radial-gradient(circle at 92% 46%, rgba(0, 230, 246, 0.035), transparent 17rem);
  border-right: 1px solid rgba(72, 122, 146, 0.10);
  box-shadow:
    22px 0 50px rgba(5, 16, 21, 0.18),
    -26px 0 54px rgba(5, 8, 9, 0.22);
}

.site-header {
  position: relative;
  min-height: 4.25rem;
  height: 4.25rem;
  max-height: 4.25rem;
  padding: 0 1rem;
  box-sizing: border-box;
  display: flex;
  align-items: center;
  overflow: visible;
  background: transparent !important;
  border-bottom: 0 !important;
  box-shadow: none !important;
}

.site-header::after {
  display: none !important;
  content: none !important;
}

.site-title {
  color: var(--np-gold);
  font-size: 1.15rem;
  font-weight: 800;
  font-size: 0.78rem;
  letter-spacing: 0.01em;
  white-space: nowrap;
  text-shadow: 0 0 16px rgba(236, 183, 110, 0.14);
}

.site-title:hover {
  color: var(--np-gold-soft);
  background: transparent;
}

.site-nav {
  padding-top: 1.25rem;
}

/* Navigation */

.nav-list .nav-list-item {
  margin: 0.1rem 0;
}

.nav-list .nav-list-item .nav-list-link {
  color: var(--np-text-muted);
  border-radius: 0.45rem;
  transition:
    color 0.15s ease,
    background 0.15s ease,
    border-color 0.15s ease,
    box-shadow 0.15s ease;
}

.nav-list .nav-list-item .nav-list-link:hover {
  color: var(--np-cyan);
  background: rgba(0, 230, 246, 0.065);
}

.nav-list .nav-list-item .nav-list-link.active {
  color: var(--np-cyan);
  background:
    linear-gradient(90deg, rgba(111, 130, 75, 0.16), rgba(21, 56, 74, 0.30));
  font-weight: 700;
  border-left: 3px solid var(--np-moss);
  box-shadow:
    inset 0 0 0 1px rgba(72, 122, 146, 0.20),
    0 0 16px rgba(0, 230, 246, 0.035);
}

/* Moderner Kopfbereich / Suche */

.main-header {
  position: sticky;
  top: 0;
  z-index: 20;
  min-height: 4.25rem;
  height: 4.25rem;
  max-height: 4.25rem;
  padding: 0.42rem 1.2rem;
  box-sizing: border-box;
  display: flex;
  align-items: center;
  gap: 1rem;
  overflow: visible;
  background: transparent !important;
  border-bottom: 0 !important;
  box-shadow: none !important;
}

.main-header::before {
  display: none !important;
  content: none !important;
}

/* Suche */

@media (min-width: 66.5rem) {
  .main-header .search {
    flex: 0 1 320px !important;
    max-width: 320px !important;
    margin-left: auto !important;
  }

  .main-header .aux-nav {
    margin-left: 0.35rem !important;
  }
}

.search {
  flex: 1 1 auto;
  display: flex !important;
  justify-content: center;
  align-items: center;
  background: transparent !important;
  border: 0 !important;
}

.search-input-wrap {
  width: min(320px, 100%);
  max-width: 320px;
  min-height: 2.05rem;
  padding: 0 0.72rem;
  display: flex;
  align-items: center;
  border: 1px solid rgba(72, 122, 146, 0.52);
  border-radius: 999px;
  background:
    linear-gradient(180deg, rgba(14, 18, 20, 0.92), rgba(21, 56, 74, 0.48));
  box-shadow:
    inset 0 0 0 1px rgba(0, 230, 246, 0.04),
    0 8px 18px rgba(0, 0, 0, 0.13);
  overflow: hidden;
  transition:
    border-color 0.16s ease,
    box-shadow 0.16s ease,
    background 0.16s ease;
}

.search-input-wrap:focus-within {
  border-color: rgba(0, 230, 246, 0.70);
  background:
    linear-gradient(180deg, rgba(14, 18, 20, 0.98), rgba(21, 56, 74, 0.62));
  box-shadow:
    0 0 0 2px rgba(0, 230, 246, 0.12),
    0 8px 18px rgba(0, 0, 0, 0.15);
}

.search-input {
  width: 100%;
  min-height: 1.95rem;
  border: 0 !important;
  border-radius: 999px !important;
  background: transparent !important;
  color: var(--np-text) !important;
  box-shadow: none !important;
  outline: none !important;
}

.search-input:focus {
  border: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
  outline: none !important;
}

.search-input::placeholder {
  color: rgba(245, 234, 220, 0.58);
}

.search-label .search-icon {
  color: rgba(0, 230, 246, 0.74);
}

/* Suchergebnisse */

.search-results {
  background: rgba(14, 18, 20, 0.98);
  border: 1px solid rgba(72, 122, 146, 0.46);
  border-radius: 0.75rem;
  box-shadow: 0 18px 38px rgba(0, 0, 0, 0.30);
}

.search-result {
  border-bottom: 1px solid rgba(72, 122, 146, 0.18);
}

.search-result-title {
  color: var(--np-cyan);
}

.search-result-preview {
  color: var(--np-text-muted);
}

/* Discord-Button rechts */

.aux-nav {
  flex: 0 0 auto;
  padding-right: 0.2rem;
}

.aux-nav a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.48rem;
  min-height: 2.1rem;
  color: var(--np-cyan);
  border: 1px solid rgba(0, 230, 246, 0.36);
  border-radius: 999px;
  padding: 0.36rem 0.85rem;
  background:
    radial-gradient(circle at top left, rgba(0, 230, 246, 0.085), transparent 60%),
    linear-gradient(180deg, rgba(14, 18, 20, 0.72), rgba(21, 56, 74, 0.48));
  font-weight: 800;
  font-size: 0.78rem;
  letter-spacing: 0.01em;
  line-height: 1;
  text-decoration: none;
  box-shadow:
    inset 0 0 0 1px rgba(0, 230, 246, 0.04),
    0 8px 18px rgba(0, 0, 0, 0.12);
  transition:
    background 0.15s ease,
    color 0.15s ease,
    box-shadow 0.15s ease,
    border-color 0.15s ease;
}

.aux-nav a::before {
  content: "";
  width: 0.9rem;
  height: 0.9rem;
  display: inline-block;
  flex: 0 0 auto;
  background-color: currentColor;
  opacity: 0.95;
  -webkit-mask-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 127.14 96.36' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M107.7 8.07A105.15 105.15 0 0 0 81.47 0a72.06 72.06 0 0 0-3.36 6.83 97.68 97.68 0 0 0-29.11 0A72.37 72.37 0 0 0 45.64 0 105.89 105.89 0 0 0 19.39 8.09C2.79 32.65-1.71 56.6.54 80.21A105.73 105.73 0 0 0 32.71 96.36a77.7 77.7 0 0 0 6.89-11.11 68.42 68.42 0 0 1-10.85-5.18c.91-.66 1.8-1.34 2.66-2a75.57 75.57 0 0 0 64.28 0c.87.71 1.76 1.39 2.66 2a68.68 68.68 0 0 1-10.87 5.19 77 77 0 0 0 6.89 11.1A105.25 105.25 0 0 0 126.6 80.2c2.64-27.38-4.51-51.11-18.9-72.13ZM42.45 65.69C36.18 65.69 31 60 31 53s5-12.74 11.43-12.74S54 46 53.89 53 48.84 65.69 42.45 65.69Zm42.24 0C78.41 65.69 73.25 60 73.25 53s5-12.74 11.44-12.74S96.25 46 96.14 53 91.08 65.69 84.69 65.69Z'/%3E%3C/svg%3E");
  mask-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 127.14 96.36' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M107.7 8.07A105.15 105.15 0 0 0 81.47 0a72.06 72.06 0 0 0-3.36 6.83 97.68 97.68 0 0 0-29.11 0A72.37 72.37 0 0 0 45.64 0 105.89 105.89 0 0 0 19.39 8.09C2.79 32.65-1.71 56.6.54 80.21A105.73 105.73 0 0 0 32.71 96.36a77.7 77.7 0 0 0 6.89-11.11 68.42 68.42 0 0 1-10.85-5.18c.91-.66 1.8-1.34 2.66-2a75.57 75.57 0 0 0 64.28 0c.87.71 1.76 1.39 2.66 2a68.68 68.68 0 0 1-10.87 5.19 77 77 0 0 0 6.89 11.1A105.25 105.25 0 0 0 126.6 80.2c2.64-27.38-4.51-51.11-18.9-72.13ZM42.45 65.69C36.18 65.69 31 60 31 53s5-12.74 11.43-12.74S54 46 53.89 53 48.84 65.69 42.45 65.69Zm42.24 0C78.41 65.69 73.25 60 73.25 53s5-12.74 11.44-12.74S96.25 46 96.14 53 91.08 65.69 84.69 65.69Z'/%3E%3C/svg%3E");
  -webkit-mask-repeat: no-repeat;
  mask-repeat: no-repeat;
  -webkit-mask-position: center;
  mask-position: center;
  -webkit-mask-size: contain;
  mask-size: contain;
}

.aux-nav a:hover {
  color: #7ff8ff;
  border-color: rgba(0, 230, 246, 0.58);
  background:
    radial-gradient(circle at top left, rgba(0, 230, 246, 0.15), transparent 60%),
    linear-gradient(180deg, rgba(0, 230, 246, 0.11), rgba(21, 56, 74, 0.60));
  box-shadow:
    0 0 20px rgba(0, 230, 246, 0.15),
    0 8px 18px rgba(0, 0, 0, 0.17);
  transform: none;
}

/* Typografie */

.main-content h1 {
  max-width: 760px;
  color: var(--np-gold);
  font-size: 2.25rem;
  font-weight: 550;
  letter-spacing: 0.01em;
  margin-bottom: 0.75rem;
}

.main-content h2 {
  color: var(--np-gold);
  margin-top: 2.25rem;
  padding-bottom: 0.4rem;
  border-bottom: 1px solid var(--np-border-soft);
}

.main-content h3 {
  color: var(--np-gold-soft);
}

.main-content p,
.main-content li {
  color: var(--np-text);
  font-size: 0.98rem;
}

.main-content > p {
  max-width: 860px;
}

.main-content strong {
  color: var(--np-gold-soft);
}

.main-content a {
  color: var(--np-cyan);
  text-decoration-thickness: 2px;
  text-underline-offset: 0.18rem;
}

.main-content a:hover {
  color: #7ff8ff;
}

/* Moderner Hero-Bereich */

.np-hero {
  position: relative;
  display: grid;
  grid-template-columns: minmax(0, 1fr) 320px;
  gap: 2.25rem;
  align-items: center;
  margin: 0 0 1.35rem;
  padding: 1.75rem 2.35rem;
  border: 1px solid var(--np-border-soft);
  border-top: 1px solid rgba(236, 183, 110, 0.28);
  border-radius: 1.1rem;
  background:
    radial-gradient(circle at 78% 42%, rgba(0, 230, 246, 0.13), transparent 18rem),
    radial-gradient(circle at 0% 0%, rgba(236, 183, 110, 0.08), transparent 18rem),
    linear-gradient(90deg, rgba(111, 130, 75, 0.08), transparent 24%),
    linear-gradient(135deg, rgba(72, 122, 146, 0.44), rgba(21, 56, 74, 0.88) 46%, rgba(4, 13, 18, 0.96));
  box-shadow: 0 18px 38px rgba(0, 0, 0, 0.26);
  overflow: hidden;
}

.np-hero::before {
  content: "";
  position: absolute;
  left: 1.25rem;
  right: 1.25rem;
  top: 0;
  height: 2px;
  border-radius: 999px;
  background: linear-gradient(90deg, var(--np-moss), rgba(236, 183, 110, 0.86), rgba(0, 230, 246, 0.72));
  opacity: 0.62;
}

.np-hero::after {
  content: "";
  position: absolute;
  right: -4rem;
  bottom: -4rem;
  width: 16rem;
  height: 16rem;
  border-radius: 999px;
  background: radial-gradient(circle, rgba(0, 230, 246, 0.08), transparent 62%);
  pointer-events: none;
}

.np-hero-content {
  position: relative;
  z-index: 1;
}

.np-kicker {
  margin: 0 0 0.5rem;
  color: var(--np-cyan);
  font-size: 0.74rem;
  font-weight: 800;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.np-hero h1 {
  margin: 0 0 0.72rem;
  padding: 0;
  border: 0;
  color: var(--np-gold);
  font-size: clamp(3rem, 4.3vw, 4.35rem);
  line-height: 0.96;
  letter-spacing: -0.045em;
  text-wrap: balance;
}


.np-hero-title-main,
.np-hero-title-sub {
  display: block;
}

.np-hero-title-main {
  color: #f4cf7f;
}

.np-hero-title-sub {
  margin-top: 0.18rem;
  color: var(--np-gold);
  font-size: 0.74em;
  letter-spacing: -0.025em;
}

.np-hero-text {
  max-width: 760px;
  margin: 0 0 1rem;
  color: var(--np-text);
  font-size: 1rem;
}

.np-hero-highlight {
  max-width: 800px;
  padding: 0.82rem 1rem;
  border: 1px solid rgba(72, 122, 146, 0.78);
  border-left: 4px solid var(--np-moss);
  border-radius: 0.75rem;
  background:
    linear-gradient(135deg, rgba(111, 130, 75, 0.08), transparent 42%),
    rgba(11, 24, 30, 0.66);
  color: var(--np-text-muted);
}

.np-hero-logo {
  position: relative;
  z-index: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  width: min(285px, 100%);
  height: 285px;
  justify-self: center;
  opacity: 0.98;
  transition: transform 0.16s ease, opacity 0.16s ease;
}

.np-hero-logo:hover {
  transform: scale(1.055) translateY(-2px);
  opacity: 1;
  filter:
    drop-shadow(0 0 16px rgba(0, 230, 246, 0.32))
    drop-shadow(0 12px 22px rgba(0, 0, 0, 0.34));
}

.np-hero-logo img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  border: 0;
  background: transparent;
}

/* ECHO – Wegbegleiter-Box Startseite */

.echo-guide-box {
  --echo-accent: var(--np-cyan);

  position: relative;
  display: grid;
  grid-template-columns: 166px minmax(0, 1fr);
  gap: 0.95rem;
  align-items: center;
  margin: 0 0 1.75rem;
  padding: 0.95rem 1.35rem 0.95rem 1.55rem;
  min-height: 152px;
  border: 1px solid rgba(72, 122, 146, 0.56);
  border-radius: 0.95rem;
  background:
    linear-gradient(var(--echo-accent), var(--echo-accent)) left 1.05rem top 1.2rem / 3px calc(100% - 2.4rem) no-repeat,
    radial-gradient(circle at 8% 50%, rgba(0, 230, 246, 0.10), transparent 12rem),
    radial-gradient(circle at 100% 50%, rgba(111, 130, 75, 0.08), transparent 16rem),
    linear-gradient(135deg, rgba(21, 56, 74, 0.82), rgba(11, 24, 30, 0.86));
  box-shadow: 0 14px 30px rgba(0, 0, 0, 0.20);
  overflow: hidden;
}

.echo-guide-box::before {
  content: "";
  position: absolute;
  left: 1.55rem;
  right: 1.35rem;
  top: 0;
  height: 1px;
  background: linear-gradient(90deg, rgba(0, 230, 246, 0.50), rgba(236, 183, 110, 0.18), transparent);
  opacity: 0.75;
  pointer-events: none;
}

.echo-guide-box::after {
  content: "";
  position: absolute;
  right: -4rem;
  top: -4rem;
  width: 11rem;
  height: 11rem;
  border-radius: 999px;
  background: radial-gradient(circle, rgba(0, 230, 246, 0.075), transparent 65%);
  pointer-events: none;
}

.echo-guide-image {
  position: relative;
  z-index: 1;
  height: 136px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.echo-guide-image img {
  width: 138px;
  max-width: 100%;
  height: auto;
  object-fit: contain;
  transition: transform 0.16s ease, opacity 0.16s ease;
  filter:
    drop-shadow(0 0 14px rgba(0, 230, 246, 0.22))
    drop-shadow(0 13px 22px rgba(0, 0, 0, 0.36));
}

.echo-guide-image img:hover {
  transform: scale(1.08) translateY(-2px);
  opacity: 1;
  filter:
    drop-shadow(0 0 18px rgba(0, 230, 246, 0.38))
    drop-shadow(0 16px 26px rgba(0, 0, 0, 0.42));
}

.echo-guide-content {
  position: relative;
  z-index: 1;
  align-self: center;
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.echo-guide-kicker {
  margin: 0 0 0.2rem;
  color: var(--np-cyan);
  font-size: 0.76rem;
  font-weight: 800;
  letter-spacing: 0.1em;
  text-transform: uppercase;
}

.echo-guide-content h2 {
  margin: 0 0 0.35rem;
  padding: 0;
  border: 0;
  color: var(--np-gold);
  font-size: 1.42rem;
  line-height: 1.2;
}

.echo-guide-content p {
  max-width: 820px;
  margin: 0;
  color: var(--np-text-muted);
  font-size: 0.94rem;
  line-height: 1.5;
}

/* ECHO – Themenboxen auf Unterseiten */

.echo-page-box {
  --echo-accent: var(--np-cyan);

  position: relative;
  display: grid;
  grid-template-columns: 154px minmax(0, 1fr);
  gap: 1.15rem;
  align-items: center;
  margin: 0 0 2rem;
  padding: 1.15rem 1.45rem 1.15rem 1.65rem;
  min-height: 154px;
  border: 1px solid rgba(72, 122, 146, 0.58);
  border-radius: 1rem;
  background:
    linear-gradient(var(--echo-accent), var(--echo-accent)) left 1.1rem top 1.2rem / 3px calc(100% - 2.4rem) no-repeat,
    radial-gradient(circle at 8% 50%, rgba(0, 230, 246, 0.09), transparent 13rem),
    radial-gradient(circle at 96% 18%, rgba(72, 122, 146, 0.14), transparent 18rem),
    linear-gradient(135deg, rgba(21, 56, 74, 0.84), rgba(11, 24, 30, 0.86));
  box-shadow:
    0 16px 34px rgba(0, 0, 0, 0.22),
    inset 0 0 0 1px rgba(0, 230, 246, 0.03);
  overflow: hidden;
}

.echo-page-box::before {
  content: "";
  position: absolute;
  left: 1.65rem;
  right: 1.45rem;
  top: 0;
  height: 2px;
  border-radius: 999px;
  background: linear-gradient(90deg, var(--echo-accent), rgba(236, 183, 110, 0.38), transparent);
  opacity: 0.72;
  pointer-events: none;
}

.echo-page-box::after {
  content: "";
  position: absolute;
  right: -5rem;
  bottom: -5rem;
  width: 15rem;
  height: 15rem;
  border-radius: 999px;
  background: radial-gradient(circle, rgba(0, 230, 246, 0.065), transparent 65%);
  pointer-events: none;
}

.echo-page-image {
  position: relative;
  z-index: 1;
  height: 136px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.echo-page-image img {
  width: 128px;
  max-width: 100%;
  height: auto;
  object-fit: contain;
  transition: transform 0.16s ease, opacity 0.16s ease;
  filter:
    drop-shadow(0 0 14px rgba(0, 230, 246, 0.22))
    drop-shadow(0 14px 24px rgba(0, 0, 0, 0.36));
}

.echo-page-image img:hover {
  transform: scale(1.08) translateY(-2px);
  opacity: 1;
  filter:
    drop-shadow(0 0 18px rgba(0, 230, 246, 0.38))
    drop-shadow(0 16px 26px rgba(0, 0, 0, 0.42));
}

.echo-page-content {
  position: relative;
  z-index: 1;
}

.echo-page-kicker {
  margin: 0 0 0.25rem;
  color: var(--np-cyan);
  font-size: 0.76rem;
  font-weight: 850;
  letter-spacing: 0.1em;
  text-transform: uppercase;
}

.echo-page-content h2 {
  margin: 0 0 0.4rem;
  padding: 0;
  border: 0;
  color: var(--np-gold);
  font-size: 1.5rem;
  line-height: 1.2;
}

.echo-page-content p {
  max-width: 840px;
  margin: 0;
  color: var(--np-text-muted);
  font-size: 0.95rem;
  line-height: 1.55;
}

/* Thematische Akzentfarben für Unterseiten */

.echo-page-box-rules {
  --echo-accent: var(--np-gold);
}

.echo-page-box-philosophy {
  --echo-accent: var(--np-moss);
}

.echo-page-box-faq {
  --echo-accent: var(--np-cyan);
}

.echo-page-box-server {
  --echo-accent: var(--np-petrol-light);
}

/* Alte Corner-Logo-Variante ausblenden */

.np-corner-logo {
  display: none;
}

/* Alte Highlight-Box, falls noch irgendwo genutzt */

.highlight-box {
  max-width: 860px;
  margin: 1.5rem 0;
  padding: 1.1rem 1.25rem;
  border: 1px solid var(--np-border);
  border-left: 4px solid var(--np-moss);
  border-radius: 0.7rem;
  background:
    linear-gradient(135deg, rgba(111, 130, 75, 0.1), transparent 55%),
    var(--np-bg-panel);
  color: var(--np-text);
  box-shadow: 0 12px 28px rgba(0, 0, 0, 0.20);
}

/* Schnellzugriff-Karten */

.np-card-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 1rem;
  margin: 1.35rem 0 1.85rem;
}

.np-card {
  position: relative;
  overflow: hidden;
  display: block;
  min-height: 124px;
  padding: 1rem 1.1rem;
  border: 1px solid rgba(72, 122, 146, 0.58);
  border-top-color: rgba(236, 183, 110, 0.20);
  border-radius: 0.9rem;
  background:
    linear-gradient(135deg, rgba(255, 255, 255, 0.035), transparent 35%),
    linear-gradient(145deg, rgba(111, 130, 75, 0.075), transparent 52%),
    linear-gradient(180deg, #1b3038, #14282f);
  text-decoration: none;
  box-shadow: 0 10px 24px rgba(0, 0, 0, 0.19);
  backdrop-filter: none;
  transition:
    transform 0.16s ease,
    border-color 0.16s ease,
    background 0.16s ease,
    box-shadow 0.16s ease;
}

.np-card::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0.8rem;
  bottom: 0.8rem;
  width: 3px;
  border-radius: 999px;
  background: linear-gradient(180deg, var(--np-moss), transparent);
  opacity: 0.60;
}

.np-card:hover {
  transform: translateY(-3px);
  border-color: rgba(0, 230, 246, 0.62);
  background:
    linear-gradient(135deg, rgba(0, 230, 246, 0.06), transparent 38%),
    linear-gradient(145deg, rgba(111, 130, 75, 0.12), transparent 52%),
    linear-gradient(180deg, #213b45, #182f38);
  box-shadow: 0 0 18px rgba(0, 230, 246, 0.12), 0 12px 28px rgba(0, 0, 0, 0.25);
}

.np-card-title {
  display: flex;
  align-items: center;
  gap: 0.45rem;
  margin-bottom: 0.45rem;
  color: var(--np-cyan);
  font-weight: 900;
  font-size: 1.14rem;
  line-height: 1.2;
  text-decoration: none;
}

.np-card-title::before {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1.1rem;
  height: 1.1rem;
  flex: 0 0 auto;
  color: var(--np-cyan);
  font-family: Arial, Helvetica, sans-serif;
  font-size: 1.02rem;
  font-weight: 900;
  line-height: 1;
  text-shadow: 0 0 10px rgba(0, 230, 246, 0.28);
  filter: drop-shadow(0 0 5px rgba(0, 230, 246, 0.22));
}

.np-card:nth-child(1) .np-card-title::before {
  content: "§";
}

.np-card:nth-child(2) .np-card-title::before {
  content: "✦";
}

.np-card:nth-child(3) .np-card-title::before {
  content: "?";
}

.np-card:nth-child(4) .np-card-title::before {
  content: "◆";
}

.np-card-title:hover,
.np-card:hover .np-card-title {
  color: var(--np-gold);
  text-decoration: none;
}

.np-card:hover .np-card-title::before {
  color: var(--np-gold);
  text-shadow: 0 0 10px rgba(236, 183, 110, 0.28);
  filter: drop-shadow(0 0 5px rgba(236, 183, 110, 0.22));
}

.np-card-text {
  display: block;
  margin: 0;
  color: var(--np-text-muted);
  font-size: 0.88rem;
  line-height: 1.45;
}

/* Inhaltsseiten */

.main-content > h1:first-child {
  padding-bottom: 0.75rem;
  border-bottom: 1px solid var(--np-border-soft);
}

.main-content blockquote {
  margin: 1rem 0;
  padding: 0.85rem 1rem;
  border-left: 4px solid var(--np-moss);
  border-radius: 0.4rem;
  background: rgba(24, 63, 83, 0.76);
  color: var(--np-text);
}

.main-content hr {
  border: 0;
  border-top: 1px solid var(--np-border-soft);
  margin: 1.75rem 0;
}

.main-content code {
  border: 1px solid var(--np-border-soft);
  border-radius: 0.25rem;
  background: #10171b;
  color: var(--np-gold-soft);
}

/* Tabellen */

.main-content table {
  border: 1px solid var(--np-border);
  border-radius: 0.5rem;
  overflow: hidden;
}

.main-content th {
  background: #10171b;
  color: var(--np-gold);
}

.main-content td {
  background: rgba(24, 63, 83, 0.74);
  color: var(--np-text);
}

/* Footer / Unterkante */

.site-footer {
  color: rgba(245, 234, 220, 0.42);
  font-size: 0.68rem;
  line-height: 1.4;
  border-top: 1px solid rgba(72, 122, 146, 0.14);
  padding-top: 1rem;
  margin-top: 2rem;
  opacity: 0.72;
}

.site-footer a {
  color: rgba(0, 230, 246, 0.66);
}

.site-footer a:hover {
  color: #7ff8ff;
}

.main-content::after {
  content: "";
  display: block;
  height: 1px;
  margin-top: 2.3rem;
  background: linear-gradient(90deg, transparent, rgba(72, 122, 146, 0.46), transparent);
}

/* Mobile */

@media (max-width: 800px) {
  .np-hero {
    grid-template-columns: 1fr;
    padding: 1.35rem;
  }

  .np-hero-logo {
    justify-self: start;
    width: 150px;
    height: 150px;
  }

  .np-hero h1 {
    font-size: 2.15rem;
    line-height: 1.02;
  }

  .echo-guide-box {
    grid-template-columns: 112px minmax(0, 1fr);
    gap: 0.85rem;
    padding: 0.9rem 1rem 0.9rem 1.2rem;
    min-height: 132px;
    background:
      linear-gradient(var(--echo-accent), var(--echo-accent)) left 0.9rem top 1rem / 3px calc(100% - 2rem) no-repeat,
      radial-gradient(circle at 8% 50%, rgba(0, 230, 246, 0.10), transparent 12rem),
      radial-gradient(circle at 100% 50%, rgba(111, 130, 75, 0.08), transparent 16rem),
      linear-gradient(135deg, rgba(21, 56, 74, 0.82), rgba(11, 24, 30, 0.86));
  }

  .echo-guide-image {
    height: 112px;
  }

  .echo-guide-image img {
    width: 108px;
  }

  .echo-page-box {
    grid-template-columns: 104px minmax(0, 1fr);
    gap: 0.9rem;
    padding: 0.95rem 1rem 0.95rem 1.2rem;
    min-height: 128px;
    background:
      linear-gradient(var(--echo-accent), var(--echo-accent)) left 0.95rem top 1rem / 3px calc(100% - 2rem) no-repeat,
      radial-gradient(circle at 8% 50%, rgba(0, 230, 246, 0.09), transparent 13rem),
      radial-gradient(circle at 96% 18%, rgba(72, 122, 146, 0.14), transparent 18rem),
      linear-gradient(135deg, rgba(21, 56, 74, 0.84), rgba(11, 24, 30, 0.86));
  }

  .echo-page-image {
    height: 104px;
  }

  .echo-page-image img {
    width: 96px;
  }

  .echo-page-content h2 {
    font-size: 1.15rem;
  }

  .echo-page-content p {
    font-size: 0.88rem;
  }

  .echo-guide-content h2 {
    font-size: 1.15rem;
  }

  .echo-guide-content p {
    font-size: 0.88rem;
  }

  .np-card {
    min-height: auto;
  }

  .np-card-title {
    font-size: 1.08rem;
  }

  .main-content h1 {
    font-size: 1.8rem;
  }

  .main-header {
    min-height: auto;
    height: auto;
    max-height: none;
    padding: 0.6rem;
    overflow: visible;
  }

  .search-input-wrap {
    width: 100%;
    max-width: none;
    border-radius: 0.8rem;
  }

  .search-input {
    border-radius: 0.8rem !important;
  }

  .aux-nav a::before {
    display: none;
  }
}


/* Desktop-Anordnung für Suche und Discord-Button */

@media (min-width: 66.5rem) {
  .main-header .search {
    flex: 0 1 330px !important;
    order: 3;
    margin-left: 0;
  }

  .main-header .aux-nav {
    order: 4;
    flex: 0 0 auto !important;
    display: flex !important;
    align-items: center !important;
    padding-right: 0;
  }

  .main-header .aux-nav-list {
    display: flex !important;
    align-items: center !important;
    margin: 0 !important;
  }

  .site-nav,
  .site-header,
  .site-footer {
    display: none !important;
  }

  .search-input-wrap {
    width: 100%;
    max-width: 330px;
  }
}

@media (min-width: 66.5rem) and (max-width: 1180px) {
  .np-topbar-title {
    display: none;
  }

  .np-top-nav a {
    padding-left: 0.58rem;
    padding-right: 0.58rem;
    font-size: 0.8rem;
  }

  .main-header .search {
    flex-basis: 260px !important;
  }
}

/* =========================================================
   Performance-Optimierung
   - fixed background wieder aktiviert, aber Bild optimiert
   - keine Blur-/Glass-Effekte
   - reduzierte Schatten/Filter auf großen Elementen
   ========================================================= */

html {
  scroll-behavior: auto;
}

body {
  background-attachment: fixed !important;
}

@media (max-width: 900px), (pointer: coarse) {
  body {
    background-attachment: scroll !important;
  }
}

.main,
.main-content-wrap,
.main-content,
.side-bar,
.site-nav,
.site-header,
.main-header,
.np-hero,
.echo-guide,
.echo-page-box,
.np-card,
.np-callout,
.np-update-box,
.search-input-wrap,
.btn-discord,
.discord-button,
.aux-nav .btn,
.aux-nav a {
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
}

.main-content-wrap {
  box-shadow:
    24px 0 46px rgba(5, 11, 14, 0.24),
    -24px 0 46px rgba(5, 11, 14, 0.22),
    0 22px 42px rgba(0, 0, 0, 0.16) !important;
}

.np-hero,
.echo-guide,
.echo-page-box,
.np-card,
.np-callout,
.np-update-box {
  box-shadow: 0 10px 24px rgba(0, 0, 0, 0.18) !important;
}

.np-hero-logo,
.echo-guide-image img,
.echo-page-image img {
  filter: drop-shadow(0 8px 14px rgba(0, 0, 0, 0.28)) !important;
}

.np-hero-logo:hover,
.echo-guide-image img:hover,
.echo-page-image img:hover {
  filter: drop-shadow(0 8px 14px rgba(0, 0, 0, 0.28)) !important;
}

.np-card:hover {
  transform: translateY(-1px) !important;
}

@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    scroll-behavior: auto !important;
    transition-duration: 0.01ms !important;
  }
}

/* =========================================================
   Zielgerichteter Hover-Lichteffekt
   Nur Logo + ECHO-Bilder leuchten leicht beim Hover.
   Keine Hover-Effekte auf großen Content-Boxen/Abteilen.
   ========================================================= */

/* Große Boxen bleiben ruhig: kein Leuchten, kein Anheben */
.np-hero,
.echo-guide,
.echo-page-box,
.np-callout,
.np-update-box {
  transition:
    border-color 0.18s ease,
    box-shadow 0.18s ease,
    background 0.18s ease !important;
}

.np-hero:hover,
.echo-guide:hover,
.echo-page-box:hover,
.np-callout:hover,
.np-update-box:hover {
  transform: none !important;
  border-color: rgba(72, 122, 146, 0.38) !important;
  box-shadow: 0 10px 24px rgba(0, 0, 0, 0.18) !important;
}

/* Karten/Schnellzugriff bleiben nur minimal interaktiv, ohne Lichtschein */
.np-card {
  transition:
    background 0.18s ease,
    border-color 0.18s ease,
    box-shadow 0.18s ease,
    transform 0.18s ease !important;
}

.np-card::after {
  content: none !important;
}

.np-card:hover {
  transform: translateY(-1px) !important;
  border-color: rgba(72, 122, 146, 0.58) !important;
  box-shadow: 0 10px 24px rgba(0, 0, 0, 0.20) !important;
}

/* Sidebar/Suche/Discord: keine zusätzlichen Lichtflächen */
.nav-list .nav-list-item .nav-list-link,
.aux-nav a,
.search-input-wrap {
  transition:
    background 0.18s ease,
    border-color 0.18s ease,
    box-shadow 0.18s ease,
    color 0.18s ease !important;
}

.nav-list .nav-list-item .nav-list-link:hover {
  color: var(--np-cyan) !important;
  background: rgba(53, 101, 125, 0.20) !important;
  box-shadow: none !important;
}

.aux-nav a:hover {
  color: #9effff !important;
  border-color: rgba(0, 230, 246, 0.62) !important;
  box-shadow: 0 6px 14px rgba(0, 0, 0, 0.20) !important;
}

.search-input-wrap:hover,
.search-input-wrap:focus-within {
  border-color: rgba(0, 230, 246, 0.48) !important;
  box-shadow: 0 6px 14px rgba(0, 0, 0, 0.18) !important;
}

/* Logo + ECHO-Bilder: gewünschter leichter Lichteffekt */
.np-hero-logo,
.echo-guide-image img,
.echo-page-image img {
  transition:
    filter 0.22s ease,
    transform 0.22s ease,
    opacity 0.22s ease !important;
  will-change: filter, transform;
}

.np-hero-logo:hover,
.echo-guide-image img:hover,
.echo-page-image img:hover {
  transform: translateY(-1px) scale(1.018) !important;
  filter:
    drop-shadow(0 8px 14px rgba(0, 0, 0, 0.30))
    drop-shadow(0 0 12px rgba(0, 230, 246, 0.26))
    drop-shadow(0 0 8px rgba(236, 183, 110, 0.12)) !important;
}

@media (prefers-reduced-motion: reduce) {
  .np-hero-logo,
  .echo-guide-image img,
  .echo-page-image img {
    transition: none !important;
  }

  .np-hero-logo:hover,
  .echo-guide-image img:hover,
  .echo-page-image img:hover {
    transform: none !important;
  }
}


/* =========================================================
   Layout-Feinschliff: Gesamtbereich leicht nach links
   + Inhalt im Mittelblock gleichmäßig zentrieren
   ========================================================= */

@media (min-width: 66.5rem) {
  :root {
    --np-layout-shift-left: 2.75rem;
    --np-layout-page-width: 1440px;
    --np-sidebar-width: 264px;
    --np-outer-gap: 1.5rem;
  }

  .side-bar {
    width: var(--np-sidebar-width) !important;
    left: max(
      var(--np-outer-gap),
      calc((100vw - var(--np-layout-page-width)) / 2 - var(--np-layout-shift-left))
    ) !important;
  }

  .main {
    max-width: 1176px !important;
    margin-left: calc(
      max(
        var(--np-outer-gap),
        calc((100vw - var(--np-layout-page-width)) / 2 - var(--np-layout-shift-left))
      ) + var(--np-sidebar-width)
    ) !important;
  }

  .main-header,
  .main-header.nav-open {
    max-width: 1176px !important;
    width: auto !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
  }

  .main-content-wrap {
    max-width: 1176px !important;
    width: 100% !important;
  }

  .main-content {
    max-width: none !important;
    width: auto !important;
    padding-left: 2rem !important;
    padding-right: 2rem !important;
    margin-left: auto !important;
    margin-right: auto !important;
  }

  .np-hero,
  .echo-guide,
  .np-section,
  .np-card-grid,
  .main-content > h2,
  .main-content > p,
  .main-content > blockquote,
  .main-content > hr,
  .main-content > table,
  .main-content > .np-update-box {
    margin-left: 0 !important;
    margin-right: 0 !important;
  }
}

/* =========================================================
   Zeitstempel-Anpassung
   - Startseite: Zeitstempel ausblenden
   - Unterseiten: Zeitstempel oben dezent und ohne Box darstellen
   ========================================================= */

/* Der automatische Markdown-Zeitstempel wird als Blockquote gerendert.
   Auf Unterseiten soll er nur als kleine, dezente Info erscheinen. */
.main-content > blockquote:has(> p:first-child > strong:first-child),
.main-content > .np-update-box {
  display: block !important;
  margin: 0 0 1.35rem 0 !important;
  padding: 0 !important;
  border: 0 !important;
  border-left: 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
  color: rgba(219, 234, 238, 0.58) !important;
  font-size: 0.72rem !important;
  line-height: 1.35 !important;
}

.main-content > blockquote:has(> p:first-child > strong:first-child) p,
.main-content > .np-update-box p {
  margin: 0 !important;
  padding: 0 !important;
  color: inherit !important;
  font-size: inherit !important;
  line-height: inherit !important;
}

.main-content > blockquote:has(> p:first-child > strong:first-child) strong,
.main-content > .np-update-box strong {
  color: rgba(236, 183, 110, 0.72) !important;
  font-weight: 700 !important;
}

/* Auf der Startseite steht der Zeitstempel aktuell nach dem Abschnitt
   „Was ist NewPath?“ – dort soll er gar nicht angezeigt werden. */
.main-content h2#was-ist-newpath ~ blockquote:has(> p:first-child > strong:first-child),
.main-content h2#was-ist-newpath ~ .np-update-box {
  display: none !important;
}

/* Falls der Zeitstempel auf der Startseite in Zukunft wieder direkt als
   Update-Box ausgegeben wird, bleibt auch diese Variante unsichtbar. */
.main-content h1#newpath--echoes-of-the-wild ~ blockquote:has(> p:first-child > strong:first-child),
.main-content h1#newpath--echoes-of-the-wild ~ .np-update-box {
  display: none !important;
}


/* =========================================================
   Footer-Neugestaltung
   - Zurück-nach-oben-Link als dezenter NewPath/ECHO-Footer
   - Projekttext darunter ruhig und stimmig
   - Just-the-Docs-Theme-Hinweis bleibt nur in der Sidebar ausgeblendet
   ========================================================= */

/* Standard-Theme-Footer in der Sidebar weiterhin entfernen */
.side-bar .site-footer {
  display: none !important;
}

/* Falls ein Footer innerhalb des Hauptinhalts vorhanden ist, darf er sichtbar sein */
.main-content .site-footer,
.main-content > .site-footer {
  display: block !important;
}

/* Trennlinie vor dem eigentlichen Seitenfooter ruhiger gestalten */
.main-content > hr:last-of-type {
  border: 0 !important;
  height: 1px !important;
  margin: 2.35rem 0 0 !important;
  background: linear-gradient(
    90deg,
    transparent 0%,
    rgba(0, 230, 246, 0.22) 18%,
    rgba(236, 183, 110, 0.24) 50%,
    rgba(0, 230, 246, 0.18) 82%,
    transparent 100%
  ) !important;
}

/* Der Just-the-Docs-Link "Zurück nach oben" wird als Footer-Kopf genutzt */
.main-content > p:has(a[href*="#top"]) {
  position: relative !important;
  margin: 1.05rem 0 0 !important;
  padding: 0.95rem 1.15rem 0.3rem !important;
  border: 1px solid rgba(72, 122, 146, 0.24) !important;
  border-bottom: 0 !important;
  border-radius: 0.95rem 0.95rem 0 0 !important;
  background:
    radial-gradient(circle at 8% 0%, rgba(0, 230, 246, 0.075), transparent 11rem),
    linear-gradient(135deg, rgba(17, 46, 64, 0.34), rgba(5, 18, 25, 0.30)) !important;
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.035),
    0 10px 22px rgba(0, 0, 0, 0.14) !important;
  color: rgba(219, 234, 238, 0.66) !important;
  font-size: 0.76rem !important;
  line-height: 1.35 !important;
}

.main-content > p:has(a[href*="#top"])::before {
  content: "ECHO-Systemnotiz";
  display: block;
  margin-bottom: 0.4rem;
  color: rgba(236, 183, 110, 0.78);
  font-size: 0.68rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.main-content > p:has(a[href*="#top"]) a {
  display: inline-flex !important;
  align-items: center !important;
  gap: 0.38rem !important;
  color: rgba(0, 230, 246, 0.84) !important;
  font-weight: 800 !important;
  text-decoration: none !important;
  letter-spacing: 0.01em !important;
  transition:
    color 0.16s ease,
    text-shadow 0.16s ease,
    transform 0.16s ease !important;
}

.main-content > p:has(a[href*="#top"]) a::before {
  content: "↑";
  color: rgba(236, 183, 110, 0.82);
  font-weight: 900;
}

.main-content > p:has(a[href*="#top"]) a:hover {
  color: #7ff8ff !important;
  text-shadow: 0 0 10px rgba(0, 230, 246, 0.22) !important;
  transform: translateY(-1px) !important;
}

/* Projekttext direkt unter dem Zurück-nach-oben-Link */
.main-content > p:has(a[href*="#top"]) + p {
  margin: 0 0 1.75rem !important;
  padding: 0.25rem 1.15rem 0.95rem !important;
  border: 1px solid rgba(72, 122, 146, 0.24) !important;
  border-top: 0 !important;
  border-radius: 0 0 0.95rem 0.95rem !important;
  background:
    radial-gradient(circle at 92% 100%, rgba(236, 183, 110, 0.045), transparent 10rem),
    linear-gradient(135deg, rgba(17, 46, 64, 0.34), rgba(5, 18, 25, 0.30)) !important;
  color: rgba(219, 234, 238, 0.50) !important;
  font-size: 0.68rem !important;
  line-height: 1.45 !important;
}

.main-content > p:has(a[href*="#top"]) + p strong {
  color: rgba(236, 183, 110, 0.74) !important;
}

/* Falls der Footer als eigener site-footer im Main gerendert wird */
.main-content > .site-footer {
  margin: 2rem 0 0 !important;
  padding: 0.95rem 1.15rem !important;
  border: 1px solid rgba(72, 122, 146, 0.24) !important;
  border-radius: 0.95rem !important;
  background:
    radial-gradient(circle at 8% 0%, rgba(0, 230, 246, 0.07), transparent 11rem),
    linear-gradient(135deg, rgba(17, 46, 64, 0.34), rgba(5, 18, 25, 0.30)) !important;
  color: rgba(219, 234, 238, 0.50) !important;
  font-size: 0.68rem !important;
  line-height: 1.45 !important;
}

.main-content > .site-footer a {
  color: rgba(0, 230, 246, 0.78) !important;
  text-decoration: none !important;
}

.main-content > .site-footer a:hover {
  color: #7ff8ff !important;
}

@media (max-width: 800px) {
  .main-content > p:has(a[href*="#top"]),
  .main-content > p:has(a[href*="#top"]) + p,
  .main-content > .site-footer {
    border-radius: 0.75rem !important;
    padding-left: 0.9rem !important;
    padding-right: 0.9rem !important;
  }

  .main-content > p:has(a[href*="#top"]) {
    border-bottom: 0 !important;
    border-radius: 0.75rem 0.75rem 0 0 !important;
  }

  .main-content > p:has(a[href*="#top"]) + p {
    border-top: 0 !important;
    border-radius: 0 0 0.75rem 0.75rem !important;
  }
}

/* =========================================================
   Fix: Zeitstempel auf Unterseiten wirklich dezent anzeigen
   - Keine Box, kein Rahmen, kein Hintergrund
   - Rechtsbündig als kleine Infozeile
   - Startseite bleibt ohne Zeitstempel
   ========================================================= */

.main-content blockquote:has(strong),
.main-content .page-content blockquote:has(strong),
.main-content .np-update-box,
.main-content .page-content .np-update-box {
  display: block !important;
  width: auto !important;
  max-width: none !important;
  margin: 0 0 1.05rem 0 !important;
  padding: 0 !important;
  border: 0 !important;
  border-left: 0 !important;
  border-right: 0 !important;
  border-top: 0 !important;
  border-bottom: 0 !important;
  border-radius: 0 !important;
  outline: 0 !important;
  background: transparent !important;
  background-image: none !important;
  box-shadow: none !important;
  text-align: right !important;
  color: rgba(219, 234, 238, 0.46) !important;
  font-size: 0.69rem !important;
  line-height: 1.25 !important;
  font-style: normal !important;
}

.main-content blockquote:has(strong)::before,
.main-content blockquote:has(strong)::after,
.main-content .page-content blockquote:has(strong)::before,
.main-content .page-content blockquote:has(strong)::after,
.main-content .np-update-box::before,
.main-content .np-update-box::after,
.main-content .page-content .np-update-box::before,
.main-content .page-content .np-update-box::after {
  content: none !important;
  display: none !important;
}

.main-content blockquote:has(strong) p,
.main-content .page-content blockquote:has(strong) p,
.main-content .np-update-box p,
.main-content .page-content .np-update-box p {
  margin: 0 !important;
  padding: 0 !important;
  color: inherit !important;
  font-size: inherit !important;
  line-height: inherit !important;
  font-style: normal !important;
}

.main-content blockquote:has(strong) strong,
.main-content .page-content blockquote:has(strong) strong,
.main-content .np-update-box strong,
.main-content .page-content .np-update-box strong {
  color: rgba(236, 183, 110, 0.52) !important;
  font-weight: 700 !important;
}

/* Startseite: Zeitstempel genauso dezent anzeigen wie auf Unterseiten */
.main-content h1#newpath--echoes-of-the-wild ~ blockquote:has(strong),
.main-content h1#newpath--echoes-of-the-wild ~ .np-update-box,
.main-content h2#was-ist-newpath ~ blockquote:has(strong),
.main-content h2#was-ist-newpath ~ .np-update-box,
.main-content .page-content h1#newpath--echoes-of-the-wild ~ blockquote:has(strong),
.main-content .page-content h1#newpath--echoes-of-the-wild ~ .np-update-box,
.main-content .page-content h2#was-ist-newpath ~ blockquote:has(strong),
.main-content .page-content h2#was-ist-newpath ~ .np-update-box {
  display: block !important;
  width: auto !important;
  max-width: none !important;
  margin: 0 0 1.05rem 0 !important;
  padding: 0 !important;
  border: 0 !important;
  border-radius: 0 !important;
  outline: 0 !important;
  background: transparent !important;
  background-image: none !important;
  box-shadow: none !important;
  text-align: right !important;
  color: rgba(219, 234, 238, 0.46) !important;
  font-size: 0.69rem !important;
  line-height: 1.25 !important;
  font-style: normal !important;
}

/* =========================================================
   Zeitstempel / Letzte Aktualisierung
   ========================================================= */

.np-last-updated {
  margin: 0 0 1.15rem 0 !important;
  padding: 0 !important;
  text-align: right !important;
  font-size: 0.72rem !important;
  line-height: 1.4 !important;
  color: rgba(226, 236, 238, 0.52) !important;
  background: transparent !important;
  border: none !important;
  box-shadow: none !important;
  border-radius: 0 !important;
  letter-spacing: 0.01em;
}
/* =========================================================
   Schritt 1 FINAL: Desktop-Topbar statt linker Sidebar
   Diese Regeln stehen bewusst am Dateiende, damit ältere
   Layout-Feinschliffe zuverlässig überschrieben werden.
   ========================================================= */

@media (min-width: 66.5rem) {
  .side-bar,
  .site-header,
  .site-nav,
  .side-bar .site-footer {
    display: none !important;
  }

  .main {
    width: 100% !important;
    max-width: none !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    background: transparent !important;
  }

  .main-header,
  .main-header.nav-open {
    position: sticky !important;
    top: 0 !important;
    left: 0 !important;
    right: 0 !important;
    z-index: 50 !important;
    width: 100% !important;
    max-width: none !important;
    min-height: 5rem !important;
    height: 5rem !important;
    max-height: 5rem !important;
    margin: 0 !important;
    padding: 0 2rem !important;
    display: flex !important;
    align-items: center !important;
    gap: 1rem !important;
    overflow: visible !important;
    background:
      linear-gradient(180deg, rgba(0, 9, 15, 0.96), rgba(0, 18, 33, 0.91)) !important;
    border-bottom: 1px solid rgba(0, 230, 246, 0.16) !important;
    border-radius: 0 !important;
    box-shadow: 0 14px 36px rgba(0, 0, 0, 0.34) !important;
  }

  .main-header::before,
  .main-header::after {
    display: none !important;
    content: none !important;
  }

  .np-topbar-brand {
    display: inline-flex !important;
    order: 1;
  }

  .np-top-nav {
    display: flex !important;
    order: 2;
  }

  .main-header .search {
    order: 3;
    flex: 0 1 330px !important;
    display: flex !important;
    justify-content: center !important;
    margin: 0 !important;
    background: transparent !important;
    border: 0 !important;
  }

  .main-header .search-input-wrap {
    width: 100% !important;
    max-width: 330px !important;
  }

  .main-header .aux-nav {
    order: 4;
    flex: 0 0 auto !important;
    display: flex !important;
    align-items: center !important;
    padding-right: 0 !important;
  }

  .main-header .aux-nav-list {
    display: flex !important;
    align-items: center !important;
    margin: 0 !important;
  }

  .main-content-wrap {
    width: 100% !important;
    max-width: none !important;
    min-height: calc(100vh - 5rem) !important;
    border-left: 0 !important;
    border-right: 0 !important;
    border-radius: 0 !important;
    box-shadow: none !important;
  }

  .main-content {
    width: min(1400px, calc(100% - 5.2rem)) !important;
    max-width: 1400px !important;
    margin-left: auto !important;
    margin-right: auto !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
    border-radius: 0 !important;
  }
}

@media (min-width: 66.5rem) and (max-width: 1180px) {
  .np-topbar-title {
    display: none !important;
  }

  .np-top-nav a {
    padding-left: 0.56rem !important;
    padding-right: 0.56rem !important;
    font-size: 0.8rem !important;
  }

  .main-header .search {
    flex-basis: 260px !important;
  }
}

/* Schritt 3: Topbar Feinschliff – Suche/Discord kleiner, Logo größer */

@media (min-width: 66.5rem) {
  .main-header {
    min-height: 4.45rem !important;
    height: 4.45rem !important;
    max-height: 4.45rem !important;
    padding-left: 1.55rem !important;
    padding-right: 1.55rem !important;
    gap: 0.55rem !important;
  }

  .np-topbar-brand {
    gap: 0.6rem !important;
    min-width: 205px !important;
  }

  .np-topbar-logo {
    width: 3.45rem !important;
    height: 3.45rem !important;
  }

  .np-topbar-title span:first-child {
    font-size: 1.34rem !important;
    line-height: 1 !important;
  }

  .np-topbar-title span:last-child {
    font-size: 0.74rem !important;
    line-height: 1 !important;
    letter-spacing: 0.13em !important;
  }

  .np-top-nav {
    gap: 0.16rem !important;
  }

  .np-top-nav a {
    min-height: 2rem !important;
    padding: 0.34rem 0.58rem !important;
    font-size: 0.8rem !important;
  }

  .main-header .search {
    order: 3 !important;
    flex: 0 0 220px !important;
    width: 220px !important;
    max-width: 220px !important;
    min-width: 220px !important;
    margin-left: 0.25rem !important;
  }

  .main-header .search-input-wrap {
    width: 220px !important;
    max-width: 220px !important;
    min-height: 1.72rem !important;
    height: 1.72rem !important;
    padding: 0 0.56rem !important;
    border-radius: 999px !important;
  }

  .main-header .search-input {
    min-height: 1.62rem !important;
    height: 1.62rem !important;
    font-size: 0.7rem !important;
    line-height: 1 !important;
  }

  .main-header .search-label .search-icon {
    width: 0.78rem !important;
    height: 0.78rem !important;
    margin-right: 0.34rem !important;
  }

  .main-header .aux-nav {
    order: 4 !important;
    flex: 0 0 auto !important;
    margin-left: 0.22rem !important;
    padding-right: 0 !important;
  }

  .main-header .aux-nav-list {
    margin: 0 !important;
  }

  .main-header .aux-nav a {
    min-height: 1.74rem !important;
    height: 1.74rem !important;
    padding: 0.22rem 0.62rem !important;
    gap: 0.32rem !important;
    font-size: 0.68rem !important;
    line-height: 1 !important;
    border-radius: 999px !important;
  }

  .main-header .aux-nav a::before {
    width: 0.72rem !important;
    height: 0.72rem !important;
  }
}

/* =========================================================
   Schritt 4: Topbar Feinschliff – Suche & Discord sauber ausrichten
   ========================================================= */

@media (min-width: 66.5rem) {
  .main-header,
  .main-header.nav-open {
    min-height: 4.35rem !important;
    height: 4.35rem !important;
    max-height: 4.35rem !important;
    padding: 0 1.45rem !important;
    gap: 0.5rem !important;
    display: flex !important;
    align-items: center !important;
    flex-wrap: nowrap !important;
    overflow: visible !important;
  }

  .np-topbar-brand {
    order: 1 !important;
    flex: 0 0 215px !important;
    min-width: 215px !important;
    max-width: 215px !important;
    gap: 0.62rem !important;
  }

  .np-topbar-logo {
    width: 3.35rem !important;
    height: 3.35rem !important;
    flex: 0 0 3.35rem !important;
  }

  .np-topbar-title span:first-child {
    font-size: 1.28rem !important;
    line-height: 1 !important;
  }

  .np-topbar-title span:last-child {
    font-size: 0.68rem !important;
    line-height: 1 !important;
    letter-spacing: 0.12em !important;
  }

  .np-top-nav {
    order: 2 !important;
    flex: 1 1 auto !important;
    min-width: 0 !important;
    display: flex !important;
    justify-content: center !important;
    align-items: center !important;
    gap: 0.08rem !important;
    white-space: nowrap !important;
  }

  .np-top-nav a {
    min-height: 1.92rem !important;
    padding: 0.28rem 0.54rem !important;
    font-size: 0.76rem !important;
    line-height: 1 !important;
  }

  .main-header .search {
    order: 3 !important;
    flex: 0 0 190px !important;
    width: 190px !important;
    min-width: 190px !important;
    max-width: 190px !important;
    height: 2rem !important;
    min-height: 2rem !important;
    margin: 0 0 0 0.25rem !important;
    padding: 0 !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    align-self: center !important;
  }

  .main-header .search-input-wrap {
    width: 190px !important;
    min-width: 190px !important;
    max-width: 190px !important;
    min-height: 1.62rem !important;
    height: 1.62rem !important;
    padding: 0 0.52rem !important;
    display: flex !important;
    align-items: center !important;
    border-radius: 999px !important;
  }

  .main-header .search-label {
    display: flex !important;
    align-items: center !important;
    height: 100% !important;
  }

  .main-header .search-label .search-icon {
    width: 0.68rem !important;
    height: 0.68rem !important;
    margin-right: 0.28rem !important;
    flex: 0 0 0.68rem !important;
  }

  .main-header .search-input {
    min-height: 1.5rem !important;
    height: 1.5rem !important;
    padding: 0 !important;
    font-size: 0.64rem !important;
    line-height: 1 !important;
  }

  .main-header .aux-nav {
    order: 4 !important;
    flex: 0 0 auto !important;
    margin: 0 0 0 0.22rem !important;
    padding: 0 !important;
    height: 2rem !important;
    min-height: 2rem !important;
    display: flex !important;
    align-items: center !important;
    align-self: center !important;
  }

  .main-header .aux-nav-list {
    height: 2rem !important;
    min-height: 2rem !important;
    display: flex !important;
    align-items: center !important;
    margin: 0 !important;
    padding: 0 !important;
  }

  .main-header .aux-nav-list-item {
    height: 2rem !important;
    min-height: 2rem !important;
    display: flex !important;
    align-items: center !important;
    margin: 0 !important;
    padding: 0 !important;
  }

  .main-header .aux-nav a {
    min-height: 1.62rem !important;
    height: 1.62rem !important;
    padding: 0.18rem 0.54rem !important;
    gap: 0.28rem !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    align-self: center !important;
    font-size: 0.64rem !important;
    line-height: 1 !important;
    border-radius: 999px !important;
    white-space: nowrap !important;
  }

  .main-header .aux-nav a::before {
    width: 0.68rem !important;
    height: 0.68rem !important;
    flex: 0 0 0.68rem !important;
  }
}

@media (min-width: 66.5rem) and (max-width: 1280px) {
  .np-topbar-brand {
    flex-basis: 190px !important;
    min-width: 190px !important;
    max-width: 190px !important;
  }

  .np-topbar-title span:first-child {
    font-size: 1.12rem !important;
  }

  .np-topbar-title span:last-child {
    font-size: 0.58rem !important;
  }

  .np-top-nav a {
    padding-left: 0.42rem !important;
    padding-right: 0.42rem !important;
    font-size: 0.7rem !important;
  }

  .main-header .search,
  .main-header .search-input-wrap {
    flex-basis: 165px !important;
    width: 165px !important;
    min-width: 165px !important;
    max-width: 165px !important;
  }
}

/* =========================================================
   Schritt 5: Topbar Balance – Suche & Discord etwas größer,
   aber weiterhin kompakt und sauber zentriert
   ========================================================= */

@media (min-width: 66.5rem) {
  .main-header,
  .main-header.nav-open {
    min-height: 4.45rem !important;
    height: 4.45rem !important;
    max-height: 4.45rem !important;
    padding: 0 1.55rem !important;
    gap: 0.62rem !important;
  }

  .np-topbar-brand {
    flex-basis: 230px !important;
    min-width: 230px !important;
    max-width: 230px !important;
  }

  .np-topbar-logo {
    width: 3.45rem !important;
    height: 3.45rem !important;
    flex-basis: 3.45rem !important;
  }

  .np-topbar-title span:first-child {
    font-size: 1.34rem !important;
  }

  .np-topbar-title span:last-child {
    font-size: 0.72rem !important;
  }

  .np-top-nav a {
    min-height: 2rem !important;
    padding: 0.32rem 0.58rem !important;
    font-size: 0.78rem !important;
  }

  .main-header .search {
    flex: 0 0 230px !important;
    width: 230px !important;
    min-width: 230px !important;
    max-width: 230px !important;
    height: 2.1rem !important;
    min-height: 2.1rem !important;
    margin-left: 0.35rem !important;
  }

  .main-header .search-input-wrap {
    width: 230px !important;
    min-width: 230px !important;
    max-width: 230px !important;
    min-height: 1.82rem !important;
    height: 1.82rem !important;
    padding: 0 0.66rem !important;
  }

  .main-header .search-label .search-icon {
    width: 0.78rem !important;
    height: 0.78rem !important;
    margin-right: 0.34rem !important;
    flex-basis: 0.78rem !important;
  }

  .main-header .search-input {
    min-height: 1.72rem !important;
    height: 1.72rem !important;
    font-size: 0.70rem !important;
  }

  .main-header .aux-nav,
  .main-header .aux-nav-list,
  .main-header .aux-nav-list-item {
    height: 2.1rem !important;
    min-height: 2.1rem !important;
  }

  .main-header .aux-nav {
    margin-left: 0.3rem !important;
  }

  .main-header .aux-nav a {
    min-height: 1.82rem !important;
    height: 1.82rem !important;
    padding: 0.22rem 0.74rem !important;
    gap: 0.34rem !important;
    font-size: 0.70rem !important;
  }

  .main-header .aux-nav a::before {
    width: 0.78rem !important;
    height: 0.78rem !important;
    flex-basis: 0.78rem !important;
  }
}

@media (min-width: 66.5rem) and (max-width: 1280px) {
  .np-topbar-brand {
    flex-basis: 200px !important;
    min-width: 200px !important;
    max-width: 200px !important;
  }

  .main-header .search,
  .main-header .search-input-wrap {
    flex-basis: 190px !important;
    width: 190px !important;
    min-width: 190px !important;
    max-width: 190px !important;
  }

  .main-header .aux-nav a {
    padding-left: 0.62rem !important;
    padding-right: 0.62rem !important;
  }
}

/* =========================================================
   Schritt 6: Suchleiste – Icon und Text sauber trennen
   ========================================================= */

@media (min-width: 66.5rem) {
  .main-header .search-input-wrap {
    position: relative !important;
    display: flex !important;
    align-items: center !important;
    padding: 0 0.78rem 0 2.15rem !important;
    overflow: hidden !important;
  }

  .main-header .search-label {
    position: absolute !important;
    left: 0.78rem !important;
    top: 50% !important;
    width: 0.82rem !important;
    height: 0.82rem !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    transform: translateY(-50%) !important;
    pointer-events: none !important;
    z-index: 2 !important;
  }

  .main-header .search-label .search-icon {
    width: 0.78rem !important;
    height: 0.78rem !important;
    margin: 0 !important;
    flex: 0 0 0.78rem !important;
  }

  .main-header .search-input {
    width: 100% !important;
    min-width: 0 !important;
    padding: 0 !important;
    margin: 0 !important;
    position: relative !important;
    z-index: 1 !important;
  }
}

/* =========================================================
   Schritt 7: Suchleiste – Lupe final links fixieren
   ========================================================= */

@media (min-width: 66.5rem) {
  .main-header .search-input-wrap {
    position: relative !important;
    display: block !important;
    padding: 0 !important;
    overflow: hidden !important;
  }

  .main-header .search-label {
    position: absolute !important;
    left: 0.72rem !important;
    top: 50% !important;
    width: 0.82rem !important;
    height: 0.82rem !important;
    margin: 0 !important;
    padding: 0 !important;
    transform: translateY(-50%) !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    pointer-events: none !important;
    z-index: 3 !important;
  }

  .main-header .search-label .search-icon,
  .main-header .search-label svg {
    width: 0.76rem !important;
    height: 0.76rem !important;
    min-width: 0.76rem !important;
    min-height: 0.76rem !important;
    margin: 0 !important;
    flex: 0 0 0.76rem !important;
  }

  .main-header .search-input {
    box-sizing: border-box !important;
    width: 100% !important;
    height: 100% !important;
    min-height: 1.82rem !important;
    padding: 0 0.72rem 0 2.05rem !important;
    margin: 0 !important;
    position: relative !important;
    z-index: 1 !important;
    line-height: 1.82rem !important;
  }
}

/* =========================================================
   Schritt 8: Hero-Bereich breiter und moderner
   - Startseite bekommt mehr Landingpage-Gefühl
   - Hero wird größer, breiter und bildhafter
   - ECHO/Schnellzugriff bleiben noch unverändert
   ========================================================= */

@media (min-width: 66.5rem) {
  .main-content {
    width: min(1500px, calc(100% - 4.4rem)) !important;
    max-width: 1500px !important;
    padding-top: 1.35rem !important;
  }

  .np-last-updated {
    margin: 0 0 1rem 0 !important;
    padding-right: 0.25rem !important;
    text-align: right !important;
  }

  .np-hero {
    min-height: 335px !important;
    grid-template-columns: minmax(0, 1.08fr) minmax(280px, 410px) !important;
    gap: 2.5rem !important;
    align-items: center !important;
    margin: 0 0 1.55rem 0 !important;
    padding: 3.05rem 3.35rem !important;
    border-radius: 1.25rem !important;
    border: 1px solid rgba(0, 230, 246, 0.24) !important;
    border-top-color: rgba(236, 183, 110, 0.34) !important;
    background:
      radial-gradient(circle at 78% 24%, rgba(0, 230, 246, 0.14), transparent 18rem),
      radial-gradient(circle at 18% 18%, rgba(236, 183, 110, 0.10), transparent 19rem),
      linear-gradient(90deg, rgba(0, 9, 15, 0.18), rgba(0, 18, 33, 0.46) 38%, rgba(0, 9, 15, 0.22)),
      linear-gradient(135deg, rgba(17, 46, 64, 0.76), rgba(5, 18, 25, 0.90) 62%, rgba(0, 9, 15, 0.88)) !important;
    box-shadow:
      inset 0 1px 0 rgba(255, 255, 255, 0.045),
      0 18px 34px rgba(0, 0, 0, 0.24) !important;
  }

  .np-hero::before {
    left: 1.35rem !important;
    right: 1.35rem !important;
    height: 2px !important;
    opacity: 0.72 !important;
  }

  .np-hero::after {
    right: -5rem !important;
    bottom: -6rem !important;
    width: 22rem !important;
    height: 22rem !important;
    background: radial-gradient(circle, rgba(0, 230, 246, 0.105), transparent 62%) !important;
  }

  .np-kicker {
    margin-bottom: 0.55rem !important;
    font-size: 0.82rem !important;
    letter-spacing: 0.14em !important;
  }

  .np-hero h1 {
    max-width: 820px !important;
    margin-bottom: 0.95rem !important;
    font-size: clamp(3rem, 4.15vw, 4.85rem) !important;
    line-height: 0.98 !important;
    letter-spacing: -0.035em !important;
    color: var(--np-gold) !important;
    text-shadow: 0 10px 24px rgba(0, 0, 0, 0.34) !important;
  }

  
.np-hero-title-main,
.np-hero-title-sub {
  display: block;
}

.np-hero-title-main {
  color: #f4cf7f;
}

.np-hero-title-sub {
  margin-top: 0.18rem;
  color: var(--np-gold);
  font-size: 0.74em;
  letter-spacing: -0.025em;
}

.np-hero-text {
    max-width: 690px !important;
    margin-bottom: 1.25rem !important;
    color: rgba(245, 234, 220, 0.92) !important;
    font-size: 1.05rem !important;
    line-height: 1.65 !important;
  }

  .np-hero-highlight {
    max-width: 790px !important;
    padding: 1rem 1.2rem !important;
    border-radius: 0.85rem !important;
    border: 1px solid rgba(72, 122, 146, 0.58) !important;
    border-left: 4px solid rgba(236, 183, 110, 0.82) !important;
    background:
      linear-gradient(135deg, rgba(236, 183, 110, 0.075), transparent 44%),
      rgba(0, 9, 15, 0.42) !important;
    color: rgba(245, 234, 220, 0.86) !important;
  }

  .np-hero-logo {
    width: 310px !important;
    height: 310px !important;
    justify-self: center !important;
    align-self: center !important;
    opacity: 1 !important;
    filter:
      drop-shadow(0 18px 24px rgba(0, 0, 0, 0.34))
      drop-shadow(0 0 16px rgba(0, 230, 246, 0.18)) !important;
  }

  .np-hero-logo img {
    width: 100% !important;
    height: 100% !important;
  }
}

@media (min-width: 66.5rem) and (max-width: 1220px) {
  .np-hero {
    grid-template-columns: minmax(0, 1fr) 250px !important;
    padding: 2.35rem 2.25rem !important;
  }

  .np-hero-logo {
    width: 230px !important;
    height: 230px !important;
  }

  .np-hero h1 {
    font-size: clamp(2.45rem, 4vw, 3.5rem) !important;
  }
}

@media (max-width: 800px) {
  .np-hero {
    min-height: auto !important;
    padding: 1.45rem !important;
  }

  .np-hero h1 {
    font-size: 2rem !important;
    line-height: 1.08 !important;
  }

  .np-hero-logo {
    width: 150px !important;
    height: 150px !important;
  }
}

/* =========================================================
   Schritt 10: Hero als moderne Bühne statt geschlossene Card
   - Hero wirkt offener und weniger blockig
   - Hintergrund scheint stärker durch
   - Logo bekommt mehr Raum und Glow
   - ECHO-Box wird optisch an den Hero angeglichen
   ========================================================= */

@media (min-width: 66.5rem) {
  .main-content {
    width: min(1540px, calc(100% - 4.2rem)) !important;
    max-width: 1540px !important;
  }

  .np-hero {
    min-height: 310px !important;
    grid-template-columns: minmax(0, 1.04fr) minmax(300px, 430px) !important;
    gap: 2.1rem !important;
    padding: 2.55rem 3.15rem 2.45rem 3.15rem !important;
    overflow: hidden !important;
    isolation: isolate !important;
    border-radius: 1.18rem !important;
    border: 1px solid rgba(0, 230, 246, 0.20) !important;
    border-top-color: rgba(236, 183, 110, 0.48) !important;
    background:
      radial-gradient(circle at 83% 42%, rgba(0, 230, 246, 0.18), transparent 17rem),
      radial-gradient(circle at 73% 50%, rgba(236, 183, 110, 0.12), transparent 19rem),
      linear-gradient(90deg, rgba(0, 9, 15, 0.48), rgba(0, 18, 33, 0.56) 43%, rgba(0, 9, 15, 0.34)),
      linear-gradient(135deg, rgba(17, 46, 64, 0.50), rgba(5, 18, 25, 0.70) 56%, rgba(0, 9, 15, 0.58)) !important;
    box-shadow:
      inset 0 1px 0 rgba(255, 255, 255, 0.05),
      inset 0 0 70px rgba(0, 230, 246, 0.045),
      0 18px 38px rgba(0, 0, 0, 0.20) !important;
  }

  .np-hero::before {
    left: 1.1rem !important;
    right: 1.1rem !important;
    top: 0 !important;
    height: 2px !important;
    opacity: 0.78 !important;
    background: linear-gradient(
      90deg,
      transparent,
      rgba(236, 183, 110, 0.72),
      rgba(0, 230, 246, 0.48),
      transparent
    ) !important;
  }

  .np-hero::after {
    right: 4.5rem !important;
    bottom: 2.1rem !important;
    width: 19rem !important;
    height: 19rem !important;
    opacity: 0.96 !important;
    z-index: -1 !important;
    background:
      radial-gradient(circle, rgba(0, 230, 246, 0.16), transparent 57%) !important;
  }

  .np-hero-content {
    max-width: 760px !important;
  }

  .np-hero h1 {
    margin-bottom: 0.8rem !important;
    font-size: clamp(3.2rem, 4vw, 4.6rem) !important;
    line-height: 0.94 !important;
  }

  .np-hero-title-sub {
    margin-top: 0.22rem !important;
    font-size: 0.70em !important;
  }

  .np-hero-text {
    max-width: 660px !important;
    margin-bottom: 1rem !important;
    font-size: 1rem !important;
    line-height: 1.58 !important;
  }

  .np-hero-highlight {
    max-width: 730px !important;
    padding: 0.86rem 1.05rem !important;
    background:
      linear-gradient(135deg, rgba(236, 183, 110, 0.08), transparent 48%),
      rgba(0, 9, 15, 0.34) !important;
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.035) !important;
  }

  .np-hero-logo {
    width: 330px !important;
    height: 330px !important;
    justify-self: center !important;
    transform: translateX(0.4rem) !important;
    filter:
      drop-shadow(0 20px 28px rgba(0, 0, 0, 0.36))
      drop-shadow(0 0 22px rgba(0, 230, 246, 0.22))
      drop-shadow(0 0 18px rgba(236, 183, 110, 0.10)) !important;
  }

  .echo-guide-box {
    margin-top: 0 !important;
    margin-bottom: 1.65rem !important;
    padding: 1.15rem 1.75rem !important;
    border-color: rgba(0, 230, 246, 0.24) !important;
    border-left: 4px solid rgba(0, 230, 246, 0.92) !important;
    background:
      radial-gradient(circle at 18% 42%, rgba(0, 230, 246, 0.13), transparent 14rem),
      linear-gradient(135deg, rgba(17, 46, 64, 0.50), rgba(0, 9, 15, 0.54)) !important;
  }

  .echo-guide-image img {
    width: 86px !important;
    height: 86px !important;
    filter:
      drop-shadow(0 12px 18px rgba(0, 0, 0, 0.34))
      drop-shadow(0 0 12px rgba(0, 230, 246, 0.18)) !important;
  }

  .echo-guide-content h2 {
    margin-bottom: 0.2rem !important;
    font-size: 1.45rem !important;
  }
}

@media (min-width: 66.5rem) and (max-width: 1220px) {
  .np-hero {
    grid-template-columns: minmax(0, 1fr) 245px !important;
    padding: 2.25rem 2.25rem !important;
  }

  .np-hero-logo {
    width: 245px !important;
    height: 245px !important;
    transform: none !important;
  }
}
