body.housing-catalog-page,
body.activity-catalog-page,
body.restaurant-catalog-page {
  --catalog-shell-max: 1360px;
  --catalog-sidebar-width: 292px;
  --catalog-gap: 24px;
  --catalog-surface:
    radial-gradient(circle at top left, rgba(255, 255, 255, 0.76), transparent 38%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.76), rgba(239, 247, 241, 0.4));
  --catalog-border: rgba(255, 255, 255, 0.72);
  --catalog-shadow:
    0 22px 46px rgba(23, 55, 35, 0.12),
    inset 0 1px 0 rgba(255, 255, 255, 0.82);
  --catalog-text: #214331;
  --catalog-muted: #5a7263;
  --catalog-accent: #2fb861;
  --catalog-accent-strong: #23784a;
  background:
    radial-gradient(circle at 6% 12%, rgba(204, 239, 210, 0.46), transparent 24%),
    radial-gradient(circle at 92% 12%, rgba(249, 250, 224, 0.46), transparent 26%),
    linear-gradient(180deg, #f5f1e8 0%, #f8faf7 220px, #f6faf6 100%);
  color: var(--catalog-text);
}

body.housing-catalog-page :is(.housing-page-shell, .housing-page-shell *),
body.activity-catalog-page :is(.activity-page-shell, .activity-page-shell *),
body.restaurant-catalog-page :is(.restaurant-page, .restaurant-page *) {
  box-sizing: border-box;
}

body.housing-catalog-page:not(.has-travel-roadmap) .housing-page-shell,
body.activity-catalog-page:not(.has-travel-roadmap) .activity-page-shell,
body.restaurant-catalog-page:not(.has-travel-roadmap) .restaurant-page {
  width: min(var(--catalog-shell-max), calc(100vw - 48px)) !important;
  margin: 30px auto 84px !important;
}

body.housing-catalog-page.has-travel-roadmap .housing-page-shell,
body.activity-catalog-page.has-travel-roadmap .activity-page-shell,
body.restaurant-catalog-page.has-travel-roadmap .restaurant-page {
  width: min(var(--catalog-shell-max), calc(100vw - var(--travel-roadmap-offset, 0px) - 52px)) !important;
  margin: 30px auto 84px 20px !important;
}

body.housing-catalog-page :is(.housing-intro, .housing-types, .housing-filters, .housing-calendar, .housing-results),
body.activity-catalog-page :is(.activity-intro, .activity-themes, .activity-filters, .activity-results),
body.restaurant-catalog-page :is(.restaurant-intro, .restaurant-themes, .restaurant-filters, .restaurant-results) {
  position: static !important;
  left: auto !important;
  right: auto !important;
  top: auto !important;
  bottom: auto !important;
  width: 100% !important;
  min-width: 0 !important;
  min-height: 0 !important;
  margin: 0 !important;
  padding: 22px 24px !important;
  border-radius: 30px !important;
  border: 1px solid var(--catalog-border) !important;
  background: var(--catalog-surface) !important;
  box-shadow: var(--catalog-shadow) !important;
  backdrop-filter: blur(24px) saturate(155%);
  -webkit-backdrop-filter: blur(24px) saturate(155%);
}

body.housing-catalog-page .housing-page-shell {
  display: grid !important;
  grid-template-columns: var(--catalog-sidebar-width) minmax(0, 1fr) !important;
  grid-template-areas:
    "filters intro"
    "filters calendar"
    "filters types"
    "filters results" !important;
  align-items: start !important;
  gap: var(--catalog-gap) !important;
}

body.activity-catalog-page .activity-page-shell {
  display: grid !important;
  grid-template-columns: var(--catalog-sidebar-width) minmax(0, 1fr) !important;
  grid-template-areas:
    "filters intro"
    "filters themes"
    "filters results" !important;
  align-items: start !important;
  gap: var(--catalog-gap) !important;
}

body.restaurant-catalog-page .restaurant-page {
  display: grid !important;
  grid-template-columns: var(--catalog-sidebar-width) minmax(0, 1fr) !important;
  grid-template-areas:
    "filters intro"
    "filters themes"
    "filters results" !important;
  align-items: start !important;
  gap: var(--catalog-gap) !important;
  padding: 0 !important;
}

body.housing-catalog-page .housing-intro { grid-area: intro; }
body.housing-catalog-page .housing-results { grid-area: results; }
body.housing-catalog-page .housing-types { grid-area: types; }
body.housing-catalog-page .housing-calendar { grid-area: calendar; }
body.housing-catalog-page .housing-filters { grid-area: filters; }

body.activity-catalog-page .activity-intro { grid-area: intro; }
body.activity-catalog-page .activity-results { grid-area: results; }
body.activity-catalog-page .activity-themes { grid-area: themes; }
body.activity-catalog-page .activity-filters { grid-area: filters; }

