/* ============================================================
   Kwata Video Player — Frontend Styles  v1.3
   ============================================================ */

:root {
  --svp-primary: #e63946;
  --svp-accent:  #ffffff;
  --svp-bg:      #0d0d0d;
  --svp-radius:  8px;
  --svp-font:    -apple-system, 'Segoe UI', Arial, sans-serif;
  --svp-pip-w:   340px;
  --svp-pip-h:   191px;
}

/* ── Wrapper ─────────────────────────────────────────────── */
.svp-wrapper {
  position: relative !important;
  display: block !important;
  width: 100% !important;
  aspect-ratio: 16 / 9 !important;
  background: #0d0d0d !important;
  border-radius: var(--svp-radius) !important;
  overflow: hidden !important;
  font-family: var(--svp-font) !important;
  user-select: none !important;
  -webkit-user-select: none !important;
  box-sizing: border-box !important;
  isolation: isolate !important;
}
/* Vertical video — capped height so it doesn't flood the feed */
.svp-wrapper.svp-vertical {
  aspect-ratio: 9 / 16 !important;
  max-height: 420px !important;   /* cap so it doesn't fill the whole screen */
  width: auto !important;          /* let width shrink to maintain ratio */
  margin: 0 auto !important;       /* centre it in the card */
}
.svp-wrapper *, .svp-wrapper *::before, .svp-wrapper *::after {
  box-sizing: border-box !important;
  font-family: var(--svp-font) !important;
  -webkit-tap-highlight-color: transparent !important;
}

/* ── Video element ───────────────────────────────────────── */
.svp-wrapper video.svp-video {
  display: block !important;
  width: 100% !important;
  height: 100% !important;
  object-fit: contain !important;
  background: #000 !important;
  pointer-events: none !important;
  border: none !important;
  outline: none !important;
}

/* ── Poster overlay ──────────────────────────────────────── */
/* NOTE: display uses a toggled class, NOT !important, so JS can hide it */
.svp-wrapper .svp-poster {
  position: absolute !important;
  inset: 0 !important;
  z-index: 2 !important;
  background-color: #111 !important;
  background-size: cover !important;
  background-position: center !important;
  cursor: pointer !important;
  display: flex;          /* NO !important — JS needs to override this */
  align-items: center !important;
  justify-content: center !important;
  border: none !important;
  margin: 0 !important;
  padding: 0 !important;
}
/* Hidden state — controlled by JS toggling this class */
.svp-wrapper .svp-poster.svp-poster--hidden {
  display: none !important;
}
.svp-wrapper .svp-poster::after {
  content: '' !important;
  width: 64px !important;
  height: 64px !important;
  flex-shrink: 0 !important;
  border-radius: 50% !important;
  background-color: rgba(0,0,0,.55) !important;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpolygon points='5,3 19,12 5,21' fill='white'/%3E%3C/svg%3E") !important;
  background-repeat: no-repeat !important;
  background-position: 56% 50% !important;
  background-size: 38% !important;
  border: 2.5px solid rgba(255,255,255,.9) !important;
  transition: transform .15s ease, box-shadow .15s ease !important;
  display: block !important;
}
.svp-wrapper .svp-poster:hover::after {
  transform: scale(1.1) !important;
  box-shadow: 0 0 0 10px rgba(255,255,255,.12) !important;
}

/* ── Logo ────────────────────────────────────────────────── */
.svp-wrapper .svp-logo {
  position: absolute !important;
  top: 10px !important; right: 12px !important;
  max-height: 26px !important; max-width: 80px !important;
  object-fit: contain !important;
  opacity: .6 !important; z-index: 5 !important;
  pointer-events: none !important; display: block !important;
}

/* ── Views badge ─────────────────────────────────────────── */
.svp-wrapper .svp-views-badge {
  position: absolute !important;
  top: 10px !important; left: 12px !important;
  z-index: 5 !important;
  background: rgba(0,0,0,.65) !important;
  color: #fff !important;
  font-size: 11px !important; font-weight: 600 !important;
  line-height: 1.4 !important;
  padding: 3px 9px !important; border-radius: 20px !important;
  pointer-events: none !important;
  display: none !important;
  border: none !important; margin: 0 !important;
}
.svp-wrapper .svp-views-badge.has-views { display: block !important; }

