/* ====================================================
   TRANSKRIPT-STYLE.CSS
   NGO-Files Transkript-Feature (Variante B — eigene Seite)
   Designsprache: wiki-style.css (DM Sans + DM Serif Display,
   --blue #0097b2, --navy #0f172a, --ink-sec #475569)
   ==================================================== */

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

:root{
  --blue:#0097b2;
  --blue-light:#00b8d9;
  --blue-dark:#007a91;
  --blue-bg:rgba(0,151,178,.06);
  --navy:#0f172a;
  --ink:#0f172a;
  --ink-sec:#475569;
  --ink-muted:#94a3b8;
  --bg:#fafbfc;
  --white:#fff;
  --border:#e2e8f0;
  --border-light:#f1f5f9;
  --red:#dc2626;
  --green:#16a34a;
  --amber:#d97706;
  --radius:10px;
  --radius-lg:16px;
  --ease:cubic-bezier(.4,0,.2,1);
  --shadow:0 1px 3px rgba(15,23,42,.06),0 1px 2px rgba(15,23,42,.04);
  --shadow-md:0 4px 6px -1px rgba(15,23,42,.07),0 2px 4px -2px rgba(15,23,42,.05);
}

html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased}
body{font-family:'DM Sans',system-ui,sans-serif;color:var(--ink);background:var(--bg);line-height:1.7;min-height:100vh}
a{color:var(--blue);text-decoration:none}
a:hover{text-decoration:underline}

/* ── Header ──────────────────────────────────────── */
.ts-header{
  position:sticky;top:0;z-index:200;
  background:rgba(255,255,255,.92);
  backdrop-filter:blur(16px) saturate(180%);
  border-bottom:1px solid var(--border);
}
.ts-header-inner{
  max-width:1200px;margin:0 auto;
  padding:0 24px;
  display:flex;align-items:center;justify-content:space-between;
  height:56px;
}
.ts-logo{
  display:flex;align-items:center;gap:10px;
  text-decoration:none;color:var(--ink);
}
.ts-logo-icon{
  width:30px;height:30px;
  background:var(--blue);border-radius:8px;
  display:grid;place-items:center;flex-shrink:0;
}
.ts-logo-icon svg{width:16px;height:16px}
.ts-logo-text{
  font-family:'DM Serif Display',serif;font-size:17px;
}
.ts-back-link{
  display:inline-flex;align-items:center;gap:6px;
  font-size:13px;font-weight:500;color:var(--ink-sec);
  padding:6px 14px;border-radius:6px;
  transition:all .15s var(--ease);text-decoration:none;
}
.ts-back-link:hover{color:var(--blue);background:var(--blue-bg);text-decoration:none}
.ts-back-link svg{width:16px;height:16px}
.ts-nav{display:flex;align-items:center;gap:8px}

/* ── Loading / Error ────────────────────────────── */
.ts-loading{
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  min-height:40vh;gap:16px;color:var(--ink-muted);font-size:14px;
}
.ts-spinner{
  width:36px;height:36px;border:3px solid var(--border);
  border-top-color:var(--blue);border-radius:50%;
  animation:ts-spin .8s linear infinite;
}
@keyframes ts-spin{to{transform:rotate(360deg)}}

