/* ============================================================
   STFC WIKI — LCARS (TNG / 24th-century) Theme · mobile-first
   ============================================================ */
:root {
  --bg:        #000005;
  --space:     #06080f;

  /* LCARS-Palette */
  --lc-orange: #ff9966;
  --lc-pump:   #ff9c00;
  --lc-gold:   #ffcc66;
  --lc-lilac:  #cc99cc;
  --lc-violet: #cc88ff;
  --lc-blue:   #6699ff;
  --lc-peri:   #99ccff;
  --lc-red:    #cc6677;
  --lc-teal:   #66cccc;
  --lc-ice:    #bcd4ff;

  --panel:     #0c1124;
  --panel-2:   #0a0f1f;
  --text:      #eef3ff;
  --text-dim:  #b3c1e2;        /* heller für besseren Kontrast (WCAG AA) */
  --border:    rgba(153, 204, 255, 0.16);

  /* System-Fonts (KEINE externen/Google-Fonts — DSGVO) */
  --font-display: 'Arial Narrow', 'Avenir Next Condensed', 'Roboto Condensed', 'Helvetica Neue', system-ui, sans-serif;
  --font-body: system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Helvetica, Arial, sans-serif;

  /* Kategorie-Farben (LCARS-gemappt) */
  --c-amber:   var(--lc-gold);
  --c-red:     var(--lc-red);
  --c-violet:  var(--lc-lilac);
  --c-teal:    var(--lc-blue);
  --c-blue:    var(--lc-peri);
  --c-green:   var(--lc-teal);

  --radius-pill: 999px;
  --maxw: 1000px;
  --rail: 96px;

  font-family: var(--font-body);
}
.lcars-font, .display { font-family: var(--font-display); font-stretch: condensed; }

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
body {
  background:
    radial-gradient(900px 600px at 50% -10%, #101a3a 0%, var(--space) 45%, var(--bg) 100%);
  color: var(--text);
  min-height: 100vh;
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
}
a { color: var(--lc-peri); text-decoration: none; }

/* Sternenfeld */
.stars {
  position: fixed; inset: 0; z-index: -1; pointer-events: none; opacity: .45;
  background-image:
    radial-gradient(1px 1px at 20% 30%, #fff, transparent),
    radial-gradient(1px 1px at 70% 60%, #cfe0ff, transparent),
    radial-gradient(1px 1px at 40% 80%, #fff, transparent),
    radial-gradient(2px 2px at 85% 20%, #9fb6ff, transparent),
    radial-gradient(1px 1px at 12% 72%, #fff, transparent);
  background-repeat: repeat; background-size: 620px 620px;
  animation: drift 140s linear infinite;
}
@keyframes drift { to { background-position: 620px 620px; } }

/* ============================================================ FRAME */
.lcars { max-width: var(--maxw); margin: 0 auto; padding: 8px 10px 0; }

/* --- Kopf: LCARS-Ellbogen + Bar --- */
.lcars-head {
  display: grid;
  grid-template-columns: var(--rail) 1fr;
  grid-template-rows: 54px 16px;
  gap: 6px;
  margin-bottom: 8px;
}
.lcars-cap {
  grid-row: 1 / 3;
  background: var(--lc-orange);
  border-top-left-radius: 46px;
  border-bottom-left-radius: 14px;
  display: flex; align-items: flex-end; justify-content: center;
  padding-bottom: 8px; font-size: 1.7rem; cursor: pointer;
  position: relative; overflow: hidden;
}
.lcars-cap:active { filter: brightness(1.12); }
.head-bar {
  background: var(--lc-pump);
  border-top-right-radius: 14px;
  display: flex; align-items: center; gap: 10px;
  padding: 0 8px 0 16px; min-width: 0;
}
.head-title {
  font-family: var(--font-display); font-weight: 700;
  letter-spacing: 4px; text-transform: uppercase;
  color: #1a0d00; font-size: clamp(.95rem, 3.4vw, 1.4rem);
  flex: 1; white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.head-tag {
  font-family: var(--font-display); letter-spacing: 1px;
  background: #1a0d00; color: var(--lc-gold);
  padding: 3px 10px; border-radius: var(--radius-pill); font-size: .72rem;
  display: none;
}
@media (min-width: 600px) { .head-tag { display: inline-block; } }
.lang-btn {
  font-family: var(--font-display); font-weight: 700; letter-spacing: 2px;
  background: #1a0d00; color: var(--lc-gold);
  border: 0; padding: 7px 16px; border-radius: var(--radius-pill);
  cursor: pointer; font-size: .82rem;
}
.lang-btn:active { transform: scale(.94); }
/* zweite Reihe: Farbsegmente */
.head-strip {
  grid-column: 2 / 3;
  display: flex; gap: 6px; align-items: stretch;
}
.head-strip i { flex: 1; border-radius: var(--radius-pill); }
.head-strip i:nth-child(1){ background: var(--lc-gold); flex: 2; }
.head-strip i:nth-child(2){ background: var(--lc-lilac); }
.head-strip i:nth-child(3){ background: var(--lc-blue); flex: 3; }
.head-strip i:nth-child(4){ background: var(--lc-red); }
.head-strip i:nth-child(5){ background: var(--lc-teal); flex: 1.5; }

/* ============================================================ HERO */
.hero { text-align: center; padding: 26px 8px 6px; }
.hero-title {
  font-family: var(--font-display); font-weight: 700; line-height: .92;
  margin: 0 0 6px; font-size: clamp(2.1rem, 9vw, 4rem);
  letter-spacing: 6px; text-transform: uppercase;
  color: var(--lc-gold);
  text-shadow: 0 0 26px rgba(255,153,102,.35);
}
.hero-title span {
  display: block;
  background: linear-gradient(90deg, var(--lc-orange), var(--lc-lilac), var(--lc-blue));
  -webkit-background-clip: text; background-clip: text; color: transparent;
}
.hero-tagline {
  color: var(--lc-peri); margin: 0 0 22px; letter-spacing: 1px;
  font-size: clamp(.85rem, 3.4vw, 1.02rem); text-transform: uppercase;
}

/* --- Suchleiste (LCARS-Pill) --- */
.searchbar {
  display: flex; align-items: center; gap: 8px;
  max-width: 660px; margin: 0 auto;
  background: var(--panel); border: 2px solid var(--lc-orange);
  border-radius: var(--radius-pill); padding: 6px 6px 6px 18px;
  box-shadow: 0 10px 44px rgba(0,0,0,.5);
}
.searchbar:focus-within { border-color: var(--lc-gold); box-shadow: 0 0 0 3px rgba(255,204,102,.2), 0 10px 44px rgba(0,0,0,.5); }
.search-glyph { font-size: 1.1rem; opacity: .85; }
.searchbar input {
  flex: 1; min-width: 0; background: transparent; border: 0; outline: none;
  color: var(--text); font-size: 1rem; font-family: inherit; padding: 11px 4px;
}
.searchbar input::placeholder { color: var(--text-dim); }
.searchbar button {
  font-family: var(--font-display); font-weight: 700; letter-spacing: 2px;
  background: var(--lc-orange); color: #1a0d00;
  border: 0; border-radius: var(--radius-pill); padding: 12px 22px; cursor: pointer;
  white-space: nowrap; font-size: .9rem; text-transform: uppercase;
}
.searchbar button:active { transform: scale(.95); }

/* ============================================================ BODY GRID */
.lcars-body { display: grid; grid-template-columns: 1fr; gap: 14px; margin-top: 22px; }
@media (min-width: 760px) { .lcars-body { grid-template-columns: var(--rail) 1fr; } }

/* Linke Schiene (nur Desktop) */
.rail { display: none; flex-direction: column; gap: 6px; }
@media (min-width: 760px) { .rail { display: flex; } }
.rail-block {
  font-family: var(--font-display); letter-spacing: 1px; text-transform: uppercase;
  color: #0a0a0a; font-size: .74rem; text-align: right;
  padding: 10px 12px 14px; border-radius: 0 0 0 6px; cursor: pointer;
  display: flex; align-items: flex-end; justify-content: flex-end; min-height: 56px;
  transition: filter .15s, transform .15s;
}
.rail-block { background: var(--lc-orange); } /* Fallback; Farbe wird per JS gesetzt */
.rail-block:hover { filter: brightness(1.12); transform: translateX(2px); }
.rail-block:first-child { border-top-left-radius: 30px; }
.rail-block:last-child { border-bottom-left-radius: 30px; }

.view { min-width: 0; }

/* ============================================================ BLÖCKE */
.block { margin-bottom: 28px; }
.block-title {
  font-family: var(--font-display); font-size: 1.1rem; letter-spacing: 2px;
  color: var(--lc-gold); margin: 0 0 14px; text-transform: uppercase;
  border-left: 6px solid var(--lc-orange); padding-left: 10px;
}

/* Vorschläge */
.suggestions { display: flex; flex-wrap: wrap; gap: 10px; }
.suggestion {
  background: var(--panel); border: 1px solid var(--border); color: var(--text);
  padding: 10px 16px; border-radius: var(--radius-pill); cursor: pointer;
  font-family: inherit; font-size: .9rem; text-align: left; transition: all .15s;
}
.suggestion:hover { border-color: var(--lc-orange); color: #fff; transform: translateY(-1px); }

/* Kategorien-Grid */
.cat-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 12px; }
@media (min-width: 560px) { .cat-grid { grid-template-columns: repeat(3, 1fr); } }
.cat-tile {
  position: relative; display: flex; flex-direction: column; gap: 8px;
  background: var(--panel); color: var(--text);
  border-radius: 6px 18px 18px 6px; padding: 14px 14px 16px;
  border-left: 8px solid var(--cat-color, var(--lc-orange));
  transition: all .15s; overflow: hidden;
}
.cat-tile:hover { transform: translateY(-2px); filter: brightness(1.08); }
.cat-tile-icon { font-size: 1.6rem; }
.cat-tile-name { font-family: var(--font-display); font-size: .9rem; letter-spacing: 1px; text-transform: uppercase; }
.cat-tile-count {
  font-family: var(--font-display); font-size: .72rem; color: #0a0a0a;
  align-self: flex-start; background: var(--cat-color, var(--lc-orange));
  padding: 1px 10px; border-radius: var(--radius-pill);
}

/* ============================================================ ERGEBNISSE */
.results-head { margin-bottom: 18px; }
.results-head h2 {
  font-family: var(--font-display); font-size: 1.3rem; letter-spacing: 1px;
  margin: 10px 0 0; line-height: 1.3; color: var(--lc-gold); text-transform: uppercase;
}
.results-head .count { color: var(--text-dim); font-size: .82rem; font-family: var(--font-body); margin-left: 6px; letter-spacing: 0; text-transform: none; }
.back { font-size: .82rem; color: var(--lc-peri); font-family: var(--font-display); letter-spacing: 1px; text-transform: uppercase; }
.back:hover { color: var(--lc-gold); }

.card-list { display: flex; flex-direction: column; gap: 12px; }
.card {
  background: var(--panel-2);
  border-radius: 6px 18px 18px 6px; overflow: hidden;
  border-left: 8px solid var(--cat-color, var(--lc-orange));
}
.card-head {
  width: 100%; display: flex; align-items: center; gap: 12px;
  background: transparent; border: 0; color: var(--text); cursor: pointer;
  padding: 15px 16px; text-align: left; font-family: inherit;
}
.card-icon { font-size: 1.5rem; flex-shrink: 0; }
.card-titles { display: flex; flex-direction: column; gap: 3px; flex: 1; min-width: 0; }
.card-title { font-family: var(--font-display); font-size: 1.05rem; letter-spacing: .8px; text-transform: uppercase; }
.card-cat { font-size: .74rem; color: var(--text-dim); }
.card-chevron { color: var(--cat-color, var(--lc-orange)); transition: transform .25s; font-size: 1rem; }
.card-head[aria-expanded="true"] .card-chevron { transform: rotate(180deg); }

.card-body { display: grid; grid-template-rows: 0fr; transition: grid-template-rows .28s ease; padding: 0 16px; }
.card-body.open { grid-template-rows: 1fr; padding-bottom: 16px; }
.card-body > * { overflow: hidden; }
.card-body { color: #cfdaf5; font-size: 1.02rem; }
.card-body :is(p, ul, ol) { margin: 0 0 14px; line-height: 1.75; }
.card-body :is(ul, ol) { padding-left: 22px; }
.card-body li { margin-bottom: 8px; line-height: 1.7; }
.card-body b { color: var(--text); }
.card-body i { color: var(--lc-peri); font-style: normal; }

/* Tabelle */
.table-wrap { overflow-x: auto; margin: 4px 0 14px; -webkit-overflow-scrolling: touch; }
table { width: 100%; border-collapse: collapse; font-size: .88rem; min-width: 240px; }
th, td { text-align: left; padding: 8px 12px; border-bottom: 1px solid var(--border); }
th { font-family: var(--font-display); font-size: .76rem; letter-spacing: 1.5px; text-transform: uppercase; color: var(--lc-gold); }
td { color: var(--text); }
tbody tr:hover { background: rgba(102,153,255,.07); }

/* Verwandt-Chips */
.related { margin-top: 6px; display: flex; flex-wrap: wrap; gap: 8px; align-items: center; }
.related-label { font-family:var(--font-display); letter-spacing:1px; text-transform:uppercase; font-size: .8rem; color: var(--lc-peri); width: 100%; margin-bottom: 2px; }
.chip {
  background: rgba(102,153,255,.12); border: 1px solid var(--border);
  color: var(--text); padding: 5px 14px; border-radius: var(--radius-pill); font-size: .82rem; transition: all .15s;
}
.chip:hover { border-color: var(--lc-orange); background: rgba(255,153,102,.18); }

/* ============================================================ QUELLEN-FETCH (LMGTFY) */
.lmgtfy {
  background: linear-gradient(180deg, rgba(255,153,102,.08), rgba(12,17,36,.6));
  border: 1px solid var(--border);
  border-left: 8px solid var(--lc-orange);
  border-radius: 6px 18px 18px 6px; padding: 18px 16px; margin: 6px 0 26px;
}
.lmgtfy-kicker {
  font-family: var(--font-display); letter-spacing: 2px; text-transform: uppercase;
  color: var(--lc-orange); font-size: .8rem; margin: 0 0 4px;
}
.lmgtfy-q { font-size: 1.05rem; color: var(--text); margin: 0 0 4px; }
.lmgtfy-q b { color: var(--lc-gold); }
.lmgtfy-hint { color: var(--text-dim); font-size: .9rem; margin: 0 0 14px; }
.source-links { display: grid; grid-template-columns: repeat(auto-fill, minmax(150px, 1fr)); gap: 10px; }
.source-link {
  display: flex; align-items: center; gap: 10px;
  background: var(--panel); border: 1px solid var(--border);
  border-left: 6px solid var(--sl-color, var(--lc-orange));
  border-radius: 6px 14px 14px 6px; padding: 12px 14px; color: var(--text);
  transition: all .15s;
}
.source-link:hover { transform: translateY(-2px); filter: brightness(1.1); border-color: var(--sl-color); }
.source-link .sl-icon { font-size: 1.25rem; }
.source-link .sl-name { font-family: var(--font-display); letter-spacing: .5px; }
.source-link .sl-go { margin-left: auto; color: var(--sl-color, var(--lc-orange)); font-weight: 700; }

.empty {
  background: var(--panel); border: 1px dashed var(--border); border-radius: 12px;
  padding: 16px; color: var(--text-dim); margin-bottom: 18px;
}

/* Quellen-Liste (Home) */
.sources { list-style: none; padding: 0; margin: 0; display: grid; gap: 8px; }
.sources a {
  display: block; background: var(--panel); border: 1px solid var(--border);
  border-left: 6px solid var(--lc-lilac);
  border-radius: 6px 12px 12px 6px; padding: 12px 14px; color: var(--text); transition: all .15s;
}
.sources a:hover { filter: brightness(1.1); border-color: var(--lc-lilac); }

/* ============================================================ FOOTER */
.footer {
  max-width: var(--maxw); margin: 30px auto 0; padding: 20px 12px;
  padding-bottom: max(20px, env(safe-area-inset-bottom));
  border-top: 2px solid var(--lc-orange); text-align: center;
  color: var(--text-dim); font-size: .78rem; line-height: 1.6;
}
.footer-cred { margin-top: 8px; opacity: .8; font-family: var(--font-display); letter-spacing: 2px; text-transform: uppercase; }
.footer-legal { margin-top: 10px; display: flex; gap: 8px 16px; justify-content: center; flex-wrap: wrap; }
.footer-legal a { color: var(--lc-peri); font-size: .82rem; }
.footer-legal a:hover { color: var(--lc-gold); text-decoration: underline; }

/* ============================================================ BARRIEREFREIHEIT */
/* Skip-Link */
.skip-link {
  position: absolute; left: 8px; top: -60px; z-index: 50;
  background: var(--lc-gold); color: #1a0d00; padding: 10px 16px;
  border-radius: 0 0 10px 10px; font-family: var(--font-display); font-weight: 700;
  letter-spacing: 1px; transition: top .15s;
}
.skip-link:focus { top: 0; }

/* Deutlich sichtbare Tastatur-Fokus-Ringe */
:focus-visible {
  outline: 3px solid var(--lc-gold);
  outline-offset: 2px;
  border-radius: 4px;
}
/* nur für Maus/Touch keinen Ring, Tastatur ja (Browser-Default via :focus-visible) */

/* Nur für Screenreader sichtbar */
.sr-only {
  position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px;
  overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0;
}

/* Rechtstext-Seiten */
.legal { max-width: 760px; margin: 0 auto; padding: 10px 16px 40px; }
.legal h1 { font-family: var(--font-display); color: var(--lc-gold); letter-spacing: 2px; text-transform: uppercase; font-size: clamp(1.6rem, 6vw, 2.4rem); }
.legal h2 { font-family: var(--font-display); color: var(--lc-peri); letter-spacing: 1px; text-transform: uppercase; margin-top: 28px; }
.legal p, .legal li { line-height: 1.75; color: #cfdaf5; }
.legal a { color: var(--lc-peri); }
.legal a:hover { color: var(--lc-gold); text-decoration: underline; }
.legal .placeholder { color: var(--lc-gold); background: rgba(255,204,102,.08); padding: 1px 6px; border-radius: 4px; }

@media (prefers-reduced-motion: reduce) { .stars { animation: none; } *, *::before, *::after { transition: none !important; animation: none !important; } }
