/* Version klickbare Boxen fertig bild */

:root{
  --bg:#0b1220;
  --page:#f3f4f6;
  --text:#111827;
  --muted:#6b7280;
  --line:#e5e7eb;
  --accent:#2563eb;

  --r:14px;
  --container: 1100px;
}

/* Scrollbar-Fix */
html{ scrollbar-gutter: stable; overflow-y: scroll; }

*{ box-sizing:border-box; }

body{
  margin:0;
  font-family: system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial;
  background: var(--page);
  color: var(--text);
  line-height:1.5;
}

.container{
  width:min(var(--container), calc(100% - 2rem));
  margin:0 auto;
}

/* ---------- Topbar (dark) ---------- */

.topbar{
  position:sticky;
  top:0;
  z-index:10;
  background:#0b1220;
  border-bottom:1px solid rgba(255,255,255,.08);
}

.topbar__inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:1rem;
  padding:.9rem 0;
}

.brand{
  display:flex;
  align-items:center;
  gap:.65rem;
  text-decoration:none;
  color:#ffffff;
}

.brand__logo{
  width:28px;
  height:28px;
  object-fit:contain;
}

.brand__name{
  font-weight:800;
  letter-spacing:.12em;
}

/* Navigation */
.nav{
  display:flex;
  gap:.28rem;
  align-items:center;
}

.nav__link{
  color: rgba(255,255,255,.85);
  text-decoration:none;
  padding:.55rem .64rem;
  border-radius:12px;
}

.nav__link:hover{
  background: rgba(255,255,255,.08);
}

.nav__link.is-active{
  background: rgba(255,255,255,.14);
  color:#ffffff;
}

.nav__discord{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:32px;
  height:32px;
  padding:0;
  border-radius:12px;
  background: rgba(88, 101, 242, 0.25);
  border: 1px solid rgba(88, 101, 242, 0.3);
  transition: all 0.15s;
}
.nav__discord:hover{
  background: rgba(88, 101, 242, 0.4);
  border-color: rgba(88, 101, 242, 0.5);
  box-shadow: 0 0 10px rgba(88, 101, 242, 0.3);
}
.nav__discord img{
  width:16px;
  height:16px;
  filter: brightness(0) invert(1);
  opacity:0.85;
}
.nav__discord:hover img{
  opacity:1;
}

/* Mobile nav button */
.navbtn{
  display:none;
  border:1px solid rgba(255,255,255,.18);
  background: rgba(255,255,255,.06);
  color:#fff;
  border-radius:12px;
  padding:.45rem .7rem;
  font-size:1.2rem;
  cursor:pointer;
}

/* ---------- Main ---------- */
.main{ padding:0 0 2.5rem; }

/* ---------- Hero (Wallpaper) ---------- */

.hero{
  position:relative;
  border-bottom:1px solid rgba(0,0,0,.06);
}

/* gleiche Höhe für alle Hero-Wallpaper */
.hero--wallpaper,
.hero--wissen,
.hero--neuigkeiten,
.hero--hilfe,
.hero--odin,
.hero--hel,
.hero--freya,
.hero--thor,
.hero--walhall,
.hero--tyr,
.hero--asgard,
.hero--midgard,
.hero--zwerge,
.hero--ragnaroek,
.hero--loki,
.hero--mythologie,
.hero--lpc,
.hero--heimdall,
.hero--frigg,
.hero--asen,
.hero--wikinger,
.hero--joetnar,
.hero--wanen,
.hero--fenris,
.hero--balder,
.hero--bragi,
.hero--idun,
.hero--sif,
.hero--riesen,
.hero--walkueren,
.hero--draugr,
.hero--nornen,
.hero--urd,
.hero--verdandi,
.hero--skuld,
.hero--yggdrasil,
.hero--bifroest,
.hero--ymir,
.hero--folkwang,
.hero--gullveig,
.hero--joermungandr,
.hero--ginnungagap,
.hero--muspelheim,
.hero--niflheim,
.hero--vanaheim,
.hero--ullr,
.hero--holmgang,
.hero--vidar,
.hero--vali,
.hero--hoenir,
.hero--lodur,
.hero--forseti,
.hero--aegir,
.hero--ran,
.hero--wikinger-zeit,
.hero--kochen,
.hero--hermodr
{
  min-height: 520px;
  display:flex;
  align-items:center;
  background-size: cover;
  background-position: center;
  background-repeat:no-repeat;
}

