/**
 * Logo Carousel Styles
 * Horizontal scrolling carousel for partner/store logos
 */

.publideals-logo-carousel {
  width: 100%;
  position: relative;
}

/* Background Colors - Standard Options */
.logo-carousel--bg-primary {
  background-color: #68468F; /* Forest Green */
}

.logo-carousel--bg-accent {
  background-color: #FF6B35; /* Coral */
}

.logo-carousel--bg-tertiary {
  background-color: #7ED9B3; /* Aqua */
}

.logo-carousel--bg-info {
  background-color: #3B82F6; /* Blue */
}

.logo-carousel--bg-warning {
  background-color: #F59E0B; /* Mustard */
}

.logo-carousel--bg-light {
  background-color: #F9FAFB; /* Off-white */
}

.logo-carousel--bg-white {
  background-color: #FFFFFF;
}

.logo-carousel--bg-custom {
  /* Custom background color applied via inline style */
}

/* Text Colors - Standard Options */
.logo-carousel--text-white .carousel-heading,
.logo-carousel--text-white .carousel-description {
  color: #FFFFFF;
}

.logo-carousel--text-dark .carousel-heading,
.logo-carousel--text-dark .carousel-description {
  color: #68468F;
}

.logo-carousel--text-custom {
  /* Custom text color applied via inline style, children inherit */
}

.logo-carousel--text-custom .carousel-heading,
.logo-carousel--text-custom .carousel-description {
  color: inherit;
}

/* Container */
.logo-carousel-container {
  max-width: 1440px;
  margin: 0 auto;
  /* padding: 0 48px; */
}

/* Header */
/* .carousel-header {
  text-align: center;
  margin-bottom: 48px;
} */

.carousel-heading {
  font-size: 36px;
  font-weight: 700;
  color: #68468F;
  margin: 0 0 16px 0;
  line-height: 1.2;
}

.carousel-description {
  font-size: 16px;
  color: #6B7280;
  margin: 0;
  /* max-width: 600px; */
  margin-left: auto;
  margin-right: auto;
  text-align: left; /* Default to left, CKEditor styles will override */
}

/* CKEditor content - ensure inline styles have highest priority */
.carousel-description [style] {
  all: revert !important;
}

.carousel-description [style] * {
  all: revert !important;
}

/* Ensure CKEditor content can override parent text-align */
.carousel-description p,
.carousel-description div,
.carousel-description h1,
.carousel-description h2,
.carousel-description h3,
.carousel-description h4,
.carousel-description h5,
.carousel-description h6,
.carousel-description ul,
.carousel-description ol,
.carousel-description li,
.carousel-description blockquote {
  text-align: inherit;
}

/* CKEditor alignment classes - highest priority */
.carousel-description .text-align-left,
.carousel-description [style*="text-align: left"],
.carousel-description [style*="text-align:left"] {
  text-align: left !important;
}

.carousel-description .text-align-center,
.carousel-description [style*="text-align: center"],
.carousel-description [style*="text-align:center"] {
  text-align: center !important;
}

.carousel-description .text-align-right,
.carousel-description [style*="text-align: right"],
.carousel-description [style*="text-align:right"] {
  text-align: right !important;
}

.carousel-description .text-align-justify,
.carousel-description [style*="text-align: justify"],
.carousel-description [style*="text-align:justify"] {
  text-align: justify !important;
}

/* Preserve specific CKEditor formatting elements */
.carousel-description strong,
.carousel-description b,
.carousel-description em,
.carousel-description i,
.carousel-description u,
.carousel-description s,
.carousel-description sub,
.carousel-description sup {
  all: revert !important;
}

/* Carousel Wrapper */
.carousel-wrapper {
  position: relative;
  display: flex;
  align-items: center;
  gap: 24px;
}

/* Navigation Arrows */
.carousel-arrow {
  position: relative;
  flex-shrink: 0;
  width: 48px;
  height: 48px;
  border-radius: 50%;
  background: #FFFFFF;
  border: 2px solid #E5E7EB;
  color: #68468F;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.2s ease;
  z-index: 2;
}

.carousel-arrow:hover {
  background: #F9FAFB;
  border-color: #68468F;
  transform: scale(1.05);
}

.carousel-arrow:disabled {
  opacity: 0.3;
  cursor: not-allowed;
  transform: none;
}

.carousel-arrow svg {
  width: 24px;
  height: 24px;
}

/* Track Container */
.carousel-track-container {
  overflow: hidden;
  flex: 1;
  position: relative;
}

/* Track */
.carousel-track {
  display: flex;
  /* gap controlled via inline style */
  transition: transform 0.5s ease;
}

/* Carousel Items */
.logo-carousel-item {
  flex: 0 0 auto;
  display: flex;
  align-items: center;
  justify-content: center;
  /* padding: 32px; */
  /* min-height removed to allow item to fit logo dimensions */
}

/* Calculate item width based on items per slide */
.carousel-track[data-items-per-slide="3"] .logo-carousel-item {
  width: calc((100% - var(--carousel-gap, 32px) * 2) / 3);
}

.carousel-track[data-items-per-slide="4"] .logo-carousel-item {
  width: calc((100% - var(--carousel-gap, 32px) * 3) / 4);
}

.carousel-track[data-items-per-slide="5"] .logo-carousel-item {
  width: calc((100% - var(--carousel-gap, 32px) * 4) / 5);
}

.carousel-track[data-items-per-slide="6"] .logo-carousel-item {
  width: calc((100% - var(--carousel-gap, 32px) * 5) / 6);
}

