/* ====== Shared ====== */
.vc-root { --vc-gap:20px; }

/* ====== Slider Layout ====== */
.video-slider {
  position: relative;
  width: 100%;
  overflow: hidden;
  margin-top: 30px;
}
.video-slide__wrapper {
  position: relative;
  width: 100%;
  aspect-ratio: 16 / 9;
  overflow: hidden;
  border-radius: 14px;
}
.video-slide__wrapper video {
  width: 100%; height: 100%;
  object-fit: contain;
  display: block;
  transition: filter 0.3s ease;
}

/* Swiper arrows */
.swiper-button-prev, .swiper-button-next {
  color: #000;
  width: 36px; height: 36px;
  background: #fff;
  border-radius: 50%;
  box-shadow: 0 2px 10px rgba(0,0,0,.15);
}
.swiper-button-prev::after, .swiper-button-next::after { font-size: 16px; }

/* ====== Grid Layout + Filters ====== */
.vc-root[data-mode="grid"] .video-slide { /* آیتم‌ها در گرید بلاک می‌شن */
  display: block;
}
.vc-filter {
  display: flex; flex-wrap: wrap; gap: 10px;
  margin-bottom: 34px;
  justify-content: center;
}
.vc-filter__btn {
  border: 1px solid #6b9dd6;
  background: #fff;
  color: #111;
  padding: 6px 12px;
  border-radius: 9999px;
  cursor: pointer;
  font-size: 16px;
  width: max-content;
  transition: background .2s ease, color .2s ease, transform .2s ease;
}
.vc-filter__btn.is-active { background: #6b9dd6; color: #fff; }

.vc-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: var(--vc-gap);
}
@media (max-width: 768px) {
  .vc-grid { grid-template-columns: 1fr; }
}

.vc-root[data-mode="grid"] .video-slide {
  overflow: hidden;
  position: relative;
  transform: scale(1);
  opacity: 1;
  transition: transform .35s ease, opacity .35s ease, filter .35s ease;
}
.vc-root[data-mode="grid"] .video-slide.is-dim {
  opacity: .35; filter: blur(1px);
}
.vc-root[data-mode="grid"] .video-slide.hidden {
  pointer-events: none;
  opacity: 0;
  transform: scale(.85);
}

/* عنوان اختیاری زیر ویدیو در گرید */
.video-slide__title {
  margin-top: 8px;
  font-size: 14px;
  color: #111;
}

/* در حالت گرید blur برای کناری‌ها نداریم؛ فقط اسلایدر */
@media (max-width: 1024px){
  .video-slider .swiper-slide { width: 50%; }
}
@media (max-width: 768px){
  .video-slider .swiper-slide { width: 100%; }
}

.single-video {
/*   max-width: 800px; */
  margin: 30px auto;
}

/* ====== Plyr integration (افزوده شده) ====== */
/* Plyr باید کل فضای کادر و نسبت تصویر رو پر کنه */
.video-slide__wrapper .plyr {
  width: 100%;
  height: 100%;
  border-radius: inherit; /* انحنای کادر روی Plyr هم اعمال شود */
}

/* ویدیوی داخل Plyr — مطابق استایل قبلی شما: contain */
.video-slide__wrapper .plyr video {
  width: 100%;
  height: 100%;
  object-fit: contain;
}

/* Wrapper داخلی Plyr هم فول‌سایز شود تا کنترل‌ها جای درست قرار گیرند */
.video-slide__wrapper .plyr__video-wrapper,
.video-slide__wrapper .plyr__poster {
  width: 100%;
  height: 100%;
}

/* اختیاری: کنترل‌ها کمی از لبه‌ها فاصله بگیرند (با انحنای شما هماهنگ) */
.video-slide__wrapper .plyr__controls {
  padding-left: 10px;
  padding-right: 10px;
}

/* اختیاری: هنگام هاور، ویدیو شارپ بماند (در صورت اعمال فیلترهای دیگر) */
.video-slide__wrapper .plyr:hover video {
  filter: none;
}

/* ====== Plyr Color Customization ====== */
:root {
  --plyr-color-main: #243b55; /* رنگ اصلی پلیر (جایگزین آبی پیش‌فرض) */
}

/* درصورت نیاز رنگ پس‌زمینه کنترل‌ها را نیز تنظیم کن */
.plyr--full-ui input[type=range] {
  accent-color: var(--plyr-color-main);
}

.plyr__control--overlaid {
  background: var(--plyr-color-main);
}

/* اگر حالت تیره داری، می‌توانی این را هم اضافه کنی */
.plyr--video.plyr--full-ui {
  --plyr-control-icon-color: #fff;         /* رنگ آیکن‌ها */
  --plyr-video-control-color-hover: #fff;  /* رنگ آیکن هنگام هاور */
}








/* ====== پوستر ویدیو به‌صورت cover ====== */
.video-slide__wrapper .plyr__poster {
  background-size: cover !important;   /* پوستر کل قاب رو پر کنه */
  background-position: center center !important;
  background-repeat: no-repeat !important;
}

/* ====== خود ویدیو به‌صورت contain ====== */
.video-slide__wrapper .plyr video {
  object-fit: contain !important;      /* نسبت ویدیو حفظ شود */
  width: 100%;
  height: 100%;
}

