:root {
  /* Colors */
  --tc-primary: #a8443e;
  --tc-white: #fff;
  --tc-border: #eee;
  --tc-text: #333;
  --tc-hover: #facc8d;

  /* Typography */
  --tc-font-primary: "Roboto", Sans-serif;
  --tc-font-size-large: 24px;
  --tc-font-size-base: 14px;

  /* Spacing */
  --tc-spacing-xs: 10px;
  --tc-spacing-sm: 12px;
  --tc-spacing-md: 15px;
  --tc-spacing-lg: 20px;
  --tc-spacing-xl: 50px;

  /* Components */
  --tc-border-radius: 12px;
  --tc-border-radius--large: 100px;
  --tc-nav-size: 50px;
  --tc-progress-height: 4px;
  --tc-arrow-size: 15px;

  /* Transitions */
  --tc-transition: all 0.3s ease;
}

/* Title */
.slider-title {
  font-size: var(--tc-font-size-large);
  font-weight: bold;
  margin-bottom: var(--tc-spacing-xl);
  text-transform: uppercase;
}

/* Slider Container */
.trading-cards-slider,
.trading-cards-grid {
  position: relative;
  overflow: hidden;
  padding-top: var(--tc-spacing-lg);
}

/* Card Item */
.trading-card-item {
  display: flex;
  flex-direction: column;
  gap: 25px;
  justify-content: start; /* or flex-start if you want content packed */
  height: 100%;
  flex: 1 1 calc(33.33% - 1rem); /* if using flexbox with 3 columns, adjust as needed */
  /* min-height: 100%; ensure stretching */
  box-sizing: border-box;

  /* Your existing styles */
  border: 3px solid var(--tc-white);
  border-radius: var(--tc-border-radius);
  overflow: hidden;
  transition: var(--tc-transition);
  background-color: var(--tc-white);
  padding: var(--tc-spacing-sm) var(--tc-spacing-md) var(--tc-spacing-md) var(--tc-spacing-md);

  &:is(:hover, :focus) {
    border: 3px solid var(--tc-hover);
  }
}

/* Flex wrapper */
.trading-card-item .flex-wrapper {
  display: flex;
  align-items: center;
  justify-content: space-between;
}

/* Swiper Slide */

.trading-cards-slider .swiper-slide {
  height: auto;
}

/* Sale badge */

.trading-card-item .flex-wrapper .sale-badge {
  background-color: var(--tc-primary);
  color: var(--tc-white);
  font-size: 12px;
  border-radius: 4px;
  padding: 4px;
}

/* Whislist */

.trading-card-item .flex-wrapper .wd-action-btn.wd-style-icon > a {
  width: auto;
  height: auto;
}

.trading-card-item .flex-wrapper > .wishlist-wrapper:first-child,
.trading-card-item .flex-wrapper > .wishlist-wrapper:nth-child(1):nth-last-child(1) {
    margin-left: auto;
}
/* Product Image */
.trading-cards-slider .product-image img,
.trading-cards-grid .product-image img {
  width: 100%;
  /* height: 128px; */
  height: 200px;
  object-fit: contain;
}

/* Language Flag */

.trading-cards-slider .language-flags img,
.trading-cards-grid .language-flags img{
  width: var(--tc-spacing-lg);
}

/* Product Title */
.trading-cards-slider .product-title,
.trading-cards-grid .product-title {
  font-family: var(--tc-font-primary);
  font-weight: 500;
  font-size: var(--tc-font-size-base);
  margin-bottom: var(--tc-spacing-lg);
}

/* Price */
.trading-card-item .price-wrapper {
  line-height: 100%;
  margin-bottom: var(--tc-spacing-xs);
}

.trading-card-item .price-wrapper > * {
  font-size: var(--tc-font-size-base);
  font-weight: 400;
}

/* Button */