body.restaurant-catalog-page .restaurant-intro { grid-area: intro; }
body.restaurant-catalog-page .restaurant-results { grid-area: results; }
body.restaurant-catalog-page .restaurant-themes { grid-area: themes; }
body.restaurant-catalog-page .restaurant-filters { grid-area: filters; }

body.housing-catalog-page .housing-filters,
body.activity-catalog-page .activity-filters,
body.restaurant-catalog-page .restaurant-filters {
  position: sticky !important;
  top: 104px !important;
  align-self: start !important;
  max-height: calc(100vh - 126px) !important;
  overflow-y: auto !important;
  overflow-x: hidden !important;
  scrollbar-width: none;
  -ms-overflow-style: none;
}

body.housing-catalog-page .housing-filters::-webkit-scrollbar,
body.activity-catalog-page .activity-filters::-webkit-scrollbar,
body.restaurant-catalog-page .restaurant-filters::-webkit-scrollbar {
  width: 0;
  height: 0;
}

body.housing-catalog-page .housing-intro,
body.activity-catalog-page .activity-intro,
body.restaurant-catalog-page .restaurant-intro {
  display: grid !important;
  gap: 10px;
  align-content: center;
  justify-items: center;
  text-align: center;
  min-height: 0 !important;
  padding: 18px 22px !important;
}

body.housing-catalog-page .page-title,
body.activity-catalog-page .page-title,
body.restaurant-catalog-page .page-title {
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
  justify-self: center;
  width: fit-content;
  max-width: min(640px, 100%);
  margin: 0 !important;
  padding: 10px 22px !important;
  border-radius: 24px !important;
  border: 1px solid rgba(255, 255, 255, 0.42) !important;
  background: linear-gradient(135deg, #2eb860 0%, #37c66a 55%, #52d57f 100%) !important;
  color: #f7fff8 !important;
  font-size: clamp(1.48rem, 2vw, 2.45rem) !important;
  line-height: 1.08 !important;
  letter-spacing: -0.03em !important;
  text-align: center !important;
  box-shadow:
    0 14px 28px rgba(42, 125, 70, 0.18),
    inset 0 1px 0 rgba(255, 255, 255, 0.24) !important;
}

body.housing-catalog-page .subtitle,
body.activity-catalog-page .subtitle,
body.restaurant-catalog-page .subtitle {
  max-width: 760px !important;
  margin: 0 !important;
  color: var(--catalog-muted) !important;
  justify-self: center;
  text-align: center !important;
  font-size: 0.98rem !important;
  line-height: 1.58 !important;
}

body.housing-catalog-page :is(.housing-types h2, .housing-calendar h2, .housing-filters h2, .housing-results h2),
body.activity-catalog-page :is(.activity-themes h2, .activity-filters h2, .activity-results h2),
body.restaurant-catalog-page :is(.restaurant-themes h2, .restaurant-filters h2, .restaurant-results h2) {
  margin: 0 0 14px !important;
  color: var(--catalog-text) !important;
  font-size: 1.5rem !important;
}

body.housing-catalog-page .theme-tags,
body.activity-catalog-page .theme-tags,
body.restaurant-catalog-page .theme-tags {
  display: flex !important;
  flex-wrap: wrap !important;
  justify-content: flex-start !important;
  gap: 10px !important;
}

body.housing-catalog-page :is(.theme-btn, .filter-check-pill),
body.activity-catalog-page .theme-btn,
body.restaurant-catalog-page .theme-btn {
  min-height: 38px !important;
  padding: 0 14px !important;
  border-radius: 999px !important;
  border: 1px solid rgba(131, 178, 141, 0.28) !important;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.82), rgba(228, 243, 231, 0.44)) !important;
  color: #29553b !important;
  font-weight: 700 !important;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.82) !important;
}

body.housing-catalog-page :is(.theme-btn:hover, .filter-check-pill:hover),
body.activity-catalog-page .theme-btn:hover,
body.restaurant-catalog-page .theme-btn:hover,
body.housing-catalog-page :is(.theme-btn.active, .filter-check-pill.is-active),
body.activity-catalog-page .theme-btn.active,
body.restaurant-catalog-page .theme-btn.active {
  background: linear-gradient(135deg, rgba(47, 184, 97, 0.18), rgba(88, 214, 126, 0.22)) !important;
  color: var(--catalog-accent-strong) !important;
}

body.housing-catalog-page .filter-grid,
body.activity-catalog-page .filter-grid,
body.restaurant-catalog-page .filter-grid {
  display: grid !important;
  grid-template-columns: 1fr !important;
  gap: 12px !important;
  align-items: stretch !important;
}

body.housing-catalog-page .filter-group,
body.activity-catalog-page .filter-group,
body.restaurant-catalog-page .filter-group {
  display: grid !important;
  gap: 7px !important;
  min-width: 0 !important;
}

body.housing-catalog-page .filter-group-wide,
body.activity-catalog-page .filter-group-wide,
body.restaurant-catalog-page .filter-group-wide {
  grid-column: auto !important;
}

