/* ============================================================
   CCIS Slider - Bulletproof Isolated Styles v4.7.0
   All rules use high-specificity to prevent theme/plugin conflicts.
   CSS custom properties power per-button hover colors.
   ============================================================ */

/* --- Scoped reset --- */
.ccis-slider,
.ccis-slider *,
.ccis-slider *::before,
.ccis-slider *::after {
  box-sizing: border-box !important;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

.ccis-slider {
  position: relative !important;
  width: 100% !important;
 
  background: #f9fafb !important;
  margin: 0 !important;
  padding: 0 !important;
  border: none !important;
  outline: none !important;
  float: none !important; 
  clear: both !important;
  max-width: 100% !important;
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen-Sans, Ubuntu, Cantarell, "Helvetica Neue", sans-serif !important;
  line-height: 1.5 !important;
  overflow: hidden !important;
}

.ccis-slider .ccis-track {
  display: flex !important;
  height: 100% !important;
  width: 100% !important;
  transition: transform 0.55s ease !important;
  will-change: transform !important;
  cursor: grab !important;
  margin: 0 !important;
  padding: 0 !important;
  border: none !important;
  list-style: none !important;
  overflow: hidden !important;
}

.ccis-slider .ccis-slide {
  flex: 0 0 100% !important;
  width: 100% !important;
  height: 100% !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  position: relative !important;
  margin: 0 !important;
  padding: 0 !important;
  border: none !important;
  overflow: hidden !important;
}

/* Slide media */
.ccis-slider .ccis-slide-media,
.ccis-slider .ccis-slide img,
.ccis-slider .ccis-slide video {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  display: block !important;
  user-select: none !important;
  -webkit-user-drag: none !important;
  margin: 0 !important;
  padding: 0 !important;
  border: none !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  outline: none !important;
  max-width: none !important;
  max-height: none !important;
}

.ccis-slider .ccis-slide > a {
  display: block !important;
  width: 100%  ;
  height: 100% ;
  text-decoration: none !important;
  border: none !important;
  outline: none !important;
}
.ccis-slider .ccis-slide > a.ccis-float-img {
  display: block !important;
  width: auto  ;
  height: auto  ;
  text-decoration: none !important;
  border: none !important;
  outline: none !important;
}

/* Desktop/Mobile responsive media */
.ccis-slider .ccis-media-mobile { display: none !important; }
.ccis-slider .ccis-ov-hidden { display: none !important; }
.ccis-slider .ccis-ov-mobile-only { display: none !important; }
/* CTA button visibility — higher specificity to beat .ccis-cta-btn display rule */
.ccis-slider .ccis-content-overlay .ccis-cta-btn.ccis-ov-hidden { display: none !important; visibility: hidden !important; }
.ccis-slider .ccis-content-overlay .ccis-cta-btn.ccis-ov-mobile-only { display: none !important; }
.ccis-slider .ccis-content-overlay .ccis-cta-btn.ccis-ov-desktop-only { display: inline-flex !important; }

@media (max-width: 768px) {
  .ccis-slider .ccis-media-desktop { display: none !important; }
  .ccis-slider .ccis-media-mobile { display: block !important; }
  .ccis-slider .ccis-ov-desktop-only { display: none !important; }
  .ccis-slider .ccis-ov-mobile-only { display: block !important; }
  /* CTA button visibility on mobile — use inline-flex not block */
  .ccis-slider .ccis-content-overlay .ccis-cta-btn.ccis-ov-desktop-only { display: none !important; }
  .ccis-slider .ccis-content-overlay .ccis-cta-btn.ccis-ov-mobile-only { display: inline-flex !important; }
}

/* --- Arrows --- */
.ccis-slider > .ccis-arrow {
  position: absolute !important;
  top: 50% !important;
  transform: translateY(-50%) !important;
  width: 44px !important;
  height: 44px !important;
  border-radius: 999px !important;
  border: 1px solid rgba(148, 163, 184, 0.5) !important;
  background: rgba(255, 255, 255, 0.9) !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  cursor: pointer !important;
  box-shadow: 0 10px 30px rgba(15, 23, 42, 0.12) !important;
  z-index: 5 !important;
  transition: all 0.2s ease !important;
  margin: 0 !important;
  padding: 0 !important;
  font-size: 18px !important;
  line-height: 1 !important;
  color: #333 !important;
  text-decoration: none !important;
  outline: none !important;
  -webkit-appearance: none !important;
  appearance: none !important;
}
.ccis-slider > .ccis-arrow--prev { left: 18px !important; right: auto !important; }
.ccis-slider > .ccis-arrow--next { right: 18px !important; left: auto !important; }
.ccis-slider > .ccis-arrow:hover {
  background: #fff !important;
  border-color: rgba(15, 23, 42, 0.4) !important;
  box-shadow: 0 12px 35px rgba(15, 23, 42, 0.18) !important;
}

/* --- Dots --- */
.ccis-slider > .ccis-dots {
  position: absolute !important;
  left: 50% !important;
  bottom: 1.25rem !important;
  transform: translateX(-50%) !important;
  display: flex !important;
  gap: 8px !important;
  padding: 8px 12px !important;
  border-radius: 999px !important;
  background: rgba(255, 255, 255, 0.92) !important;
  box-shadow: 0 10px 30px rgba(15, 23, 42, 0.25) !important;
  z-index: 5 !important;
  margin: 0 !important;
  border: none !important;
  list-style: none !important;
}
.ccis-slider > .ccis-dots > .ccis-dot {
  width: 8px !important;
  height: 8px !important;
  border-radius: 999px !important;
  border: none !important;
  background: #e5e7eb !important;
  cursor: pointer !important;
  padding: 0 !important;
  margin: 0 !important;
  transition: all 0.18s ease !important;
  outline: none !important;
  -webkit-appearance: none !important;
  appearance: none !important;
  box-shadow: none !important;
  min-width: 0 !important;
  min-height: 0 !important;
}
.ccis-slider > .ccis-dots > .ccis-dot:hover { background: #9ca3af !important; }
.ccis-slider > .ccis-dots > .ccis-dot.is-active {
  width: 18px !important;
  background: #111827 !important;
  transform: translateY(-1px) !important;
}

/* --- Dragging --- */
.ccis-slider.ccis--dragging .ccis-track {
  transition: none !important;
  cursor: grabbing !important;
}

/* --- Touch --- */
.ccis-slider,
.ccis-slider .ccis-track,
.ccis-slider .ccis-slide,
.ccis-slider .ccis-slide > a,
.ccis-slider .ccis-slide-media,
.ccis-slider .ccis-slide img {
  -ms-touch-action: pan-y !important;
  touch-action: pan-y !important;
}
.ccis-slider,
.ccis-slider .ccis-slide img {
  user-select: none !important;
  -webkit-user-drag: none !important;
}

/* --- Responsive arrows/dots --- */
@media (max-width: 1024px) {
  .ccis-slider > .ccis-arrow { width: 40px !important; height: 40px !important; }
  .ccis-slider > .ccis-arrow--prev { left: 12px !important; }
  .ccis-slider > .ccis-arrow--next { right: 12px !important; }
}
@media (max-width: 768px) {
  .ccis-slider > .ccis-arrow { width: 36px !important; height: 36px !important; font-size: 16px !important; }
  .ccis-slider > .ccis-arrow--prev { left: 10px !important; }
  .ccis-slider > .ccis-arrow--next { right: 10px !important; }
  .ccis-slider > .ccis-dots { bottom: 0.75rem !important; padding: 6px 10px !important; gap: 6px !important; }
  .ccis-slider > .ccis-dots > .ccis-dot { width: 6px !important; height: 6px !important; }
  .ccis-slider > .ccis-dots > .ccis-dot.is-active { width: 14px !important; }
}
@media (max-width: 480px) {
  .ccis-slider > .ccis-arrow { width: 32px !important; height: 32px !important; font-size: 14px !important; }
  .ccis-slider > .ccis-arrow--prev { left: 8px !important; }
  .ccis-slider > .ccis-arrow--next { right: 8px !important; }
}

/* =============================================================
   Content Overlay
   ============================================================= */
/* Gradient shadow — separate div, always covers full slide regardless of overlay position */
.ccis-slider .ccis-slide .ccis-overlay-gradient {
  position: absolute !important;
  top: 0 !important; left: 0 !important; right: 0 !important; bottom: 0 !important;
  pointer-events: none !important;
  z-index: 9 !important;
}
.ccis-slider .ccis-slide .ccis-content-overlay {
  position: absolute !important;
  top: 0; left: 0; right: 0; bottom: 0;
  display: flex !important;
  flex-direction: column !important;
  justify-content: center !important;
  z-index: 10 !important;
  padding: 40px 60px !important;
  background: none !important;
  box-sizing: border-box !important;
  margin: 0 !important;
  border: none !important;
  pointer-events: none !important;
  overflow: hidden !important;
  max-width: 100% !important;
}
.ccis-slider .ccis-content-overlay .ccis-cta-btn,
.ccis-slider .ccis-content-overlay a {
  pointer-events: auto !important;
}

/* Alignment */
.ccis-slider .ccis-content-overlay.ccis-align-left { align-items: flex-start !important; text-align: left !important; }
.ccis-slider .ccis-content-overlay.ccis-align-center { align-items: center !important; text-align: center !important; }
.ccis-slider .ccis-content-overlay.ccis-align-right { align-items: flex-end !important; text-align: right !important; }

/* --- Typography --- */
.ccis-slider .ccis-content-overlay .ccis-ov-h1 {
  font-size: clamp(24px, 4vw, 52px) !important;
  font-weight: 800 !important;
  line-height: 1.15 !important;
  margin: 0 !important;
  padding: 0 !important;
  text-shadow: 0 2px 12px rgba(0,0,0,0.4) !important;
  max-width: 80% !important;
  border: none !important;
  background: none !important;
  text-decoration: none !important;
  letter-spacing: normal !important;
  text-transform: none !important;
  float: none !important;
  overflow-wrap: break-word !important;
  word-wrap: break-word !important;
}
.ccis-slider .ccis-content-overlay .ccis-ov-h1 span[style] { text-shadow: inherit; }
.ccis-slider .ccis-content-overlay .ccis-ov-h1 a { color: inherit !important; text-decoration: underline !important; }
.ccis-slider .ccis-content-overlay .ccis-ov-h1 strong,
.ccis-slider .ccis-content-overlay .ccis-ov-h1 b { font-weight: 900 !important; }
.ccis-slider .ccis-content-overlay .ccis-ov-h1 em,
.ccis-slider .ccis-content-overlay .ccis-ov-h1 i { font-style: italic !important; }
.ccis-slider .ccis-content-overlay .ccis-ov-h1 h1,
.ccis-slider .ccis-content-overlay .ccis-ov-h1 h2,
.ccis-slider .ccis-content-overlay .ccis-ov-h1 h3,
.ccis-slider .ccis-content-overlay .ccis-ov-h1 p,
.ccis-slider .ccis-content-overlay .ccis-ov-h1 div {
  margin: 0 !important; padding: 0 !important; font-size: inherit !important;
  font-weight: inherit !important; line-height: inherit !important; color: inherit !important;
  display: inline !important; border: none !important; background: none !important;
}
.ccis-slider .ccis-content-overlay .ccis-ov-h2 {
  font-size: clamp(16px, 2.5vw, 30px) !important;
  font-weight: 600 !important;
  line-height: 1.3 !important;
  margin: 0 !important;
  padding: 0 !important;
  text-shadow: 0 2px 8px rgba(0,0,0,0.35) !important;
  max-width: 75% !important;
  opacity: 0.92 !important;
  border: none !important;
  background: none !important;
  text-decoration: none !important;
  letter-spacing: normal !important;
  text-transform: none !important;
  float: none !important;
  overflow-wrap: break-word !important;
  word-wrap: break-word !important;
}
.ccis-slider .ccis-content-overlay .ccis-ov-h2 span[style] { text-shadow: inherit; }
.ccis-slider .ccis-content-overlay .ccis-ov-h2 a { color: inherit !important; text-decoration: underline !important; }
.ccis-slider .ccis-content-overlay .ccis-ov-h2 strong,
.ccis-slider .ccis-content-overlay .ccis-ov-h2 b { font-weight: 700 !important; }
.ccis-slider .ccis-content-overlay .ccis-ov-h2 em,
.ccis-slider .ccis-content-overlay .ccis-ov-h2 i { font-style: italic !important; }
.ccis-slider .ccis-content-overlay .ccis-ov-h2 h1,
.ccis-slider .ccis-content-overlay .ccis-ov-h2 h2,
.ccis-slider .ccis-content-overlay .ccis-ov-h2 h3,
.ccis-slider .ccis-content-overlay .ccis-ov-h2 p,
.ccis-slider .ccis-content-overlay .ccis-ov-h2 div {
  margin: 0 !important; padding: 0 !important; font-size: inherit !important;
  font-weight: inherit !important; line-height: inherit !important; color: inherit !important;
  display: inline !important; border: none !important; background: none !important;
}
.ccis-slider .ccis-content-overlay .ccis-ov-para {
  font-size: clamp(13px, 1.6vw, 18px) !important;
  font-weight: 400 !important;
  line-height: 1.6 !important;
  margin: 0 !important;
  padding: 0 !important;
  text-shadow: 0 1px 6px rgba(0,0,0,0.3) !important;
  max-width: 70% !important;
  opacity: 0.88 !important;
  border: none !important;
  background: none !important;
  text-decoration: none !important;
  float: none !important;
  overflow-wrap: break-word !important;
  word-wrap: break-word !important;
}
.ccis-slider .ccis-content-overlay .ccis-ov-para p {
  margin: 0 0 0.4em 0 !important;
  padding: 0 !important;
  font-size: inherit !important;
  font-weight: inherit !important;
  line-height: inherit !important;
  color: inherit !important;
  text-shadow: inherit !important;
}
.ccis-slider .ccis-content-overlay .ccis-ov-para p:last-child { margin-bottom: 0 !important; }
.ccis-slider .ccis-content-overlay .ccis-ov-para ul,
.ccis-slider .ccis-content-overlay .ccis-ov-para ol {
  margin: 0 0 0.4em 1.2em !important;
  padding: 0 !important;
  font-size: inherit !important;
  color: inherit !important;
  text-shadow: inherit !important;
}
.ccis-slider .ccis-content-overlay .ccis-ov-para li {
  margin: 0 0 0.15em 0 !important;
  padding: 0 !important;
  font-size: inherit !important;
  color: inherit !important;
  line-height: inherit !important;
}
.ccis-slider .ccis-content-overlay .ccis-ov-para a { color: inherit !important; text-decoration: underline !important; }
.ccis-slider .ccis-content-overlay .ccis-ov-para span[style] { text-shadow: inherit; }
.ccis-slider .ccis-content-overlay .ccis-ov-para strong,
.ccis-slider .ccis-content-overlay .ccis-ov-para b { font-weight: 700 !important; }
.ccis-slider .ccis-content-overlay .ccis-ov-para em,
.ccis-slider .ccis-content-overlay .ccis-ov-para i { font-style: italic !important; }

/* --- Buttons wrapper --- */
.ccis-slider .ccis-content-overlay .ccis-buttons-wrap {
  display: flex !important;
  gap: 12px !important;
  flex-wrap: wrap !important;
  margin-top: 4px !important;
  padding: 0 !important;
  border: none !important;
  list-style: none !important;
}
.ccis-slider .ccis-align-center .ccis-buttons-wrap { justify-content: center !important; }
.ccis-slider .ccis-align-right .ccis-buttons-wrap { justify-content: flex-end !important; }

/* --- CTA Buttons (CSS custom property hover) --- */
.ccis-slider .ccis-content-overlay .ccis-cta-btn {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 12px 28px !important;
  font-size: 15px !important;
  font-weight: 600 !important;
  line-height: 1.2 !important;
  border-radius: 6px !important;
  text-decoration: none !important;
  cursor: pointer !important;
  transition: all 0.2s ease !important;
  white-space: nowrap !important;
  letter-spacing: 0.02em !important;
  box-shadow: 0 4px 14px rgba(0, 0, 0, 0.2) !important;
  visibility: visible !important;
  opacity: 1 !important;
  float: none !important;
  outline: none !important;
  text-transform: none !important;
  -webkit-appearance: none !important;
  appearance: none !important;
  --ccis-hv-text: inherit;
  --ccis-hv-bg: inherit;
  --ccis-hv-border: inherit;
  --ccis-n-text: #ffffff;
  --ccis-n-bg: #2563eb;
  --ccis-n-border: #2563eb;
  color: var(--ccis-n-text) !important;
  background: var(--ccis-n-bg) !important;
  border: 2px solid var(--ccis-n-border) !important;
}
.ccis-slider .ccis-content-overlay .ccis-cta-btn:hover {
  color: var(--ccis-hv-text) !important;
  background: var(--ccis-hv-bg) !important;
  border-color: var(--ccis-hv-border) !important;
  transform: translateY(-1px) !important;
  box-shadow: 0 6px 20px rgba(0, 0, 0, 0.3) !important;
}
.ccis-slider .ccis-content-overlay .ccis-cta-btn:active {
  transform: translateY(0) !important;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.25) !important;
}
.ccis-slider .ccis-content-overlay span.ccis-cta-btn {
  cursor: default !important;
}

/* --- Responsive overlay --- */
@media (max-width: 1024px) {
  .ccis-slider .ccis-slide .ccis-content-overlay { padding: 30px 40px !important; }
  .ccis-slider .ccis-content-overlay .ccis-cta-btn { padding: 10px 22px !important; font-size: 14px !important; }
  .ccis-slider .ccis-content-overlay .ccis-ov-h1 { max-width: 90% !important; }
  .ccis-slider .ccis-content-overlay .ccis-ov-h2 { max-width: 85% !important; }
  .ccis-slider .ccis-content-overlay .ccis-ov-para { max-width: 80% !important; }
}
@media (max-width: 768px) {
  .ccis-slider .ccis-slide .ccis-content-overlay { padding: 20px 24px !important; }
  .ccis-slider .ccis-content-overlay .ccis-buttons-wrap { gap: 8px !important; }
  .ccis-slider .ccis-content-overlay .ccis-cta-btn { padding: 8px 18px !important; font-size: 13px !important; border-radius: 5px !important; }
  .ccis-slider .ccis-content-overlay .ccis-ov-h1,
  .ccis-slider .ccis-content-overlay .ccis-ov-h2,
  .ccis-slider .ccis-content-overlay .ccis-ov-para { max-width: 95% !important; }
}
@media (max-width: 480px) {
  .ccis-slider .ccis-slide .ccis-content-overlay { padding: 14px 16px !important; }
  .ccis-slider .ccis-content-overlay .ccis-buttons-wrap { gap: 6px !important; }
  .ccis-slider .ccis-content-overlay .ccis-cta-btn { padding: 7px 14px !important; font-size: 12px !important; box-shadow: 0 2px 8px rgba(0,0,0,0.2) !important; }
  .ccis-slider .ccis-content-overlay .ccis-ov-h1,
  .ccis-slider .ccis-content-overlay .ccis-ov-h2,
  .ccis-slider .ccis-content-overlay .ccis-ov-para { max-width: 100% !important; }
}

/* --- Floating Images --- */
.ccis-slider .ccis-float-img {
  transition: transform 0.3s ease, box-shadow 0.3s ease !important;
  display: block !important;
}
.ccis-slider a.ccis-float-img:hover {
  transform: scale(1.03) !important;
}
.ccis-slider .ccis-float-img img {
  pointer-events: none !important;
}
/* Float image visibility — higher specificity to guarantee override */
@media (min-width: 1025px) {
  .ccis-slider .ccis-float-img.ccis-fi-hide-desktop { display: none !important; visibility: hidden !important; }
}
@media (min-width: 769px) and (max-width: 1024px) {
  .ccis-slider .ccis-float-img.ccis-fi-hide-tablet { display: none !important; visibility: hidden !important; }
}
@media (max-width: 768px) {
  .ccis-slider .ccis-float-img.ccis-fi-hide-mobile { display: none !important; visibility: hidden !important; }
}
/* All devices hidden */
.ccis-slider .ccis-float-img.ccis-ov-hidden { display: none !important; visibility: hidden !important; }
