/* ==========================================================================
   Aberhol YouTube Slider — дизайн-токени (CSS-змінні)
   ========================================================================== */
:root {
  /* Відступи / розміри */
  --abyts-gap: 10px;
  /* На сторінці немає скруглень — тримаємо єдиний стиль */
  --abyts-radius: 0px;
  --abyts-title-margin-bottom: 10px;
  --abyts-caption-margin-top: 8px;
  --abyts-card-play-offset: 10px;
  /* Фіксована висота прев'ю (вимога): 150px для будь-яких відео */
  --abyts-thumb-height: 150px;
  --abyts-carousel-native-scroll-padding-bottom: 6px;

  /* Типографіка */
  --abyts-title-font-size: 18px;
  --abyts-title-font-weight: 700;
  --abyts-caption-font-size: 13px;
  --abyts-caption-line-height: 1.25;
  --abyts-modal-title-font-size: 15px;
  --abyts-modal-title-font-weight: 600;
  --abyts-modal-close-font-size: 22px;

  /* Кольори */
  --abyts-color-text: #111;
  --abyts-color-white: #fff;
  --abyts-color-black: #000;
  --abyts-color-surface-muted: rgba(0, 0, 0, 0.04);
  --abyts-color-overlay: rgba(0, 0, 0, 0.65);
  --abyts-color-control-bg: rgba(0, 0, 0, 0.55);
  --abyts-color-control-bg-hover: rgba(0, 0, 0, 0.75);
  --abyts-color-close-bg: rgba(255, 255, 255, 0.14);
  --abyts-color-close-bg-hover: rgba(255, 255, 255, 0.22);
  --abyts-color-modal-bg: #0b0b0b;
  --abyts-color-modal-title: rgba(255, 255, 255, 0.92);

  /* Скелетон */
  --abyts-skeleton-c1: rgba(0, 0, 0, 0.06);
  --abyts-skeleton-c2: rgba(0, 0, 0, 0.1);
  --abyts-skeleton-bg-size: 400% 100%;
  --abyts-skeleton-anim-duration: 1.2s;

  /* Елементи керування Flickity */
  --abyts-flickity-btn-size: 34px;
  --abyts-flickity-btn-radius: 999px;

  /* Кнопка відтворення на картці */
  --abyts-card-play-size: 46px;
  --abyts-card-play-radius: 999px;
  --abyts-card-triangle-left: 18px;
  --abyts-card-triangle-top: 14px;
  --abyts-card-triangle-border-y: 9px;
  --abyts-card-triangle-border-x: 14px;

  /* Модальне вікно */
  --abyts-modal-z: 999999;
  --abyts-modal-width-max: 980px;
  --abyts-modal-side-gap: 24px;
  --abyts-modal-radius: 14px;
  --abyts-modal-padding: 14px;
  --abyts-modal-close-size: 34px;
  --abyts-modal-close-offset: 10px;
  --abyts-modal-title-padding-right: 44px;
  --abyts-modal-title-margin-bottom: 10px;

  --abyts-modal-play-size: 70px;
  --abyts-modal-play-radius: 999px;
  --abyts-modal-play-shadow: 0 10px 30px rgba(0, 0, 0, 0.35);
  --abyts-modal-play-triangle-border-y: 14px;
  --abyts-modal-play-triangle-border-x: 22px;
  --abyts-modal-play-triangle-shift-x: -43%;

}

:root.abyts-modal-open {
  overflow: hidden;
}

.abyts {
  /* Контейнер для можливих локальних перевизначень через inline-стилі */
  color: var(--abyts-color-text);
}

.abyts__title {
  font-size: var(--abyts-title-font-size);
  font-weight: var(--abyts-title-font-weight);
  margin: 0 0 var(--abyts-title-margin-bottom) 0;
  color: var(--abyts-color-text);
}

.abyts__skeleton-row {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--abyts-gap);
}

.abyts__skeleton-card {
  border-radius: var(--abyts-radius);
  background: linear-gradient(
    90deg,
    var(--abyts-skeleton-c1) 25%,
    var(--abyts-skeleton-c2) 37%,
    var(--abyts-skeleton-c1) 63%
  );
  background-size: var(--abyts-skeleton-bg-size);
  animation: abyts-skel var(--abyts-skeleton-anim-duration) ease infinite;
  height: var(--abyts-thumb-height);
  aspect-ratio: 16 / 9;
}

@keyframes abyts-skel {
  0% { background-position: 100% 0; }
  100% { background-position: 0 0; }
}

.abyts__carousel {
  position: relative;
}

.abyts__empty {
  padding: 12px 0;
  color: var(--abyts-color-text);
  font-size: 14px;
  line-height: 1.35;
}

.abyts__carousel .flickity-viewport {
  overflow: visible; /* легкий “підгляд” наступної картки */
}

.abyts__carousel .flickity-prev-next-button {
  width: var(--abyts-flickity-btn-size);
  height: var(--abyts-flickity-btn-size);
  border-radius: var(--abyts-flickity-btn-radius);
  background: var(--abyts-color-control-bg);
}
.abyts__carousel .flickity-prev-next-button:hover {
  background: var(--abyts-color-control-bg-hover);
}
.abyts__carousel .flickity-prev-next-button .flickity-button-icon {
  fill: var(--abyts-color-white);
}

.abyts-cell {
  width: auto;
  margin-right: var(--abyts-gap);
  flex: 0 0 auto;
}

.abyts-card {
  display: block;
  width: auto;
  border: 0;
  padding: 0;
  background: transparent;
  text-align: left;
  cursor: pointer;
}

