.travelray-content .card-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap: 1.5rem;
  margin: 1.5rem 0;
}

.travelray-content .card {
  background: #fff;
  border-radius: 12px;
  overflow: hidden;
  box-shadow: 0 8px 24px rgba(18, 53, 91, 0.08);
}

.travelray-content .card img {
  width: 100%;
  height: 180px;
  object-fit: cover;
  display: block;
}

.travelray-content .card h2,
.travelray-content .card h3 {
  margin: 1rem;
  font-size: 1.1rem;
}

.travelray-content .meta,
.travelray-content .price,
.travelray-content .warning {
  margin: 0 1rem 1rem;
}

.travelray-content .warning {
  color: #b45309;
  font-weight: bold;
}

.travelray-content .travelray-button {
  display: inline-block;
  margin: 1rem;
  padding: 0.75rem 1rem;
  background: #12355b;
  color: #fff;
  text-decoration: none;
  border-radius: 999px;
  font: inherit;
}

.travelray-content .product-filters {
  margin: 1rem 0 2rem;
}

.travelray-content .room-card {
  display: flex;
  flex-direction: column;
}

.travelray-content .room-card h3 a {
  color: inherit;
  text-decoration: none;
}

.travelray-content .room-card h3 a:hover {
  text-decoration: underline;
}

.travelray-content .room-card .room-card-link {
  margin-top: auto;
}

.travelray-content .room-breadcrumb {
  margin: 0 0 1rem;
}

.travelray-content .room-breadcrumb a {
  color: #12355b;
  text-decoration: none;
}

.travelray-content .room-breadcrumb a:hover {
  text-decoration: underline;
}

.travelray-content .single-room .booking-box,
.travelray-content .single-tour .booking-box {
  margin-top: 2rem;
}

.travelray-content .on-request-note {
  margin-top: 1.5rem;
  color: #64748b;
}
