/* PORT CARD IMPROVEMENTS - Override cruise-line-ports-carousel.css */

/* Fix cruise-ports search page grid */
.view-cruise-ports-search .view-content {
  display: grid !important;
  grid-template-columns: repeat(1, 1fr) !important;
  gap: 2rem !important;
}

@media (min-width: 768px) {
  .view-cruise-ports-search .view-content {
    grid-template-columns: repeat(3, 1fr) !important;
  }
}

@media (min-width: 1024px) {
  .view-cruise-ports-search .view-content {
    grid-template-columns: repeat(4, 1fr) !important;
  }
}

.view-cruise-ports-search .cruise-port-card {
  width: 100% !important;
}

/* PORT CARD IMPROVEMENTS - Override cruise-line-ports-carousel.css */

/* Fix placeholder styling */
.cruise-line-ports-carousel .cruise-port-card__image--placeholder,
.cruise-port-card__image--placeholder {
  background: linear-gradient(135deg, #e0e7ff 0%, #c7d2fe 100%) !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  min-height: 250px !important;
  height: 250px !important;
  position: relative !important;
}

.port-placeholder-content {
  text-align: center !important;
  padding: 20px !important;
  z-index: 10 !important;
  position: relative !important;
}

.port-placeholder-text {
  margin-top: 15px !important;
  font-size: 16px !important;
  font-weight: 700 !important;
  color: #1e40af !important;
  text-transform: uppercase !important;
  letter-spacing: 0.5px !important;
}

/* Fix all port card images - MUST respect Splide slide width */
.cruise-line-ports-carousel .splide__slide,
.cruise-line-ports-carousel .port-card-wrapper {
  width: 300px !important;
  max-width: 300px !important;
  flex: 0 0 300px !important;
}

.cruise-line-ports-carousel .cruise-port-card,
.cruise-line-ports-carousel .cruise-port-card__link {
  width: 100% !important;
  max-width: 100% !important;
}

.cruise-line-ports-carousel .cruise-port-card__image {
  position: absolute !important;
  top: 0 !important;
  left: 0 !important;
  width: 100% !important;
  height: 100% !important;
  overflow: hidden !important;
  background: transparent !important;
  display: block !important;
}

/* For search pages - different layout */
.view-cruise-ports-search .cruise-port-card__image {
  position: relative !important;
  width: 100% !important;
  min-height: 250px !important;
  max-height: 250px !important;
  height: 250px !important;
  overflow: hidden !important;
  background: #f0f4f8 !important;
  display: block !important;
}

/* Ensure all wrapper divs are visible */
.cruise-port-card__image .field,
.cruise-port-card__image .field__item,
.cruise-port-card__image .media,
.cruise-port-card__image .field__items {
  display: block !important;
  width: 100% !important;
  height: 100% !important;
  margin: 0 !important;
  padding: 0 !important;
  position: relative !important;
}

/* Fix image aspect ratio - don't stretch */
.cruise-line-ports-carousel .cruise-port-card__image img,
.cruise-port-card__image img,
.view-cruise-ports-search .cruise-port-card__image img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  object-position: center !important;
  display: block !important;
  position: absolute !important;
  top: 0 !important;
  left: 0 !important;
}

/* Ensure port name is always visible */
.cruise-port-card__title {
  font-size: 1.125rem !important;
  font-weight: 700 !important;
  color: #1e3a8a !important;
  margin-bottom: 0.75rem !important;
  line-height: 1.3 !important;
  min-height: 2.6em !important;
  display: flex !important;
  align-items: center !important;
}

.cruise-port-card__content {
  padding: 1.25rem !important;
  flex: 1 !important;
  display: flex !important;
  flex-direction: column !important;
}

/* Card hover effect */
.cruise-port-card {
  transition: transform 0.3s ease, box-shadow 0.3s ease !important;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1) !important;
  border-radius: 12px !important;
  overflow: hidden !important;
  background: transparent !important;
  height: 100% !important;
  display: flex !important;
  flex-direction: column !important;
}

/* Only use white background on search pages, not carousel */
.view-cruise-ports-search .cruise-port-card {
  background: #fff !important;
}

.cruise-port-card:hover {
  transform: translateY(-4px) !important;
  box-shadow: 0 8px 20px rgba(0, 0, 0, 0.15) !important;
}

.cruise-port-card__link {
  display: flex !important;
  flex-direction: column !important;
  height: 100% !important;
  text-decoration: none !important;
  color: inherit !important;
}
