/* Base Keen slider container */
.wp-block-query.is-style-slider ul.keen-slider {
  display: flex;
  gap: 0;
  overflow: hidden;
  scroll-behavior: smooth;
}

/* Grid fallback when slider is disabled */
.wp-block-query.is-style-slider ul.keen-slider.no-slider {
    gap: var(--wp--preset--spacing--60);
    display: grid;
}

/* Mobile: horizontal scroll fallback with snap */
@media (max-width: 600px) {
    .wp-block-query:has( >.ul.keen-slider.no-slider ){
        margin-left: calc(var(--wp--style--root--padding-left) * -1) !important;
        margin-right: calc(var(--wp--style--root--padding-right) * -1) !important;
    }

    .wp-block-query.is-style-slider ul.keen-slider.no-slider {
        display: flex !important;
        overflow-x: scroll;
        scroll-snap-type: x mandatory;
        scroll-margin-left: var(--wp--style--root--padding-left);
        scroll-margin-right: var(--wp--style--root--padding-right);
        gap: 0;

        > .wp-block-post {
            flex: 0 0 80%;
            scroll-snap-align: start;
            padding-left: var(--wp--style--root--padding-left);

            &:last-child {
                margin-right: var(--wp--style--root--padding-left);
            }
        }

        > .wp-block-post:only-child {
            flex: 0 0 100%
        }
    }
}

/* Default slide layout in grid or fallback */
.wp-block-query.is-style-slider ul.keen-slider > li.keen-slider__slide {
  flex: 0 0 calc(33.33% - var(--wp--preset--spacing--60));
  opacity: 1;
  transition: opacity 0.3s ease-in-out;
}

/* Keen overrides layout after init */
.wp-block-query.is-style-slider ul.keen-slider.keen-slider-initialized > li.keen-slider__slide {
  flex: unset;
}

/* Fade effect for active/inactive slides */
.wp-block-query.is-style-slider ul.keen-slider:not(.no-slider) li.keen-slider__slide {
  opacity: 0.3;
  transition: opacity 0.3s ease;
}
.wp-block-query.is-style-slider ul.keen-slider li.keen-slider__slide.is-active {
  opacity: 1;
}

/* Navigation container */
.slider-nav {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-top: 1rem;
  gap: var(--wp--preset--spacing--80);
}

/* Scrollbar track */
.slider-progress {
  flex: 1;
  height: 1px;
  background: rgba(28, 28, 28, 0.30);
  position: relative;
}

/* Scrollbar draggable handle */
.slider-progress-bar {
  position: absolute;
  top: -2px;
  left: 0;
  width: 80px;
  height: 6px;
  background: var(--wp--preset--color--secondary);
  cursor: grab;
}
.slider-progress-bar.is-dragging {
  cursor: grabbing;
}

/* Arrow buttons container */
.slider-arrows {
  display: flex;
  gap: var(--wp--preset--spacing--40);
}

/* Arrow button style */
.slider-arrows button {
    display: flex;
    cursor: pointer;
    justify-content: center;
    text-align: center;
    align-items: center;
    border: 2px solid var(--wp--preset--color--secondary);
    gap: 0;
    overflow: hidden;
    transition: all 0.3s ease-in-out;
    width: 44px;
    height: 44px;
    position: relative;
    text-indent: -9999px;
    color: var(--wp--preset--color--secondary);
}

/* Arrow button hover state */
.slider-arrows button:hover {
    background-color: var(--wp--preset--color--secondary);
    color: var(--wp--preset--color--base);
}

/* Arrow icons */
.slider-arrows button:before {
    content: "";
    font-family: "icomoon" !important;
    font-size: var(--wp--preset--font-size--large);
    font-weight: 100;
    text-indent: 0;
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
}

.slider-arrows button.slider-prev:before {
    content:"\e974";
}

.slider-arrows button.slider-next:before {
    content:"\e975";
}

/* Keen container positioning */
.wp-block-query.is-style-slider {
  position: relative;
}
.wp-block-query.is-style-slider ul.keen-slider li.keen-slider__slide {
  will-change: transform, opacity;
}

/* Mobile: disable slider, show single column */
@media (max-width: 1023px) {
  .wp-block-query.is-style-slider ul.keen-slider > li.keen-slider__slide {
    flex: none;
    width: 100%;
    opacity: 1 !important;
    transform: none !important;
  }
  .slider-nav {
    display: none;
  }
}