/**
 * glulando — Member Video Player CSS v6
 * 06.03.2026: Light/Dark Mode CSS-Variablen, Video clamp(), Input nie abgeschnitten
 */

* { scrollbar-width: thin; scrollbar-color: rgba(128,128,128,.2) transparent; }
::-webkit-scrollbar        { width: 4px; }
::-webkit-scrollbar-track  { background: transparent; }
::-webkit-scrollbar-thumb  { background: rgba(128,128,128,.2); border-radius: 4px; }

/* ── PLAYER CSS-VARIABLEN ───────────────────────────── */
:root {
  --player-bg:           #f1f5f9;
  --player-sidebar-bg:   #ffffff;
  --player-sidebar-bdr:  rgba(0,0,0,.08);
  --player-agent-bg:     #f8fafc;
  --player-input-bg:     rgba(0,0,0,.04);
  --player-input-bdr:    rgba(0,0,0,.12);
  --player-text:         #1e293b;
  --player-text-muted:   rgba(0,0,0,.45);
  --player-msg-agent-bg: rgba(0,0,0,.05);
  --player-msg-agent-cl: #1e293b;
  --player-topbar-grad:  linear-gradient(rgba(0,0,0,.55), transparent);
  --player-input-row-bg: #ffffff;
  --player-input-row-bdr:rgba(0,0,0,.08);
  --player-item-color:   rgba(0,0,0,.45);
  --player-item-hover:   rgba(0,0,0,.06);
}
body.dark {
  --player-bg:           #0f0f0f;
  --player-sidebar-bg:   #141414;
  --player-sidebar-bdr:  rgba(255,255,255,.07);
  --player-agent-bg:     #141414;
  --player-input-bg:     rgba(255,255,255,.06);
  --player-input-bdr:    rgba(255,255,255,.1);
  --player-text:         #e8e8e8;
  --player-text-muted:   rgba(255,255,255,.35);
  --player-msg-agent-bg: rgba(255,255,255,.07);
  --player-msg-agent-cl: #e8e8e8;
  --player-topbar-grad:  linear-gradient(rgba(0,0,0,.65), transparent);
  --player-input-row-bg: #141414;
  --player-input-row-bdr:rgba(255,255,255,.07);
  --player-item-color:   rgba(255,255,255,.5);
  --player-item-hover:   rgba(255,255,255,.04);
}

body.gl-immersive { overflow: hidden; }

/* ── KURS-PLAYER LAYOUT ─────────────────────────────── */
.gl-player-layout {
  display: flex; height: 100dvh; overflow: hidden;
  background: var(--player-bg);
}