/* Startseite */
.hero--wallpaper{
  background-image: url("../img/hero.jpg");
}

/* Wiki */
.hero--wissen{
  background-image: url("../img/wissen.jpg");
}

/* Neuigkeiten */
.hero--neuigkeiten{
  background-image: url("../img/neuigkeiten.jpg");
}

/* Hilfe */
.hero--hilfe{
  background-image: url("../img/hilfe.jpg");
}

/* Wiki Wallpapers */
.hero--odin{ background-image: url("../img/odin.jpg"); }
.hero--hel{ background-image: url("../img/hel.jpg"); }
.hero--freya{ background-image: url("../img/freya.jpg"); }
.hero--thor{ background-image: url("../img/thor.jpg"); }
.hero--walhall{ background-image: url("../img/walhall.jpg"); }
.hero--tyr{ background-image: url("../img/tyr.jpg"); }
.hero--asgard{ background-image: url("../img/asgard.jpg"); }
.hero--midgard{ background-image: url("../img/midgard.jpg"); }
.hero--zwerge{ background-image: url("../img/zwerge.jpg"); }
.hero--ragnaroek{ background-image: url("../img/ragnaroek.jpg"); }
.hero--loki{ background-image: url("../img/loki.jpg"); }
.hero--mythologie{ background-image: url("../img/nordische_mythologie.jpg"); }
.hero--lpc{ background-image: url("../img/lpc.jpg"); }
.hero--heimdall{ background-image: url("../img/heimdall.jpg"); }
.hero--frigg{ background-image: url("../img/frigg.jpg"); }
.hero--asen{ background-image: url("../img/asen.jpg"); }
.hero--wikinger{ background-image: url("../img/wikinger.jpg"); }
.hero--joetnar{ background-image: url("../img/joetnar.jpg"); }
.hero--wanen{ background-image: url("../img/wanen.jpg"); }
.hero--fenris{ background-image: url("../img/fenriswolf.jpg"); }
.hero--balder{ background-image: url("../img/balder.jpg"); }
.hero--bragi{ background-image: url("../img/bragi.jpg"); }
.hero--idun{ background-image: url("../img/idun.jpg"); }
.hero--sif{ background-image: url("../img/sif.jpg"); }
.hero--riesen{ background-image: url("../img/riesen.jpg"); }
.hero--walkueren{ background-image: url("../img/walkueren.jpg"); }
.hero--draugr{ background-image: url("../img/draugr.jpg"); }
.hero--nornen{ background-image: url("../img/nornen.jpg"); }
.hero--urd{ background-image: url("../img/urd.jpg"); }
.hero--verdandi{ background-image: url("../img/verdandi.jpg"); }
.hero--skuld{ background-image: url("../img/skuld.jpg"); }
.hero--yggdrasil{ background-image: url("../img/yggdrasil.jpg"); }
.hero--bifroest{ background-image: url("../img/bifroest.jpg"); }
.hero--ymir{ background-image: url("../img/ymir.jpg"); }
.hero--folkwang{ background-image: url("../img/folkwang.jpg"); }
.hero--gullveig{ background-image: url("../img/gullveig.jpg"); }
.hero--joermungandr{ background-image: url("../img/joermungandr.jpg"); }
.hero--ginnungagap{ background-image: url("../img/ginnungagap.jpg"); }
.hero--muspelheim{ background-image: url("../img/muspelheim.jpg"); }
.hero--niflheim{ background-image: url("../img/niflheim.jpg"); }
.hero--vanaheim{ background-image: url("../img/vanaheim.jpg"); }
.hero--ullr{ background-image: url("../img/ullr.jpg"); }
.hero--holmgang{ background-image: url("../img/holmgang.jpg"); }
.hero--vidar{ background-image: url("../img/vidar.jpg"); }
.hero--vali{ background-image: url("../img/vali.jpg"); }
.hero--hoenir{ background-image: url("../img/hoenir.jpg"); }
.hero--lodur{ background-image: url("../img/lodur.jpg"); }
.hero--forseti{ background-image: url("../img/forseti.jpg"); }
.hero--aegir{ background-image: url("../img/aegir.jpg"); }
.hero--ran{ background-image: url("../img/ran.jpg"); }
.hero--wikinger-zeit{ background-image: url("../img/wikinger-zeit.jpg"); }
.hero--kochen{ background-image: url("../img/kochen.jpg"); }
.hero--hermodr{ background-image: url("../img/hermodr.jpg"); }