.ts-error{
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  min-height:50vh;gap:16px;text-align:center;padding:32px 24px;
}
.ts-error-icon svg{width:48px;height:48px;color:var(--ink-muted)}
.ts-error h2{font-family:'DM Serif Display',serif;font-size:24px;margin-bottom:8px}
.ts-error p{font-size:14px;color:var(--ink-sec);max-width:400px}
.ts-btn{
  display:inline-flex;align-items:center;gap:6px;
  padding:10px 20px;border-radius:8px;
  background:var(--blue);color:#fff;font-size:13px;font-weight:600;
  text-decoration:none;transition:background .15s var(--ease);
  margin-top:8px;
}
.ts-btn:hover{background:var(--blue-dark);text-decoration:none;color:#fff}

/* ── Hero Bar ────────────────────────────────────── */
.ts-hero{
  background:var(--navy);
  color:#fff;padding:32px 24px;
}
.ts-hero-inner{max-width:1200px;margin:0 auto}
.ts-hero-badge{
  display:inline-block;
  font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:1.2px;
  padding:4px 12px;border-radius:50px;
  background:rgba(0,151,178,.25);color:var(--blue-light);
  margin-bottom:12px;
}
.ts-hero-badge.ts-badge-video{background:rgba(124,58,237,.25);color:#a78bfa}
.ts-hero-title{
  font-family:'DM Serif Display',serif;
  font-size:clamp(22px,3.5vw,36px);
  line-height:1.2;letter-spacing:-.3px;
  margin-bottom:12px;
}
.ts-hero-meta{
  display:flex;align-items:center;flex-wrap:wrap;gap:8px;
  font-size:13px;color:rgba(255,255,255,.65);
}
.ts-meta-sep{opacity:.4;margin:0 2px}

/* ── Player Stripe ───────────────────────────────── */
.ts-player-stripe{
  background:var(--white);
  border-bottom:1px solid var(--border);
  position:sticky;top:56px;z-index:100;
  box-shadow:var(--shadow-md);
}
.ts-player-stripe-inner{
  max-width:1200px;margin:0 auto;
  padding:16px 24px;
  display:flex;flex-direction:column;gap:12px;
}
.ts-audio-player{
  width:100%;border-radius:12px;
  /* Custom audio appearance */
  accent-color:var(--blue);
}
.ts-video-player{
  width:100%;max-height:320px;border-radius:12px;
  background:#000;
}
.ts-no-media{font-size:13px;color:var(--ink-muted);padding:8px 0}

.ts-controls-row{
  display:flex;align-items:center;gap:12px;flex-wrap:wrap;
}
.ts-search-wrap{
  position:relative;display:flex;align-items:center;
  flex:1;min-width:200px;
}
.ts-search-icon{
  position:absolute;left:10px;
  width:14px;height:14px;color:var(--ink-muted);pointer-events:none;
}
.ts-search-input{
  width:100%;padding:8px 12px 8px 32px;
  border:1px solid var(--border);border-radius:8px;
  font-size:13px;font-family:inherit;
  background:var(--bg);color:var(--ink);
  outline:none;transition:border-color .15s var(--ease);
}
.ts-search-input:focus{border-color:var(--blue);background:var(--white)}
.ts-search-input::placeholder{color:var(--ink-muted)}
.ts-match-count{
  position:absolute;right:10px;
  font-size:11px;color:var(--blue);font-weight:600;
  white-space:nowrap;
}
.ts-scroll-lock-btn{
  display:inline-flex;align-items:center;gap:6px;
  padding:7px 14px;border-radius:8px;
  border:1px solid var(--border);background:var(--bg);
  font-size:12px;font-weight:500;color:var(--ink-muted);
  cursor:pointer;font-family:inherit;
  transition:all .15s var(--ease);white-space:nowrap;
}
.ts-scroll-lock-btn svg{width:14px;height:14px}
.ts-scroll-lock-btn:hover{border-color:var(--blue);color:var(--blue)}
.ts-scroll-lock-btn.ts-scroll-lock-active{
  background:var(--blue-bg);border-color:var(--blue);color:var(--blue);
}

/* ── Layout: Sidebar + Content ───────────────────── */
.ts-layout{
  max-width:1200px;margin:0 auto;
  display:grid;grid-template-columns:220px 1fr;
  min-height:calc(100vh - 56px - 120px);
  align-items:start;
}

/* ── Sidebar / TOC ───────────────────────────────── */
.ts-sidebar{
  position:sticky;top:calc(56px + 120px);
  height:calc(100vh - 56px - 120px);
  overflow-y:auto;
  padding:24px 16px 24px 24px;
  border-right:1px solid var(--border);
}
.ts-toc-title{
  font-size:10px;font-weight:700;text-transform:uppercase;
  letter-spacing:1.5px;color:var(--ink-muted);margin-bottom:12px;
}
.ts-toc-list{display:flex;flex-direction:column;gap:2px}
.ts-toc-link{
  display:flex;flex-direction:column;
  padding:7px 10px;border-radius:8px;
  font-size:12px;color:var(--ink-sec);
  text-decoration:none;cursor:pointer;
  transition:all .15s var(--ease);
  border:1px solid transparent;
}
.ts-toc-link:hover,.ts-toc-link.active{
  background:var(--blue-bg);color:var(--blue);
  border-color:rgba(0,151,178,.1);
  text-decoration:none;
}
.ts-toc-time{
  font-size:10px;font-weight:700;color:var(--blue);
  font-variant-numeric:tabular-nums;
  margin-bottom:2px;
}
.ts-toc-label{line-height:1.3}

/* ── Transcript Content ──────────────────────────── */
.ts-content{padding:32px 48px 80px}

.ts-transcript{display:flex;flex-direction:column;gap:0}

.ts-section{
  border-bottom:1px solid var(--border-light);
  padding:28px 0;
  transition:background .2s var(--ease);
  border-radius:var(--radius);
  scroll-margin-top:200px;
}
.ts-section:last-child{border-bottom:none}

.ts-section-active{
  background:var(--blue-bg);
  margin:0 -16px;padding:28px 16px;
  border-radius:var(--radius);
  border-bottom:1px solid transparent;
}

.ts-section-no-match{
  opacity:.3;
  filter:grayscale(1);
}

.ts-section-header{
  display:flex;align-items:flex-start;gap:12px;
  margin-bottom:16px;
}

.ts-ts-btn{
  display:inline-flex;align-items:center;
  background:none;border:1px solid var(--border);
  border-radius:8px;cursor:pointer;
  padding:0;flex-shrink:0;
  transition:all .15s var(--ease);
  font-family:inherit;
}
.ts-ts-btn:hover{border-color:var(--blue);box-shadow:0 0 0 3px rgba(0,151,178,.1)}
.ts-ts-btn:hover .ts-ts-badge{background:var(--blue);color:#fff}

.ts-ts-badge{
  display:block;
  padding:5px 10px;
  font-size:11px;font-weight:700;
  font-variant-numeric:tabular-nums;
  color:var(--blue);
  background:var(--blue-bg);
  border-radius:7px;
  transition:all .15s var(--ease);
  min-width:40px;text-align:center;
  letter-spacing:.3px;
}

.ts-section-title{
  font-family:'DM Serif Display',serif;
  font-size:18px;line-height:1.3;
  color:var(--ink);margin:0;
  padding-top:3px;
  flex:1;
}

.ts-section-body p{
  font-size:14px;color:var(--ink-sec);
  line-height:1.8;margin-bottom:14px;
}
.ts-section-body p:last-child{margin-bottom:0}

/* Active section body text slightly more readable */
.ts-section-active .ts-section-body p{color:var(--ink)}

/* ── Search highlight ────────────────────────────── */
mark.ts-highlight{
  background:rgba(255,200,0,.35);
  color:inherit;
  border-radius:3px;
  padding:0 2px;
}

/* ── Footer meta ────────────────────────────────── */
.ts-footer-meta{
  margin-top:48px;padding-top:16px;
  border-top:1px solid var(--border);
  font-size:11px;color:var(--ink-muted);
}
.ts-footer-meta code{
  background:var(--border-light);
  padding:1px 5px;border-radius:4px;
  font-size:10px;
}
.ts-empty{font-size:14px;color:var(--ink-muted);padding:24px 0}

/* ── Responsive ─────────────────────────────────── */
@media(max-width:900px){
  .ts-layout{grid-template-columns:1fr}
  .ts-sidebar{
    display:none; /* hide TOC on mobile — it's huge */
  }
  .ts-content{padding:24px 20px 60px}
  .ts-player-stripe{position:static}
}
@media(max-width:600px){
  .ts-hero{padding:20px 16px}
  .ts-hero-title{font-size:20px}
  .ts-player-stripe-inner{padding:12px 16px}
  .ts-section-title{font-size:16px}
  .ts-header-inner{padding:0 16px}
}

/* ── Errata-Box (Tool-Härtung 2026-05-15) ────────────
   Sichtbare Korrektur-Karte für Wiki-Updates nach Audio/Video-Produktion.
   Designsprache: amber-Akzent (--amber), klarer Kontrast zum sonst-blauen
   Layout. Klickbar pro Eintrag → Sprung zum Kapitel.
   ==================================================== */
.ts-errata{
  background:#fffbeb;
  border-top:1px solid #fde68a;
  border-bottom:1px solid #fde68a;
}
.ts-errata-inner{
  max-width:1200px;margin:0 auto;
  padding:18px 24px 20px;
}
.ts-errata-head{
  display:flex;align-items:flex-start;gap:12px;
  margin-bottom:10px;
  color:var(--amber);
}
.ts-errata-icon{width:22px;height:22px;flex-shrink:0;margin-top:2px}
.ts-errata-title{
  display:block;font-size:15px;font-weight:700;
  color:#92400e;letter-spacing:-.01em;
}
.ts-errata-sub{
  display:block;font-size:13px;font-weight:400;
  color:#92400e;opacity:.8;margin-top:2px;
}
.ts-errata-list{
  list-style:none;padding:0;margin:0;
  display:grid;gap:10px;
}
.ts-errata-entry{
  background:#fff;
  border:1px solid #fde68a;
  border-radius:var(--radius);
  padding:12px 14px;
  cursor:pointer;
  transition:border-color .15s var(--ease),box-shadow .15s var(--ease),transform .15s var(--ease);
}
.ts-errata-entry:hover{
  border-color:var(--amber);
  box-shadow:var(--shadow-md);
  transform:translateY(-1px);
}
.ts-errata-entry-head{
  font-weight:600;font-size:14px;
  color:var(--navy);
  margin-bottom:6px;
}
.ts-errata-row{
  font-size:14px;line-height:1.55;
  margin-top:3px;color:var(--ink);
}
.ts-errata-row-secondary{
  font-size:13px;color:var(--ink-sec);
}
.ts-errata-label{
  font-size:11px;text-transform:uppercase;letter-spacing:.06em;
  color:var(--ink-muted);font-weight:600;
  margin-right:6px;
}
.ts-errata-row s{color:var(--ink-muted);text-decoration-color:var(--amber)}
.ts-errata-row a{color:var(--blue);text-decoration:underline}

@media(max-width:600px){
  .ts-errata-inner{padding:14px 16px 16px}
  .ts-errata-entry{padding:10px 12px}
}