/* ── Spinner ─────────────────────────────────────────────── */
.svp-wrapper .svp-spinner {
  position: absolute !important; inset: 0 !important;
  display: none !important;
  align-items: center !important; justify-content: center !important;
  z-index: 6 !important; pointer-events: none !important;
  background: none !important;
}
.svp-wrapper .svp-spinner.active { display: flex !important; }
.svp-wrapper .svp-spinner svg { width: 48px !important; height: 48px !important; animation: svp-spin 1s linear infinite !important; }
@keyframes svp-spin { to { transform: rotate(360deg); } }

/* ── Ad overlay ──────────────────────────────────────────── */
.svp-wrapper .svp-ad-overlay {
  position: absolute !important; inset: 0 !important;
  z-index: 20 !important; background: #000 !important;
  display: none !important; flex-direction: column !important;
}
.svp-wrapper .svp-ad-overlay.active { display: flex !important; }
.svp-wrapper .svp-ad-overlay video {
  width: 100% !important; height: 100% !important;
  object-fit: contain !important; pointer-events: none !important;
}
.svp-wrapper .svp-ad-badge {
  position: absolute !important; top: 10px !important; left: 12px !important;
  background: rgba(0,0,0,.75) !important; color: #facc15 !important;
  font-size: 11px !important; font-weight: 700 !important;
  padding: 3px 8px !important; border-radius: 4px !important;
  letter-spacing: .5px !important; pointer-events: none !important;
  border: none !important; margin: 0 !important; z-index: 25 !important;
}
.svp-wrapper .svp-ad-click-layer {
  position: absolute !important; inset: 0 !important;
  cursor: pointer !important; z-index: 21 !important;
  background: transparent !important;
}

/* Skip button — always on top of click layer */
.svp-wrapper .svp-skip-btn {
  position: absolute !important;
  bottom: 56px !important; right: 12px !important;
  background: rgba(0,0,0,.85) !important;
  color: #fff !important;
  border: 1.5px solid rgba(255,255,255,.6) !important;
  border-radius: 4px !important;
  padding: 7px 16px !important;
  font-size: 13px !important; font-weight: 600 !important;
  cursor: pointer !important;
  z-index: 26 !important;   /* above click layer (21) and badge (25) */
  display: none !important; /* hidden until JS adds .svp-visible */
  line-height: 1.4 !important;
  pointer-events: auto !important;
}
.svp-wrapper .svp-skip-btn.svp-visible { display: block !important; }
.svp-wrapper .svp-skip-btn:hover,
.svp-wrapper .svp-skip-btn:focus,
.svp-wrapper .svp-skip-btn:active {
  background: rgba(0,0,0,.85) !important;
  color: #fff !important; outline: none !important;
}

/* Ad countdown — always on top */
.svp-wrapper .svp-ad-countdown {
  position: absolute !important;
  bottom: 56px !important; right: 12px !important;
  background: rgba(0,0,0,.75) !important; color: #fff !important;
  font-size: 12px !important;
  padding: 7px 12px !important; border-radius: 4px !important;
  z-index: 26 !important;
  display: none !important;  /* hidden until JS adds .svp-visible */
  border: none !important; pointer-events: none !important;
}
.svp-wrapper .svp-ad-countdown.svp-visible { display: block !important; }

/* ── Controls bar ────────────────────────────────────────── */
.svp-wrapper .svp-controls {
  position: absolute !important;
  bottom: 0 !important; left: 0 !important; right: 0 !important;
  z-index: 10 !important;
  background: linear-gradient(transparent, rgba(0,0,0,.90)) !important;
  padding: 28px 10px 8px !important;
  opacity: 1 !important;
  transform: translateY(0) !important;
  transition: opacity .2s, transform .2s !important;
  color: #fff !important;
  border: none !important; margin: 0 !important;
}