.hero__overlay{
  position:absolute;
  inset:0;
  background: linear-gradient(
    to bottom,
    rgba(0,0,0,.55),
    rgba(0,0,0,.33)
  );
}

.hero__content{
  position:relative;
  z-index:1;
  padding: 3.2rem 0;
  color:#ffffff;
}

.hero h1{
  margin:0 0 .6rem;
  font-size: clamp(2.2rem, 4vw, 3.4rem);
  letter-spacing:-.02em;
  text-shadow: 0 1px 10px rgba(0,0,0,.35);
}

.lead{
  margin:0 0 1.4rem;
  font-size:1.1rem;
  color: rgba(255,255,255,.88);
  max-width: 48rem;
}

/* CTA */
.cta-main{
  display:inline-block;
  padding: .9rem 1.7rem;
  font-size: 1.15rem;
  font-weight: 700;
  background: var(--accent);
  color:#ffffff;
  border-radius: 12px;
  border:1px solid rgba(0,0,0,0);
  text-decoration:none;
  transition: background .15s ease;
}

.cta-main:hover,
.cta-main:focus-visible{
  background:#1e40af;
  text-decoration:none;
}

.cta-sub{
  margin:.55rem 0 0;
  font-size:.95rem;
  color: rgba(255,255,255,.85);
}

/* Section spacing */
.section{ padding: 1.4rem 0 0; }

/* ---------- Cards / Grids ---------- */

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

.stack{ display:grid; gap:1rem; }

.card{
  background:#ffffff;
  border:1px solid rgba(0,0,0,.08);
  border-radius: 16px;
  padding: 1.2rem;
  box-shadow: 0 8px 24px rgba(0,0,0,.06);
}

.card h2{
  margin:.1rem 0 .5rem;
  font-size: 1.35rem;
}

.muted{ color: var(--muted); }

.card--nav p.muted{
  margin-top: -15px;     /* näher an h2 */
  margin-bottom: 0;  /* optional, falls es unten auch zu viel ist */
}

/* Links in content + footer */
.main a:not(.cta-main),
.footer a{
  color:#1d4ed8;
  text-decoration:none;
}
.main a:not(.cta-main):visited,
.footer a:visited{
  color:#1d4ed8;
}
.main a:not(.cta-main):hover,
.footer a:hover{
  text-decoration:underline;
}

/* Page head (für Unterseiten) */
.pagehead{
  padding: 1.6rem 0 1rem;
}
.pagehead h1{
  margin:0 0 .35rem;
  font-size: clamp(1.8rem, 3vw, 2.4rem);
}
.pagehead .lead{
  margin:0;
  color: var(--muted);
  text-shadow:none;
}

pre{
  max-width: 100%;
  white-space: pre-wrap;
  overflow-wrap: anywhere;

  margin: .8rem 0;
  padding: .75rem .9rem;
  border: 1px solid var(--line);
  border-radius: 14px;
  background: #f9fafb;
}