.abyts-card__thumb {
  display: block;
  border-radius: var(--abyts-radius);
  background-color: var(--abyts-color-surface-muted);
  background-size: cover;
  background-position: center;
  height: var(--abyts-thumb-height);
  width: auto;
  aspect-ratio: 16 / 9;
  position: relative;
  overflow: hidden;
}

.abyts-card__play {
  position: absolute;
  width: var(--abyts-card-play-size);
  height: var(--abyts-card-play-size);
  left: var(--abyts-card-play-offset);
  bottom: var(--abyts-card-play-offset);
  border-radius: var(--abyts-card-play-radius);
  background: var(--abyts-color-control-bg);
  opacity: 0;
  transform: scale(0.98);
  transition: opacity 180ms ease, transform 180ms ease, background 180ms ease;
  pointer-events: none;
}
.abyts-card__play::before {
  content: "";
  position: absolute;
  left: var(--abyts-card-triangle-left);
  top: var(--abyts-card-triangle-top);
  width: 0;
  height: 0;
  border-top: var(--abyts-card-triangle-border-y) solid transparent;
  border-bottom: var(--abyts-card-triangle-border-y) solid transparent;
  border-left: var(--abyts-card-triangle-border-x) solid var(--abyts-color-white);
}

.abyts-card__caption {
  display: block;
  margin-top: var(--abyts-caption-margin-top);
  font-size: var(--abyts-caption-font-size);
  line-height: var(--abyts-caption-line-height);
  color: var(--abyts-color-text);
  display: -webkit-box;
  line-clamp: 2;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.abyts--no-captions .abyts-card__caption {
  display: none !important;
}

.abyts-card:hover .abyts-card__play {
  background: var(--abyts-color-control-bg-hover);
  opacity: 1;
  transform: scale(1);
}

.abyts-cell--stack {
  width: calc((100% - var(--abyts-gap)) / 2);
  margin-right: var(--abyts-gap);
  display: grid;
  grid-template-rows: 1fr 1fr;
  gap: var(--abyts-gap);
}

.abyts-card--stacked .abyts-card__caption {
  line-clamp: 1;
  -webkit-line-clamp: 1;
}

@media (max-width: 767px) {
  .abyts__skeleton-row {
    grid-template-columns: repeat(2, 1fr);
  }

  /* На мобілці: шортси 9:16, лонги 16:9; висота однакова */
  .abyts-card--shorts .abyts-card__thumb {
    aspect-ratio: 9 / 16;
  }
}

.abyts__carousel--native-scroll {
  display: flex;
  flex-wrap: nowrap;
  overflow-x: auto;
  gap: var(--abyts-gap);
  scroll-snap-type: x mandatory;
  padding-bottom: var(--abyts-carousel-native-scroll-padding-bottom);
}

.abyts__carousel--native-scroll .abyts-cell {
  width: auto;
  margin-right: 0;
  scroll-snap-align: start;
}

/* Модальне вікно */
.abyts-modal {
  position: fixed;
  inset: 0;
  z-index: var(--abyts-modal-z);
}
.abyts-modal__backdrop {
  position: absolute;
  inset: 0;
  background: var(--abyts-color-overlay);
}
.abyts-modal__dialog {
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  width: min(var(--abyts-modal-width-max), calc(100% - var(--abyts-modal-side-gap)));
  background: var(--abyts-color-modal-bg);
  color: var(--abyts-color-white);
  border-radius: var(--abyts-modal-radius);
  padding: var(--abyts-modal-padding);
}
.abyts-modal__close {
  position: absolute;
  right: var(--abyts-modal-close-offset);
  top: var(--abyts-modal-close-offset);
  width: var(--abyts-modal-close-size);
  height: var(--abyts-modal-close-size);
  border-radius: var(--abyts-flickity-btn-radius);
  border: 0;
  background: var(--abyts-color-close-bg);
  color: var(--abyts-color-white);
  font-size: var(--abyts-modal-close-font-size);
  line-height: 1;
  cursor: pointer;
}
.abyts-modal__close:hover { background: var(--abyts-color-close-bg-hover); }

.abyts-modal__title {
  font-size: var(--abyts-modal-title-font-size);
  font-weight: var(--abyts-modal-title-font-weight);
  color: var(--abyts-color-modal-title);
  padding-right: var(--abyts-modal-title-padding-right);
  margin-bottom: var(--abyts-modal-title-margin-bottom);
  display: -webkit-box;
  line-clamp: 2;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.abyts-modal__player {
  position: relative;
  border-radius: var(--abyts-radius);
  overflow: hidden;
  background: var(--abyts-color-black);
  aspect-ratio: 16 / 9;
}

.abyts-modal__cover {
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center;
}
.abyts-modal__cover--hidden {
  display: none;
}

.abyts-modal__play {
  position: absolute;
  inset: 0;
  border: 0;
  background: transparent;
  cursor: pointer;
}
.abyts-modal__play::before {
  content: "";
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  width: var(--abyts-modal-play-size);
  height: var(--abyts-modal-play-size);
  border-radius: var(--abyts-modal-play-radius);
  background: var(--abyts-color-control-bg);
  box-shadow: var(--abyts-modal-play-shadow);
}
.abyts-modal__play::after {
  content: "";
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(var(--abyts-modal-play-triangle-shift-x), -50%);
  width: 0;
  height: 0;
  border-top: var(--abyts-modal-play-triangle-border-y) solid transparent;
  border-bottom: var(--abyts-modal-play-triangle-border-y) solid transparent;
  border-left: var(--abyts-modal-play-triangle-border-x) solid var(--abyts-color-white);
}

.abyts-modal__iframe {
  position: absolute;
  inset: 0;
}
.abyts-modal__iframe iframe {
  width: 100%;
  height: 100%;
  display: block;
}
