/* Video Stories v2.1 — assets/video-stories.css */
@import url('https://fonts.googleapis.com/css2?family=Heebo:wght@300;400;600;700;800&display=swap');

:root {
  --vs-accent:  #7b2d8b;
  --vs-accent2: #c084d4;
  --vs-gold:    #c9a96e;
  --vs-dark:    #1a1018;
  --vs-font:    'Heebo', system-ui, sans-serif;
  --vs-card-w:  210px;
  --vs-card-h:  360px;
  --vs-radius:  18px;
  --vs-gap:     14px;
  --vs-ease:    cubic-bezier(.4,0,.2,1);
}

/* ── Wrapper ── */
.vs-wrap { font-family:var(--vs-font); padding:24px 0 32px; position:relative; }
.vs-header { text-align:center; margin-bottom:22px; }
.vs-title { font-size:clamp(22px,4vw,36px); font-weight:800; margin:0 0 6px; color:var(--vs-dark); letter-spacing:-.01em; }
.vs-subtitle { color:#999; font-size:14px; font-weight:300; margin:0; }

/* ── Track ── */
.vs-track-outer { position:relative; }
.vs-track {
  display:flex; gap:var(--vs-gap);
  overflow-x:auto; scroll-snap-type:x mandatory;
  -webkit-overflow-scrolling:touch;
  padding:14px 24px 18px; scrollbar-width:none;
}
.vs-track::-webkit-scrollbar { display:none }

/* ── Card ── */
.vs-card {
  flex:0 0 var(--vs-card-w); height:var(--vs-card-h);
  scroll-snap-align:start; border-radius:var(--vs-radius);
  overflow:hidden; position:relative; cursor:pointer;
  background:#111; box-shadow:0 6px 28px rgba(0,0,0,.18);
  transition:transform .22s var(--vs-ease), box-shadow .22s var(--vs-ease);
  will-change:transform;
}
.vs-card:hover { transform:translateY(-6px) scale(1.025); box-shadow:0 18px 48px rgba(0,0,0,.28); }
.vs-card:focus-visible { outline:3px solid var(--vs-accent); outline-offset:2px; }

.vs-card-vid, .vs-card-img {
  position:absolute; inset:0; width:100%; height:100%;
  object-fit:cover; display:block;
}
.vs-card-overlay {
  position:absolute; inset:0;
  background:linear-gradient(to bottom,transparent 40%,rgba(0,0,0,.65) 100%);
  pointer-events:none;
}
.vs-badge {
  position:absolute; top:12px; left:12px;
  background:linear-gradient(135deg,var(--vs-accent),var(--vs-accent2));
  color:#fff; font-size:10px; font-weight:700;
  padding:3px 10px; border-radius:20px; letter-spacing:.04em;
  white-space:nowrap; pointer-events:none;
  box-shadow:0 2px 8px rgba(123,45,139,.4);
}
.vs-card-bottom {
  position:absolute; bottom:0; left:0; right:0;
  padding:10px 12px; display:flex;
  align-items:flex-end; justify-content:space-between; gap:8px;
}
.vs-card-name {
  color:#fff; font-size:12px; font-weight:700;
  text-shadow:0 1px 4px rgba(0,0,0,.6);
  flex:1; min-width:0; overflow:hidden; text-overflow:ellipsis; white-space:nowrap;
}
.vs-card-controls { display:flex; gap:6px; align-items:center; flex-shrink:0; }

.vs-snd-btn, .vs-open-btn {
  width:30px; height:30px; border-radius:50%; border:none;
  background:rgba(255,255,255,.2); color:#fff;
  display:flex; align-items:center; justify-content:center;
  cursor:pointer; backdrop-filter:blur(6px); -webkit-backdrop-filter:blur(6px);
  transition:background .18s, transform .18s; padding:0; flex-shrink:0;
}
.vs-snd-btn svg, .vs-open-btn svg { width:13px; height:13px; display:block; }
.vs-snd-btn:hover, .vs-open-btn:hover { background:rgba(123,45,139,.75); transform:scale(1.12); }

/* ── Scroll arrows ── */
.vs-arr {
  position:absolute; top:50%; transform:translateY(-60%);
  width:38px; height:38px; border-radius:50%; border:none;
  background:rgba(255,255,255,.95); color:var(--vs-dark);
  box-shadow:0 4px 14px rgba(0,0,0,.14); display:flex;
  align-items:center; justify-content:center; cursor:pointer;
  z-index:5; transition:box-shadow .18s, transform .18s; opacity:.9;
}
.vs-arr:hover { opacity:1; box-shadow:0 8px 22px rgba(0,0,0,.2); transform:translateY(-60%) scale(1.08); }
.vs-arr svg { width:16px; height:16px; }
.vs-arr-l { left:4px; } .vs-arr-r { right:4px; }
.vs-arr.hidden { opacity:0; pointer-events:none; }

/* ══════════════════════════════════════════
   MODAL
   dir="ltr" on #vsm ensures sound=LEFT, close=RIGHT
   even on RTL Hebrew themes
══════════════════════════════════════════ */
.vsm {
  position:fixed; inset:0; z-index:999999;
  display:flex; align-items:center; justify-content:center;
  opacity:0; pointer-events:none;
  transition:opacity .28s var(--vs-ease);
}
.vsm.open { opacity:1; pointer-events:all; }

/* Semi-transparent backdrop — page visible behind */
.vsm-backdrop {
  position:absolute; inset:0;
  background:rgba(0,0,0,.72);
  backdrop-filter:blur(10px); -webkit-backdrop-filter:blur(10px);
}

.vsm-layout {
  position:relative; z-index:2;
  display:flex; align-items:center; justify-content:center;
  gap:16px; padding:16px;
  /* direction:ltr inherited from dir="ltr" on #vsm */
}

/* Video card */
.vsm-card {
  position:relative;
  width:min(380px, 82vw);
  height:min(680px, 88vh);
  border-radius:22px; overflow:hidden;
  background:#000;
  box-shadow:0 32px 80px rgba(0,0,0,.6), 0 0 0 1px rgba(255,255,255,.06);
  flex-shrink:0;
}
#vsm-vid, #vsm-ifr { width:100%; height:100%; object-fit:cover; display:block; }

.vsm-gradient {
  position:absolute; inset:0;
  background:linear-gradient(to bottom,rgba(0,0,0,.4) 0%,transparent 28%,transparent 52%,rgba(0,0,0,.72) 100%);
  pointer-events:none;
}

/* ── Top bar: 🔊 LEFT | ✕ RIGHT ──
   dir="ltr" on parent ensures this visual order */
.vsm-top {
  position:absolute; top:0; left:0; right:0; z-index:10;
  display:flex; align-items:center; justify-content:space-between;
  padding:14px 14px 0;
  direction:ltr; /* explicit — immune to page RTL context */
}
.vsm-icon-btn {
  width:38px; height:38px; border-radius:50%; border:none;
  background:rgba(255,255,255,.16); color:#fff;
  display:flex; align-items:center; justify-content:center;
  cursor:pointer; backdrop-filter:blur(8px); -webkit-backdrop-filter:blur(8px);
  transition:background .18s, transform .15s; padding:0;
}
.vsm-icon-btn svg { width:16px; height:16px; display:block; }
.vsm-icon-btn:hover { background:rgba(255,255,255,.3); transform:scale(1.1); }

/* ── Bottom: reviewer + product ── */
.vsm-bottom {
  position:absolute; bottom:0; left:0; right:0; z-index:10;
  padding:12px 14px 18px;
}
.vsm-reviewer {
  color:#fff; font-size:14px; font-weight:700;
  text-shadow:0 1px 6px rgba(0,0,0,.5);
  margin-bottom:10px;
  /* RTL text — reverse direction just for this text */
  direction:rtl; text-align:right;
}

/* ── Product CTA card ── */
.vsm-product {
  display:flex; align-items:center; gap:10px;
  background:rgba(255,255,255,.96); border-radius:14px;
  padding:8px 10px 8px 8px;
  backdrop-filter:blur(8px); -webkit-backdrop-filter:blur(8px);
  box-shadow:0 4px 20px rgba(0,0,0,.25);
  direction:ltr; /* keep layout LTR for consistent image+info+btn order */
}
.vsm-product.hidden { display:none; }

.vsm-product-img {
  width:54px; height:54px; object-fit:cover;
  border-radius:9px; flex-shrink:0; background:#eee;
}
.vsm-product-info {
  flex:1; min-width:0;
  direction:rtl; /* Hebrew text right-to-left */
}
.vsm-product-name {
  font-size:12px; font-weight:700; color:#111;
  line-height:1.3; white-space:nowrap;
  overflow:hidden; text-overflow:ellipsis;
}
.vsm-product-price {
  font-size:12px; color:var(--vs-accent); font-weight:700; margin-top:2px;
}

/* CTA button — shows label text + arrow */
.vsm-product-btn {
  display:inline-flex; align-items:center; gap:5px; flex-shrink:0;
  background:linear-gradient(135deg,var(--vs-accent),#9b3dab);
  color:#fff; text-decoration:none;
  font-family:var(--vs-font); font-weight:700; font-size:12px;
  padding:8px 14px 8px 10px; border-radius:50px; white-space:nowrap;
  box-shadow:0 4px 14px rgba(123,45,139,.45);
  transition:transform .18s, box-shadow .18s;
  direction:rtl; /* Hebrew label reads right-to-left */
}
.vsm-product-btn:hover { transform:scale(1.05); box-shadow:0 8px 20px rgba(123,45,139,.6); color:#fff; }
.vsm-product-btn svg { width:14px; height:14px; flex-shrink:0; }
.vsm-product-label { white-space:nowrap; }

button.vs-open-btn,button.vs-snd-btn,button#vsm-next,button#vsm-prev,button#vsm-close,button#vsm-snd,button.vs-arr.vs-arr-r,button.vs-arr.vs-arr-l {
    padding: 0px;
}
/* Nav arrows */
.vsm-nav {
  width:44px; height:44px; border-radius:50%; border:none;
  background:rgba(255,255,255,.18); color:#fff;
  display:flex; align-items:center; justify-content:center;
  cursor:pointer; backdrop-filter:blur(8px); -webkit-backdrop-filter:blur(8px);
  transition:background .18s, transform .18s; flex-shrink:0;
}
.vsm-nav svg { width:20px; height:20px; }
.vsm-nav:hover { background:rgba(255,255,255,.3); transform:scale(1.08); }

/* ── Mobile — NOT fullscreen ── */
@media (max-width:600px) {
  :root { --vs-card-w:165px; --vs-card-h:290px; }
  .vsm-layout { gap:8px; padding:12px; }
  .vsm-card { width:min(340px,86vw); height:min(600px,85svh); border-radius:18px; }
  .vsm-nav { width:36px; height:36px; }
  .vsm-nav svg { width:16px; height:16px; }
  .vsm-product-img { width:46px; height:46px; }
  .vsm-product-btn { font-size:11px; padding:7px 10px 7px 8px; }
}
@media (max-width:400px) {
  .vsm-nav { display:none; }
  .vsm-card { width:92vw; height:82svh; }
}
@media (max-width: 600px) {
  .vsm-layout { gap: 0; }

  .vsm-nav {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    z-index: 20;
    background: rgba(255,255,255,.2);
  }

  .vsm-nav-l { left: 8px; }
  .vsm-nav-r { right: 8px; }

  .vsm-card { position: relative; }
}
/* ══════════════════════════════════════════
   STICKY MINI PLAYER — video only, clean
══════════════════════════════════════════ */
.vs-sticky {
  position: fixed;
  bottom: 20px;
  left: 20px;
  z-index: 99998;
  width: min(120px, 25vw);
  border-radius: 14px;
  overflow: hidden;
  background: #000;
  box-shadow: 0 8px 28px rgba(0,0,0,.45);
  cursor: pointer;
  opacity: 0;
  transform: translateY(16px);
  pointer-events: none;
  transition: opacity .28s ease, transform .28s ease;
}
.vs-sticky.visible {
  opacity: 1;
  transform: translateY(0);
  pointer-events: all;
}

/* Thumbnail — 9:16 ratio */
.vs-sticky-thumb {
  width: 100%;
  aspect-ratio: 9 / 16;
  overflow: hidden;
  position: relative;
  background: #111;
}
.vs-sticky-thumb video,
.vs-sticky-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

/* Close button */
.vs-sticky-close {
  position: absolute;
  top: 6px;
  right: 6px;
  width: 22px;
  height: 22px;
  border-radius: 50%;
  border: none;
  background: rgba(0,0,0,.6);
  color: #fff;
  font-size: 12px;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  line-height: 1;
  z-index: 2;
  transition: background .15s;
  backdrop-filter: blur(4px);
}
.vs-sticky-close:hover { background: rgba(123,45,139,.85); }

/* RTL sites */
[dir="rtl"] .vs-sticky {
  left: auto;
  right: 20px;
}