.trading-card-item .button-wrapper a {
      border-radius: var(--btn-accented-brd-radius);
    color: var(--btn-accented-color);
    box-shadow: var(--btn-accented-box-shadow);
    background-color: var(--btn-accented-bgcolor);
    text-transform: var(--btn-accented-transform, var(--btn-transform, uppercase));
    font-weight: var(--btn-accented-font-weight, var(--btn-font-weight, 600));
    font-family: var(--btn-accented-font-family, var(--btn-font-family, inherit));
    font-style: var(--btn-accented-font-style, var(--btn-font-style, unset));
    width: 100%;

    &:is(:hover, :focus) {
   color: var(--btn-accented-color-hover);
    box-shadow: var(--btn-accented-box-shadow-hover);
    background-color: var(--btn-accented-bgcolor-hover);
    }
}

.trading-card-item .button-wrapper a:is(:hover, :focus) svg path {
  fill: var(--tc-white);
}

/* Progress Bar */
.trading-cards-slider .swiper-pagination {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: var(--tc-progress-height);
  background: rgba(0, 0, 0, 0.1);
  overflow: hidden;
  border-radius: 10px;
}

.trading-cards-slider .swiper-pagination-progressbar-fill {
  background: var(--tc-primary) !important;
}

/* Navigation Buttons */
.trading-cards-slider .swiper-button-next,
.trading-cards-slider .swiper-button-prev {
  background-color: var(--tc-primary);
  width: var(--tc-nav-size);
  height: var(--tc-nav-size);
  border-radius: 50%;
}

.trading-cards-slider .swiper-button-next:after,
.trading-cards-slider .swiper-button-prev:after {
  content: "";
  background-image: url("/wp-content/uploads/2024/12/arrow-right.svg");
  background-size: var(--tc-arrow-size);
  background-position: center;
  background-repeat: no-repeat;
  width: var(--tc-arrow-size);
  height: var(--tc-arrow-size);
}

.trading-cards-slider .swiper-button-prev:after {
  transform: rotate(180deg);
}

.trading-cards-grid {
  display: grid;
  gap: 20px; /* Adds spacing between grid items */
}

.trading-cards-grid.grid-columns-2 {
  grid-template-columns: repeat(2, 1fr); /* Creates 2 columns */
}

.trading-cards-grid.grid-columns-3 {
  grid-template-columns: repeat(3, 1fr); /* Creates 3 columns */
}

.trading-cards-grid.grid-columns-4 {
  grid-template-columns: repeat(4, 1fr); /* Creates 4 columns */
}

.trading-cards-grid.grid-columns-5 {
  grid-template-columns: repeat(5, 1fr); /* Creates 5 columns */
}

@media (max-width: 1024px) {
   .trading-cards-grid.grid-columns-4,
  .trading-cards-grid.grid-columns-5 {
     grid-template-columns: 1fr 1fr;
  }
}

/* Responsive */
@media (max-width: 768px) {
  .trading-cards-slider {
    /* margin: 0 var(--tc-spacing-lg); */
  }


  .trading-cards-grid.grid-columns-2,
  .trading-cards-grid.grid-columns-3,
  .trading-cards-grid.grid-columns-4,
  .trading-cards-grid.grid-columns-5  {
  grid-template-columns: 1fr; /* Creates 2 columns */
}

}

/* AJAX Placeholder - Diagonal Stripes Animation */
.trading-cards-widget-placeholder {
    min-height: 500px;
    background-color: #f7f7f7; /* Base color */
    border-radius: var(--tc-border-radius);
    display: flex;
    align-items: center;
    justify-content: center;
    
    /* Stripe Pattern */
    background-image: repeating-linear-gradient(
        45deg,
        #f7f7f7,
        #f7f7f7 20px,
        #ededed 20px,
        #ededed 40px
    );
    background-size: 56px 56px; /* Match pattern repeat size (approx 40px * sqrt(2)) */
    animation: trading-cards-stripe-scroll 1.5s linear infinite;
}

@keyframes trading-cards-stripe-scroll {
    to {
        background-position: 56px 0;
    }
}

.trading-cards-widget-placeholder .trading-cards-loader {
   display: none; /* Hide text, animation is enough */
}