/*
 * HEUREKA Wiki · Fanarchiv · Stylesheet
 * Fanwiki-Mockup · alle Inhalte fiktiv
 * Wahr ist, was trägt.
 */

:root {
      --serif: Georgia, "Times New Roman", serif;
      --paper: #eee7d7;
      --paper-2: #f7f1e4;
      --ink: #1f1d18;
      --muted: #6f6758;
      --gold: #b99654;
      --gold-2: #d2b26d;
      --line: rgba(31, 29, 24, 0.18);
      --dark: #11100e;
      --link: #6a4a14;
      --blue: #29364d;
      --red: #8a3a26;
      --green: #3d5a3a;
    }

    * { box-sizing: border-box; }

    body {
      margin: 0;
      font-family: Georgia, "Times New Roman", serif;
      color: var(--ink);
      background:
        radial-gradient(circle at 20% 0%, rgba(185, 150, 84, 0.24), transparent 28%),
        radial-gradient(circle at 85% 12%, rgba(41, 54, 77, 0.20), transparent 24%),
        linear-gradient(180deg, #f8f2e6 0%, var(--paper) 48%, #e5dcc8 100%);
      min-height: 100vh;
    }

    a { color: var(--link); text-decoration: none; }
    a:hover { text-decoration: underline; }

    .topbar {
      height: 56px;
      background: rgba(17, 16, 14, 0.94);
      color: var(--paper);
      display: flex;
      align-items: center;
      justify-content: space-between;
      padding: 0 24px;
      border-bottom: 2px solid var(--gold);
      position: sticky;
      top: 0;
      z-index: 10;
      backdrop-filter: blur(8px);
    }

    .brand {
      display: flex;
      align-items: baseline;
      gap: 12px;
      letter-spacing: 0.08em;
      text-transform: uppercase;
    }

    .brand strong { font-size: 19px; color: var(--gold-2); }
    .brand span { font-size: 11px; color: #cfc5b2; }

    .topbar-meta {
      display: flex;
      gap: 18px;
      font-size: 11px;
      color: #cfc5b2;
      letter-spacing: 0.05em;
      text-transform: uppercase;
    }
    .topbar-meta span b { color: var(--gold-2); font-weight: normal; }

    .search {
      display: flex;
      width: min(360px, 42vw);
      border: 1px solid rgba(210, 178, 109, 0.45);
      background: rgba(255,255,255,0.06);
      border-radius: 999px;
      overflow: hidden;
    }

    .search input {
      flex: 1;
      border: 0;
      outline: 0;
      background: transparent;
      color: var(--paper);
      padding: 9px 14px;
      font-family: inherit;
    }

    .search button {
      border: 0;
      background: var(--gold);
      color: #1a1510;
      padding: 0 14px;
      font-weight: bold;
      cursor: pointer;
    }

    .featured-banner {
      max-width: 1440px;
      margin: 18px auto 0;
      padding: 0 24px;
    }
    .featured-banner-inner {
      background: linear-gradient(100deg, rgba(17,16,14,0.94), rgba(41,54,77,0.85));
      color: var(--paper);
      border: 1px solid var(--gold);
      padding: 14px 22px;
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 18px;
      flex-wrap: wrap;
    }
    .featured-banner-inner .label {
      font-size: 11px;
      letter-spacing: 0.18em;
      text-transform: uppercase;
      color: var(--gold-2);
    }
    .featured-banner-inner .title {
      font-size: 17px;
      letter-spacing: 0.03em;
    }
    .featured-banner-inner .cta {
      background: var(--gold);
      color: #1a1510;
      padding: 6px 14px;
      font-size: 12px;
      letter-spacing: 0.08em;
      text-transform: uppercase;
    }

    .page {
      display: grid;
      grid-template-columns: 220px minmax(0, 1fr) 320px;
      gap: 24px;
      max-width: 1440px;
      margin: 0 auto;
      padding: 24px;
    }

    .sidebar,
    .infobox,
    .content,
    .right-stack > * {
      background: rgba(247, 241, 228, 0.82);
      border: 1px solid var(--line);
      box-shadow: 0 18px 50px rgba(31, 29, 24, 0.08);
    }

    .sidebar {
      padding: 18px;
      align-self: start;
      position: sticky;
      top: 80px;
      max-height: calc(100vh - 100px);
      overflow-y: auto;
    }

    .wiki-logo {
      aspect-ratio: 1;
      border: 1px solid var(--gold);
      display: grid;
      place-items: center;
      margin-bottom: 18px;
      background:
        radial-gradient(circle, rgba(185,150,84,0.35), transparent 45%),
        linear-gradient(135deg, #1b1a17, #2a2117);
      color: var(--gold-2);
      text-align: center;
      letter-spacing: 0.11em;
    }

    .wiki-logo .omega { font-size: 48px; line-height: 1; }
    .wiki-logo small { display: block; font-size: 10px; margin-top: 7px; }

    .nav-section { border-top: 1px solid var(--line); padding-top: 14px; margin-top: 14px; }
    .nav-section h3 { margin: 0 0 8px; font-size: 13px; text-transform: uppercase; letter-spacing: 0.08em; color: var(--muted); }
    .nav-section ul { list-style: none; padding: 0; margin: 0; }
    .nav-section li { margin: 8px 0; font-size: 14px; }
    .nav-section li small { color: var(--muted); font-size: 11px; }

    .content {
      padding: 28px 34px 36px;
      min-width: 0;
    }

    .tabs {
      display: flex;
      gap: 8px;
      border-bottom: 1px solid var(--line);
      margin: -8px 0 22px;
      padding-bottom: 10px;
      font-size: 13px;
    }

    .tab {
      padding: 6px 11px;
      border: 1px solid var(--line);
      background: rgba(255,255,255,0.38);
      border-radius: 999px;
    }

    .tab.active {
      background: var(--dark);
      color: var(--paper);
      border-color: var(--dark);
    }

    h1 {
      font-size: clamp(36px, 5vw, 62px);
      margin: 0 0 6px;
      letter-spacing: 0.06em;
      text-transform: uppercase;
      font-weight: normal;
    }

    .subtitle {
      color: var(--muted);
      font-style: italic;
      margin-bottom: 18px;
      font-size: 17px;
    }

    .notice {
      border-left: 4px solid var(--gold);
      background: rgba(185, 150, 84, 0.12);
      padding: 13px 16px;
      margin: 20px 0 24px;
      font-size: 15px;
    }
    .notice.warn { border-left-color: var(--red); background: rgba(138,58,38,0.10); }
    .notice.info { border-left-color: var(--blue); background: rgba(41,54,77,0.10); }

    .lead {
      font-size: 18px;
      line-height: 1.7;
      margin-bottom: 24px;
    }

    .toc {
      border: 1px solid var(--line);
      background: rgba(255,255,255,0.32);
      padding: 16px 18px;
      width: min(520px, 100%);
      margin: 18px 0 30px;
    }

    .toc h2 {
      margin: 0 0 10px;
      font-size: 16px;
      text-transform: uppercase;
      letter-spacing: 0.08em;
      color: var(--muted);
    }

    .toc ol { margin: 0; padding-left: 20px; line-height: 1.8; }
    .toc ol ol { padding-left: 22px; font-size: 14px; }

    section { margin-top: 32px; }

    section h2 {
      font-size: 27px;
      font-weight: normal;
      border-bottom: 1px solid var(--line);
      padding-bottom: 8px;
      margin-bottom: 14px;
      letter-spacing: 0.03em;
    }

    section h3 {
      font-size: 19px;
      font-weight: normal;
      margin: 22px 0 8px;
      letter-spacing: 0.02em;
      color: #2a2620;
    }

    section p, section li {
      font-size: 16px;
      line-height: 1.72;
    }

    .quote-box {
      margin: 18px 0;
      padding: 20px;
      background: #171512;
      color: var(--paper);
      border-left: 5px solid var(--gold);
      font-size: 20px;
      line-height: 1.5;
    }

    .quote-box small {
      display: block;
      color: #cdbb91;
      margin-top: 8px;
      font-size: 13px;
      letter-spacing: 0.04em;
    }

    .cards {
      display: grid;
      grid-template-columns: repeat(2, minmax(0, 1fr));
      gap: 14px;
      margin-top: 16px;
    }

    .card {
      border: 1px solid var(--line);
      padding: 16px;
      background: rgba(255,255,255,0.28);
      min-height: 126px;
      position: relative;
    }

    .card h3 { margin: 0 0 8px; font-size: 18px; }
    .card p { margin: 0; font-size: 14px; color: #3d372f; }
    .card .figure-meta {
      margin-top: 10px;
      font-size: 11px;
      color: var(--muted);
      letter-spacing: 0.05em;
      text-transform: uppercase;
      border-top: 1px dashed var(--line);
      padding-top: 8px;
    }
    .card .figure-status {
      position: absolute;
      top: 12px;
      right: 12px;
      font-size: 10px;
      letter-spacing: 0.1em;
      text-transform: uppercase;
      padding: 2px 7px;
      border-radius: 999px;
    }
    .status-z2 { background: rgba(41,54,77,0.18); color: var(--blue); }
    .status-z3 { background: rgba(185,150,84,0.25); color: #5a3d10; }
    .status-meta { background: rgba(61,90,58,0.18); color: var(--green); }
    .status-mystery { background: rgba(138,58,38,0.18); color: var(--red); }

    .timeline {
      border-left: 2px solid var(--gold);
      margin: 20px 0 0 10px;
      padding-left: 22px;
    }

    .event {
      position: relative;
      margin-bottom: 22px;
    }

    .event::before {
      content: "";
      position: absolute;
      left: -30px;
      top: 6px;
      width: 13px;
      height: 13px;
      border-radius: 50%;
      background: var(--gold);
      box-shadow: 0 0 0 4px rgba(185,150,84,0.18);
    }

    .event strong { display: block; color: #322512; margin-bottom: 3px; }
    .event .note {
      display: inline-block;
      font-size: 11px;
      color: var(--muted);
      background: rgba(255,255,255,0.4);
      border: 1px solid var(--line);
      padding: 1px 6px;
      margin-left: 6px;
      vertical-align: middle;
    }
    .event .note.warn { color: var(--red); border-color: rgba(138,58,38,0.4); }
    .event .note.cite { color: var(--blue); border-color: rgba(41,54,77,0.4); }

    .infobox {
      align-self: start;
      overflow: hidden;
    }

    .infobox-title {
      background: var(--dark);
      color: var(--gold-2);
      text-align: center;
      padding: 16px 12px;
      text-transform: uppercase;
      letter-spacing: 0.12em;
      font-size: 22px;
    }

    .poster {
      height: 230px;
      display: grid;
      place-items: center;
      color: var(--paper);
      background:
        radial-gradient(circle at 50% 50%, rgba(210,178,109,0.65), transparent 18%),
        radial-gradient(circle at 50% 65%, rgba(41,54,77,0.65), transparent 38%),
        linear-gradient(160deg, #080807, #2b2318 55%, #0e1522);
      border-bottom: 1px solid var(--line);
      text-align: center;
      padding: 20px;
    }

    .poster .symbol { font-size: 74px; line-height: 0.9; color: var(--gold-2); }
    .poster .tag { font-size: 13px; letter-spacing: 0.12em; margin-top: 10px; text-transform: uppercase; }

    .info-row {
      display: grid;
      grid-template-columns: 110px 1fr;
      border-top: 1px solid var(--line);
      font-size: 14px;
    }

    .info-row b {
      padding: 10px 12px;
      background: rgba(185,150,84,0.12);
      color: #493815;
    }

    .info-row span { padding: 10px 12px; }

    .right-stack {
      display: flex;
      flex-direction: column;
      gap: 18px;
      align-self: start;
      position: sticky;
      top: 80px;
      max-height: calc(100vh - 100px);
      overflow-y: auto;
    }
    .right-stack > * { padding: 0; }
    .right-stack h4 {
      background: var(--dark);
      color: var(--gold-2);
      margin: 0;
      padding: 12px 14px;
      font-size: 13px;
      letter-spacing: 0.1em;
      text-transform: uppercase;
      font-weight: normal;
    }
    .right-stack .body { padding: 14px 16px; font-size: 13px; line-height: 1.6; }
    .right-stack .body ul { padding-left: 18px; margin: 0; }
    .right-stack .body li { margin-bottom: 6px; }

    .discussion-item {
      border-top: 1px solid var(--line);
      padding: 10px 14px;
      font-size: 13px;
    }
    .discussion-item:first-of-type { border-top: 0; }
    .discussion-item .user { color: var(--blue); font-weight: bold; }
    .discussion-item .meta { color: var(--muted); font-size: 11px; }

    .editor-item {
      display: flex;
      align-items: center;
      gap: 10px;
      border-top: 1px solid var(--line);
      padding: 10px 14px;
      font-size: 13px;
    }
    .editor-item:first-of-type { border-top: 0; }
    .editor-item .avatar {
      width: 30px; height: 30px; border-radius: 50%;
      background: linear-gradient(135deg, var(--gold), var(--blue));
      color: var(--paper);
      display: grid; place-items: center;
      font-size: 11px; font-weight: bold;
      flex-shrink: 0;
    }
    .editor-item .user { color: var(--link); font-weight: bold; }
    .editor-item .meta { color: var(--muted); font-size: 11px; }

    .categories {
      display: flex;
      flex-wrap: wrap;
      gap: 8px;
      margin-top: 28px;
      border-top: 1px solid var(--line);
      padding-top: 18px;
    }

    .category {
      background: rgba(17,16,14,0.08);
      border: 1px solid var(--line);
      padding: 7px 10px;
      border-radius: 999px;
      font-size: 13px;
    }

    .footer {
      grid-column: 1 / -1;
      text-align: center;
      color: var(--muted);
      font-size: 13px;
      padding: 18px 0 8px;
      line-height: 1.7;
    }
    .footer a { color: var(--link); }

    /* Theorien-Boxen */
    .theory {
      border: 1px solid var(--line);
      background: rgba(255,255,255,0.32);
      padding: 14px 18px;
      margin: 14px 0;
      position: relative;
    }
    .theory .theory-tag {
      position: absolute;
      top: -10px;
      left: 14px;
      background: var(--dark);
      color: var(--gold-2);
      font-size: 10px;
      letter-spacing: 0.12em;
      text-transform: uppercase;
      padding: 3px 9px;
    }
    .theory h3 { margin-top: 8px; }
    .theory .supporters {
      margin-top: 10px;
      font-size: 12px;
      color: var(--muted);
      letter-spacing: 0.04em;
    }
    .theory .supporters b { color: var(--ink); font-weight: normal; }

    /* Trivia-Liste */
    .trivia-grid {
      display: grid;
      grid-template-columns: repeat(2, 1fr);
      gap: 10px;
    }
    .trivia-item {
      border-left: 3px solid var(--gold);
      padding: 10px 14px;
      background: rgba(255,255,255,0.32);
      font-size: 14px;
      line-height: 1.55;
    }

    /* Relations / Beziehungstabelle */
    .relations {
      width: 100%;
      border-collapse: collapse;
      margin-top: 12px;
      font-size: 14px;
    }
    .relations th, .relations td {
      padding: 9px 11px;
      border: 1px solid var(--line);
      text-align: left;
      vertical-align: top;
    }
    .relations th {
      background: rgba(185,150,84,0.12);
      font-weight: normal;
      color: #493815;
      letter-spacing: 0.04em;
    }
    .relations tr:nth-child(even) td { background: rgba(255,255,255,0.18); }

    /* Controversy boxes */
    .controversy {
      border-top: 1px solid var(--line);
      padding: 14px 0;
    }
    .controversy:first-of-type { border-top: 0; padding-top: 4px; }
    .controversy h3 {
      margin: 0 0 6px;
      font-size: 17px;
      color: var(--red);
    }
    .controversy .side {
      display: grid;
      grid-template-columns: 70px 1fr;
      gap: 10px;
      margin-top: 6px;
      font-size: 14px;
    }
    .controversy .side b {
      font-style: italic;
      color: var(--muted);
      font-weight: normal;
    }

    /* Easter eggs */
    .egg-list {
      display: grid;
      grid-template-columns: 1fr;
      gap: 8px;
    }
    .egg {
      display: grid;
      grid-template-columns: 90px 1fr;
      gap: 14px;
      padding: 10px 14px;
      border: 1px solid var(--line);
      background: rgba(255,255,255,0.28);
      font-size: 14px;
    }
    .egg b { color: var(--blue); letter-spacing: 0.02em; }

    /* Stub-Hinweis */
    .stub {
      font-size: 13px;
      color: var(--muted);
      font-style: italic;
      border: 1px dashed var(--line);
      padding: 10px 14px;
      margin-top: 10px;
      background: rgba(255,255,255,0.18);
    }

    .inline-cite {
      color: var(--blue);
      font-size: 11px;
      vertical-align: super;
      margin-left: 1px;
    }

    .merch-grid {
      display: grid;
      grid-template-columns: repeat(3, 1fr);
      gap: 12px;
      margin-top: 14px;
    }
    .merch-item {
      border: 1px solid var(--line);
      background: rgba(255,255,255,0.32);
      padding: 12px;
      font-size: 13px;
      line-height: 1.5;
    }
    .merch-item .icon {
      height: 60px;
      display: grid;
      place-items: center;
      font-size: 30px;
      color: var(--gold);
      border-bottom: 1px solid var(--line);
      margin-bottom: 10px;
    }
    .merch-item b { color: #322512; display: block; margin-bottom: 4px; font-size: 14px; }

    /* Behind the Scenes */
    .bts {
      display: grid;
      grid-template-columns: 130px 1fr;
      gap: 16px;
      align-items: start;
      border-top: 1px solid var(--line);
      padding: 14px 0;
    }
    .bts:first-of-type { border-top: 0; padding-top: 4px; }
    .bts b { color: #322512; }
    .bts small { color: var(--muted); display: block; font-size: 11px; margin-top: 2px; letter-spacing: 0.03em; }

    /* Figuren-Profil (ausgebaut) */
    .profile {
      border: 1px solid var(--line);
      background: rgba(255,255,255,0.32);
      margin: 22px 0;
      padding: 0;
      overflow: hidden;
    }
    .profile-head {
      display: grid;
      grid-template-columns: 90px 1fr auto;
      gap: 14px;
      align-items: center;
      background: linear-gradient(95deg, rgba(17,16,14,0.92), rgba(41,54,77,0.78));
      color: var(--paper);
      padding: 14px 18px;
    }
    .profile-head .glyph {
      width: 60px; height: 60px;
      border: 1px solid var(--gold);
      display: grid; place-items: center;
      font-size: 26px; color: var(--gold-2);
      background: rgba(0,0,0,0.3);
    }
    .profile-head .who { letter-spacing: 0.03em; }
    .profile-head .who h3 { margin: 0; font-size: 22px; font-weight: normal; color: var(--gold-2); letter-spacing: 0.04em; text-transform: uppercase; }
    .profile-head .who small { color: #cfc5b2; font-size: 12px; letter-spacing: 0.06em; }
    .profile-head .badge {
      font-size: 10px;
      padding: 4px 9px;
      border-radius: 999px;
      letter-spacing: 0.12em;
      text-transform: uppercase;
      background: rgba(185,150,84,0.25);
      color: var(--gold-2);
      border: 1px solid var(--gold);
    }
    .profile-body { padding: 16px 20px 18px; }
    .profile-body p { margin: 0 0 10px; font-size: 15px; }
    .profile-grid {
      display: grid;
      grid-template-columns: repeat(2, 1fr);
      gap: 10px 18px;
      margin: 12px 0;
      font-size: 13px;
      border-top: 1px dashed var(--line);
      padding-top: 12px;
    }
    .profile-grid div b {
      display: block;
      color: var(--muted);
      letter-spacing: 0.05em;
      text-transform: uppercase;
      font-size: 10px;
      font-weight: normal;
      margin-bottom: 1px;
    }
    .profile-quotes {
      border-top: 1px dashed var(--line);
      padding-top: 12px;
      margin-top: 8px;
    }
    .profile-quotes .pq {
      font-style: italic;
      color: #2a2620;
      margin: 6px 0;
      padding-left: 14px;
      border-left: 2px solid var(--gold);
      font-size: 14px;
    }
    .profile-quotes .pq small { display: block; color: var(--muted); font-style: normal; font-size: 11px; margin-top: 2px; }
    .profile-fanlore {
      margin-top: 12px;
      padding-top: 10px;
      border-top: 1px dashed var(--line);
      font-size: 13px;
      color: #3d372f;
    }
    .profile-fanlore b { color: var(--blue); font-weight: normal; letter-spacing: 0.04em; }

    /* Glossar */
    .glossary {
      column-count: 2;
      column-gap: 28px;
      margin-top: 12px;
    }
    .glossary dt {
      font-weight: bold;
      color: #322512;
      margin-top: 8px;
      letter-spacing: 0.02em;
    }
    .glossary dd {
      margin: 2px 0 8px;
      font-size: 14px;
      line-height: 1.55;
      color: #3d372f;
    }

    /* Zitate-Tafel */
    .quote-table {
      display: grid;
      grid-template-columns: 1fr;
      gap: 6px;
      margin-top: 10px;
    }
    .qt-row {
      display: grid;
      grid-template-columns: 130px 1fr 110px;
      gap: 10px;
      padding: 8px 10px;
      border-bottom: 1px solid var(--line);
      font-size: 14px;
      align-items: baseline;
    }
    .qt-row:nth-child(even) { background: rgba(255,255,255,0.18); }
    .qt-row .figure { font-weight: bold; color: var(--blue); letter-spacing: 0.02em; }
    .qt-row .text { font-style: italic; }
    .qt-row .src { font-size: 11px; color: var(--muted); text-align: right; letter-spacing: 0.04em; }

    /* Fanfiction-Liste */
    .ff-list { display: flex; flex-direction: column; gap: 10px; margin-top: 10px; }
    .ff-item {
      display: grid;
      grid-template-columns: 1fr auto;
      gap: 14px;
      border: 1px solid var(--line);
      background: rgba(255,255,255,0.28);
      padding: 12px 16px;
      font-size: 14px;
    }
    .ff-item .title { font-weight: bold; color: #322512; font-size: 15px; }
    .ff-item .meta { color: var(--muted); font-size: 12px; margin-top: 3px; letter-spacing: 0.03em; }
    .ff-item .desc { margin-top: 6px; font-size: 13px; line-height: 1.5; color: #3d372f; }
    .ff-item .rating {
      align-self: start;
      font-size: 11px;
      letter-spacing: 0.1em;
      padding: 3px 9px;
      border: 1px solid var(--line);
      background: rgba(185,150,84,0.18);
      color: #493815;
    }

    /* Adaptionen */
    .adapt {
      border-left: 4px solid var(--blue);
      padding: 12px 16px;
      background: rgba(41,54,77,0.08);
      margin: 12px 0;
    }
    .adapt h3 { margin: 0 0 6px; font-size: 17px; color: var(--blue); }
    .adapt .status {
      font-size: 11px;
      letter-spacing: 0.1em;
      text-transform: uppercase;
      color: var(--muted);
      margin-bottom: 6px;
    }
    .adapt .status b {
      color: var(--gold);
      background: rgba(185,150,84,0.15);
      padding: 1px 7px;
      margin-right: 6px;
      font-weight: normal;
    }
    .adapt p { margin: 4px 0; font-size: 14px; }

    /* Kanon vs Fanon */
    .kvf {
      width: 100%;
      border-collapse: collapse;
      margin-top: 12px;
      font-size: 14px;
    }
    .kvf th, .kvf td {
      padding: 8px 11px;
      border: 1px solid var(--line);
      vertical-align: top;
    }
    .kvf th {
      background: rgba(185,150,84,0.18);
      font-weight: normal;
      color: #493815;
      letter-spacing: 0.04em;
      text-align: left;
    }
    .kvf td:nth-child(2) { background: rgba(61,90,58,0.06); }
    .kvf td:nth-child(3) { background: rgba(138,58,38,0.06); }
    .kvf td:nth-child(2)::before { content: "✓  "; color: var(--green); font-weight: bold; }
    .kvf td:nth-child(3)::before { content: "○  "; color: var(--red); font-weight: bold; }

    /* Theorie-Box ausgebaut */
    .theory-detail {
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 12px;
      margin-top: 12px;
      font-size: 13px;
    }
    .theory-detail .pro, .theory-detail .con {
      border: 1px solid var(--line);
      padding: 10px 12px;
      background: rgba(255,255,255,0.32);
    }
    .theory-detail .pro b { color: var(--green); display: block; margin-bottom: 4px; letter-spacing: 0.06em; text-transform: uppercase; font-size: 11px; }
    .theory-detail .con b { color: var(--red); display: block; margin-bottom: 4px; letter-spacing: 0.06em; text-transform: uppercase; font-size: 11px; }
    .theory-detail ul { margin: 0; padding-left: 18px; }
    .theory-detail li { margin: 3px 0; font-size: 13px; }

    /* Kontroverse-Chronik */
    .ctrl-chronicle {
      border-left: 2px dashed var(--muted);
      margin: 12px 0 4px 4px;
      padding-left: 14px;
      font-size: 13px;
      color: #3d372f;
    }
    .ctrl-chronicle div { margin: 5px 0; }
    .ctrl-chronicle b { color: var(--blue); font-weight: normal; }

    /* Forum-Posts */
    .forum-quote {
      background: rgba(247, 241, 228, 0.6);
      border: 1px solid var(--line);
      border-left: 3px solid var(--blue);
      padding: 10px 14px;
      margin: 10px 0;
      font-size: 13px;
      line-height: 1.55;
    }
    .forum-quote .user { color: var(--blue); font-weight: bold; }
    .forum-quote .when { color: var(--muted); font-size: 11px; }
    .forum-quote p { margin: 6px 0 0; font-size: 13px; }

    @media (max-width: 1100px) {
      .page { grid-template-columns: 1fr; }
      .sidebar, .infobox, .right-stack { position: static; max-height: none; }
      .sidebar { order: 2; }
      .content { order: 1; }
      .right-stack { order: 3; }
      .infobox { order: 4; }
      .search { display: none; }
      .topbar-meta { display: none; }
    }

    @media (max-width: 640px) {
      .topbar { padding: 0 14px; }
      .brand span { display: none; }
      .page { padding: 14px; }
      .content { padding: 22px 18px; }
      .cards, .trivia-grid, .merch-grid { grid-template-columns: 1fr; }
      .tabs { flex-wrap: wrap; }
      .info-row { grid-template-columns: 92px 1fr; }
      .featured-banner-inner { flex-direction: column; align-items: flex-start; }
      .bts { grid-template-columns: 1fr; }
      .egg { grid-template-columns: 1fr; }
      .controversy .side { grid-template-columns: 1fr; }
      .profile-head { grid-template-columns: 1fr; }
      .profile-grid { grid-template-columns: 1fr; }
      .theory-detail { grid-template-columns: 1fr; }
      .glossary { column-count: 1; }
      .qt-row { grid-template-columns: 1fr; }
      .qt-row .src { text-align: left; }
      .ff-item { grid-template-columns: 1fr; }
    }

/* === Multi-Page-Ergänzungen === */

.topbar-inner {
  display: flex;
  align-items: center;
  gap: 24px;
  width: 100%;
  max-width: 1400px;
  margin: 0 auto;
}

.brand a {
  color: inherit;
  text-decoration: none;
  display: flex;
  align-items: baseline;
  gap: 8px;
}
.brand a:hover { text-decoration: none; }
.brand-mark {
  color: var(--gold);
  font-size: 22px;
  font-weight: 700;
  letter-spacing: 0;
  text-transform: none;
}
.brand-sub {
  font-size: 11px !important;
  color: #cfc5b2 !important;
  text-transform: none !important;
  letter-spacing: 0.04em !important;
  margin-left: 8px;
}

.topnav {
  display: flex;
  gap: 18px;
  margin-left: auto;
  margin-right: 24px;
}
.topnav a {
  color: #d8cdb6;
  font-size: 12px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  text-decoration: none;
  padding: 6px 0;
  border-bottom: 1px solid transparent;
  transition: color 0.2s, border-color 0.2s;
}
.topnav a:hover {
  color: var(--gold);
  border-bottom-color: var(--gold);
  text-decoration: none;
}

.edits, .watchers {
  font-size: 11px;
  color: #cfc5b2;
  letter-spacing: 0.05em;
  text-transform: uppercase;
}
.edits { color: var(--gold-2); }

.breadcrumb {
  background: rgba(17, 16, 14, 0.04);
  padding: 10px 24px;
  font-size: 13px;
  color: var(--muted);
  border-bottom: 1px solid rgba(17,16,14,0.08);
  max-width: 1400px;
  margin: 0 auto;
}
.breadcrumb a {
  color: var(--link);
  text-decoration: none;
}
.breadcrumb a:hover { text-decoration: underline; }
.breadcrumb span {
  color: var(--ink);
  font-weight: 500;
}

/* === Hub-Seite (Index) === */

.hero {
  padding: 48px 32px 36px;
  text-align: center;
  border-bottom: 1px solid rgba(17,16,14,0.10);
  margin-bottom: 28px;
}
.hero h1 {
  font-family: var(--serif);
  font-size: 42px;
  margin: 0 0 12px;
  letter-spacing: 0.02em;
  color: var(--ink);
}
.hero .hero-sub {
  font-size: 16px;
  color: var(--muted);
  margin-bottom: 18px;
}
.hero .hero-axiom {
  font-family: var(--serif);
  font-style: italic;
  font-size: 20px;
  color: var(--gold);
  letter-spacing: 0.03em;
}

.hub-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 22px;
  margin: 24px 0 32px;
}
.hub-card {
  background: #fdfaf2;
  border: 1px solid rgba(17,16,14,0.10);
  border-left: 4px solid var(--gold);
  padding: 20px 22px;
  border-radius: 4px;
  transition: transform 0.15s, box-shadow 0.15s;
}
.hub-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 6px 18px rgba(0,0,0,0.08);
}
.hub-card h3 {
  margin: 0 0 8px;
  font-family: var(--serif);
  font-size: 22px;
  color: var(--ink);
}
.hub-card h3 a {
  color: inherit;
  text-decoration: none;
}
.hub-card h3 a:hover { color: var(--gold); }
.hub-card .hub-desc {
  font-size: 14px;
  line-height: 1.55;
  color: var(--ink);
  margin: 8px 0 12px;
}
.hub-card .hub-cta {
  font-size: 12px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--gold);
}
.hub-card .hub-cta a {
  color: var(--gold);
  font-weight: 600;
  text-decoration: none;
}
.hub-card .hub-cta a:hover { text-decoration: underline; }

.hub-grid.small {
  grid-template-columns: repeat(3, 1fr);
  gap: 14px;
}
.hub-grid.small .hub-card {
  padding: 14px 16px;
}
.hub-grid.small .hub-card h3 {
  font-size: 16px;
  margin-bottom: 4px;
}
.hub-grid.small .hub-card .hub-desc {
  font-size: 12.5px;
  margin: 4px 0 6px;
}

.hub-section-title {
  font-family: var(--serif);
  font-size: 14px;
  letter-spacing: 0.10em;
  text-transform: uppercase;
  color: var(--muted);
  border-bottom: 1px solid rgba(17,16,14,0.10);
  padding-bottom: 8px;
  margin: 28px 0 12px;
}

/* === Index-/Übersichtsseiten in Unterordnern === */

.subindex-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 16px;
  margin: 18px 0 28px;
}
.subindex-card {
  background: #fdfaf2;
  border: 1px solid rgba(17,16,14,0.10);
  border-left: 3px solid var(--gold);
  padding: 14px 16px;
  border-radius: 3px;
}
.subindex-card h4 {
  margin: 0 0 6px;
  font-family: var(--serif);
  font-size: 17px;
}
.subindex-card h4 a {
  color: var(--ink);
  text-decoration: none;
}
.subindex-card h4 a:hover { color: var(--gold); }
.subindex-card p {
  margin: 0;
  font-size: 13px;
  color: var(--muted);
  line-height: 1.5;
}

/* === Mobile === */
@media (max-width: 980px) {
  .topnav { display: none; }
  .topbar-inner { gap: 12px; }
  .hub-grid { grid-template-columns: 1fr; }
  .hub-grid.small { grid-template-columns: 1fr 1fr; }
  .subindex-grid { grid-template-columns: 1fr; }
  .hero h1 { font-size: 30px; }
  .hero { padding: 28px 18px 22px; }
}

@media (max-width: 600px) {
  .hub-grid.small { grid-template-columns: 1fr; }
  .topbar-meta { display: none; }
}



/* === V2: Forum & Werkarchitektur === */
.forum-board { display:flex; flex-direction:column; gap:12px; margin-top:18px; }
.forum-category {
  border:1px solid var(--line); background:rgba(255,255,255,0.30); border-left:4px solid var(--gold);
  padding:14px 16px; display:grid; grid-template-columns:1fr auto; gap:14px; align-items:start;
}
.forum-category h3 { margin:0 0 4px; font-size:18px; color:#2b261f; }
.forum-category .desc { font-size:13.5px; color:#3d372f; line-height:1.55; }
.forum-category .count { text-align:right; font-size:11px; color:var(--muted); letter-spacing:.06em; text-transform:uppercase; white-space:nowrap; }
.thread-list { border:1px solid var(--line); margin:16px 0; background:rgba(255,255,255,.30); }
.thread-row { display:grid; grid-template-columns:1fr 94px 120px; gap:12px; padding:12px 14px; border-top:1px solid var(--line); align-items:center; }
.thread-row:first-child { border-top:0; }
.thread-row .thread-title { font-size:15px; font-weight:bold; color:#2b261f; }
.thread-row .thread-title a { color:#2b261f; }
.thread-row .thread-meta { font-size:12px; color:var(--muted); margin-top:3px; }
.thread-row .thread-stats { font-size:11px; color:var(--muted); text-align:right; letter-spacing:.05em; text-transform:uppercase; }
.thread-row .last-post { font-size:12px; color:#3d372f; text-align:right; }
.thread-badge { display:inline-block; font-size:10px; letter-spacing:.12em; text-transform:uppercase; padding:2px 7px; border-radius:999px; margin-right:6px; border:1px solid var(--line); background:rgba(185,150,84,.16); color:#5a3d10; }
.thread-badge.hot { background:rgba(138,58,38,.12); color:var(--red); border-color:rgba(138,58,38,.28); }
.thread-badge.mod { background:rgba(41,54,77,.12); color:var(--blue); border-color:rgba(41,54,77,.28); }
.thread-head { border:1px solid var(--line); background:rgba(17,16,14,.05); padding:16px 18px; margin:12px 0 18px; }
.thread-head h2 { margin-top:0; }
.thread-head .thread-sub { color:var(--muted); font-size:13px; letter-spacing:.03em; }
.post { display:grid; grid-template-columns:130px 1fr; gap:0; border:1px solid var(--line); background:rgba(255,255,255,.34); margin:12px 0; }
.post .post-user { border-right:1px solid var(--line); background:rgba(185,150,84,.08); padding:12px; font-size:12px; }
.post .post-user .avatar { width:42px; height:42px; border-radius:50%; display:grid; place-items:center; background:linear-gradient(135deg,var(--gold),var(--blue)); color:var(--paper); font-weight:bold; margin-bottom:8px; }
.post .post-user .name { color:var(--blue); font-weight:bold; }
.post .post-user .role { color:var(--muted); font-size:11px; margin-top:3px; }
.post .post-body { padding:13px 16px; font-size:14px; line-height:1.66; }
.post .post-body .post-meta { color:var(--muted); font-size:11px; margin-bottom:8px; letter-spacing:.04em; text-transform:uppercase; }
.post .post-body blockquote { margin:10px 0; padding:8px 12px; background:rgba(17,16,14,.04); border-left:3px solid var(--gold); font-size:13px; }
.vote { display:inline-block; color:#5a3d10; background:rgba(185,150,84,.15); border:1px solid rgba(185,150,84,.35); padding:1px 6px; border-radius:999px; font-size:11px; margin-left:6px; }
.archive-note { font-size:12px; color:var(--muted); border:1px dashed var(--line); padding:10px 12px; background:rgba(255,255,255,.2); margin:12px 0; }
.status-strip { display:flex; flex-wrap:wrap; gap:8px; margin:14px 0; }
.status-strip span { font-size:11px; letter-spacing:.08em; text-transform:uppercase; padding:4px 9px; border:1px solid var(--line); background:rgba(255,255,255,.32); color:var(--muted); border-radius:999px; }
.meta-map { display:grid; grid-template-columns:repeat(3,1fr); gap:12px; margin:18px 0; }
.meta-map .node { border:1px solid var(--line); background:rgba(255,255,255,.30); padding:14px; min-height:120px; position:relative; }
.meta-map .node h3 { margin:0 0 8px; color:#2b261f; }
.meta-map .node .tag { position:absolute; top:10px; right:10px; font-size:10px; color:var(--muted); letter-spacing:.10em; text-transform:uppercase; }
.inkarnation-list { display:grid; grid-template-columns:repeat(2,1fr); gap:10px; margin:14px 0; }
.inkarnation { border-left:3px solid var(--gold); background:rgba(255,255,255,.28); padding:11px 13px; font-size:13.5px; line-height:1.55; }
.inkarnation b { display:block; color:#2b261f; margin-bottom:3px; }
@media (max-width: 760px) {
  .thread-row { grid-template-columns:1fr; }
  .thread-row .thread-stats, .thread-row .last-post { text-align:left; }
  .post { grid-template-columns:1fr; }
  .post .post-user { border-right:0; border-bottom:1px solid var(--line); display:flex; align-items:center; gap:10px; }
  .post .post-user .avatar { margin-bottom:0; }
  .meta-map, .inkarnation-list { grid-template-columns:1fr; }
}
