/**
 * This file was automatically generated. Please run `npm run dist` to update.
 */

[data-slider] {
  position: relative;
}

[data-slider-panel] {
  position: relative;
  overflow: hidden;
}

[data-slider-rail] {
  position: relative;
  display: flex;
  flex-wrap: nowrap;
  left: 0;
  transition-property: left;
  transition-duration: 0.5s;
}
@media (min-width: 768px) {
  [data-slider-rail] {
    transition-duration: 1s;
  }
}

.ct-banner__inner {
  padding: 0 !important;
}
.ct-slider {
  padding: 0 !important;
}

/* Brought from older stylesheet */
.ct-slider-highlight-mode .ct-slider__container {
  background: var(--main-b-1);
  border-radius: 0.25rem;
  box-shadow: 0 0.5rem 1.5rem rgba(0,0,0,0.2);
}

.ct-slider-highlight-mode .ct-slider__container .ct-tag {
  position: relative;
  bottom: calc(28px + 16px);
  right: 16px;
  float: right;

  height: 0px;
  background: none;
  border: none;
  color: black;
}

.ct-slider-highlight-mode .ct-slider__slides {
  border-radius: 0.25rem 0 0;
  box-shadow: none;
}
/* END Brought from older stylesheet */

/* Full-width slider */
.ct-slider.ct-slider--full-width {
  width: 100vw;
  position: relative;
  left: 50%;
  right: 50%;
  margin-left: -50vw;
  margin-right: -50vw;
  max-width: none;
}

.ct-slider.ct-slider--full-width > .container-fluid {
  padding-left: 0;
  padding-right: 0;
}

.ct-slider.ct-slider--full-width .ct-slider__slides {
  width: 100%;
}

.ct-slider.ct-slider--full-width .ct-slide__image img {
  width: 100%;
  height: auto;
  object-fit: cover;
}

/* Responsive image container */
.ct-slide__responsive-images {
  position: relative;
  width: 100%;
}

.ct-slide__responsive-images > div {
  width: 100%;
}

.ct-slide__responsive-images img {
  width: 100%;
  height: auto;
  display: block;
}

/* Slide with responsive images modifier */
.ct-slide.ct-slide--responsive .ct-slide__image {
  overflow: hidden;
}

/* Full-width slide adjustments */
.ct-slider--full-width .ct-slide {
  width: 100%;
}

.ct-slider--full-width .ct-slide__row {
  margin: 0;
}

.ct-slider--full-width .ct-slide__image {
  margin: 0;
  padding: 0;
}

/* Ensure images fill container in full-width mode */
.ct-slider--full-width .ct-slide__responsive-images img,
.ct-slider--full-width .ct-slide__image img {
  max-width: 100%;
  height: auto;
}

/* Override grid column padding in full-width mode */
.ct-slider--full-width [class*="col-"] {
  padding-left: 0;
  padding-right: 0;
}

/* Highlight mode specifics */
.ct-slider.ct-slider-highlight-mode.ct-slider--full-width {
  overflow: hidden;
}

.ct-slide--jumbotron {
  position: relative;
  width: 100%;
  min-height: 400px;
  overflow: hidden;
}

/* Background image layer - full coverage */
.ct-slide__background {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 1;
}

.ct-slide__background-image {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

.ct-slide__background-image img {
  width: 100%;
  object-fit: cover !important;
  object-position: center;
}

/* Overlay gradient for text readability */
.ct-slide__overlay {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 2;
  background: linear-gradient(
    to right,
    rgba(0, 0, 0, 0.7) 0%,
    rgba(0, 0, 0, 0.5) 40%,
    rgba(0, 0, 0, 0.2) 70%,
    transparent 100%
  );
}

/* Dark theme overlay adjustment */
.ct-theme-dark .ct-slide__overlay {
  background: linear-gradient(
    to right,
    rgba(0, 0, 0, 0.8) 0%,
    rgba(0, 0, 0, 0.6) 40%,
    rgba(0, 0, 0, 0.3) 70%,
    transparent 100%
  );
}

/* Caption content layer - positioned on top, fills container */
.ct-slide__caption {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 3;
  display: flex;
}

.ct-slide__caption > .container {
  width: 100%;
  height: 100%;
  display: flex;
  align-items: start;
}

.ct-slide__caption-inner {
  padding-top: 4rem;
  max-width: 600px;
  color: #fff;
}

/* Override text colors for jumbotron */
.ct-slide--jumbotron .ct-slide__title,
.ct-slide--jumbotron .ct-slide__content,
.ct-slide--jumbotron .ct-slide__date,
.ct-slide--jumbotron .ct-slide__tags {
  color: #fff;
}

.ct-slide--jumbotron .ct-slide__title {
  margin-bottom: 1rem;
  text-shadow: 0 2px 4px rgba(0, 0, 0, 0.3);
}

.ct-slide--jumbotron .ct-slide__content {
  font-size: 1.125rem;
  line-height: 1.6;
  margin-bottom: 1.5rem;
  text-shadow: 0 1px 2px rgba(0, 0, 0, 0.2);
}

.ct-slider--full-width .ct-slide--jumbotron {
  width: 100%;
}

.ct-slider--full-width .ct-slide__caption {
  padding-left: 2rem;
  padding-right: 2rem;
}

.ct-slider-highlight-mode .ct-slider__controls {
  position: absolute;
  bottom: 2rem;
  left: 0;
  right: 0;
  z-index: 10;
  pointer-events: none;
}

.ct-slider-highlight-mode .ct-slider__controls__inner {
  width: 100%;
  display: flex;
  gap: 1rem;
  flex-direction: column-reverse;
  justify-content: flex-end;
  align-items: center;
  pointer-events: auto;
}

.ct-slider-highlight-mode .ct-slider__controls .ct-button {
  min-width: 32px;
  background-color: hsla(0, 0%, 50%, .4);
  padding: 12px;
  border-radius: 50%;
  z-index: 1;
  cursor: pointer;
  -webkit-transition: background-color .4s, opacity .4s;
  transition: background-color .4s, opacity .4s;
}

.ct-slider-highlight-mode .ct-slider__controls .ct-button:disabled {
  background-color: hsl(0deg 0% 15.23% / 40%);
}

.ct-slider-highlight-mode .ct-slider__controls .ct-button .ct-icon {
  width: 32px;
  height: 32px;
  fill: #fff;
  display: block;
  position: relative;
}

.ct-slider .ct-slider__controls__previous, .ct-slider .ct-slider__controls__next {
  width: initial ;
}

.ct-slider__dots {
  display: flex;
  align-items: center;
  gap: 8px;
}

.ct-slider__dot {
  width: 10px;
  height: 10px;
  padding: 0;
  border: none;
  border-radius: 50%;
  background-color: hsla(0, 0%, 100%, 0.5);
  cursor: pointer;
  transition: all 0.3s ease;
  position: relative;
  flex-shrink: 0;
}

.ct-slider__dot:hover {
  background-color: hsla(0, 0%, 100%, 0.8);
  transform: scale(1.1);
}

.ct-slider__dot:focus {
  outline: 2px solid hsla(0, 0%, 100%, 0.8);
  outline-offset: 2px;
}

.ct-slider__dot:focus-visible {
  outline: 2px solid #fff;
  outline-offset: 3px;
}

.ct-slider__dot--active {
  width: 12px;
  height: 12px;
  background-color: hsla(0, 0%, 100%, 1);
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.3);
}