body.housing-catalog-page .filter-group label,
body.activity-catalog-page .filter-group label,
body.restaurant-catalog-page .filter-group label,
body.activity-catalog-page .inline-toggle span {
  margin: 0 !important;
  color: #2d563e !important;
  font-size: 0.84rem !important;
  font-weight: 700 !important;
  line-height: 1.35;
}

body.housing-catalog-page :is(.filter-group input, .filter-group select),
body.activity-catalog-page :is(.filter-group input, .filter-group select),
body.restaurant-catalog-page :is(.filter-group input, .filter-group select) {
  width: 100% !important;
  min-height: 44px !important;
  padding: 10px 13px !important;
  border-radius: 16px !important;
  border: 1px solid rgba(113, 162, 124, 0.28) !important;
  background: rgba(255, 255, 255, 0.88) !important;
  color: var(--catalog-text) !important;
  font-size: 0.95rem !important;
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.86),
    0 8px 20px rgba(19, 45, 30, 0.06) !important;
  transform: none !important;
}

body.housing-catalog-page :is(.filter-group input:hover, .filter-group select:hover, .filter-group input:focus, .filter-group select:focus),
body.activity-catalog-page :is(.filter-group input:hover, .filter-group select:hover, .filter-group input:focus, .filter-group select:focus),
body.restaurant-catalog-page :is(.filter-group input:hover, .filter-group select:hover, .filter-group input:focus, .filter-group select:focus) {
  border-color: rgba(68, 130, 89, 0.46) !important;
  box-shadow:
    0 0 0 4px rgba(102, 187, 124, 0.14),
    inset 0 1px 0 rgba(255, 255, 255, 0.9) !important;
}

body.activity-catalog-page .inline-toggle {
  display: grid !important;
  grid-template-columns: 1fr auto !important;
  align-items: center !important;
  gap: 12px !important;
}

body.activity-catalog-page .inline-toggle input[type="checkbox"] {
  width: 18px !important;
  height: 18px !important;
  accent-color: var(--catalog-accent) !important;
}

body.housing-catalog-page .filter-check-pills {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 8px !important;
}

body.housing-catalog-page .filter-check-pill {
  display: inline-flex !important;
  align-items: center !important;
  gap: 8px !important;
  min-height: 34px !important;
  padding: 0 12px !important;
  font-size: 0.8rem !important;
}

body.housing-catalog-page .filter-actions,
body.activity-catalog-page .filter-actions,
body.restaurant-catalog-page .filter-actions {
  display: grid !important;
  grid-template-columns: 1fr !important;
  gap: 10px !important;
  grid-column: auto !important;
  margin-top: 4px !important;
  justify-content: stretch !important;
}

body.housing-catalog-page :is(.filter-btn, .reset-btn),
body.activity-catalog-page :is(.filter-btn, .reset-btn),
body.restaurant-catalog-page :is(.filter-btn, .reset-btn) {
  min-height: 44px !important;
  padding: 0 18px !important;
  border-radius: 16px !important;
  font-size: 0.94rem !important;
  text-transform: none !important;
  letter-spacing: 0 !important;
}

body.housing-catalog-page .housing-results,
body.activity-catalog-page .activity-results,
body.restaurant-catalog-page .restaurant-results {
  display: grid !important;
  gap: 18px !important;
  align-content: start;
}

body.housing-catalog-page .results-header,
body.activity-catalog-page .results-header,
body.restaurant-catalog-page .results-header {
  display: flex !important;
  align-items: end !important;
  justify-content: space-between !important;
  gap: 16px !important;
  margin: 0 !important;
}

body.housing-catalog-page .results-header > div:first-child,
body.activity-catalog-page .results-header > div:first-child,
body.restaurant-catalog-page .results-header > div:first-child {
  display: grid;
  gap: 6px;
}

body.housing-catalog-page :is(#housing-results-meta, #housing-dates-summary),
body.activity-catalog-page #activity-results-meta {
  margin: 0 !important;
  color: var(--catalog-muted) !important;
  line-height: 1.6 !important;
}

body.restaurant-catalog-page > .button-next,
body.housing-catalog-page .button-next,
body.activity-catalog-page .button-next,
body.restaurant-catalog-page .button-next {
  display: none !important;
}

body.housing-catalog-page #calendar-container {
  display: grid !important;
  grid-template-columns: repeat(auto-fill, minmax(46px, 1fr)) !important;
  gap: 8px !important;
  width: 100% !important;
  min-height: 0 !important;
  max-height: 220px !important;
  padding: 14px !important;
  border-radius: 20px !important;
  overflow-y: auto !important;
}

body.housing-catalog-page #housing-container,
body.activity-catalog-page #activities-container,
body.restaurant-catalog-page #restaurant-list {
  display: grid !important;
  grid-template-columns: repeat(auto-fill, minmax(270px, 1fr)) !important;
  gap: 18px !important;
  align-items: stretch !important;
  width: 100% !important;
}

