
/* FIX: Prevent cards from being cut off on the right */
.cruise-type-section {
  width: 100% !important;
  max-width: 100% !important;
  overflow-x: hidden !important;
  padding: 0 !important;
  margin: 40px 0 !important;
  box-sizing: border-box !important;
}

/* Ensure the grid container doesn't overflow */
.views-view-grid,
.views-view-grid--horizontal {
  width: 100% !important;
  max-width: 100% !important;
  box-sizing: border-box !important;
  padding: 0 !important;
  margin: 0 !important;
}

/* Prevent individual grid items from overflowing */
.views-view-grid__item {
  box-sizing: border-box !important;
  max-width: 100% !important;
  padding: 0 !important;
}

.views-view-grid__item-inner {
  box-sizing: border-box !important;
  max-width: 100% !important;
  width: 100% !important;
}

/* FIX: Widen cruise line badge for longer names */
.cruise-ship-card__cruise-line-badge {
  position: absolute !important;
  top: 12px !important;
  left: 12px !important;
  background: rgba(255, 255, 255, 0.95) !important;
  padding: 6px 12px !important;
  border-radius: 12px !important;
  font-size: 11px !important;
  font-weight: 500 !important;
  color: #2c3e50 !important;
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1) !important;
  z-index: 5 !important;
  /* Increased width limits */
  max-width: 70% !important; /* Increased from 150px to 70% of card width */
  min-width: auto !important;
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
}

/* For very long names, allow wrapping on smaller screens */
@media (max-width: 600px) {
  .cruise-ship-card__cruise-line-badge {
    white-space: normal !important;
    max-width: 80% !important;
    line-height: 1.2 !important;
  }
}

/* Ensure cards themselves don't overflow */
.cruise-ship-card,
.cruise-line-card {
  box-sizing: border-box !important;
  max-width: 100% !important;
  width: 100% !important;
}

/* FORCE image heights to 200px - override global.css height: auto */
.cruise-line-card__image-wrapper img,
.cruise-line-card__cover-image img,
.cruise-ship-card__image-wrapper img,
.cruise-ship-card__image img {
  width: 100% !important;
  height: 200px !important;
  min-height: 200px !important;
  max-height: 200px !important;
  object-fit: cover !important;
  object-position: center !important;
  display: block !important;
}

/* Fix grid gaps to prevent overflow */
.views-view-grid,
.views-view-grid--horizontal {
  gap: 20px !important; /* Reduced from 24px to give more room */
}

/* Responsive adjustments with proper containment */
@media (min-width: 1200px) {
  .views-view-grid,
  .views-view-grid--horizontal {
    grid-template-columns: repeat(4, minmax(0, 1fr)) !important; /* Use minmax for better sizing */
  }
}

@media (max-width: 1199px) and (min-width: 900px) {
  .views-view-grid,
  .views-view-grid--horizontal {
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  }
}

@media (max-width: 899px) and (min-width: 600px) {
  .views-view-grid,
  .views-view-grid--horizontal {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }
}

@media (max-width: 599px) {
  .views-view-grid,
  .views-view-grid--horizontal {
    grid-template-columns: minmax(0, 1fr) !important;
  }
}