/* Inline-Code weiterhin hübsch */
code{
  padding:.22rem .45rem;
  border-radius:10px;
  border:1px solid var(--line);
  background:#f9fafb;
}

/* Code INSIDE pre neutralisieren */
pre code{
  padding: 0;
  border: 0;
  background: transparent;
}

/* ---------- Timeline (schöner / chronikartig) ---------- */

.timeline{
  display:grid;
  gap:1.1rem;
  margin-top:1rem;
}

.timeline__item{
  display:grid;
  grid-template-columns: 140px 1fr;
  gap:1rem;
  padding:.2rem 0;
  border:0;
  background:transparent;
}

.timeline__date{
  font-weight:800;
  color:#111827;
}

.timeline__content{
  color: var(--muted);
  padding-left: .9rem;
  border-left: 2px solid rgba(0,0,0,.08);
}

/* ---------- DML table (ALT, kann bleiben) ---------- */

.tablewrap{ width:100%; overflow:auto; }
.dml{
  width:100%;
  border-collapse:collapse;
  min-width:720px;
}
.dml th,
.dml td{
  text-align:left !important;
  padding:.75rem .7rem;
  border-top:1px solid var(--line);
  vertical-align:top;
}
.dml thead th{
  border-top:0;
  font-weight:800;
  background:#f9fafb;
}
.dml small{ font-weight:400; }