body.housing-catalog-page .catalog-empty-state,
body.activity-catalog-page .catalog-empty-state {
  grid-column: 1 / -1;
  display: grid;
  gap: 8px;
  padding: 22px 24px !important;
  border-radius: 24px !important;
  border: 1px solid rgba(255, 255, 255, 0.72) !important;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.84), rgba(235, 246, 238, 0.48)) !important;
  color: var(--catalog-text);
  box-shadow: var(--catalog-shadow) !important;
}

body.housing-catalog-page .catalog-empty-state h3,
body.activity-catalog-page .catalog-empty-state h3,
body.housing-catalog-page .catalog-empty-state p,
body.activity-catalog-page .catalog-empty-state p {
  margin: 0;
}

body.housing-catalog-page .housing-item,
body.activity-catalog-page .activity-item,
body.restaurant-catalog-page .restaurant-card {
  min-height: 100% !important;
  padding: 12px !important;
  border-radius: 26px !important;
  border: 1px solid rgba(255, 255, 255, 0.76) !important;
  background:
    radial-gradient(circle at top right, rgba(255, 255, 255, 0.46), transparent 40%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.9), rgba(237, 246, 239, 0.56)) !important;
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.82),
    0 16px 30px rgba(20, 47, 30, 0.08) !important;
  overflow: hidden !important;
  transition: transform 0.22s ease, box-shadow 0.22s ease !important;
}

body.housing-catalog-page .housing-item:hover,
body.activity-catalog-page .activity-item:hover,
body.restaurant-catalog-page .restaurant-card:hover {
  transform: translateY(-4px) !important;
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.86),
    0 22px 38px rgba(20, 47, 30, 0.12) !important;
}

body.housing-catalog-page .housing-link,
body.activity-catalog-page .activity-item,
body.restaurant-catalog-page .restaurant-card {
  text-decoration: none !important;
  color: inherit !important;
}

body.housing-catalog-page .housing-link {
  display: grid !important;
  grid-template-rows: auto 1fr !important;
  gap: 14px;
  min-height: 100%;
}

body.housing-catalog-page .housing-card-media,
body.activity-catalog-page .activity-card-media,
body.restaurant-catalog-page .carousel-container {
  position: relative !important;
  overflow: hidden !important;
  border-radius: 20px !important;
}

body.housing-catalog-page .housing-card-media img,
body.activity-catalog-page .activity-card-media img,
body.restaurant-catalog-page .restaurant-image {
  width: 100% !important;
  height: 198px !important;
  object-fit: cover !important;
  border-radius: 20px !important;
}

body.housing-catalog-page .details,
body.activity-catalog-page .activity-card-body,
body.restaurant-catalog-page .restaurant-info {
  display: grid !important;
  gap: 10px !important;
  align-content: start !important;
  min-width: 0 !important;
  padding: 0 !important;
}

body.housing-catalog-page .housing-card-top,
body.activity-catalog-page .activity-card-top {
  display: flex !important;
  align-items: flex-start !important;
  justify-content: space-between !important;
  gap: 12px !important;
}

body.housing-catalog-page .housing-item h3,
body.activity-catalog-page .activity-item h3,
body.restaurant-catalog-page .restaurant-name {
  margin: 0 !important;
  color: var(--catalog-text) !important;
  font-size: 1.12rem !important;
  line-height: 1.3 !important;
  display: -webkit-box !important;
  -webkit-line-clamp: 2 !important;
  -webkit-box-orient: vertical !important;
  overflow: hidden !important;
}

body.housing-catalog-page .housing-card-price,
body.activity-catalog-page .activity-card-price,
body.restaurant-catalog-page .restaurant-price {
  position: static !important;
  left: auto !important;
  right: auto !important;
  top: auto !important;
  bottom: auto !important;
  display: inline-flex !important;
  align-items: center !important;
  width: fit-content !important;
  max-width: 100% !important;
  min-height: 34px !important;
  padding: 6px 11px !important;
  border-radius: 999px !important;
  border: 1px solid rgba(255, 255, 255, 0.74) !important;
  background: linear-gradient(180deg, rgba(228, 244, 231, 0.94), rgba(214, 237, 219, 0.78)) !important;
  color: #2d6b48 !important;
  font-size: 0.78rem !important;
  font-weight: 700 !important;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.82) !important;
}

body.housing-catalog-page .housing-card-location,
body.activity-catalog-page .activity-card-location,
body.restaurant-catalog-page :is(.restaurant-cuisine, .restaurant-city) {
  margin: 0 !important;
  color: var(--catalog-muted) !important;
  line-height: 1.55 !important;
}

body.housing-catalog-page .housing-card-copy,
body.activity-catalog-page .activity-card-copy,
body.restaurant-catalog-page .restaurant-copy {
  margin: 0 !important;
  color: var(--catalog-muted) !important;
  line-height: 1.58 !important;
  display: -webkit-box !important;
  -webkit-line-clamp: 3 !important;
  -webkit-box-orient: vertical !important;
  overflow: hidden !important;
  min-height: 4.74em !important;
}

