:root {
  --bg: #f5f7fb;
  --card: #fff;
  --ink: #172033;
  --muted: #65758b;
  --line: #d9e1ec;
  --primary: #1c5cff;
  --primary-dark: #0c3bb0;
  --danger: #bd2536;
  --success: #0a7f45;
  --shadow: 0 10px 30px rgba(20, 40, 80, .08);
  --radius: 18px;
}

* { box-sizing: border-box; }
html, body {
  margin: 0;
  padding: 0;
  font-family: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  color: var(--ink);
  background: var(--bg);
}
a { color: var(--primary); text-decoration: none; }
a:hover { text-decoration: underline; }

.topbar {
  height: 68px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 28px;
  background: #fff;
  border-bottom: 1px solid var(--line);
  position: sticky;
  top: 0;
  z-index: 10;
}
.brand { font-weight: 800; color: var(--ink); font-size: 1.05rem; }
.nav { display: flex; gap: 18px; align-items: center; }
.nav a { color: var(--ink); font-weight: 600; }

.page { max-width: 1280px; margin: 0 auto; padding: 28px; }
.auth-bg { min-height: 100vh; background: radial-gradient(circle at 10% 10%, #e8f0ff, transparent 35%), linear-gradient(135deg, #f7f9fe, #edf3ff); }
.lite-bg { background: #f5f7fb; min-height: 100vh; }
.auth-card { max-width: 460px; margin: 7vh auto; background: var(--card); padding: 32px; border-radius: var(--radius); box-shadow: var(--shadow); }
.auth-card.wide { max-width: 880px; }
.auth-card h1 { margin-top: 0; }

.hero { margin: 4px 0 20px; }
.hero h1 { font-size: clamp(1.65rem, 3vw, 2.45rem); line-height: 1.1; margin: 0 0 8px; }
.hero p { color: var(--muted); font-size: 1.05rem; margin: 0; }

.card, .live-card {
  background: var(--card);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  padding: 24px;
  margin-bottom: 22px;
}

.form { display: grid; gap: 16px; }
.form h2 { margin: 10px 0 0; }
.form label { display: grid; gap: 7px; font-weight: 700; }
.form input, .form select {
  width: 100%;
  font: inherit;
  border: 1px solid var(--line);
  border-radius: 12px;
  padding: 12px 13px;
  background: #fff;
  color: var(--ink);
}
.form input:focus, .form select:focus { outline: 3px solid rgba(28, 92, 255, .16); border-color: var(--primary); }
.grid2 { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 16px; }
.grid3 { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 16px; }
.grid3 .tile { min-height: 145px; }
.inline-form { grid-template-columns: 1.5fr 1fr 1fr auto; align-items: end; }
.check { display: flex !important; align-items: center; gap: 10px; border: 1px solid var(--line); border-radius: 12px; padding: 12px; background: #fafcff; }
.check input { width: auto; }

.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 1px solid var(--line);
  background: #fff;
  color: var(--ink);
  padding: 11px 16px;
  border-radius: 12px;
  font-weight: 800;
  cursor: pointer;
  min-height: 42px;
}
.btn:hover { text-decoration: none; border-color: #b9c5d8; }
.btn.primary { background: var(--primary); border-color: var(--primary); color: #fff; }
.btn.primary:hover { background: var(--primary-dark); }
.btn.danger { color: #fff; background: var(--danger); border-color: var(--danger); }
.btn.small { min-height: 34px; padding: 7px 10px; font-size: .86rem; }
.actions { display: flex; gap: 12px; flex-wrap: wrap; }
.actions-cell { display: flex; gap: 8px; align-items: center; flex-wrap: wrap; }
.password-mini { display: flex; gap: 6px; }
.password-mini input { max-width: 160px; }

.flash { padding: 13px 16px; margin-bottom: 16px; border-radius: 14px; border: 1px solid; }
.flash-success { background: #eefaf3; color: #075d35; border-color: #bde7cf; }
.flash-error { background: #fff1f1; color: #8f1525; border-color: #ffc8cf; }
.notice { background: #f8fbff; border: 1px solid var(--line); border-radius: 15px; padding: 14px; margin: 14px 0; }
.notice.success { background: #eefaf3; border-color: #bde7cf; }
.notice.error { background: #fff1f1; border-color: #ffc8cf; }
.compact { margin: 8px 0 0; padding-left: 22px; }
.small { font-size: .9rem; color: var(--muted); }
.muted { font-weight: 500; color: var(--muted); }
.secret-box { border: 1px dashed #8aa3d6; background: #f8fbff; border-radius: 14px; padding: 16px; font-size: 1.15rem; letter-spacing: .04em; overflow: auto; }
.wrap { white-space: normal; overflow-wrap: anywhere; }

.subnav { display: flex; gap: 10px; flex-wrap: wrap; margin-bottom: 18px; }
.subnav a { background: #fff; border: 1px solid var(--line); border-radius: 999px; padding: 9px 13px; color: var(--ink); font-weight: 700; }
.subnav a:hover { border-color: var(--primary); text-decoration: none; }
.tile { display: flex; flex-direction: column; gap: 10px; background: #fff; border: 1px solid var(--line); border-radius: var(--radius); padding: 22px; color: var(--ink); box-shadow: var(--shadow); }
.tile:hover { text-decoration: none; border-color: var(--primary); transform: translateY(-1px); }
.tile strong { font-size: 1.1rem; }
.tile span { color: var(--muted); }
.table-wrap { overflow: auto; }
table { width: 100%; border-collapse: collapse; }
th, td { text-align: left; border-bottom: 1px solid var(--line); padding: 11px; vertical-align: top; }
th { font-size: .86rem; color: var(--muted); text-transform: uppercase; letter-spacing: .03em; }
.copy-input { width: 100%; min-width: 320px; border: 1px solid var(--line); border-radius: 9px; padding: 8px; background: #f8fbff; }
.checklist { display: grid; gap: 10px; list-style: none; padding: 0; margin: 0; }
.checklist li { display: flex; justify-content: space-between; gap: 18px; padding: 14px; border: 1px solid var(--line); border-radius: 13px; background: #fff; }
.checklist .warn { background: #fff9ea; }

.live-toolbar { display: flex; justify-content: flex-end; align-items: center; gap: 12px; margin-bottom: 12px; flex-wrap: wrap; }
#liveStatus { margin-right: auto; color: var(--muted); font-size: .95rem; }
#liveStatus:empty { display: none; }
.live-stage {
  width: 100%;
  height: auto;
  min-height: 0;
  background: transparent;
  border-radius: 0;
  overflow: hidden;
  display: block;
  position: relative;
  line-height: 0;
  touch-action: none;
  user-select: none;
  cursor: zoom-in;
}
.live-stage.is-zoomed { cursor: grab; }
.live-stage.is-dragging { cursor: grabbing; }
.live-stage img {
  display: block;
  width: 100%;
  height: auto;
  max-width: 100%;
  max-height: none;
  object-fit: initial;
  transform-origin: center center;
  will-change: transform;
  transition: opacity .18s ease;
  user-select: none;
  -webkit-user-drag: none;
}
.live-stage:fullscreen,
.live-stage:-webkit-full-screen {
  width: 100vw;
  height: 100vh;
  background: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
}
.live-stage:fullscreen img,
.live-stage:-webkit-full-screen img {
  width: 100%;
  height: auto;
  max-height: 100vh;
  object-fit: contain;
}
.live-card .small { margin-bottom: 0; }
.auth-card .notice { font-size: .92rem; }

.lite-live { min-height: 100vh; margin: -28px; background: #f5f7fb; }
.lite-head { min-height: 58px; background: #fff; color: var(--ink); border-bottom: 1px solid var(--line); display: flex; align-items: center; justify-content: space-between; gap: 14px; padding: 0 18px; }
.lite-head span { font-size: .9rem; color: var(--muted); }
.lite-head span:empty { display: none; }
.lite-head a { color: var(--ink); font-weight: 700; }
.live-stage.lite { height: auto; border-radius: 0; background: transparent; }
.live-stage.lite img { width: 100%; height: auto; max-height: none; object-fit: initial; }

@media (max-width: 760px) {
  .page { padding: 18px; }
  .topbar { padding: 0 16px; }
  .nav { gap: 10px; }
  .grid2, .grid3, .inline-form { grid-template-columns: 1fr; }
  .hero h1 { font-size: 1.65rem; }
  .auth-card { margin: 20px auto; padding: 22px; }
  .checklist li { display: block; }
  .copy-input { min-width: 240px; }
  .lite-live { margin: -18px; }
  .lite-head { height: auto; align-items: flex-start; flex-direction: column; padding: 12px 14px; }
}

/* Patch 0.4: Wiedergabe-/Clip-Index-Ansicht */
.playback-filter { margin-bottom: 18px; }
.playback-form { grid-template-columns: 1.2fr .8fr .8fr auto; align-items: end; }
.index-inline { margin-top: 14px; align-items: center; }
.playback-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(360px, 46%);
  gap: 20px;
  align-items: start;
}
.player-panel { position: sticky; top: 88px; }
.player-placeholder {
  min-height: 340px;
  border: 1px dashed #aebbd0;
  border-radius: 16px;
  background: linear-gradient(135deg, #f8fbff, #eef3fb);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 10px;
  text-align: center;
  color: var(--muted);
  padding: 28px;
}
.player-placeholder strong { color: var(--ink); font-size: 1.25rem; }
.meta-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
  margin-top: 16px;
}
.meta-grid > div {
  border: 1px solid var(--line);
  border-radius: 13px;
  background: #fff;
  padding: 12px;
  display: grid;
  gap: 4px;
}
.meta-grid strong { font-size: .78rem; text-transform: uppercase; color: var(--muted); letter-spacing: .04em; }
.meta-grid span { font-weight: 800; }
.clip-panel {
  position: sticky;
  top: 88px;
  max-height: calc(100vh - 112px);
  display: flex;
  flex-direction: column;
  overflow: hidden;
}
.clip-head { display: flex; align-items: flex-start; justify-content: space-between; gap: 14px; margin-bottom: 12px; flex: 0 0 auto; }
.clip-head h2 { margin: 0 0 4px; }
.pill { display: inline-flex; align-items: center; border-radius: 999px; background: #eef3ff; border: 1px solid #d5e0ff; padding: 7px 11px; font-weight: 800; color: var(--primary-dark); white-space: nowrap; }
.clip-list {
  display: grid;
  gap: 12px;
  overflow-y: auto;
  overscroll-behavior: contain;
  padding-right: 8px;
  min-height: 0;
  flex: 1 1 auto;
}
.clip-list::-webkit-scrollbar { width: 10px; }
.clip-list::-webkit-scrollbar-thumb { background: #cbd5e1; border-radius: 999px; border: 2px solid #fff; }
.clip-list::-webkit-scrollbar-track { background: #f1f5f9; border-radius: 999px; }
.clip-item {
  display: grid;
  grid-template-columns: 118px minmax(0, 1fr);
  gap: 14px;
  border: 1px solid var(--line);
  border-radius: 16px;
  background: #fff;
  padding: 12px;
}
.clip-thumb {
  min-height: 82px;
  border-radius: 12px;
  background: #edf2fa;
  border: 1px solid #d8e1ee;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 900;
  color: var(--muted);
  letter-spacing: .08em;
}
.clip-info { min-width: 0; display: grid; gap: 5px; }
.clip-info > strong { font-size: 1.1rem; }
.clip-name { color: var(--ink); overflow-wrap: anywhere; }
.clip-info dl {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px 14px;
  margin: 8px 0 0;
}
.clip-info dl div { display: grid; gap: 2px; }
.clip-info dt { color: var(--muted); font-size: .78rem; text-transform: uppercase; letter-spacing: .03em; }
.clip-info dd { margin: 0; font-weight: 700; }
.clip-info details { margin-top: 7px; }
.clip-info summary { cursor: pointer; color: var(--muted); font-weight: 700; }
.empty-state {
  border: 1px dashed #b9c5d8;
  border-radius: 15px;
  background: #f8fbff;
  padding: 18px;
}
.empty-state p { margin-bottom: 0; color: var(--muted); }

@media (max-width: 980px) {
  .playback-layout { grid-template-columns: 1fr; }
  .player-panel { position: static; }
  .clip-panel { position: static; max-height: 70vh; }
  .playback-form { grid-template-columns: 1fr; }
}

@media (max-width: 600px) {
  .clip-item { grid-template-columns: 1fr; }
  .clip-thumb { min-height: 62px; }
  .clip-info dl { grid-template-columns: 1fr; }
  .meta-grid { grid-template-columns: 1fr; }
}

/* Patch 0.4.2: Clip-Übersicht begrenzen und intern scrollbar machen */
.clip-panel {
  display: flex;
  flex-direction: column;
  max-height: calc(100vh - 110px);
  overflow: hidden;
}
.clip-list {
  overflow-y: auto;
  overscroll-behavior: contain;
  padding-right: 6px;
  max-height: var(--clip-list-max-height, 620px);
}
.clip-list::-webkit-scrollbar { width: 10px; }
.clip-list::-webkit-scrollbar-track { background: #f2f5fa; border-radius: 999px; }
.clip-list::-webkit-scrollbar-thumb { background: #c7d2e3; border-radius: 999px; }
.clip-list::-webkit-scrollbar-thumb:hover { background: #aebbd0; }

@media (max-width: 980px) {
  .clip-panel { max-height: none; overflow: visible; }
  .clip-list { max-height: 70vh; }
}

/* Patch 0.5: Videoplayer und lokaler Video-Cache */
.video-shell {
  position: relative;
  background: #0f172a;
  border: 1px solid #111827;
  min-height: 340px;
  display: grid;
  place-items: center;
  overflow: hidden;
}
.video-shell video {
  display: block;
  width: 100%;
  max-height: 68vh;
  background: #000;
}
.video-empty {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 8px;
  text-align: center;
  color: #cbd5e1;
  padding: 28px;
  background: linear-gradient(135deg, #111827, #1f2937);
}
.video-empty strong { color: #fff; font-size: 1.25rem; }
.video-empty span { max-width: 520px; }
.video-empty.is-hidden { display: none; }
.player-status {
  margin-top: 12px;
  min-height: 24px;
  color: var(--muted);
  font-weight: 700;
}
.player-status.loading { color: var(--primary-dark); }
.player-status.success { color: var(--success); }
.player-status.error { color: var(--danger); }
.playback-meta { margin-bottom: 12px; }
.clip-item { transition: border-color .15s ease, box-shadow .15s ease, transform .15s ease; }
.clip-item.is-active {
  border-color: var(--primary);
  box-shadow: 0 0 0 3px rgba(28, 92, 255, .12);
}
.clip-title-row { display: flex; align-items: center; justify-content: space-between; gap: 8px; }
.cache-badge {
  display: inline-flex;
  align-items: center;
  border-radius: 999px;
  background: #fff7ed;
  border: 1px solid #fed7aa;
  color: #9a3412;
  padding: 4px 8px;
  font-size: .78rem;
  font-weight: 900;
  white-space: nowrap;
}
.cache-badge.is-cached {
  background: #ecfdf5;
  border-color: #bbf7d0;
  color: #047857;
}
.clip-actions {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
  margin-top: 8px;
}
.clip-play.is-loading { pointer-events: none; opacity: .75; }
@media (max-width: 980px) {
  .video-shell { min-height: 240px; }
  .video-shell video { max-height: 55vh; }
}

/* Patch 0.5: Videoplayer und lokaler Video-Cache */
.video-shell {
  width: 100%;
  background: #0f172a;
  border-radius: 14px;
  overflow: hidden;
  border: 1px solid var(--line);
}
.video-shell video {
  display: block;
  width: 100%;
  min-height: 320px;
  max-height: 68vh;
  background: #0f172a;
}
.player-status {
  margin-top: 12px;
  border: 1px solid var(--line);
  border-radius: 13px;
  background: #f8fbff;
  color: var(--muted);
  padding: 12px 14px;
  font-weight: 650;
}
.player-status:empty { display: none; }
.player-status.is-loading { background: #fff9ea; border-color: #f5d78b; color: #7a5600; }
.player-status.is-success { background: #eefaf3; border-color: #bde7cf; color: #075d35; }
.player-status.is-error { background: #fff1f1; border-color: #ffc8cf; color: #8f1525; }
.selected-clip {
  margin-top: 12px;
  border: 1px solid var(--line);
  border-radius: 13px;
  background: #fff;
  padding: 12px 14px;
  display: grid;
  gap: 4px;
}
.selected-clip strong { overflow-wrap: anywhere; }
.selected-clip span { color: var(--muted); font-size: .92rem; }
.clip-button {
  width: 100%;
  text-align: left;
  font: inherit;
  color: inherit;
  cursor: pointer;
}
.clip-button:hover,
.clip-button.is-active {
  border-color: var(--primary);
  box-shadow: 0 0 0 3px rgba(28, 92, 255, .10);
}
.clip-button:disabled {
  opacity: .68;
  cursor: wait;
}
.clip-button details { cursor: auto; }

@media (max-width: 980px) {
  .video-shell video { min-height: 240px; max-height: 60vh; }
}
.clip-path { margin-top: 7px; display: grid; gap: 3px; }
.clip-path span { color: var(--muted); font-weight: 700; font-size: .82rem; }

/* Patch 0.5: Videoplayer und lokaler Video-Cache */
.video-shell {
  position: relative;
  width: 100%;
  background: #eef3fb;
  border: 1px solid var(--line);
  border-radius: 14px;
  overflow: hidden;
  min-height: 260px;
  display: grid;
  place-items: center;
}
.video-shell video {
  display: block;
  width: 100%;
  max-height: min(62vh, 720px);
  background: #000;
}
.video-empty {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 8px;
  text-align: center;
  padding: 26px;
  color: var(--muted);
  background: linear-gradient(135deg, #f8fbff, #eef3fb);
}
.video-empty[hidden] { display: none; }
.video-empty strong { color: var(--ink); font-size: 1.2rem; }
.player-status {
  min-height: 26px;
  margin: 12px 0 0;
  color: var(--muted);
  font-weight: 700;
}
.player-status.is-loading { color: var(--primary-dark); }
.player-status.is-error { color: var(--danger); }
.playback-meta { margin-top: 12px; }
.clip-title-row { display: flex; align-items: center; justify-content: space-between; gap: 10px; }
.cache-badge {
  display: inline-flex;
  align-items: center;
  border-radius: 999px;
  background: #f3f6fb;
  border: 1px solid var(--line);
  color: var(--muted);
  padding: 3px 8px;
  font-size: .75rem;
  font-weight: 900;
  white-space: nowrap;
}
.cache-badge.is-cached { background: #eefaf3; border-color: #bde7cf; color: var(--success); }
.clip-actions { display: flex; gap: 10px; align-items: center; flex-wrap: wrap; margin-top: 8px; }
.clip-thumb.clip-play {
  cursor: pointer;
  font: inherit;
  flex-direction: column;
  gap: 5px;
}
.clip-thumb.clip-play:hover { border-color: var(--primary); color: var(--primary-dark); }
.clip-thumb small { font-size: .72rem; letter-spacing: 0; text-transform: none; }
.clip-item.is-active { border-color: var(--primary); box-shadow: 0 0 0 3px rgba(28, 92, 255, .12); }
.clip-item.is-loading { opacity: .76; }

/* Patch 0.5.1: globales Design ohne runde Ecken + Videoplayer ohne schwarze Rahmen */
:root { --radius: 0px; }
*, *::before, *::after { border-radius: 0 !important; }
.video-shell,
.video-frame,
.video-box {
  background: #fff !important;
  border-color: var(--line) !important;
  min-height: 300px;
  line-height: 0;
  overflow: visible;
}
.video-shell video,
.video-frame video,
.video-box video,
.video-player {
  display: block;
  width: 100%;
  height: auto !important;
  max-height: none !important;
  object-fit: contain !important;
  background: #fff !important;
}
.video-empty,
.player-empty {
  background: #f8fbff !important;
  color: var(--muted) !important;
  border: 1px dashed var(--line);
  min-height: 300px;
  line-height: 1.45;
}
.video-empty strong,
.player-empty strong { color: var(--ink) !important; }
.video-empty span,
.player-empty span { color: var(--muted) !important; }

/* Patch 0.5.2: dauerhaft eckiges UI und Videoplayer ohne Abschneiden */
:root { --radius: 0px !important; }
html *, html *::before, html *::after { border-radius: 0 !important; }
.card, .live-card, .auth-card, .tile, .notice, .flash, .btn, input, select, textarea,
.subnav a, .pill, .cache-badge, .clip-item, .clip-thumb, .meta-grid > div,
.video-shell, .video-empty, .player-status, .empty-state, .copy-input, .check,
.checklist li, .secret-box { border-radius: 0 !important; }
.video-shell {
  background: #fff !important;
  border: 1px solid var(--line) !important;
  overflow: visible !important;
  line-height: 0 !important;
}
.video-shell video {
  display: block !important;
  width: 100% !important;
  height: auto !important;
  min-height: 0 !important;
  max-height: none !important;
  object-fit: contain !important;
  background: #fff !important;
}
.video-empty {
  background: #f8fbff !important;
  color: var(--muted) !important;
}
.clip-list::-webkit-scrollbar-track,
.clip-list::-webkit-scrollbar-thumb { border-radius: 0 !important; }

/* Patch 0.5.4: keine zusätzliche Cliplängen-Einblendung im Videoplayer. */
.check-inline {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  margin-top: 8px;
  font-weight: 800;
}

/* Patch 0.5.4: Falls alte Browser/PHP-Ausgabe noch ein Badge enthält, wird es verborgen. */
.video-duration-badge { display: none !important; }

/* Patch 0.6: Thumbnails und Medienmetadaten */
.clip-thumb {
  position: relative;
  overflow: hidden !important;
  line-height: 1.2;
}
.clip-thumb.has-thumb {
  padding: 0;
  background: #000;
  border-color: var(--line);
}
.clip-thumb.has-thumb img {
  display: block;
  width: 100%;
  height: 100%;
  min-height: 82px;
  object-fit: cover;
}
.clip-thumb.has-thumb::after {
  content: '▶';
  position: absolute;
  inset: auto 8px 8px auto;
  display: grid;
  place-items: center;
  width: 30px;
  height: 30px;
  background: rgba(15, 23, 42, .78);
  color: #fff;
  font-size: .9rem;
  font-weight: 900;
}
@media (max-width: 600px) {
  .clip-thumb.has-thumb img { min-height: 150px; }
}

.pagination {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  border: 1px solid var(--line);
  background: #f8fbff;
  padding: 10px;
  margin: 10px 0 14px;
}
.pagination-actions {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}
.page-indicator {
  font-weight: 800;
  white-space: nowrap;
}
.btn.disabled,
.btn.disabled:hover {
  opacity: .45;
  cursor: not-allowed;
  background: #f8fafc;
  border-color: var(--line);
  color: var(--muted);
}
@media (max-width: 760px) {
  .pagination { align-items: flex-start; flex-direction: column; }
}

.clip-refresh-status {
  display: inline-block;
  margin-left: 8px;
  color: var(--muted);
  font-weight: 700;
}
.clip-refresh-status.is-error { color: var(--danger); }

/* Patch 0.7: Exportjobs */
.export-panel .meta-grid,
.export-preview { margin-top: 14px; }
.export-actions { margin-top: 16px; }
.export-status {
  display: inline-flex;
  align-items: center;
  padding: 4px 8px;
  border: 1px solid var(--line);
  background: #f8fbff;
  font-weight: 800;
  white-space: nowrap;
}
.export-status-completed { background: #eefaf3; color: #075d35; border-color: #bde7cf; }
.export-status-failed { background: #fff1f1; color: #8f1525; border-color: #ffc8cf; }
.export-status-queued,
.export-status-preparing,
.export-status-ready_concat { background: #fff9ea; color: #7a4b00; border-color: #ffe0a3; }
.nowrap { white-space: nowrap; }

/* Patch 0.7.2: Export-Sicherheitswarnung */
.alert {
  margin: 14px 0 0;
  padding: 10px 12px;
  border: 1px solid var(--line);
  font-weight: 700;
}
.alert.warning {
  background: #fff9ea;
  border-color: #ffe0a3;
  color: #7a4b00;
}

/* Patch 0.8: Wartung */
.code-block {
  max-height: 360px;
  overflow: auto;
  padding: 12px;
  border: 1px solid var(--line);
  background: #f8fbff;
  font-size: 12px;
  line-height: 1.45;
  white-space: pre-wrap;
}
.warning-list li { margin: 6px 0; }
.danger-check { border-color: #ffb3bd; background: #fff7f8; }
.alert.error { background: #fff1f1; border-color: #ffc8cf; color: #8f1525; }

/* Patch 0.9.0: Admin-Komfort, Logs und kompakte Formularbuttons */
.inline-post { display: inline-flex; margin: 0; }
.inline-form-mini { display: flex; gap: 8px; align-items: center; flex-wrap: wrap; }
.inline-form-mini select { min-width: 170px; padding: 7px 9px; border: 1px solid var(--line); background: #fff; font: inherit; }
.pill.ok { background: #eefaf3; color: #075d35; border-color: #bde7cf; }
.pill.warn { background: #fff9ea; color: #7a4b00; border-color: #ffe0a3; }
.log-table td { max-width: 420px; }
.log-table .wrap { white-space: pre-wrap; overflow-wrap: anywhere; }

/* Patch 0.9.1: Corporate Design + Wiedergabe-/Export-UX */
:root {
  --primary: #19345E !important;
  --primary-dark: #275091 !important;
  --accent: #F7985E !important;
  --ink: #000000;
  --card: #FFFFFF;
  --bg: #f4f6fa;
  --line: #d7dfeb;
}

a { color: var(--primary); }
.nav a:hover,
.subnav a:hover { color: var(--primary-dark); border-color: var(--primary-dark); }
.btn.primary,
button.btn.primary {
  background: #19345E !important;
  border-color: #19345E !important;
  color: #FFFFFF !important;
}
.btn.primary:hover,
button.btn.primary:hover {
  background: #275091 !important;
  border-color: #275091 !important;
}
.btn:focus-visible,
.form input:focus,
.form select:focus {
  outline: 3px solid rgba(25, 52, 94, .18) !important;
  border-color: #19345E !important;
}
.pill {
  background: #fff7f1 !important;
  border-color: #F7985E !important;
  color: #19345E !important;
}
.alert.warning,
.notice.export-help,
.export-status-queued,
.export-status-preparing,
.export-status-ready_concat,
.pill.warn {
  background: #fff7f1 !important;
  border-color: #F7985E !important;
  color: #6f390f !important;
}
.cache-badge {
  background: #f7f9fc !important;
  border-color: var(--line) !important;
  color: #19345E !important;
}
.cache-badge.is-cached,
.export-status-completed,
.pill.ok {
  background: #eefaf3 !important;
  border-color: #bde7cf !important;
  color: #075d35 !important;
}

.playback-dashboard {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 340px;
  gap: 22px;
  align-items: start;
}
.playback-main {
  display: grid;
  gap: 22px;
  min-width: 0;
}
.player-panel,
.clip-panel {
  position: static !important;
  top: auto !important;
  max-height: none !important;
  overflow: visible !important;
}
.export-widget {
  position: sticky;
  top: 88px;
  align-self: start;
}
.export-widget .clip-head {
  align-items: flex-start;
}
.export-widget .meta-grid,
.export-widget-meta {
  grid-template-columns: 1fr !important;
}
.export-widget-actions {
  display: grid;
  grid-template-columns: 1fr;
}
.export-widget-actions .btn {
  width: 100%;
}
.clip-panel .clip-list {
  max-height: var(--clip-list-max-height, 760px);
}
.clip-item {
  grid-template-columns: minmax(220px, 300px) minmax(0, 1fr) !important;
  gap: 18px !important;
  padding: 14px !important;
}
.clip-thumb {
  width: 100%;
  min-height: 0 !important;
  aspect-ratio: 16 / 9;
}
.clip-thumb.has-thumb img {
  width: 100%;
  height: 100%;
  min-height: 0 !important;
  object-fit: cover;
}
.clip-info dl {
  grid-template-columns: repeat(4, minmax(115px, 1fr)) !important;
  gap: 10px 18px !important;
}
.clip-info > strong,
.clip-title-row > strong {
  font-size: 1.15rem;
}
.video-shell {
  background: #FFFFFF !important;
}
.video-empty {
  background: #f7f9fc !important;
}
.export-builder {
  grid-template-columns: 1.1fr .8fr .8fr auto !important;
}
.export-builder .btn.primary {
  min-width: 180px;
}
.export-help {
  margin-top: 14px;
}

@media (max-width: 1120px) {
  .playback-dashboard { grid-template-columns: 1fr; }
  .export-widget { position: static; order: -1; }
  .export-widget .meta-grid,
  .export-widget-meta { grid-template-columns: repeat(2, minmax(0, 1fr)) !important; }
}
@media (max-width: 860px) {
  .clip-item { grid-template-columns: 1fr !important; }
  .clip-info dl { grid-template-columns: repeat(2, minmax(0, 1fr)) !important; }
  .export-builder { grid-template-columns: 1fr !important; }
}
@media (max-width: 560px) {
  .clip-info dl,
  .export-widget .meta-grid,
  .export-widget-meta { grid-template-columns: 1fr !important; }
}

/* Patch 0.9.1: Corporate Design und Wiedergabe-/Export-UX */
:root {
  --bg: #F4F6FA !important;
  --card: #FFFFFF !important;
  --ink: #000000 !important;
  --muted: #5E6C82 !important;
  --line: #D5DEEA !important;
  --primary: #19345E !important;
  --primary-dark: #275091 !important;
  --accent: #F7985E !important;
  --danger: #BD2536 !important;
  --success: #0A7F45 !important;
  --shadow: 0 10px 26px rgba(25, 52, 94, .08) !important;
  --radius: 0px !important;
}
body { color: var(--ink); }
.hero h1, h1, h2, h3, .brand { color: var(--primary); }
a { color: var(--primary); }
a:hover { color: var(--primary-dark); }
.nav a { color: #000000; }
.nav a:hover { color: var(--primary-dark); }
.btn.primary,
button.btn.primary,
a.btn.primary {
  background: var(--primary) !important;
  border-color: var(--primary) !important;
  color: #FFFFFF !important;
}
.btn.primary:hover,
button.btn.primary:hover,
a.btn.primary:hover {
  background: var(--primary-dark) !important;
  border-color: var(--primary-dark) !important;
  color: #FFFFFF !important;
}
.btn:not(.primary):not(.danger) {
  background: #FFFFFF;
  color: var(--primary);
  border-color: var(--line);
}
.btn:not(.primary):not(.danger):hover {
  border-color: var(--primary-dark);
  color: var(--primary-dark);
}
.btn.danger { background: var(--danger) !important; border-color: var(--danger) !important; color: #fff !important; }
.pill {
  color: var(--primary) !important;
  background: #FFFFFF !important;
  border-color: #C9D4E5 !important;
}
.cache-badge { color: var(--primary); background: #fff; border-color: var(--line); }
.export-status-queued,
.export-status-preparing,
.export-status-ready_concat {
  background: #FFFFFF !important;
  color: #000000 !important;
  border-color: var(--accent) !important;
  border-left: 4px solid var(--accent) !important;
}
.alert.warning,
.notice.export-help {
  background: #FFFFFF !important;
  color: #000000 !important;
  border: 1px solid var(--line) !important;
  border-left: 4px solid var(--accent) !important;
}
.flash-success,
.notice.success { background: #FFFFFF !important; border-color: #BDE7CF !important; border-left: 4px solid var(--success) !important; color: #000000 !important; }
.flash-error,
.notice.error,
.alert.error { background: #FFFFFF !important; border-color: #FFC8CF !important; border-left: 4px solid var(--danger) !important; color: #000000 !important; }
input:focus, select:focus, textarea:focus,
.form input:focus, .form select:focus {
  outline: 3px solid rgba(39, 80, 145, .16) !important;
  border-color: var(--primary-dark) !important;
}

.playback-dashboard {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 360px;
  gap: 20px;
  align-items: start;
}
.playback-main {
  display: grid;
  gap: 20px;
  min-width: 0;
}
.player-panel,
.clip-panel { position: static !important; max-height: none !important; overflow: visible !important; }
.export-widget {
  position: sticky;
  top: 88px;
  align-self: start;
}
.export-widget .meta-grid,
.export-widget-meta { grid-template-columns: 1fr !important; }
.export-widget .clip-head { align-items: flex-start; }
.export-widget .actions { flex-direction: column; align-items: stretch; }
.export-widget .btn { width: 100%; }

.clip-panel .clip-list {
  max-height: var(--clip-list-max-height, 760px);
  display: grid;
  gap: 14px;
}
.clip-item {
  grid-template-columns: minmax(220px, 30%) minmax(0, 1fr) !important;
  gap: 18px !important;
  align-items: start;
}
.clip-thumb {
  width: 100%;
  min-height: 0 !important;
  aspect-ratio: 16 / 9;
  align-self: start;
}
.clip-thumb.has-thumb img,
.clip-thumb img {
  min-height: 0 !important;
  height: 100% !important;
  width: 100% !important;
  object-fit: cover !important;
}
.clip-info dl {
  grid-template-columns: repeat(4, minmax(110px, 1fr)) !important;
  gap: 10px 18px !important;
}
.clip-info > strong,
.clip-title-row strong { color: var(--primary); }
.clip-item.is-active {
  border-color: var(--primary) !important;
  box-shadow: inset 4px 0 0 var(--primary) !important;
}
.video-shell {
  background: #FFFFFF !important;
  border-color: var(--line) !important;
}
.video-empty {
  background: #FFFFFF !important;
  border: 1px dashed var(--line) !important;
}
.playback-meta-secondary {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.export-unified-form { margin-bottom: 14px; }
.export-unified-grid,
.export-filter.export-builder {
  display: grid !important;
  grid-template-columns: minmax(180px, 1fr) minmax(130px, .6fr) minmax(130px, .6fr) auto !important;
  gap: 14px !important;
  align-items: end !important;
}
.export-unified-grid .btn,
.export-filter.export-builder .btn {
  min-width: 190px;
}
.export-preview-meta { margin-top: 14px; }
.export-preview[open] {
  border: 1px solid var(--line);
  border-left: 4px solid var(--accent);
  padding: 12px 14px;
  margin-top: 14px;
  background: #fff;
}
.export-preview summary { font-weight: 800; color: var(--primary); cursor: pointer; }

@media (max-width: 1180px) {
  .playback-dashboard { grid-template-columns: 1fr; }
  .export-widget { position: static; order: -1; }
  .export-widget .meta-grid,
  .export-widget-meta { grid-template-columns: repeat(2, minmax(0, 1fr)) !important; }
  .export-widget .actions { flex-direction: row; }
  .export-widget .btn { width: auto; }
}
@media (max-width: 760px) {
  .clip-item { grid-template-columns: 1fr !important; }
  .clip-info dl { grid-template-columns: repeat(2, minmax(0, 1fr)) !important; }
  .playback-meta-secondary { grid-template-columns: 1fr; }
  .export-unified-grid,
  .export-filter.export-builder { grid-template-columns: 1fr !important; }
  .export-unified-grid .btn,
  .export-filter.export-builder .btn { width: 100%; min-width: 0; }
}
@media (max-width: 520px) {
  .clip-info dl { grid-template-columns: 1fr !important; }
}

/* Patch 0.9.2: Player-Metadaten rechts und Clip-Übersicht als horizontale Scrollleiste */
.player-panel {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) minmax(280px, 340px);
  grid-template-areas:
    "title title"
    "video selected"
    "status selected"
    "summary summary";
  gap: 14px 18px;
  align-items: start;
}
.player-panel > h2 { grid-area: title; margin-bottom: 0; }
.player-panel .video-shell { grid-area: video; }
.player-panel .player-status { grid-area: status; }
.player-panel .playback-meta {
  grid-area: selected;
  grid-template-columns: 1fr !important;
  margin-top: 0 !important;
  align-self: stretch;
}
.player-panel .playback-meta > div {
  min-height: 0;
}
.player-panel .playback-meta-secondary {
  grid-area: summary;
  grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
  margin-top: 2px !important;
}

.clip-panel {
  overflow: visible !important;
}
.clip-panel .clip-list {
  display: grid !important;
  grid-auto-flow: column;
  grid-auto-columns: minmax(560px, 640px);
  grid-template-columns: none !important;
  overflow-x: auto !important;
  overflow-y: hidden !important;
  max-height: none !important;
  padding: 0 0 14px 0 !important;
  scroll-snap-type: x proximity;
  overscroll-behavior-x: contain;
}
.clip-panel .clip-list::-webkit-scrollbar {
  height: 12px;
  width: auto;
}
.clip-panel .clip-list::-webkit-scrollbar-track {
  background: #EEF2F7;
}
.clip-panel .clip-list::-webkit-scrollbar-thumb {
  background: #B9C6D8;
  border: 2px solid #EEF2F7;
}
.clip-panel .clip-list::-webkit-scrollbar-thumb:hover {
  background: var(--primary-dark);
}
.clip-panel .clip-item {
  width: 100%;
  grid-template-columns: 220px minmax(0, 1fr) !important;
  scroll-snap-align: start;
}
.clip-panel .clip-thumb {
  aspect-ratio: 16 / 9;
}
.clip-panel .clip-head {
  margin-bottom: 16px;
}
.clip-panel .pagination {
  margin-bottom: 16px;
}

@media (max-width: 1180px) {
  .player-panel {
    grid-template-columns: minmax(0, 1fr) minmax(260px, 320px);
  }
  .clip-panel .clip-list {
    grid-auto-columns: minmax(520px, 620px);
  }
}
@media (max-width: 900px) {
  .player-panel {
    grid-template-columns: 1fr;
    grid-template-areas:
      "title"
      "video"
      "status"
      "selected"
      "summary";
  }
  .player-panel .playback-meta,
  .player-panel .playback-meta-secondary {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }
}
@media (max-width: 720px) {
  .clip-panel .clip-list {
    grid-auto-flow: row;
    grid-auto-columns: auto;
    overflow-x: visible !important;
    overflow-y: visible !important;
    padding-bottom: 0 !important;
  }
  .clip-panel .clip-item {
    grid-template-columns: 1fr !important;
  }
}
@media (max-width: 560px) {
  .player-panel .playback-meta,
  .player-panel .playback-meta-secondary {
    grid-template-columns: 1fr !important;
  }
}

/* Patch 0.9.2: Player-Metadaten rechts, Clip-Übersicht horizontal */
.player-workspace {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 360px;
  gap: 22px;
  align-items: start;
}
.player-media { min-width: 0; }
.player-meta-aside {
  border-left: 3px solid #F7985E;
  padding-left: 18px;
  min-width: 0;
}
.player-meta-aside h3 {
  margin: 0 0 10px;
  font-size: 1rem;
  color: #19345E;
}
.player-meta-aside h3 + .meta-grid { margin-top: 0; }
.player-meta-aside .meta-grid {
  grid-template-columns: 1fr !important;
  gap: 9px;
}
.player-meta-aside .meta-grid + h3 { margin-top: 18px; }
.player-meta-aside .meta-grid > div {
  padding: 10px 11px;
}
.player-meta-aside .meta-grid span {
  overflow-wrap: anywhere;
}

.clip-panel .clip-list {
  display: flex !important;
  grid-template-columns: none !important;
  flex-wrap: nowrap;
  gap: 14px;
  overflow-x: auto !important;
  overflow-y: hidden !important;
  max-height: none !important;
  padding: 0 0 16px 0;
  scroll-snap-type: x proximity;
  overscroll-behavior-x: contain;
}
.clip-panel .clip-list .clip-item {
  flex: 0 0 clamp(560px, 72vw, 860px);
  scroll-snap-align: start;
  align-self: stretch;
}
.clip-panel .clip-list::-webkit-scrollbar {
  height: 12px;
  width: auto;
}
.clip-panel .clip-list::-webkit-scrollbar-track {
  background: #edf1f7;
  border-radius: 0 !important;
}
.clip-panel .clip-list::-webkit-scrollbar-thumb {
  background: #19345E;
  border: 2px solid #edf1f7;
  border-radius: 0 !important;
}
.clip-panel .clip-list::-webkit-scrollbar-thumb:hover {
  background: #275091;
}

@media (max-width: 1180px) {
  .player-workspace { grid-template-columns: 1fr; }
  .player-meta-aside {
    border-left: 0;
    border-top: 3px solid #F7985E;
    padding-left: 0;
    padding-top: 16px;
  }
  .player-meta-aside .meta-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }
}
@media (max-width: 760px) {
  .clip-panel .clip-list .clip-item { flex-basis: 86vw; }
  .player-meta-aside .meta-grid { grid-template-columns: 1fr !important; }
}

/* Patch 0.9.3: Wiedergabe-Layout-Fix
   Entfernt den Konflikt aus 0.9.2 zwischen altem Player-Grid und neuer player-workspace-Struktur. */
.playback-hero,
.playback-filter,
.playback-dashboard {
  width: 100%;
}
.playback-dashboard {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) 360px !important;
  gap: 24px !important;
  align-items: start !important;
}
.playback-main {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) !important;
  gap: 24px !important;
  min-width: 0 !important;
  width: 100% !important;
}
.player-panel {
  display: block !important;
  width: 100% !important;
  min-width: 0 !important;
  max-height: none !important;
  overflow: visible !important;
}
.player-panel > h2 {
  margin: 0 0 16px !important;
  grid-area: auto !important;
}
.player-panel > .player-workspace {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) minmax(300px, 380px) !important;
  gap: 20px !important;
  align-items: start !important;
  width: 100% !important;
  min-width: 0 !important;
  grid-area: auto !important;
}
.player-media {
  min-width: 0 !important;
  width: 100% !important;
}
.player-meta-aside {
  min-width: 0 !important;
  width: 100% !important;
  border-left: 4px solid var(--accent) !important;
  border-top: 0 !important;
  padding-left: 18px !important;
  padding-top: 0 !important;
}
.player-meta-aside .playback-meta,
.player-meta-aside .playback-meta-secondary {
  display: grid !important;
  grid-template-columns: 1fr !important;
  margin-top: 0 !important;
  grid-area: auto !important;
}
.video-shell {
  width: 100% !important;
  min-height: 0 !important;
  aspect-ratio: 16 / 9 !important;
  background: #FFFFFF !important;
  border: 1px solid var(--line) !important;
  overflow: hidden !important;
}
.video-shell video {
  width: 100% !important;
  height: 100% !important;
  max-height: none !important;
  object-fit: contain !important;
  background: #000000 !important;
}
.video-empty {
  background: #FFFFFF !important;
  border: 1px dashed var(--line) !important;
  color: var(--muted) !important;
}
.video-empty strong { color: var(--primary) !important; }
.clip-panel {
  width: 100% !important;
  min-width: 0 !important;
  overflow: visible !important;
}
.clip-panel .clip-head {
  align-items: flex-start !important;
  gap: 14px !important;
  flex-wrap: wrap !important;
}
.clip-panel .clip-list {
  display: flex !important;
  flex-wrap: nowrap !important;
  gap: 16px !important;
  overflow-x: auto !important;
  overflow-y: hidden !important;
  max-height: none !important;
  padding: 0 0 18px !important;
  scroll-snap-type: x proximity !important;
  -webkit-overflow-scrolling: touch !important;
}
.clip-panel .clip-list .clip-item {
  flex: 0 0 clamp(640px, 72vw, 940px) !important;
  display: grid !important;
  grid-template-columns: 260px minmax(0, 1fr) !important;
  gap: 18px !important;
  scroll-snap-align: start !important;
  align-self: stretch !important;
  width: auto !important;
  max-width: none !important;
}
.clip-panel .clip-thumb {
  width: 100% !important;
  aspect-ratio: 16 / 9 !important;
  min-height: 0 !important;
  align-self: start !important;
}
.clip-panel .clip-info dl {
  grid-template-columns: repeat(4, minmax(100px, 1fr)) !important;
  gap: 10px 16px !important;
}
.export-widget {
  width: 100% !important;
  min-width: 0 !important;
  position: sticky !important;
  top: 88px !important;
}

@media (max-width: 1260px) {
  .playback-dashboard {
    grid-template-columns: 1fr !important;
  }
  .export-widget {
    position: static !important;
    order: -1 !important;
  }
}
@media (max-width: 960px) {
  .player-panel > .player-workspace {
    grid-template-columns: 1fr !important;
  }
  .player-meta-aside {
    border-left: 0 !important;
    border-top: 4px solid var(--accent) !important;
    padding-left: 0 !important;
    padding-top: 16px !important;
  }
  .player-meta-aside .playback-meta,
  .player-meta-aside .playback-meta-secondary {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }
}
@media (max-width: 760px) {
  .clip-panel .clip-list {
    overflow-x: auto !important;
  }
  .clip-panel .clip-list .clip-item {
    flex-basis: 86vw !important;
    grid-template-columns: 1fr !important;
  }
  .clip-panel .clip-info dl,
  .player-meta-aside .playback-meta,
  .player-meta-aside .playback-meta-secondary {
    grid-template-columns: 1fr !important;
  }
}

/* Patch 0.9.4: Wiedergabe-Layout vereinfacht, Player breiter, Clip-Details einklappbar */
.playback-dashboard {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) 320px !important;
  gap: 24px !important;
  align-items: start !important;
}
.playback-main {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) !important;
  gap: 24px !important;
  min-width: 0 !important;
}
.player-panel {
  width: 100% !important;
  min-width: 0 !important;
  overflow: visible !important;
}
.player-panel > .player-workspace {
  display: block !important;
  width: 100% !important;
  min-width: 0 !important;
}
.player-media {
  width: 100% !important;
  min-width: 0 !important;
}
.video-shell {
  width: 100% !important;
  aspect-ratio: 16 / 9 !important;
  min-height: 0 !important;
  overflow: hidden !important;
  background: #FFFFFF !important;
}
.video-shell video {
  width: 100% !important;
  height: 100% !important;
  object-fit: contain !important;
  background: #000000 !important;
}
.selected-clip-details {
  margin-top: 14px !important;
  border: 1px solid var(--line) !important;
  background: #FFFFFF !important;
}
.selected-clip-details > summary {
  cursor: pointer !important;
  list-style: none !important;
  padding: 13px 16px !important;
  font-weight: 900 !important;
  color: var(--primary) !important;
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 12px !important;
  user-select: none !important;
}
.selected-clip-details > summary::-webkit-details-marker { display: none !important; }
.selected-clip-details > summary::after {
  content: "+" !important;
  font-size: 1.2rem !important;
  line-height: 1 !important;
  color: var(--accent) !important;
}
.selected-clip-details[open] > summary {
  border-bottom: 1px solid var(--line) !important;
}
.selected-clip-details[open] > summary::after { content: "–" !important; }
.selected-clip-details-body {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr) !important;
  gap: 18px !important;
  padding: 16px !important;
}
.selected-clip-details-body h3 {
  margin: 0 0 10px !important;
  font-size: 1rem !important;
}
.selected-clip-details .playback-meta,
.selected-clip-details .playback-meta-secondary {
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  gap: 10px !important;
  margin-top: 0 !important;
}
.player-meta-aside { display: none !important; }

/* Clip-Scroller: horizontal, mit groesserem 16:9-Thumbnail und kompakteren Metadaten */
.clip-panel .clip-list {
  display: flex !important;
  flex-wrap: nowrap !important;
  gap: 16px !important;
  overflow-x: auto !important;
  overflow-y: hidden !important;
  max-height: none !important;
  padding: 0 0 18px !important;
  scroll-snap-type: x proximity !important;
  overscroll-behavior-x: contain !important;
  -webkit-overflow-scrolling: touch !important;
}
.clip-panel .clip-list .clip-item {
  flex: 0 0 clamp(760px, 78vw, 1040px) !important;
  display: grid !important;
  grid-template-columns: minmax(300px, 38%) minmax(0, 1fr) !important;
  gap: 18px !important;
  width: auto !important;
  max-width: none !important;
  scroll-snap-align: start !important;
  align-self: stretch !important;
  padding: 14px !important;
}
.clip-panel .clip-thumb {
  width: 100% !important;
  aspect-ratio: 16 / 9 !important;
  min-height: 0 !important;
  align-self: start !important;
  background: #eef3fb !important;
}
.clip-panel .clip-thumb img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
}
.clip-panel .clip-info {
  min-width: 0 !important;
  font-size: .88rem !important;
}
.clip-panel .clip-title-row strong {
  font-size: 1.05rem !important;
}
.clip-panel .clip-name {
  display: block !important;
  font-size: .86rem !important;
  line-height: 1.35 !important;
  overflow-wrap: anywhere !important;
  margin: 4px 0 8px !important;
}
.clip-panel .clip-info dl {
  display: grid !important;
  grid-template-columns: repeat(4, minmax(82px, 1fr)) !important;
  gap: 8px 12px !important;
  margin: 8px 0 !important;
}
.clip-panel .clip-info dt {
  font-size: .66rem !important;
  letter-spacing: .04em !important;
  color: var(--muted) !important;
}
.clip-panel .clip-info dd {
  font-size: .82rem !important;
  line-height: 1.2 !important;
  font-weight: 800 !important;
}
.clip-panel .clip-actions {
  gap: 8px !important;
  margin-top: 8px !important;
}
.clip-panel .clip-actions .small,
.clip-panel details summary,
.clip-panel details code {
  font-size: .78rem !important;
}

/* Normale Nutzer sollen nicht durch manuelle Index-Aktionen verwirrt werden. */
.index-inline { display: none !important; }

@media (max-width: 1260px) {
  .playback-dashboard { grid-template-columns: 1fr !important; }
  .export-widget { position: static !important; order: -1 !important; }
}
@media (max-width: 900px) {
  .selected-clip-details-body { grid-template-columns: 1fr !important; }
  .selected-clip-details .playback-meta,
  .selected-clip-details .playback-meta-secondary { grid-template-columns: 1fr !important; }
  .clip-panel .clip-list .clip-item {
    flex-basis: 86vw !important;
    grid-template-columns: 1fr !important;
  }
  .clip-panel .clip-info dl { grid-template-columns: repeat(2, minmax(0, 1fr)) !important; }
}
@media (max-width: 560px) {
  .clip-panel .clip-info dl { grid-template-columns: 1fr !important; }
}

/* Patch 0.9.5: kompakte Clip-Karten, Player-Spulbuttons, stabileres horizontales Scrollen */
.player-extra-controls {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 8px !important;
  margin-top: 10px !important;
  align-items: center !important;
}
.player-extra-controls .btn {
  min-width: 82px !important;
  justify-content: center !important;
}

.clip-panel .clip-list {
  display: flex !important;
  flex-wrap: nowrap !important;
  gap: 16px !important;
  overflow-x: auto !important;
  overflow-y: hidden !important;
  max-height: none !important;
  padding: 0 0 18px !important;
  scroll-snap-type: none !important;
  overscroll-behavior-x: contain !important;
  overscroll-behavior-y: auto !important;
  -webkit-overflow-scrolling: touch !important;
}
.clip-panel .clip-list .clip-item,
.clip-panel .clip-list .clip-item.clip-item-compact {
  flex: 0 0 clamp(320px, 32vw, 430px) !important;
  width: clamp(320px, 32vw, 430px) !important;
  max-width: clamp(320px, 32vw, 430px) !important;
  display: block !important;
  padding: 0 !important;
  overflow: hidden !important;
  background: #FFFFFF !important;
  border: 1px solid var(--line) !important;
  scroll-snap-align: none !important;
}
.clip-panel .clip-list .clip-item.is-active {
  border-color: var(--primary) !important;
  box-shadow: 0 0 0 3px rgba(25, 52, 94, .18) !important;
}
.clip-panel .clip-thumb,
.clip-panel .clip-list .clip-thumb {
  width: 100% !important;
  aspect-ratio: 16 / 9 !important;
  min-height: 0 !important;
  height: auto !important;
  border: 0 !important;
  border-bottom: 1px solid var(--line) !important;
  background: #eef3fb !important;
  position: relative !important;
  display: grid !important;
  place-items: center !important;
}
.clip-panel .clip-thumb.has-thumb img,
.clip-panel .clip-thumb img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  display: block !important;
}
.thumb-play-indicator {
  position: absolute !important;
  right: 12px !important;
  bottom: 12px !important;
  width: 34px !important;
  height: 34px !important;
  display: grid !important;
  place-items: center !important;
  background: rgba(0,0,0,.62) !important;
  color: #FFFFFF !important;
  font-weight: 900 !important;
  font-size: 1rem !important;
}
.thumb-duration {
  position: absolute !important;
  left: 12px !important;
  bottom: 10px !important;
  background: rgba(0,0,0,.68) !important;
  color: #FFFFFF !important;
  font-size: .86rem !important;
  font-weight: 900 !important;
  padding: 4px 7px !important;
}
.clip-card-summary {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 10px !important;
  padding: 12px 14px !important;
  background: #FFFFFF !important;
}
.clip-card-date-row {
  display: grid !important;
  grid-template-columns: 1fr auto !important;
  align-items: baseline !important;
  gap: 16px !important;
  width: 100% !important;
  min-width: 0 !important;
}
.clip-card-date {
  color: #53657c !important;
  font-size: 1.02rem !important;
  font-weight: 700 !important;
  white-space: nowrap !important;
}
.clip-card-time {
  color: #000000 !important;
  font-size: 1.08rem !important;
  font-weight: 900 !important;
  white-space: nowrap !important;
}
.clip-details-compact {
  border-top: 1px solid var(--line) !important;
  background: #fbfdff !important;
}
.clip-details-compact > summary {
  cursor: pointer !important;
  padding: 10px 14px !important;
  color: var(--primary) !important;
  font-weight: 900 !important;
  list-style: none !important;
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
}
.clip-details-compact > summary::-webkit-details-marker { display: none !important; }
.clip-details-compact > summary::after {
  content: "+" !important;
  color: var(--accent) !important;
  font-size: 1.1rem !important;
  line-height: 1 !important;
}
.clip-details-compact[open] > summary::after { content: "–" !important; }
.clip-details-compact .clip-info {
  padding: 0 14px 14px !important;
  font-size: .82rem !important;
  display: grid !important;
  gap: 8px !important;
}
.clip-details-compact .clip-name {
  display: block !important;
  font-size: .78rem !important;
  line-height: 1.35 !important;
  overflow-wrap: anywhere !important;
  color: var(--muted) !important;
}
.clip-details-compact .clip-info dl {
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  gap: 7px 10px !important;
  margin: 0 !important;
}
.clip-details-compact .clip-info dt {
  font-size: .62rem !important;
  color: var(--muted) !important;
  letter-spacing: .04em !important;
  text-transform: uppercase !important;
}
.clip-details-compact .clip-info dd {
  font-size: .78rem !important;
  font-weight: 800 !important;
  line-height: 1.2 !important;
}
.clip-details-compact .clip-actions {
  margin-top: 4px !important;
  gap: 8px !important;
}
.clip-details-compact details summary,
.clip-details-compact details code,
.clip-details-compact .small {
  font-size: .74rem !important;
}

@media (max-width: 900px) {
  .clip-panel .clip-list .clip-item,
  .clip-panel .clip-list .clip-item.clip-item-compact {
    flex-basis: 78vw !important;
    width: 78vw !important;
    max-width: 78vw !important;
  }
}
@media (max-width: 560px) {
  .player-extra-controls .btn { flex: 1 1 44% !important; }
  .clip-panel .clip-list .clip-item,
  .clip-panel .clip-list .clip-item.clip-item-compact {
    flex-basis: 86vw !important;
    width: 86vw !important;
    max-width: 86vw !important;
  }
  .clip-card-summary { padding: 10px 12px !important; }
  .clip-card-date { font-size: .92rem !important; }
  .clip-card-time { font-size: .98rem !important; }
}

/* Patch 0.9.6: nur ein Play-Overlay in der kompakten Clipkarte anzeigen */
.clip-panel .clip-thumb.has-thumb::after,
.clip-panel .clip-thumb.clip-play.has-thumb::after {
  content: none !important;
  display: none !important;
}
.clip-panel .clip-thumb .thumb-play-indicator {
  pointer-events: none !important;
}


/* Patch 0.9.6 final: altes Thumbnail-Pseudo-Play-Icon global deaktivieren, damit nur das neue Icon sichtbar bleibt. */
.clip-thumb.has-thumb::after,
.clip-thumb.clip-play.has-thumb::after,
.clip-panel .clip-thumb.has-thumb::after,
.clip-panel .clip-thumb.clip-play.has-thumb::after {
  content: none !important;
  display: none !important;
  opacity: 0 !important;
  width: 0 !important;
  height: 0 !important;
}

/* Patch 0.9.8: Monitoring & Warnungen */
.monitor-banner {
  margin: 0 0 18px;
  padding: 16px 18px;
  border: 1px solid var(--line);
  border-left: 5px solid #35b779;
  background: #fff;
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
}
.monitor-banner strong { display:block; font-size:1.05rem; color:var(--text); margin-bottom:4px; }
.monitor-banner span { display:block; color:var(--muted); font-size:.9rem; }
.monitor-banner ul { margin-top:10px; }
.monitor-ok { border-left-color:#35b779; }
.monitor-warn { border-left-color:var(--accent); background:#fffaf6; }
.monitor-error { border-left-color:#c42b3a; background:#fff6f7; }
.badge.warn { background:#fff1e7; border-color:#f6c29f; color:#8c3f12; }
.badge.error { background:#ffe9ec; border-color:#f1a8b1; color:#9e1d2c; }
.badge.success { background:#e9f8f0; border-color:#a9dfc0; color:#126b3b; }
@media (max-width:760px){ .monitor-banner{ flex-direction:column; } }
.badge {
  display:inline-flex;
  align-items:center;
  gap:4px;
  padding:4px 8px;
  border:1px solid var(--line);
  background:#fff;
  color:var(--text);
  font-weight:800;
  font-size:.82rem;
  line-height:1.1;
}

/* Patch 0.9.9: Monitoring-Wartungsmodus */
.monitor-maintenance { border-left-color: var(--accent); background:#fffaf6; }
.monitor-maintenance strong { color: var(--primary); }


/* Patch 1.0.7: Wiedergabe wieder als Arbeitsansicht: Player links, Clipauswahl rechts, Export darunter */
.playback-dashboard {
  display: block !important;
  width: 100% !important;
}
.playback-main {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) minmax(360px, 430px) !important;
  gap: 24px !important;
  align-items: start !important;
  min-width: 0 !important;
  width: 100% !important;
}
.player-panel,
.clip-panel {
  min-width: 0 !important;
  width: 100% !important;
}
.player-panel {
  align-self: start !important;
}
.video-shell {
  width: 100% !important;
  aspect-ratio: 16 / 9 !important;
  min-height: 0 !important;
}
.clip-panel {
  position: sticky !important;
  top: 88px !important;
  overflow: hidden !important;
  max-height: calc(100vh - 112px) !important;
  display: flex !important;
  flex-direction: column !important;
}
.clip-panel .clip-head {
  flex: 0 0 auto !important;
  margin-bottom: 12px !important;
}
.clip-panel .clip-head p {
  margin-bottom: 0 !important;
}
.clip-panel .clip-list {
  display: grid !important;
  grid-template-columns: 1fr !important;
  gap: 14px !important;
  overflow-y: auto !important;
  overflow-x: hidden !important;
  max-height: none !important;
  min-height: 0 !important;
  flex: 1 1 auto !important;
  padding: 0 8px 6px 0 !important;
  scroll-snap-type: none !important;
  overscroll-behavior: contain !important;
  -webkit-overflow-scrolling: touch !important;
}
.clip-panel .clip-list::-webkit-scrollbar { width: 10px !important; height: 10px !important; }
.clip-panel .clip-list::-webkit-scrollbar-track { background: #f2f5fa !important; }
.clip-panel .clip-list::-webkit-scrollbar-thumb { background: #c7d2e3 !important; }
.clip-panel .clip-list::-webkit-scrollbar-thumb:hover { background: #aebbd0 !important; }
.clip-panel .clip-list .clip-item,
.clip-panel .clip-list .clip-item.clip-item-compact {
  flex: none !important;
  width: 100% !important;
  max-width: none !important;
  display: block !important;
  padding: 0 !important;
  overflow: hidden !important;
  background: #FFFFFF !important;
  border: 1px solid var(--line) !important;
  scroll-snap-align: none !important;
}
.clip-panel .clip-thumb,
.clip-panel .clip-list .clip-thumb {
  width: 100% !important;
  aspect-ratio: 16 / 9 !important;
  min-height: 0 !important;
  border: 0 !important;
  border-bottom: 1px solid var(--line) !important;
}
.clip-card-summary {
  padding: 10px 12px !important;
}
.clip-card-date {
  font-size: .95rem !important;
}
.clip-card-time {
  font-size: 1rem !important;
}
.clip-details-compact > summary {
  padding: 9px 12px !important;
}
.clip-details-compact .clip-info {
  padding: 0 12px 12px !important;
}
.clip-details-compact .clip-info dl {
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
}
.export-widget {
  position: static !important;
  top: auto !important;
  width: 100% !important;
  margin-top: 24px !important;
}
.export-widget .clip-head {
  align-items: flex-start !important;
}
.export-widget .meta-grid,
.export-widget-meta {
  grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
}
.export-widget-actions {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 10px !important;
}
.export-widget-actions .btn {
  width: auto !important;
  min-width: 190px !important;
}

@media (max-width: 1180px) {
  .playback-main {
    grid-template-columns: minmax(0, 1fr) minmax(320px, 380px) !important;
  }
}
@media (max-width: 980px) {
  .playback-main {
    grid-template-columns: 1fr !important;
  }
  .clip-panel {
    position: static !important;
    max-height: none !important;
    overflow: visible !important;
  }
  .clip-panel .clip-list {
    max-height: 70vh !important;
  }
  .export-widget .meta-grid,
  .export-widget-meta {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }
}
@media (max-width: 560px) {
  .export-widget .meta-grid,
  .export-widget-meta {
    grid-template-columns: 1fr !important;
  }
  .export-widget-actions .btn {
    width: 100% !important;
  }
}

/* Patch 1.0.7: Wiedergabe-Layout wieder nebeneinander: Player links, Clip-Übersicht rechts, Export darunter */
.playback-dashboard {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) !important;
  gap: 24px !important;
  align-items: start !important;
}
.playback-main {
  display: grid !important;
  grid-template-columns: minmax(0, 2.05fr) minmax(340px, .95fr) !important;
  gap: 24px !important;
  min-width: 0 !important;
  align-items: stretch !important;
}
.player-panel,
.clip-panel,
.export-widget {
  position: static !important;
  top: auto !important;
  min-width: 0 !important;
}
.player-panel {
  width: 100% !important;
  align-self: stretch !important;
}
.player-panel > .player-workspace,
.player-media,
.video-shell {
  width: 100% !important;
  min-width: 0 !important;
}
.clip-panel {
  width: 100% !important;
  align-self: stretch !important;
  display: flex !important;
  flex-direction: column !important;
  overflow: hidden !important;
  max-height: var(--clip-list-max-height, 760px) !important;
}
.clip-panel .clip-head {
  flex: 0 0 auto !important;
  gap: 12px !important;
  margin-bottom: 12px !important;
}
.clip-panel .clip-head h2 { margin-bottom: 4px !important; }
.clip-panel .clip-head .small { font-size: .78rem !important; line-height: 1.35 !important; }
.clip-panel .clip-list {
  flex: 1 1 auto !important;
  min-height: 0 !important;
  max-height: none !important;
  display: flex !important;
  flex-direction: column !important;
  flex-wrap: nowrap !important;
  gap: 12px !important;
  overflow-y: auto !important;
  overflow-x: hidden !important;
  padding: 0 10px 2px 0 !important;
  scroll-snap-type: none !important;
  overscroll-behavior: contain !important;
  -webkit-overflow-scrolling: touch !important;
}
.clip-panel .clip-list::-webkit-scrollbar { width: 10px !important; height: 10px !important; }
.clip-panel .clip-list::-webkit-scrollbar-track { background: #f2f5fa !important; }
.clip-panel .clip-list::-webkit-scrollbar-thumb { background: #c7d2e3 !important; border: 2px solid #f2f5fa !important; }
.clip-panel .clip-list::-webkit-scrollbar-thumb:hover { background: #aebbd0 !important; }
.clip-panel .clip-list .clip-item,
.clip-panel .clip-list .clip-item.clip-item-compact {
  flex: 0 0 auto !important;
  width: 100% !important;
  max-width: none !important;
  display: grid !important;
  grid-template-columns: 154px minmax(0, 1fr) !important;
  grid-template-areas:
    "thumb summary"
    "details details" !important;
  gap: 0 !important;
  padding: 0 !important;
  overflow: hidden !important;
  background: #FFFFFF !important;
  border: 1px solid var(--line) !important;
  scroll-snap-align: none !important;
}
.clip-panel .clip-list .clip-item.is-active,
.clip-panel .clip-list .clip-item.clip-item-compact.is-active {
  border-color: var(--primary) !important;
  box-shadow: 0 0 0 3px rgba(25, 52, 94, .16) !important;
}
.clip-panel .clip-thumb,
.clip-panel .clip-list .clip-thumb {
  grid-area: thumb !important;
  width: 154px !important;
  height: 87px !important;
  aspect-ratio: 16 / 9 !important;
  min-height: 0 !important;
  border: 0 !important;
  border-right: 1px solid var(--line) !important;
  border-bottom: 0 !important;
  background: #eef3fb !important;
  align-self: stretch !important;
}
.clip-panel .clip-thumb.has-thumb img,
.clip-panel .clip-thumb img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  display: block !important;
}
.clip-panel .thumb-play-indicator {
  right: 8px !important;
  bottom: 8px !important;
  width: 28px !important;
  height: 28px !important;
  font-size: .86rem !important;
}
.clip-panel .thumb-duration {
  left: 7px !important;
  bottom: 7px !important;
  font-size: .72rem !important;
  padding: 3px 6px !important;
}
.clip-card-summary {
  grid-area: summary !important;
  display: flex !important;
  flex-direction: column !important;
  justify-content: center !important;
  align-items: stretch !important;
  padding: 10px 12px !important;
  min-width: 0 !important;
  gap: 8px !important;
  background: #FFFFFF !important;
}
.clip-card-date-row {
  display: grid !important;
  grid-template-columns: 1fr !important;
  gap: 4px !important;
  width: 100% !important;
}
.clip-card-date {
  font-size: .82rem !important;
  color: var(--muted) !important;
  font-weight: 800 !important;
  white-space: nowrap !important;
}
.clip-card-time {
  font-size: 1.08rem !important;
  color: #000000 !important;
  font-weight: 900 !important;
  white-space: nowrap !important;
}
.clip-card-summary .cache-badge {
  align-self: flex-start !important;
  font-size: .72rem !important;
  padding: 3px 7px !important;
}
.clip-details-compact {
  grid-area: details !important;
  border-top: 1px solid var(--line) !important;
  background: #fbfdff !important;
}
.clip-details-compact > summary {
  padding: 9px 12px !important;
  font-size: .78rem !important;
}
.clip-details-compact .clip-info {
  padding: 0 12px 12px !important;
  font-size: .76rem !important;
}
.clip-details-compact .clip-info dl {
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  gap: 7px 10px !important;
}
.clip-details-compact .clip-info dt { font-size: .58rem !important; }
.clip-details-compact .clip-info dd { font-size: .74rem !important; }
.clip-details-compact .clip-name { font-size: .72rem !important; }
.clip-details-compact .clip-actions { margin-top: 6px !important; }
.export-widget {
  width: 100% !important;
  max-width: none !important;
  grid-column: 1 / -1 !important;
}
.export-widget .clip-head {
  align-items: flex-start !important;
}
.export-widget .meta-grid,
.export-widget-meta {
  grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
}
.export-widget-actions,
.export-widget .actions {
  flex-direction: row !important;
  align-items: center !important;
  justify-content: flex-start !important;
}
.export-widget-actions .btn,
.export-widget .btn {
  width: auto !important;
}

@media (max-width: 1180px) {
  .playback-main { grid-template-columns: 1fr !important; }
  .clip-panel { max-height: 620px !important; }
  .clip-panel .clip-list .clip-item,
  .clip-panel .clip-list .clip-item.clip-item-compact {
    grid-template-columns: 180px minmax(0, 1fr) !important;
  }
  .clip-panel .clip-thumb,
  .clip-panel .clip-list .clip-thumb {
    width: 180px !important;
    height: 101px !important;
  }
  .export-widget .meta-grid,
  .export-widget-meta { grid-template-columns: repeat(2, minmax(0, 1fr)) !important; }
}
@media (max-width: 700px) {
  .clip-panel { max-height: 72vh !important; }
  .clip-panel .clip-list .clip-item,
  .clip-panel .clip-list .clip-item.clip-item-compact {
    grid-template-columns: 1fr !important;
    grid-template-areas:
      "thumb"
      "summary"
      "details" !important;
  }
  .clip-panel .clip-thumb,
  .clip-panel .clip-list .clip-thumb {
    width: 100% !important;
    height: auto !important;
    border-right: 0 !important;
    border-bottom: 1px solid var(--line) !important;
  }
  .clip-card-date-row { grid-template-columns: 1fr auto !important; }
  .export-widget .meta-grid,
  .export-widget-meta { grid-template-columns: 1fr !important; }
  .export-widget-actions,
  .export-widget .actions { flex-direction: column !important; align-items: stretch !important; }
  .export-widget-actions .btn,
  .export-widget .btn { width: 100% !important; }
}

/* Patch 1.0.8: Wiedergabe-Höhe und 2FA-Auswahl */
.playback-main {
  align-items: stretch !important;
}
.player-panel,
.clip-panel {
  height: 100% !important;
}
.clip-panel {
  max-height: none !important;
}
.clip-panel .clip-list {
  min-height: 0 !important;
  flex: 1 1 auto !important;
}
.compact-form {
  margin-top: 10px !important;
}
.twofa-register-method[hidden] {
  display: none !important;
}
.twofa-register-method {
  border: 1px solid var(--line) !important;
  background: #fbfdff !important;
  padding: 14px !important;
  margin: 10px 0 !important;
}
@media (min-width: 1181px) {
  .clip-panel .clip-list {
    max-height: none !important;
  }
}
@media (max-width: 1180px) {
  .player-panel,
  .clip-panel {
    height: auto !important;
  }
  .clip-panel {
    max-height: 620px !important;
  }
}


/* Patch 1.0.8: Player und Clip-Übersicht auf gleicher Containerhöhe */
.playback-main {
  align-items: stretch !important;
}
.playback-main > .player-panel,
.playback-main > .clip-panel {
  align-self: stretch !important;
}
.playback-main > .clip-panel {
  height: 100% !important;
  max-height: none !important;
}
.playback-main > .clip-panel .clip-list {
  flex: 1 1 auto !important;
  min-height: 0 !important;
}
@media (max-width: 1100px) {
  .playback-main > .clip-panel {
    height: auto !important;
    max-height: none !important;
  }
}

/* Patch 1.0.8: Clip-Übersicht an Playerhöhe koppeln */
@media (min-width: 981px) {
  .playback-main {
    align-items: stretch !important;
  }
  .clip-panel {
    min-height: 420px !important;
    max-height: none !important;
  }
  .clip-panel .clip-list {
    min-height: 0 !important;
    flex: 1 1 auto !important;
  }
}

/* Patch 1.0.9: Clip-Übersicht rechts begrenzen und intern scrollen. */
@media (min-width: 981px) {
  .playback-main {
    align-items: start !important;
  }
  .playback-main > .player-panel {
    align-self: start !important;
    height: auto !important;
  }
  .playback-main > .clip-panel {
    align-self: start !important;
    height: var(--clip-panel-synced-height, 640px) !important;
    max-height: var(--clip-panel-synced-height, 640px) !important;
    min-height: 0 !important;
    overflow: hidden !important;
    display: flex !important;
    flex-direction: column !important;
  }
  .playback-main > .clip-panel .clip-head,
  .playback-main > .clip-panel .pagination {
    flex: 0 0 auto !important;
  }
  .playback-main > .clip-panel .clip-list {
    flex: 1 1 auto !important;
    min-height: 0 !important;
    max-height: none !important;
    overflow-y: auto !important;
    overflow-x: hidden !important;
  }
}
@media (max-width: 980px) {
  .playback-main > .clip-panel {
    height: auto !important;
    max-height: none !important;
    overflow: visible !important;
  }
  .playback-main > .clip-panel .clip-list {
    max-height: 72vh !important;
    overflow-y: auto !important;
  }
}

/* Patch 1.0.13: Exportjobs Auto-Aktualisierung */
.export-jobs-card #exportJobsRefreshStatus {
  color: var(--muted);
  font-weight: 800;
}
.export-jobs-card #exportJobsRefreshStatus.is-error {
  color: var(--danger);
}