.playbtn{
  display:inline-block;
  padding:.45rem .75rem;
  border:1px solid var(--line);
  border-radius:12px;
  background:#ffffff;
  text-decoration:none;
  color:#1d4ed8;
}
.playbtn:hover{ background:#f9fafb; text-decoration:none; }

/* ---------- DML Liste (NEU, ersetzt Table im Markup) ---------- */

.dmlList{
  display:grid;
  gap:.85rem;
  margin-top:.6rem;
}

.dmlItem{
  border:1px solid rgba(0,0,0,.08);
  border-radius:16px;
  padding:1rem;
  background:#ffffff;
  box-shadow: 0 8px 24px rgba(0,0,0,.04);
}

.dmlHead{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:.9rem;
  padding-bottom:.8rem;
  border-bottom:1px solid var(--line);
}

.dmlTitle{
  display:flex;
  align-items:baseline;
  flex-wrap:wrap;
  gap:.45rem;
  min-width:0;
}

.dmlName{
  font-weight:800;
  font-size:1.05rem;
  text-decoration:none;
}

.dmlName:hover{ text-decoration:underline; }

.dmlLang{ font-size:.95rem; }

.dmlPlay{
  flex:0 0 auto;
  white-space:nowrap;
}

.dmlMeta{
  display:grid;
  gap:.65rem;
  padding-top:.85rem;
}

.dmlRow{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:1rem;
}

.dmlLabel{
  flex:0 0 auto;
  min-width:130px;
}

.dmlRow code{
  max-width:100%;
  overflow-wrap:anywhere;
}

/* ---------- Wiki Matrix ---------- */

.wikiMatrix{
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1rem;
  margin-top:.8rem;
}

.wikiCell{
  border:1px solid rgba(0,0,0,.07);
  background:#ffffff;
  border-radius:14px;
  padding:.95rem 1rem;
  box-shadow: 0 8px 24px rgba(0,0,0,.04);
}

.wikiCell h3{
  margin:0 0 .55rem;
  font-size:.98rem;
}

/* Keywords */
.kwRow{
  display:flex;
  flex-wrap:wrap;
  line-height:1.7;
}

.kwRow a{
  font-weight:700;
  color:#1d4ed8;
  text-decoration:none;
}

.kwRow a:hover{ text-decoration:underline; }

.kwSep{
  color: rgba(17,24,39,.35);
  user-select:none;
  white-space:nowrap;
}

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

.footer{
  margin-top:2.2rem;
  background:#0b1220;
  border-top:1px solid rgba(255,255,255,.08);
}

.footer__inner{
  padding:1.2rem 0;
  color: rgba(255,255,255,.72);
  font-size:.95rem;
}

.footer__inner a{
  color: rgba(255,255,255,.85);
}

.footer__inner a:hover{
  text-decoration:underline;
}

.sep{ margin:0 .45rem; opacity:.7; }

/* ---------- Mobile ---------- */

@media (max-width: 860px){
  .navbtn{ display:block; }

  .nav{
    display:none;
    position:absolute;
    top:64px;
    left:1rem;
    right:1rem;
    background:#0b1220;
    border:1px solid rgba(255,255,255,.12);
    border-radius:14px;
    flex-direction:column;
    padding:.6rem;
  }

  .nav.is-open{ display:flex; }

  .grid{ grid-template-columns:1fr; }
  .wikiMatrix{ grid-template-columns:1fr; }

  .cta-main{
    width:100%;
    text-align:center;
  }

  .timeline__item{
    grid-template-columns: 1fr;
  }

  .timeline__content{
    padding-left: 0;
    border-left: 0;
    border-top: 2px solid rgba(0,0,0,.08);
    padding-top: .6rem;
  }
}

@media (max-width: 640px){
  .dmlHead{
    flex-direction:column;
    align-items:stretch;
  }

  .dmlPlay{
    align-self:flex-start;
  }

  .dmlRow{
    flex-direction:column;
    gap:.35rem;
  }

  .dmlLabel{
    min-width:0;
  }
}

/* Footer links white */
.footer a,
.footer a:visited{
  color:#ffffff;
}
.footer a:hover{
  text-decoration:underline;
}


/* =========================================================
   TOC (Inhaltsverzeichnis) – Kacheln mit Nummern-Badge
   ========================================================= */

/* Dein Markup hat:
   <nav class="toc">
     <ol class="toc__list">
       <li> <a href="..."> ... </a> <span class="toc__meta"> ... </span> </li>
     </ol>
   </nav>
*/

.toc{
  display:block;
}

.toc__list{
  list-style:none;
  padding:0;
  margin:0;
  display:grid;
  grid-template-columns: 1fr;   /* Mobile */
  gap:.85rem;
}

/* Desktop: 2 Kacheln */
@media (min-width: 860px){
  .toc__list{
    grid-template-columns: 1fr 1fr;
  }
}

.toc__list li{
  margin:0;
  padding:0;
}

/* Wir machen den Link zur Kachel */
.toc__list li > a{
  display:flex;
  align-items:flex-start;
  gap:.9rem;

  padding:1.05rem 1.1rem;
  border-radius:18px;
  background:#ffffff;
  border:1px solid rgba(0,0,0,.08);
  box-shadow: 0 8px 22px rgba(0,0,0,.05);

  color: var(--text);
  text-decoration:none;

  /* Wichtig: KEIN translate => kein „hochspringen“ */
  transition: background .15s ease, border-color .15s ease, box-shadow .15s ease;
}

/* Nummer-Badge automatisch via CSS Counter */
.toc__list{
  counter-reset: toc;
}

.toc__list li > a::before{
  counter-increment: toc;
  content: counter(toc);

  min-width:2.5rem;
  height:2.5rem;
  display:inline-flex;
  align-items:center;
  justify-content:center;

  border-radius:12px;
  font-weight:900;
  font-size:.95rem;

  color: var(--accent);
  background: rgba(37,99,235,.12);
  border: 1px solid rgba(37,99,235,.25);
}

/* Titel im Link: schöner und kompakter */
.toc__list li > a{
  line-height:1.25;
  font-weight:800;
}

/* Meta-Text bleibt unterhalb, nicht im Link */
.toc__meta{
  display:block;
  margin-top:.35rem;
  margin-left: 0;     /* NICHT eingerückt */
  font-size:.95rem;
  color: var(--muted);
}

/* Hover: nur hellgrau, kein Underline, kein Springen */
.toc__list li > a:hover{
  background:#f9fafb;
  border-color: rgba(0,0,0,.12);
  box-shadow: 0 10px 26px rgba(0,0,0,.06);
}

/* Fokus */
.toc__list li > a:focus-visible{
  outline: 3px solid rgba(37, 99, 235, .25);
  outline-offset: 3px;
}

/* WICHTIG: TOC-Links NIE unterstreichen (überschreibt deine globale Hover-Regel) */
.toc a,
.toc a:hover,
.toc a:focus,
.toc a:active,
.toc a:visited{
  text-decoration:none !important;
}

/* =========================================================
   Startseite – Navi-Karten (voll klickbar + Bild unten 65%)
   ========================================================= */

.card--nav{
  position:relative;
  overflow:hidden;
  min-height: 250px; /* 170px */
  padding: 1.2rem;
  display:flex;
  flex-direction:column;
  gap:.45rem;
  justify-content:flex-start;
  cursor:pointer;

  /* no “hochgehen” */
  transition: background .15s ease, border-color .15s ease, box-shadow .15s ease;
}

/* Bild unten 65% (ohne Transparenz) */
.card--nav::after{
  content:"";
  position:absolute;
  left:0;
  right:0;
  bottom:0;
  height:65%; /* Höhe Bilder bei Boxen */
  background-image: var(--card-bg);
  background-size:cover;
  background-position:center;
  background-repeat:no-repeat;
  z-index:0;
}

/* dezente Trennkante zwischen Text und Bild */
.card--nav::before{
  content:"";
  position:absolute;
  left:0;
  right:0;
  bottom:65%;
  height:1px;
  background: rgba(0,0,0,.08);
  z-index:1;
}

.card--nav > *{
  position:relative;
  z-index:2;
}

/* Der unsichtbare "Hit-Link" macht die ganze Karte klickbar */
.card__hit{
  position:absolute;
  inset:0;
  z-index:1;
  display:block;
  border-radius:16px;
  text-decoration:none;
}

/* Damit Klicks auf Text zur Card-Navigation durchgehen */
.card--nav h2,
.card--nav p{
  pointer-events:none;
}

/* Hover nur farblich / shadow, kein translate */
.card--nav:hover{
  background:#f9fafb;
  border-color: rgba(0,0,0,.12);
  box-shadow: 0 10px 26px rgba(0,0,0,.06);
}

.card--nav:focus-within{
  border-color: rgba(37, 99, 235, .35);
  box-shadow: 0 10px 26px rgba(0,0,0,.06);
}

/* Button wie TOC-Badge, aber NICHT transparent (solid) */
/* card__btn Button von Info-Boxen, wie Neuigkeiten, Hilfe, usw. auf Startseite */

.card__btn{
  /* Positionierung */
  margin-top: auto;
  margin-left: auto;

  display: inline-flex;
  align-items: center;
  justify-content: center;

  /* ursprüngliche Größe */
  padding: .55rem .85rem;
  border-radius: 12px;
  font-size: .95rem;
  font-weight: 900;

  /* Farben */
  background: var(--accent);
  color: #ffffff !important;   /* 👈 erzwingt weiße Schrift */
  border: 1px solid transparent;

  text-decoration: none;

  position: relative;
  z-index: 3;
  pointer-events: auto;

  transition: background .15s ease;
}

.card__btn:hover,
.card__btn:focus-visible{
  background: #1e40af;
  color: #ffffff !important;   /* 👈 bleibt weiß beim Hover */
  text-decoration: none;
}

.card__btn:focus-visible{
  outline: 3px solid rgba(37, 99, 235, .25);
  outline-offset: 3px;
}


/* globale Hover-Unterstreichung für diesen Button sicher aus */
.main a.card__btn,
.main a.card__btn:hover,
.main a.card__btn:visited{
  text-decoration:none !important;
}