body.housing-catalog-page :is(.housing-card-stats, .amenities),
body.activity-catalog-page .activity-card-tags {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 7px !important;
}

body.housing-catalog-page :is(.housing-stat-pill, .amenity-icon),
body.activity-catalog-page .activity-tag {
  display: inline-flex !important;
  align-items: center !important;
  min-height: 30px !important;
  padding: 0 10px !important;
  border-radius: 999px !important;
  border: 1px solid rgba(214, 229, 217, 0.94) !important;
  background: linear-gradient(180deg, rgba(248, 251, 248, 0.98), rgba(236, 244, 238, 0.9)) !important;
  color: #355b43 !important;
  font-size: 0.76rem !important;
  font-weight: 700 !important;
}

body.restaurant-catalog-page .restaurant-copy {
  font-size: 0.95rem;
}

body.restaurant-catalog-page .restaurant-cards,
body.restaurant-catalog-page #restaurant-list {
  display: grid !important;
  gap: 18px !important;
}

body.housing-catalog-page .pro-badge,
body.activity-catalog-page .pro-badge,
body.restaurant-catalog-page .pro-badge {
  top: 12px !important;
  left: 12px !important;
  z-index: 2;
}

@media (max-width: 1180px) {
  body.housing-catalog-page .housing-page-shell,
  body.activity-catalog-page .activity-page-shell,
  body.restaurant-catalog-page .restaurant-page {
    grid-template-columns: 1fr !important;
    grid-template-areas:
      "intro"
      "filters"
      "calendar"
      "themes"
      "types"
      "results" !important;
  }

  body.housing-catalog-page .housing-filters,
  body.activity-catalog-page .activity-filters,
  body.restaurant-catalog-page .restaurant-filters {
    position: relative !important;
    top: auto !important;
    max-height: none !important;
    overflow: visible !important;
  }

  body.housing-catalog-page:not(.has-travel-roadmap) .housing-page-shell,
  body.activity-catalog-page:not(.has-travel-roadmap) .activity-page-shell,
  body.restaurant-catalog-page:not(.has-travel-roadmap) .restaurant-page,
  body.housing-catalog-page.has-travel-roadmap .housing-page-shell,
  body.activity-catalog-page.has-travel-roadmap .activity-page-shell,
  body.restaurant-catalog-page.has-travel-roadmap .restaurant-page {
    width: calc(100% - 34px) !important;
    margin: 24px auto 74px !important;
  }
}

@media (max-width: 760px) {
  body.housing-catalog-page :is(.housing-intro, .housing-types, .housing-filters, .housing-calendar, .housing-results),
  body.activity-catalog-page :is(.activity-intro, .activity-themes, .activity-filters, .activity-results),
  body.restaurant-catalog-page :is(.restaurant-intro, .restaurant-themes, .restaurant-filters, .restaurant-results) {
    padding: 18px !important;
    border-radius: 24px !important;
  }

  body.housing-catalog-page #housing-container,
  body.activity-catalog-page #activities-container,
  body.restaurant-catalog-page #restaurant-list {
    grid-template-columns: 1fr !important;
  }

  body.housing-catalog-page .page-title,
  body.activity-catalog-page .page-title,
  body.restaurant-catalog-page .page-title {
    font-size: clamp(1.75rem, 8vw, 2.4rem) !important;
    padding: 12px 18px !important;
  }
}

/* Catalog refinement pass */
body.housing-catalog-page,
body.activity-catalog-page,
body.restaurant-catalog-page {
  --catalog-sidebar-width: 306px;
  --catalog-gap: 24px;
}

body.housing-catalog-page.has-travel-roadmap .housing-page-shell,
body.activity-catalog-page.has-travel-roadmap .activity-page-shell,
body.restaurant-catalog-page.has-travel-roadmap .restaurant-page {
  width: calc(100vw - var(--travel-roadmap-offset, 0px) - 48px) !important;
  max-width: none !important;
  margin: 30px auto 84px 24px !important;
}

body.housing-catalog-page .housing-filters,
body.activity-catalog-page .activity-filters,
body.restaurant-catalog-page .restaurant-filters {
  padding: 18px 16px 16px !important;
}

body.housing-catalog-page .housing-filters h2,
body.activity-catalog-page .activity-filters h2,
body.restaurant-catalog-page .restaurant-filters h2 {
  margin-bottom: 12px !important;
  font-size: 1.32rem !important;
  line-height: 1.18 !important;
}

body.housing-catalog-page .housing-filters .filter-grid,
body.activity-catalog-page .activity-filters .filter-grid,
body.restaurant-catalog-page .restaurant-filters .filter-grid {
  grid-template-columns: 1fr !important;
  gap: 12px !important;
}