/* Custom items per slide - uses CSS custom properties for any value */
.carousel-track:not([data-items-per-slide="3"]):not([data-items-per-slide="4"]):not([data-items-per-slide="5"]):not([data-items-per-slide="6"]) .logo-carousel-item {
  width: calc((100% - var(--carousel-gap, 32px) * (var(--items-per-slide, 4) - 1)) / var(--items-per-slide, 4));
}

/* Logo Wrapper */
.logo-link,
.logo-wrapper {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
  text-decoration: none;
  transition: transform 0.2s ease;
}

.logo-link:hover {
  transform: scale(1.05);
}

/* Logo Image - dimensions and object-fit controlled via inline styles */
.logo-image {
  max-width: 100%;
  transition: filter 0.3s ease, opacity 0.3s ease;
}

/* Logo Style: Default */
.logo-style-default .logo-image {
  filter: none;
  opacity: 1;
}

/* Logo Style: Grayscale */
.logo-style-grayscale .logo-image {
  filter: grayscale(100%);
  opacity: 0.7;
}

.logo-style-grayscale .logo-link:hover .logo-image,
.logo-style-grayscale .logo-wrapper:hover .logo-image {
  filter: grayscale(0%);
  opacity: 1;
}

/* Logo Style: Boxed */
.logo-style-boxed {
  border: 1px solid #E5E7EB;
  border-radius: 8px;
  background: #FFFFFF;
}

.logo-style-boxed:hover {
  border-color: #68468F;
  box-shadow: 0 4px 12px rgba(0, 40, 35, 0.1);
}

/* Dot Indicators */
.carousel-dots {
  display: flex;
  justify-content: center;
  gap: 12px;
  margin-top: 25px;
}

.carousel-dot {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: #D1D5DB;
  border: none;
  cursor: pointer;
  padding: 0;
  transition: all 0.3s ease;
}

.carousel-dot:hover {
  background: #9CA3AF;
  transform: scale(1.2);
}

.carousel-dot.active {
  background: #68468F;
  width: 32px;
  border-radius: 5px;
}

/* View More Button */
.carousel-footer {
  text-align: center;
  margin-top: 30px;
}

.view-more-button {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  padding: 12px 35px;
  background: #68468F;
  color: #FFFFFF;
  border: 2px solid #68468F;
  border-radius: 8px;
  font-size: 16px;
  font-weight: 600;
  text-decoration: none;
  transition: all 0.3s ease;
  line-height: 1.5;
}

.view-more-button:hover {
  background: #003D35;
  border-color: #003D35;
  transform: translateY(-2px);
  box-shadow: 0 8px 16px rgba(0, 40, 35, 0.2);
}

.view-more-button svg {
  width: 20px;
  height: 20px;
  transition: transform 0.2s ease;
}

.view-more-button:hover svg {
  transform: translateX(4px);
}

/* Grid Layout */
.logo-grid {
  width: 100%;
}

.logo-grid .logo-grid-item {
  display: flex;
  align-items: center;
  justify-content: center;
}

/* Responsive Design - Grid Mode */
@media (max-width: 767px) {
  .logo-grid {
    grid-template-columns: repeat(2, 1fr) !important;
  }
}

@media (max-width: 480px) {
  .logo-grid {
    grid-template-columns: 1fr !important;
  }
}

/* Responsive Design - Carousel Mode */
@media (max-width: 1200px) {
  .carousel-track[data-items-per-slide="6"] .logo-carousel-item,
  .carousel-track[data-items-per-slide="5"] .logo-carousel-item {
    width: calc((100% - var(--carousel-gap, 32px) * 3) / 4);
  }
}

@media (max-width: 1024px) {

  .carousel-heading {
    font-size: 32px;
  }

  .carousel-track[data-items-per-slide="6"] .logo-carousel-item,
  .carousel-track[data-items-per-slide="5"] .logo-carousel-item,
  .carousel-track[data-items-per-slide="4"] .logo-carousel-item {
    width: calc((100% - var(--carousel-gap, 32px) * 2) / 3);
  }

  .carousel-arrow {
    width: 40px;
    height: 40px;
  }

  .carousel-arrow svg {
    width: 20px;
    height: 20px;
  }
}

@media (max-width: 767px) {

  .carousel-heading {
    font-size: 28px;
  }

  .carousel-description {
    font-size: 14px;
  }

  .carousel-header {
    margin-bottom: 32px;
  }

  .carousel-wrapper {
    gap: 16px;
  }

  /* All configurations show 2 items on tablet */
  .carousel-track[data-items-per-slide] .logo-carousel-item {
    width: calc((100% - 16px) / 2);
  }


  .carousel-arrow {
    width: 36px;
    height: 36px;
  }

  .carousel-arrow svg {
    width: 18px;
    height: 18px;
  }
}

@media (max-width: 480px) {

  .carousel-heading {
    font-size: 24px;
  }

  .carousel-header {
    margin-bottom: 24px;
  }

  /* Show 1 item on mobile */
  .carousel-track[data-items-per-slide] .logo-carousel-item {
    width: 100%;
  }

  .carousel-wrapper {
    gap: 12px;
  }

  .carousel-arrow {
    width: 32px;
    height: 32px;
  }

  .view-more-button {
    width: 100%;
    justify-content: center;
    max-width: 300px;
  }

  .carousel-dots {
    margin-top: 24px;
    gap: 8px;
  }

  .carousel-dot {
    width: 8px;
    height: 8px;
  }

  .carousel-dot.active {
    width: 24px;
  }
}

/* Accessibility */
.carousel-arrow:focus-visible,
.carousel-dot:focus-visible,
.view-more-button:focus-visible {
  outline: 2px solid #7ED9B3;
  outline-offset: 2px;
}

/* Loading State */
.carousel-track.is-transitioning {
  pointer-events: none;
}

.logo-carousel-container .logo-carousel-item a{
  justify-content: center !important;
}