@media (hover: hover) {
  .svp-wrapper.svp-playing .svp-controls {
    opacity: 0 !important; transform: translateY(4px) !important;
  }
  .svp-wrapper.svp-playing:hover .svp-controls {
    opacity: 1 !important; transform: translateY(0) !important;
  }
}
.svp-wrapper.svp-paused .svp-controls,
.svp-wrapper.svp-pip    .svp-controls {
  opacity: 1 !important; transform: translateY(0) !important;
}

/* Progress rail */
.svp-wrapper .svp-progress-rail {
  width: 100% !important; height: 4px !important;
  background: rgba(255,255,255,.25) !important;
  border-radius: 2px !important; cursor: pointer !important;
  position: relative !important; margin-bottom: 8px !important;
  transition: height .12s !important; border: none !important;
}
.svp-wrapper .svp-progress-rail:hover { height: 7px !important; }
.svp-wrapper .svp-progress-fill {
  height: 100% !important; border-radius: 2px !important;
  background: var(--svp-primary) !important;
  pointer-events: none !important;
  transition: width .1s linear !important;
  position: absolute !important; top: 0 !important; left: 0 !important;
}
.svp-wrapper .svp-progress-thumb {
  position: absolute !important; top: 50% !important;
  width: 13px !important; height: 13px !important;
  border-radius: 50% !important; background: #fff !important;
  transform: translate(-50%,-50%) scale(0) !important;
  transition: transform .12s !important;
  pointer-events: none !important;
  border: none !important; margin: 0 !important; padding: 0 !important;
}
.svp-wrapper .svp-progress-rail:hover .svp-progress-thumb {
  transform: translate(-50%,-50%) scale(1) !important;
}

/* Control row */
.svp-wrapper .svp-ctrl-row {
  display: flex !important; align-items: center !important;
  gap: 8px !important; color: #fff !important;
  background: none !important; border: none !important;
  margin: 0 !important; padding: 0 !important;
}

/* ALL control buttons — white, no bg, no hover bg */
.svp-wrapper .svp-controls button,
.svp-wrapper .svp-controls .svp-btn {
  display: flex !important; align-items: center !important; justify-content: center !important;
  background: transparent !important; background-color: transparent !important;
  border: none !important; outline: none !important;
  box-shadow: none !important; color: #fff !important; fill: #fff !important;
  cursor: pointer !important; padding: 4px !important; margin: 0 !important;
  opacity: .92 !important; flex-shrink: 0 !important; line-height: 1 !important;
  border-radius: 0 !important; text-decoration: none !important;
  transition: opacity .1s, transform .1s !important;
}
.svp-wrapper .svp-controls button:hover,
.svp-wrapper .svp-controls button:focus,
.svp-wrapper .svp-controls button:active,
.svp-wrapper .svp-controls .svp-btn:hover,
.svp-wrapper .svp-controls .svp-btn:focus,
.svp-wrapper .svp-controls .svp-btn:active {
  background: transparent !important; background-color: transparent !important;
  border: none !important; outline: none !important;
  box-shadow: none !important; color: #fff !important; fill: #fff !important;
  opacity: 1 !important; transform: scale(1.12) !important;
  text-decoration: none !important;
}
.svp-wrapper .svp-controls button svg,
.svp-wrapper .svp-controls .svp-btn svg {
  display: block !important; width: 20px !important; height: 20px !important;
  color: #fff !important; fill: currentColor !important; stroke: currentColor !important;
  flex-shrink: 0 !important;
}

/* Time */
.svp-wrapper .svp-time {
  font-size: 12px !important; font-weight: 600 !important;
  white-space: nowrap !important; flex-shrink: 0 !important;
  color: #fff !important; background: none !important;
  border: none !important; padding: 0 !important; margin: 0 !important;
}