body.housing-catalog-page .housing-filters .filter-group,
body.activity-catalog-page .activity-filters .filter-group,
body.restaurant-catalog-page .restaurant-filters .filter-group {
  padding: 12px 12px 13px !important;
  border-radius: 18px !important;
  border: 1px solid rgba(255, 255, 255, 0.72) !important;
  background:
    radial-gradient(circle at top right, rgba(255, 255, 255, 0.34), transparent 40%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.68), rgba(235, 246, 238, 0.36)) !important;
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.84),
    0 10px 22px rgba(19, 45, 30, 0.05) !important;
}

body.housing-catalog-page .housing-filters .filter-group label,
body.activity-catalog-page .activity-filters .filter-group label,
body.restaurant-catalog-page .restaurant-filters .filter-group label,
body.activity-catalog-page .activity-filters .inline-toggle span {
  font-size: 0.88rem !important;
  line-height: 1.35 !important;
}

body.housing-catalog-page .housing-filters :is(input, select),
body.activity-catalog-page .activity-filters :is(input, select),
body.restaurant-catalog-page .restaurant-filters :is(input, select) {
  min-height: 42px !important;
  padding: 9px 12px !important;
  font-size: 0.92rem !important;
}

body.housing-catalog-page .housing-filters .filter-group-wide,
body.activity-catalog-page .activity-filters .filter-group-wide,
body.restaurant-catalog-page .restaurant-filters .filter-group-wide {
  gap: 10px !important;
}

body.activity-catalog-page .activity-filters .inline-toggle {
  grid-template-columns: 1fr auto !important;
  gap: 10px !important;
}

body.housing-catalog-page .filter-actions,
body.activity-catalog-page .filter-actions,
body.restaurant-catalog-page .filter-actions {
  margin-top: 2px !important;
}

body.housing-catalog-page :is(.filter-btn, .reset-btn),
body.activity-catalog-page :is(.filter-btn, .reset-btn),
body.restaurant-catalog-page :is(.filter-btn, .reset-btn) {
  min-height: 42px !important;
}

body.activity-catalog-page .activity-results,
body.housing-catalog-page .housing-results,
body.restaurant-catalog-page .restaurant-results {
  padding-top: 20px !important;
}

@media (max-width: 1180px) {
  body.housing-catalog-page.has-travel-roadmap .housing-page-shell,
  body.activity-catalog-page.has-travel-roadmap .activity-page-shell,
  body.restaurant-catalog-page.has-travel-roadmap .restaurant-page {
    width: calc(100% - 34px) !important;
    margin: 24px auto 74px !important;
  }
}

/* Catalog intro visual refinement */
body.housing-catalog-page .housing-intro,
body.activity-catalog-page .activity-intro,
body.restaurant-catalog-page .restaurant-intro {
  position: relative;
  overflow: hidden;
  padding: 20px 24px 22px !important;
  gap: 12px !important;
}

body.housing-catalog-page .housing-intro::before,
body.activity-catalog-page .activity-intro::before,
body.restaurant-catalog-page .restaurant-intro::before {
  content: "";
  position: absolute;
  left: 50%;
  top: -36px;
  width: 260px;
  height: 180px;
  transform: translateX(-50%);
  border-radius: 50%;
  background: radial-gradient(circle, rgba(72, 197, 106, 0.18), transparent 72%);
  filter: blur(18px);
  pointer-events: none;
}

body.housing-catalog-page .housing-intro::after,
body.activity-catalog-page .activity-intro::after,
body.restaurant-catalog-page .restaurant-intro::after {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(90deg, rgba(255, 255, 255, 0.04), transparent 18%, transparent 82%, rgba(255, 255, 255, 0.05)),
    radial-gradient(circle at 50% 18%, rgba(255, 255, 255, 0.32), transparent 26%);
  pointer-events: none;
}

body.housing-catalog-page .housing-intro > *,
body.activity-catalog-page .activity-intro > *,
body.restaurant-catalog-page .restaurant-intro > * {
  position: relative;
  z-index: 1;
}

