.carousel-block {
  padding: 20px 0;
}

.carousel-block__wrap {
  position: relative;
  display: flex;
  align-items: center;
}

/* Slider area */
.carousel-block__slider {
  width: 100%;
}

/* 3px gap between slides (1.5px each side) */
.carousel-block__slide {
  padding: 0 1.5px;
  box-sizing: border-box;
}

.carousel-block__slider .slick-list {
  margin: 0 -1.5px; /* cancels slide padding at edges */
}

/* Images */
.carousel-block__slide img {
  width: 100%;
  object-fit: cover;
  display: block;
}

/* =========================
   ARROWS (DESKTOP - sides)
   ========================= */
.carousel-block__arrow {
  border: 0;
  background: transparent;
  padding: 0;
  line-height: 1;
  cursor: pointer;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  z-index: 5;
  opacity: 0.85;
  transition: opacity 0.2s ease;
}

.carousel-block__arrow:hover {
  opacity: 1;
}
.carousel-block__arrow:focus {
    border:none;
    outline:none;
}

.carousel-block__arrow--prev {
  left: -28px;
}

.carousel-block__arrow--next {
  right: -28px;
}

/* We render FA icon via ::after on the span */
.carousel-block__arrow-icon {
  display: inline-block;

  position: relative;
}

.carousel-block__arrow--prev .carousel-block__arrow-icon::after,
.carousel-block__arrow--next .carousel-block__arrow-icon::after {
  font-family: "FontAwesome";
    font-size: 30px;
    color: var(--blue);
    display: flex;
    align-items: center;
    justify-content: center;
    height: 100%;
    width: 100%;
    transition: color 0.3s ease;
  content: "";
}

.carousel-block__arrow--prev .carousel-block__arrow-icon::after {
  content: "\f104"; /* fa-chevron-left */
}

.carousel-block__arrow--next .carousel-block__arrow-icon::after {
  content: "\f105"; /* fa-chevron-right */
}

/* Slick disabled arrow */
.carousel-block__arrow.slick-disabled {
  opacity: 0.25;
  cursor: default;
}

/* =========================
   MOBILE: arrows appended into slick-arrows-wrap
   ========================= */

/* You said you already have styling for slick-arrows-wrap.
   We'll just ensure it shows and arrows behave like normal inline elements. */
.carousel-block__mobile-arrows {
  display: none; /* desktop: hidden */
}

/* Mobile breakpoint: you wanted "on mobile" — you asked 576px specifically */
@media (max-width: 575.98px) {
  .carousel-block__wrap {
    flex-direction: column;
    align-items: stretch;
  }


  /* show the arrows wrapper on mobile */
  .carousel-block__mobile-arrows {
    display: flex;
    justify-content: center;
    gap: 20px;
    margin-top: 10px;
  }

  /* When buttons are moved into .carousel-block__mobile-arrows,
     they should not be absolutely positioned */
  .carousel-block__mobile-arrows .carousel-block__arrow {
    width: 57px;
    height: 57px;
    border-radius: 50%;
    border: 2px solid var(--blue);
    background: transparent;
    z-index: 5;
    transition: all 0.3s ease;
    position: relative;
    top: 0;
    transform: none;
  }
  .carousel-block__mobile-arrows .carousel-block__arrow:hover {
    background: var(--blue);
  }
  .carousel-block__mobile-arrows .carousel-block__arrow:hover .carousel-block__arrow-icon::after {
    color: #fff;
  }

  .carousel-block__mobile-arrows .carousel-block__arrow-icon {
    width: 44px;
    height: 44px;
  }
  .carousel-block__mobile-arrows .carousel-block__arrow--prev {
    left:0;
  }
  .carousel-block__mobile-arrows .carousel-block__arrow--next {
    right: 0;
  }

  .carousel-block__mobile-arrows .carousel-block__arrow--prev .carousel-block__arrow-icon::after,
  .carousel-block__mobile-arrows .carousel-block__arrow--next .carousel-block__arrow-icon::after {
    font-size: 30px;
  }
}
