.travel-offers-wrap { margin: 0 auto 30px; }

.travel-offers-heading {
  color: var(--travel-offers-h1-color, inherit);
  text-align: center;
  margin-bottom: 20px;
  font-size: var(--travel-offers-heading-size, 1.5em);
  line-height: 1.1;
}

@media screen and (min-width: 769px) {
  .travel-offers-heading {
    margin-bottom: 40px;
  }
}

.offers-card-container {
  display: grid;
  grid-template-columns: repeat(var(--to-desktop-cols, 4), minmax(0, 1fr));
  gap: 20px;
  max-width: 90%;
  margin: auto;
}

.offers-card {
  width: 100%;
  height: 500px;
  perspective: 1000px;
  box-shadow: 0 4px 10px rgba(0,0,0,.5);
  overflow: hidden;
  position: relative;
}

.offers-card-front,
.offers-card-back {
  position: absolute;
  width: 100%;
  height: 100%;
  backface-visibility: hidden;
  background: #fff;
  transition: transform .6s ease-in-out;
}

.offers-card-front { transform: rotateY(0deg); z-index: 2; }
.offers-card-back { transform: rotateY(180deg); z-index: 1; padding: 20px; font-size: 12px; overflow: auto; }

.offers-card.flipped .offers-card-front { transform: rotateY(-180deg); z-index: 1; }
.offers-card.flipped .offers-card-back { transform: rotateY(0deg); z-index: 2; }

.offers-card-front > img {
  width: 100%;
  height: 200px;
  object-fit: cover;
  display: block;
}

.offers-card-content {
  padding: 20px;
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  align-items: center;
}

.offers-headline {
  color: var(--travel-offers-headline-color, inherit);
  font-size: 18px;
  font-weight: bold;
  margin: 10px 0;
  text-align: center;
}

.offers-description {
  font-size: 14px;
  color: #666;
  text-align: center;
  margin: 10px 0;
}

.offers-view-details,
.offers-interest-link {
  border: 1px solid var(--travel-offers-accent-color, currentColor) !important;
  background: #fff;
  color: var(--travel-offers-accent-color, currentColor);
  padding: 10px 20px;
  cursor: pointer;
  margin: 20px auto;
  display: inline-block;
  text-transform: uppercase;
  text-decoration: none;
  transition: background-color .3s ease, color .3s ease;
}

.offers-view-details:hover,
.offers-interest-link:hover {
  background-color: var(--travel-offers-hover-color, var(--travel-offers-accent-color, currentColor));
  border: 1px solid var(--travel-offers-hover-color, var(--travel-offers-accent-color, currentColor)) !important;
}

.offers-logo {
  width: 80%;
  position: absolute;
  bottom: 20px;
  left: 10%;
  display: flex;
  justify-content: center;
  align-items: center;
}

.offers-logo img {
  width: auto;
  height: auto;
  max-width: 100%;
  max-height: 50px;
  object-fit: contain;
}

.offers-card-back-inner {
  display: flex;
  flex-direction: column;
  gap: 14px;
  min-height: 100%;
  justify-content: space-between;
}

.offers-cta-wrap {
  text-align: center;
  margin: 0;
}

.offers-legal {
  text-align: center;
  font-size: 12px;
  line-height: 1.4;
}

.offers-legal p { margin: 0 0 6px; }
.offers-legal p:last-child { margin-bottom: 0; }

.travel-offers-load-more-wrap {
  text-align: center;
  margin-top: 24px;
}

.travel-offers-load-more {
  border: 1px solid var(--travel-offers-accent-color, currentColor);
  background: #fff;
  color: var(--travel-offers-accent-color, currentColor);
  padding: 10px 20px;
  cursor: pointer;
  text-transform: uppercase;
}

.travel-offers-load-more:hover {
  background: var(--travel-offers-hover-color, var(--travel-offers-accent-color, currentColor));
  color: #fff;
  border-color: var(--travel-offers-hover-color, var(--travel-offers-accent-color, currentColor));
}

@media screen and (max-width: 1024px) {
  .offers-card-container {
    grid-template-columns: repeat(var(--to-tablet-cols, 2), minmax(0, 1fr));
  }
}

@media screen and (max-width: 768px) {
  .offers-card-container {
    grid-template-columns: repeat(var(--to-mobile-cols, 1), minmax(0, 1fr));
  }
}