body.housing-catalog-page :is(.housing-intro, .activity-intro, .restaurant-intro) .page-title,
body.activity-catalog-page :is(.housing-intro, .activity-intro, .restaurant-intro) .page-title,
body.restaurant-catalog-page :is(.housing-intro, .activity-intro, .restaurant-intro) .page-title {
  min-height: 0 !important;
  padding: 10px 20px !important;
  border-radius: 999px !important;
  border: 1px solid rgba(255, 255, 255, 0.78) !important;
  background:
    radial-gradient(circle at top left, rgba(255, 255, 255, 0.32), transparent 38%),
    linear-gradient(135deg, #2ea95a, #45c96a) !important;
  color: #f8fff8 !important;
  font-size: clamp(1.32rem, 1.7vw, 1.95rem) !important;
  line-height: 1.06 !important;
  letter-spacing: -0.03em !important;
  box-shadow:
    0 14px 28px rgba(41, 123, 69, 0.18),
    inset 0 1px 0 rgba(255, 255, 255, 0.24) !important;
}

body.housing-catalog-page :is(.housing-intro, .activity-intro, .restaurant-intro) .subtitle,
body.activity-catalog-page :is(.housing-intro, .activity-intro, .restaurant-intro) .subtitle,
body.restaurant-catalog-page :is(.housing-intro, .activity-intro, .restaurant-intro) .subtitle {
  max-width: 720px !important;
  margin-inline: auto !important;
  color: #547061 !important;
  font-size: 0.95rem !important;
  line-height: 1.55 !important;
}

/* ═══════════════════════════════════════════════════════════════
   COUP DE CŒUR step — shared catalog shell
═══════════════════════════════════════════════════════════════ */

body.coupdecoeur-catalog-page {
  --catalog-shell-max: 1360px;
  --catalog-sidebar-width: 306px;
  --catalog-gap: 22px;
  --catalog-surface:
    radial-gradient(circle at top left, rgba(255, 255, 255, 0.76), transparent 38%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.76), rgba(239, 247, 241, 0.4));
  --catalog-border: rgba(255, 255, 255, 0.72);
  --catalog-shadow:
    0 22px 46px rgba(23, 55, 35, 0.12),
    inset 0 1px 0 rgba(255, 255, 255, 0.82);
  --catalog-text: #214331;
  --catalog-muted: #5a7263;
  --catalog-accent: #2fb861;
  --catalog-accent-strong: #23784a;
  background:
    radial-gradient(circle at 6% 12%, rgba(204, 239, 210, 0.46), transparent 24%),
    radial-gradient(circle at 92% 12%, rgba(249, 250, 224, 0.46), transparent 26%),
    linear-gradient(180deg, #f5f1e8 0%, #f8faf7 220px, #f6faf6 100%);
  color: var(--catalog-text);
}

body.coupdecoeur-catalog-page :is(.coupdecoeur-page-shell, .coupdecoeur-page-shell *) {
  box-sizing: border-box;
}

body.coupdecoeur-catalog-page:not(.has-travel-roadmap) .coupdecoeur-page-shell {
  width: min(var(--catalog-shell-max), calc(100vw - 48px)) !important;
  margin: 30px auto 84px !important;
}

body.coupdecoeur-catalog-page.has-travel-roadmap .coupdecoeur-page-shell {
  width: min(var(--catalog-shell-max), calc(100vw - var(--travel-roadmap-offset, 0px) - 52px)) !important;
  margin: 30px auto 84px 20px !important;
}

body.coupdecoeur-catalog-page :is(.coupdecoeur-intro, .coupdecoeur-filters, .coupdecoeur-results) {
  position: static !important;
  left: auto !important; right: auto !important;
  top: auto !important; bottom: auto !important;
  width: 100% !important;
  min-width: 0 !important; min-height: 0 !important;
  margin: 0 !important;
  padding: 22px 24px !important;
  border-radius: 30px !important;
  border: 1px solid var(--catalog-border) !important;
  background: var(--catalog-surface) !important;
  box-shadow: var(--catalog-shadow) !important;
  backdrop-filter: blur(24px) saturate(155%);
  -webkit-backdrop-filter: blur(24px) saturate(155%);
}

body.coupdecoeur-catalog-page .coupdecoeur-page-shell {
  display: grid !important;
  grid-template-columns: var(--catalog-sidebar-width) minmax(0, 1fr) !important;
  grid-template-areas:
    "filters intro"
    "filters results" !important;
  align-items: start !important;
  gap: var(--catalog-gap) !important;
  padding: 0 !important;
}

body.coupdecoeur-catalog-page .coupdecoeur-intro   { grid-area: intro; }
body.coupdecoeur-catalog-page .coupdecoeur-results  { grid-area: results; }
body.coupdecoeur-catalog-page .coupdecoeur-filters  { grid-area: filters; }

body.coupdecoeur-catalog-page .coupdecoeur-filters {
  position: sticky !important;
  top: 104px !important;
  align-self: start !important;
  max-height: calc(100vh - 126px) !important;
  overflow-y: auto !important;
  overflow-x: hidden !important;
  scrollbar-width: none;
  -ms-overflow-style: none;
  padding: 18px 16px 16px !important;
}

body.coupdecoeur-catalog-page .coupdecoeur-filters::-webkit-scrollbar {
  width: 0; height: 0;
}

body.coupdecoeur-catalog-page .coupdecoeur-intro {
  display: grid !important;
  gap: 12px;
  align-content: start;
  min-height: 0 !important;
}

body.coupdecoeur-catalog-page .page-title {
  display: inline-flex !important;
  align-items: center;
  width: fit-content;
  max-width: min(760px, 100%);
  margin: 0 !important;
  padding: 14px 24px !important;
  border-radius: 26px !important;
  background: linear-gradient(135deg, var(--catalog-accent), #3ec86e) !important;
  color: #f7fff8 !important;
  font-size: clamp(1.95rem, 2.8vw, 3.2rem) !important;
  line-height: 1.04 !important;
  box-shadow: 0 18px 36px rgba(42, 125, 70, 0.22) !important;
}

body.coupdecoeur-catalog-page .subtitle {
  max-width: 860px !important;
  margin: 0 !important;
  color: var(--catalog-muted) !important;
  font-size: 1.02rem !important;
  line-height: 1.68 !important;
}

body.coupdecoeur-catalog-page :is(.coupdecoeur-filters h2, .coupdecoeur-results h2) {
  margin: 0 0 14px !important;
  color: var(--catalog-text) !important;
  font-size: 1.5rem !important;
}

body.coupdecoeur-catalog-page .coupdecoeur-filters h2 {
  margin-bottom: 12px !important;
  font-size: 1.32rem !important;
  line-height: 1.18 !important;
}

body.coupdecoeur-catalog-page .filter-grid {
  display: grid !important;
  grid-template-columns: 1fr !important;
  gap: 12px !important;
  align-items: stretch !important;
}

body.coupdecoeur-catalog-page .filter-group {
  display: grid !important;
  gap: 7px !important;
  min-width: 0 !important;
  padding: 12px 12px 13px !important;
  border-radius: 18px !important;
  border: 1px solid rgba(255, 255, 255, 0.72) !important;
  background:
    radial-gradient(circle at top right, rgba(255, 255, 255, 0.34), transparent 40%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.68), rgba(235, 246, 238, 0.36)) !important;
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.84),
    0 10px 22px rgba(19, 45, 30, 0.05) !important;
}