.gl-player-sidebar {
  width: 220px; min-width: 220px;
  background: var(--player-sidebar-bg);
  border-right: 1px solid var(--player-sidebar-bdr);
  overflow-y: auto; display: flex; flex-direction: column;
}
.gl-player-sidebar .sidebar-logo {
  padding: 16px; font-weight: 700; font-size: 14px;
  color: var(--accent, #e85d44);
  border-bottom: 1px solid var(--player-sidebar-bdr); line-height: 1.4;
}
.gl-sidebar-item {
  padding: 9px 16px; cursor: pointer; font-size: 13px;
  color: var(--player-item-color);
  display: flex; align-items: center; gap: 6px;
  transition: background .12s, color .12s;
  border-left: 2px solid transparent;
}
.gl-sidebar-item:hover { background: var(--player-item-hover); color: var(--player-text); }
.gl-sidebar-item.active {
  color: var(--accent, #e85d44); font-weight: 600;
  border-left-color: var(--accent, #e85d44);
  background: rgba(232,93,68,.07);
}
.gl-sidebar-item .dot {
  width: 6px; height: 6px; background: var(--accent, #e85d44);
  border-radius: 50%; flex-shrink: 0;
}
.gl-sidebar-footer {
  padding: 12px 16px; margin-top: auto;
  border-top: 1px solid var(--player-sidebar-bdr);
  font-size: 11px; color: var(--player-text-muted);
}
.gl-progress-bar {
  background: rgba(128,128,128,.15); height: 4px; border-radius: 2px;
  overflow: hidden; margin: 4px 0;
}
.gl-progress-fill {
  height: 100%; border-radius: 2px;
  background: var(--accent, #e85d44); transition: width .4s ease;
}

/* ── MAIN COLUMN ────────────────────────────────────── */
.gl-player-main {
  flex: 1; min-width: 0;
  display: flex; flex-direction: column;
  overflow: hidden;
  background: var(--player-bg);
}

/* ── VIDEO: clamp verhindert Abschneiden ────────────── */
.gl-video-wrap { position: relative; background: #000; flex-shrink: 0; }
.gl-video-wrap video,
.gl-video-wrap iframe {
  width: 100%;
  height: clamp(220px, 55vh, calc(100dvh - 180px));
  display: block; border: none; background: #000;
}
.gl-video-topbar {
  position: absolute; top: 0; left: 0; right: 0;
  display: flex; justify-content: space-between; align-items: center;
  padding: 10px 14px;
  background: var(--player-topbar-grad);
  pointer-events: none;
}
.gl-video-topbar > * { pointer-events: auto; }
.gl-video-topbar span { font-size: 13px; font-weight: 600; color: #fff; }
.gl-next-btn {
  background: rgba(255,255,255,.18); border: none; color: #fff;
  padding: 5px 12px; border-radius: 6px; cursor: pointer; font-size: 12px;
  font-weight: 500; transition: background .15s;
}
.gl-next-btn:hover { background: rgba(255,255,255,.28); }

.gl-subtitle-bar {
  background: rgba(0,0,0,.75); padding: 6px 16px; text-align: center;
  font-size: 13px; font-style: italic; color: rgba(255,255,255,.85);
  border-bottom: 1px solid var(--player-sidebar-bdr); flex-shrink: 0;
  display: none;
}
.gl-subtitle-bar:not(:empty) { display: block; }

/* ── AGENT BOX ──────────────────────────────────────── */
.gl-agent-box {
  flex: 1; min-height: 0;
  display: flex; flex-direction: column;
  overflow: hidden; background: var(--player-agent-bg);
}
.gl-messages {
  flex: 1; min-height: 0;
  overflow-y: auto;
  padding: 12px 16px;
  display: flex; flex-direction: column; gap: 10px;
}
.gl-msg {
  padding: 10px 14px; border-radius: 12px;
  font-size: 14px; line-height: 1.55; max-width: 88%;
}
.gl-msg-user {
  align-self: flex-end; background: var(--accent, #e85d44); color: #fff;
  border-radius: 12px 12px 4px 12px;
}
.gl-msg-agent {
  align-self: flex-start;
  background: var(--player-msg-agent-bg);
  color: var(--player-msg-agent-cl);
  border-radius: 4px 12px 12px 12px;
}
.gl-action-row { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 8px; }
.gl-action-btn {
  background: rgba(128,128,128,.12); border: 1px solid rgba(128,128,128,.2);
  color: var(--player-text); padding: 5px 12px; border-radius: 8px;
  cursor: pointer; font-size: 12px; transition: background .15s;
}
.gl-action-btn:hover { background: rgba(128,128,128,.2); }

/* ── INPUT ROW — nie abgeschnitten ──────────────────── */
.gl-input-row {
  flex-shrink: 0;
  display: flex; gap: 8px; padding: 10px 12px;
  padding-bottom: calc(10px + env(safe-area-inset-bottom, 0px));
  border-top: 1px solid var(--player-input-row-bdr);
  background: var(--player-input-row-bg);
}
.gl-input-row input {
  flex: 1; background: var(--player-input-bg);
  border: 1px solid var(--player-input-bdr); border-radius: 8px;
  padding: 9px 12px; color: var(--player-text); font-size: 14px;
  font-family: inherit; outline: none;
}
.gl-input-row input::placeholder { color: var(--player-text-muted); }
.gl-input-row input:focus { border-color: var(--accent, #e85d44); }
.gl-send-btn {
  background: var(--accent, #e85d44); border: none; color: #fff;
  padding: 9px 18px; border-radius: 8px; cursor: pointer;
  font-size: 14px; font-weight: 600; font-family: inherit; transition: opacity .15s;
}
.gl-send-btn:hover { opacity: .85; }
.gl-mic-btn {
  background: var(--player-input-bg); border: 1px solid var(--player-input-bdr);
  color: var(--player-text-muted); padding: 9px 11px; border-radius: 8px;
  cursor: pointer; font-size: 16px; transition: background .15s;
}
.gl-mic-btn:hover { background: rgba(128,128,128,.14); }
.gl-mic-btn.recording { background: rgba(239,68,68,.2); color: #ef4444; animation: micPulse 1s infinite; }
@keyframes micPulse { 0%,100%{opacity:1} 50%{opacity:.5} }
.gl-seek-btn {
  display: block; margin-top: 8px; background: rgba(128,128,128,.12);
  border: 1px solid rgba(128,128,128,.2); color: var(--player-text);
  padding: 5px 10px; border-radius: 6px; cursor: pointer; font-size: 12px;
}

/* ── WEBINAR LAYOUT ─────────────────────────────────── */
.gl-webinar-layout { display: flex; flex-direction: column; height: 100dvh; overflow: hidden; background: var(--player-bg); }
.gl-webinar-header {
  display: flex; align-items: center; gap: 12px; padding: 9px 16px;
  background: var(--player-sidebar-bg); border-bottom: 1px solid var(--player-sidebar-bdr); flex-shrink: 0;
}
.gl-live-badge { background: #ef4444; color: #fff; font-size: 11px; font-weight: 700; padding: 3px 8px; border-radius: 4px; animation: livePulse 2s infinite; }
@keyframes livePulse { 0%,100%{opacity:1} 50%{opacity:.65} }
.gl-viewer-count { font-size: 13px; color: var(--player-text-muted); }
.gl-webinar-body { flex: 1; min-height: 0; display: flex; overflow: hidden; }
.gl-webinar-video-col { flex: 1; min-width: 0; display: flex; flex-direction: column; overflow: hidden; }
.gl-webinar-video-col .gl-video-wrap video,
.gl-webinar-video-col .gl-video-wrap iframe { height: clamp(180px, 45vh, calc(100dvh - 220px)); }
.gl-viewers-sidebar {
  width: 130px; min-width: 130px; background: var(--player-sidebar-bg);
  border-left: 1px solid var(--player-sidebar-bdr); overflow: hidden;
}
.gl-viewers-sidebar .viewers-title { padding: 10px 10px 6px; font-size: 11px; color: var(--player-text-muted); text-transform: uppercase; letter-spacing: .6px; }
.gl-viewers-sidebar .viewers-list { opacity: .35; filter: blur(.6px); pointer-events: none; font-size: 11px; padding: 0 8px 8px; display: flex; flex-direction: column; gap: 8px; }
.viewer-msg { color: var(--player-text); line-height: 1.4; }
.viewer-name { color: #f2cc8f; font-weight: 600; }

/* ── CTA ZONE ───────────────────────────────────────── */
.gl-cta-zone { display: none; padding: 12px 16px; background: var(--player-sidebar-bg); border-top: 1px solid var(--player-sidebar-bdr); align-items: center; gap: 16px; flex-wrap: wrap; flex-shrink: 0; }
.gl-cta-zone.visible { display: flex; animation: glSlideUp .4s ease; }
@keyframes glSlideUp { from{transform:translateY(14px);opacity:0} to{transform:translateY(0);opacity:1} }
.gl-cta-btn { display: inline-block; text-decoration: none; background: linear-gradient(135deg,#e85d44,#c1553d); color: #fff; border: none; cursor: pointer; padding: 11px 26px; border-radius: 10px; font-size: 15px; font-weight: 600; transition: opacity .15s; }
.gl-cta-btn:hover { opacity: .88; }
.gl-countdown-wrap { display: flex; flex-direction: column; gap: 2px; }
.gl-countdown-label { font-size: 11px; color: var(--player-text-muted); }
.gl-countdown-timer { font-family: monospace; font-size: 18px; color: #f97316; font-weight: 700; }
.gl-scarcity { font-size: 12px; color: #ef4444; background: rgba(239,68,68,.1); border: 1px solid rgba(239,68,68,.25); padding: 5px 10px; border-radius: 6px; display: none; }
.gl-scarcity.visible { display: block; }
.seat-bar-wrap { width: 72px; height: 5px; background: rgba(128,128,128,.15); border-radius: 3px; overflow: hidden; }
.seat-bar { height: 100%; background: linear-gradient(90deg,#ef4444,#f97316); border-radius: 3px; transition: width .8s ease; }
.seat-number { font-size: 13px; color: var(--player-text); font-weight: 600; margin-left: 6px; }
.gl-expired-overlay { position: fixed; inset: 0; z-index: 200; background: rgba(0,0,0,.88); backdrop-filter: blur(10px); display: none; flex-direction: column; align-items: center; justify-content: center; gap: 16px; text-align: center; padding: 24px; color: #fff; }
.gl-expired-overlay.visible { display: flex; }
.gl-expired-overlay h2 { font-size: 22px; margin: 0; }
.gl-expired-overlay p  { font-size: 14px; color: rgba(255,255,255,.6); margin: 0; }

/* ── MOBILE ─────────────────────────────────────────── */
@media (max-width: 640px) {
  .gl-player-sidebar { display: none; }
  .gl-video-wrap video, .gl-video-wrap iframe { height: clamp(180px, 40vw, 260px); }
  .gl-webinar-video-col .gl-video-wrap video,
  .gl-webinar-video-col .gl-video-wrap iframe { height: clamp(160px, 38vw, 240px); }
  .gl-viewers-sidebar { display: none; }
  .gl-cta-zone { flex-direction: column; align-items: stretch; }
}