.ct-slider__arrows {
  position: relative;
  top: 42px;
  display: flex;
  align-items: center;
  gap: 0.5rem;
  margin-left: calc(100% - 128px);
}

.ct-slider--single-slide .ct-slider__controls,
.ct-slider-highlight-mode .ct-slider__controls__progress-indicator {
  display: none !important;
}

@media (max-width: 767.98px) {
  .ct-slide--jumbotron,
  .ct-slide__caption,
  .ct-slider.ct-slider--full-width.ct-slider-highlight-mode,
  .ct-slider.ct-slider--full-width [data-slider-rail],
  .ct-slider.ct-slider--full-width [data-slider-slide] {
    height: 640px !important;
    min-height: 640px;
  }
  
  .ct-slide__overlay {
    background: linear-gradient(
      to top,
      rgba(0, 0, 0, 0.8) 0%,
      rgba(0, 0, 0, 0.5) 50%,
      rgba(0, 0, 0, 0.3) 100%
    );
  }

  .ct-slider--full-width .ct-slide__inner {
    padding: 1rem;
  }
  
  .ct-slider-highlight-mode .ct-slider__controls__inner {
    align-items: center;
    justify-content: center;
    gap: 12px;
  }

  .ct-slider__arrows {
    margin: initial;
    justify-content: space-between;
    width: 100%;
  }
}

@media (min-width: 768px) {
  .ct-slider--full-width .ct-slide__inner {
    padding: 2rem;
  }
}

@media (min-width: 768px) and (max-width: 991.98px) {
  .ct-slide--jumbotron,
  .ct-slide__caption,
  .ct-slider.ct-slider--full-width.ct-slider-highlight-mode,
  .ct-slider.ct-slider--full-width [data-slider-rail],
  .ct-slider.ct-slider--full-width [data-slider-slide] {
    height: 580px !important;
    min-height: 580px;
  }

  .ct-slider .ct-slider__controls {
    display: block;
  }
}

@media (min-width: 992px) and (max-width: 1199.98px) {
  .ct-slide--jumbotron,
  .ct-slide__caption,
  .ct-slider.ct-slider--full-width.ct-slider-highlight-mode,
  .ct-slider.ct-slider--full-width [data-slider-rail],
  .ct-slider.ct-slider--full-width [data-slider-slide] {
    height: 580px !important;
    min-height: 580px;
  }
}

@media (min-width: 992px) {
  .ct-slider--full-width .ct-slide__caption {
    padding-left: 4rem;
    padding-right: 4rem;
  }

  .ct-slider .ct-slider__controls {
    display: flex;
    align-items: center;
    text-align: unset;
  }
}

@media (min-width: 1200px) {
  .ct-slide--jumbotron,
  .ct-slide__caption,
  .ct-slider.ct-slider--full-width.ct-slider-highlight-mode,
  .ct-slider.ct-slider--full-width [data-slider-rail],
  .ct-slider.ct-slider--full-width [data-slider-slide] {
    height: 580px !important;
    min-height: 580px;
  }
}

@media (prefers-reduced-motion: reduce) {
  .ct-slider__dot {
    transition: none;
  }
}

@media (prefers-contrast: high) {
  .ct-slider__dot {
    border: 2px solid currentColor;
  }
  
  .ct-slider__dot--active {
    background-color: currentColor;
  }
}