body.coupdecoeur-catalog-page .filter-group label {
  margin: 0 !important;
  color: #2d563e !important;
  font-size: 0.88rem !important;
  font-weight: 700 !important;
  line-height: 1.35;
}

body.coupdecoeur-catalog-page :is(.filter-group input, .filter-group select) {
  width: 100% !important;
  min-height: 42px !important;
  padding: 9px 12px !important;
  border-radius: 16px !important;
  border: 1px solid rgba(113, 162, 124, 0.28) !important;
  background: rgba(255, 255, 255, 0.88) !important;
  color: var(--catalog-text) !important;
  font-size: 0.92rem !important;
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.86),
    0 8px 20px rgba(19, 45, 30, 0.06) !important;
  transform: none !important;
}

body.coupdecoeur-catalog-page :is(.filter-group input:hover, .filter-group select:hover,
  .filter-group input:focus, .filter-group select:focus) {
  border-color: rgba(68, 130, 89, 0.46) !important;
  box-shadow:
    0 0 0 4px rgba(102, 187, 124, 0.14),
    inset 0 1px 0 rgba(255, 255, 255, 0.9) !important;
}

body.coupdecoeur-catalog-page .filter-actions {
  display: grid !important;
  grid-template-columns: 1fr !important;
  gap: 10px !important;
  grid-column: auto !important;
  margin-top: 2px !important;
  justify-content: stretch !important;
}

body.coupdecoeur-catalog-page :is(.filter-btn, .reset-btn) {
  min-height: 42px !important;
  padding: 0 18px !important;
  border-radius: 16px !important;
  font-size: 0.94rem !important;
  text-transform: none !important;
  letter-spacing: 0 !important;
}

body.coupdecoeur-catalog-page .coupdecoeur-results {
  display: grid !important;
  gap: 18px !important;
  align-content: start;
  padding-top: 20px !important;
}

body.coupdecoeur-catalog-page .results-header {
  display: flex !important;
  align-items: end !important;
  justify-content: space-between !important;
  gap: 16px !important;
  margin: 0 !important;
}

body.coupdecoeur-catalog-page .results-header > div:first-child {
  display: grid;
  gap: 6px;
}

body.coupdecoeur-catalog-page #cdc-results-meta {
  margin: 0 !important;
  color: var(--catalog-muted) !important;
  line-height: 1.6 !important;
}

@media (max-width: 1180px) {
  body.coupdecoeur-catalog-page .coupdecoeur-page-shell {
    grid-template-columns: 1fr !important;
    grid-template-areas:
      "intro"
      "filters"
      "results" !important;
  }

  body.coupdecoeur-catalog-page .coupdecoeur-filters {
    position: relative !important;
    top: auto !important;
    max-height: none !important;
    overflow: visible !important;
  }

  body.coupdecoeur-catalog-page:not(.has-travel-roadmap) .coupdecoeur-page-shell,
  body.coupdecoeur-catalog-page.has-travel-roadmap .coupdecoeur-page-shell {
    width: calc(100% - 34px) !important;
    margin: 24px auto 74px !important;
  }
}

@media (max-width: 760px) {
  body.coupdecoeur-catalog-page :is(.coupdecoeur-intro, .coupdecoeur-filters, .coupdecoeur-results) {
    padding: 18px !important;
    border-radius: 24px !important;
  }

  body.coupdecoeur-catalog-page .page-title {
    font-size: clamp(1.75rem, 8vw, 2.4rem) !important;
    padding: 12px 18px !important;
  }
}