/* Volume */
.svp-wrapper .svp-volume-wrap {
  display: flex !important; align-items: center !important;
  gap: 4px !important; background: none !important;
}
.svp-wrapper .svp-volume-rail {
  width: 68px !important; height: 4px !important;
  background: rgba(255,255,255,.28) !important;
  border-radius: 2px !important; cursor: pointer !important;
  position: relative !important; flex-shrink: 0 !important; border: none !important;
}
.svp-wrapper .svp-volume-fill {
  height: 100% !important; border-radius: 2px !important;
  background: #fff !important; pointer-events: none !important;
  position: absolute !important; top: 0 !important; left: 0 !important;
}
.svp-wrapper .svp-spacer { flex: 1 !important; }

/* ── Centre flash ────────────────────────────────────────── */
.svp-wrapper .svp-flash {
  position: absolute !important; inset: 0 !important;
  display: flex !important; align-items: center !important; justify-content: center !important;
  pointer-events: none !important; z-index: 8 !important; background: none !important;
}
.svp-wrapper .svp-flash-icon {
  width: 70px !important; height: 70px !important;
  border-radius: 50% !important; background: rgba(0,0,0,.52) !important;
  display: flex !important; align-items: center !important; justify-content: center !important;
  opacity: 0 !important; transform: scale(.6) !important;
  color: #fff !important; font-size: 24px !important; border: none !important;
}
.svp-wrapper .svp-flash-icon.pop { animation: svp-pop .55s ease forwards !important; }
@keyframes svp-pop {
  0%   { opacity:.9; transform:scale(.8);  }
  60%  { opacity:.7; transform:scale(1.1); }
  100% { opacity:0;  transform:scale(1.3); }
}

/* ── PIP bar ─────────────────────────────────────────────── */
.svp-wrapper .svp-pip-bar {
  display: none !important;
  position: absolute !important; top: 0 !important; left: 0 !important; right: 0 !important;
  background: rgba(0,0,0,.78) !important;
  padding: 4px 10px !important;
  align-items: center !important; justify-content: space-between !important;
  z-index: 30 !important; border: none !important; margin: 0 !important;
}
.svp-wrapper.svp-pip .svp-pip-bar { display: flex !important; }
.svp-wrapper .svp-pip-bar span { color: #fff !important; font-size: 11px !important; background: none !important; }
.svp-wrapper .svp-pip-close {
  background: transparent !important; background-color: transparent !important;
  border: none !important; outline: none !important;
  color: #fff !important; cursor: pointer !important;
  font-size: 16px !important; line-height: 1 !important;
  padding: 0 4px !important; margin: 0 !important;
}
.svp-wrapper .svp-pip-close:hover,
.svp-wrapper .svp-pip-close:focus {
  background: transparent !important; color: var(--svp-primary) !important; outline: none !important;
}

/* ── PIP sticky mode — NO transition (prevents shake) ───── */
.svp-wrapper.svp-pip {
  position: fixed !important;
  bottom: 20px !important; right: 20px !important;
  width: var(--svp-pip-w) !important;
  height: var(--svp-pip-h) !important;
  aspect-ratio: unset !important;
  z-index: 99999 !important;
  border-radius: 10px !important;
  box-shadow: 0 8px 40px rgba(0,0,0,.72) !important;
  cursor: move !important;
}

/* ── Fullscreen ──────────────────────────────────────────── */
.svp-wrapper:-webkit-full-screen { width:100vw !important; height:100vh !important; border-radius:0 !important; aspect-ratio:unset !important; }
.svp-wrapper:fullscreen           { width:100vw !important; height:100vh !important; border-radius:0 !important; aspect-ratio:unset !important; }

/* ── Hide WP default player remnants ────────────────────── */
.wp-video, .wp-video-shortcode, .mejs-container,
.mejs-overlay, .wp-video-shortcode video { display: none !important; }

/* ── Responsive ──────────────────────────────────────────── */
@media (max-width: 600px) {
  :root { --svp-pip-w: 240px; --svp-pip-h: 135px; }
  .svp-wrapper .svp-volume-rail { width: 48px !important; }
  .svp-wrapper .svp-time { font-size: 11px !important; }
}
