/* =========================================================
   cards.css — Shared listing card styles (Everjoy)
   Layout + styling modeled after the original Vendors page:
   - Image with category pill + save heart
   - Title + info line
   - Price left / rating right footer
   - Works with .card, .card-media, .card-type-pill, .card-save
   - Also supports dynamic hearts (.heart-btn / [data-save-btn])
========================================================= */

:root {
  --ej-line:   #e5e7eb;
  --ej-sub:    #64748b;
  --ej-card:   #ffffff;
  --ej-brand:  #025fbc;
  --ej-brand2: #06a2dd;
  --ej-ink:    #0f172a;
  --ej-shadow: 0 8px 22px rgba(15,23,42,.08);
}

/* Base grid wrapper */
.cards-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 24px;
}

/* Card container (supports static <article.card> and generic children) */
.cards-grid > *,
.cards-grid > .card {
  position: relative;
  background: var(--ej-card);
  border-radius: 18px;
  border: 1px solid rgba(148,163,184,.5);
  box-shadow: var(--ej-shadow);
  overflow: hidden;
  padding: 0;
  display: flex;
  flex-direction: column;
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}

.cards-grid > *:hover,
.cards-grid > .card:hover {
  transform: translateY(-3px);
  box-shadow: 0 12px 28px rgba(15,23,42,.16);
  border-color: rgba(148,163,184,.9);
}

/* Media block */
.cards-grid .card-media,
.cards-grid > * > :first-child {
  position: relative;
  display: block;
  background: #f3f4f6;
  aspect-ratio: 16 / 9;
  overflow: hidden;
}

.cards-grid .card-media img,
.cards-grid > * > :first-child img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform .35s ease;
}

/* Hover zoom only on the main media image */
.cards-grid > *:hover .card-media img {
  transform: scale(1.04);
}

/* Category pill on image (original .card-type-pill style) */
.cards-grid .card-type-pill {
  position: absolute;
  left: 14px;
  top: 14px;
  padding: 6px 12px;
  border-radius: 999px;
  background: rgba(15,23,42,.82);
  color: #e5e7eb;
  font: 600 11px/1.1 "Poppins", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  text-transform: uppercase;
  letter-spacing: .12em;
  pointer-events: none;
  z-index: 2; /* stay above the image, even when it’s transformed */
}

/* Deal badge / alt pill (if present) */
.cards-grid .deal-badge,
.cards-grid .card-badge {
  position: absolute;
  top: 14px;
  left: 14px;
  padding: 5px 11px;
  border-radius: 999px;
  font: 600 11px/1 "Poppins", system-ui;
  color: #fff;
  background: linear-gradient(90deg, var(--ej-brand), var(--ej-brand2));
  box-shadow: 0 4px 12px rgba(2,95,188,.35);
  pointer-events: none;
  z-index: 3;
}

/* Save / heart button (original .card-save look, extended to dynamic hearts) */
.cards-grid .card-save,
.cards-grid :is(
  .heart-btn,
  .favorite-btn,
  .card-like,
  .card-heart,
  .save-btn,
  [data-save-btn]
) {
  position: absolute;
  right: 14px;
  top: 14px;
  width: 36px;
  height: 36px;
  border-radius: 999px;
  border: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: rgba(15,23,42,.78);
  color: #fff;
  box-shadow: 0 10px 24px rgba(15,23,42,.45);
  cursor: pointer;
  transition: background-color .15s ease, transform .1s ease, color .15s ease, box-shadow .15s ease;
}

.cards-grid :is(
  .heart-btn,
  .favorite-btn,
  .card-like,
  .card-heart,
  .save-btn,
  [data-save-btn]
) svg {
  width: 18px;
  height: 18px;
  display: block;
  fill: currentColor !important;
  stroke: none !important;
}

.cards-grid .card-save:hover,
.cards-grid :is(
  .heart-btn,
  .favorite-btn,
  .card-like,
  .card-heart,
  .save-btn,
  [data-save-btn]
):hover {
  background: rgba(15,23,42,.9);
  transform: translateY(-1px) scale(1.02);
  box-shadow: 0 12px 26px rgba(15,23,42,.5);
}

/* Saved state (heart filled / red) */
.cards-grid :is(
  .heart-btn,
  .favorite-btn,
  .card-like,
  .card-heart,
  .save-btn,
  [data-save-btn]
)[data-saved="1"],
.cards-grid :is(
  .heart-btn,
  .favorite-btn,
  .card-like,
  .card-heart,
  .save-btn,
  [data-save-btn]
)[aria-pressed="true"],
.cards-grid :is(
  .heart-btn,
  .favorite-btn,
  .card-like,
  .card-heart,
  .save-btn,
  [data-save-btn]
).is-saved {
  background: #fff;
  color: #e11d48;
  box-shadow: 0 3px 12px rgba(15,23,42,.25), 0 0 0 1px rgba(248,113,113,.3);
}

/* Focus ring on hearts */
.cards-grid :is(
  .heart-btn,
  .favorite-btn,
  .card-like,
  .card-heart,
  .save-btn,
  [data-save-btn]
):focus-visible {
  outline: none;
  box-shadow: 0 0 0 3px rgba(2,95,188,.4);
}

/* Body */
.cards-grid .card-body,
.cards-grid > * .card-body {
  padding: 18px 18px 14px;
  display: flex;
  flex-direction: column;
  gap: 4px;
}

/* Category text (generic default) */
.cards-grid .card-cat,
.cards-grid .category,
.cards-grid .card-category {
  font: 600 11px/1 "Poppins", system-ui;
  text-transform: uppercase;
  letter-spacing: .08em;
  color: #94a3b8;
  margin-bottom: 4px;
}

.card-kind-line {
  font-size: 11px;
  font-weight: 500;
  padding-bottom: 2px;
  letter-spacing: 0.09em;
  color: #94a3b8;
  text-transform: uppercase;
}

/* Browse grid: keep category in the body only (no pill on the image).
   This frees the top-left corner for the deal pill + heart only. */
body[data-page-kind] #gridResults.cards-grid .card-media .card-cat,
body[data-page-kind] #gridResults.cards-grid .card-media .category,
body[data-page-kind] #gridResults.cards-grid .card-media .card-category,
body[data-page-kind] #gridResults.cards-grid .card-media .card-type-pill {
  display: none !important;
}

/* Title */
.cards-grid .card-title,
.cards-grid h3.title,
.cards-grid .title {
  margin: 0 0 4px;
  font: 700 1.02rem/1.25 "Poppins", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  color: var(--ej-ink);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.cards-grid .card-title a {
  color: inherit;
  text-decoration: none;
}

/* Info line / subtitle */
.cards-grid .card-info-line,
.cards-grid .card-sub,
.cards-grid .subtitle {
  margin: 0;
  font: 500 .88rem/1.4 "Poppins", system-ui;
  color: var(--ej-sub);
}

/* Footer: price + rating */
.cards-grid .card-footer,
.cards-grid .card .card-footer {
  margin-top: 10px;
  display: flex;
  justify-content: space-between;
  gap: 10px;
}

/* Price */
.cards-grid .price,
.cards-grid .card-price,
.cards-grid .pricing {
  font: 400 .9rem/1.2 "Poppins", system-ui;
  color: var(--ej-ink);
  white-space: nowrap;
}

.cards-grid .price .from {
  font-weight: 400;
  opacity: .7;
  margin-right: 4px;
}

.cards-grid .price .unit {
  font-weight: 500;
  opacity: .7;
  margin-left: 4px;
  font-size: .8rem;
}

/* Rating block */
.cards-grid .rating,
.cards-grid .rating-row {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font: 500 .82rem/1 "Poppins", system-ui;
  color: #0f172a;
  white-space: nowrap;
}

.cards-grid .rating span:first-child {
  font-weight: 600;
}

.cards-grid .rating .stars {
  display: inline-flex;
  gap: 2px;
  font-size: .8rem;
  color: #f59e0b;
}

.cards-grid .rating .stars .star {
  opacity: .35;
}

.cards-grid .rating .stars .star.on {
  opacity: 1;
}

/* Accessible focus for entire card link wrapper (if used) */
.cards-grid a[data-card-link] {
  outline: none;
}

.cards-grid a[data-card-link]:focus-visible {
  box-shadow: 0 0 0 3px rgba(2,95,188,.35);
  border-radius: 14px;
}

/* Ensure card pieces are visually connected */
.card,
.card-media,
.card-media img,
.card-body {
  background: #fff;
}

/* =========================================================
   Shared card UI extras: results tip + hearts visibility
========================================================= */

.results-tip {
  margin: 6px 0 10px;
  padding: 10px 12px;
  border-radius: 999px;
  background: #e5f0ff;
  font: 500 13px/1.3 "Poppins", system-ui;
  color: #1d4ed8;
  display: inline-flex;
  align-items: center;
  gap: 8px;
}

.results-tip .tip-icon {
  flex: 0 0 auto;
  width: 18px;
  height: 18px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.results-tip .tip-icon svg {
  width: 18px;
  height: 18px;
}

.results-tip .tip-text-wrap {
  display: inline-flex;
  flex-direction: column;
}

.results-tip .tip-label {
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: #1d4ed8;
}

.results-tip .tip-text {
  font-size: 13px;
  color: #1e293b;
}

.results-tip .tip-dismiss {
  margin-left: 6px;
  border: 0;
  padding: 4px;
  border-radius: 999px;
  background: transparent;
  cursor: pointer;
  color: #64748b;
  flex: 0 0 auto;
}

.results-tip .tip-dismiss:hover {
  background: rgba(148,163,184,.15);
}

.results-tip.is-visible {
  opacity: 1;
}

/* Make sure hearts are visible for authed users */
html.auth-user .cards-grid :is(
  .heart-btn,
  .favorite-btn,
  .card-like,
  .card-heart,
  .save-btn,
  [data-save-btn]
) {
  visibility: visible !important;
}

/* =========================================================
   Mobile / tablet horizontal scroller for non-browse carousels
   (e.g., "More like this") — keep, but listing pages override it.
========================================================= */

@media (max-width: 960px) {
  .results-section .cards-grid {
    display: flex !important;
    gap: 12px !important;
    -webkit-overflow-scrolling: touch;
    scroll-snap-type: x mandatory;
    scroll-padding-left: 16px;
    overflow-x: auto;
    scrollbar-width: none;
  }

  .results-section .cards-grid::-webkit-scrollbar {
    display: none;
  }

  .results-section .cards-grid > * {
    flex: 0 0 clamp(240px, 70vw, 320px);
    max-width: clamp(240px, 70vw, 320px);
    scroll-snap-align: start;
  }

  .results-tip {
    padding-left: 12px;
  }
}

/* =========================================================
   Listing pages grid layout (Browse / Vendors / Rentals / etc.)
   - 5 columns desktop, 3 columns tablet, 2 columns mobile
   - Always vertical scroll, no horizontal carousel for #gridResults
========================================================= */

/* Desktop (≥1025px) → 5 columns (Airbnb-like full width) */
body[data-page-kind="vendor"]   #gridResults.cards-grid,
body[data-page-kind="rental"]   #gridResults.cards-grid,
body[data-page-kind="catering"] #gridResults.cards-grid,
body[data-page-kind="venue"]    #gridResults.cards-grid {
  display: grid !important;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 20px;
}

/* Tablet: 3 columns */
@media (max-width: 1024px) {
  body[data-page-kind="vendor"]   #gridResults.cards-grid,
  body[data-page-kind="rental"]   #gridResults.cards-grid,
  body[data-page-kind="catering"] #gridResults.cards-grid,
  body[data-page-kind="venue"]    #gridResults.cards-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

/* Undo horizontal flex scroller from cards.css on main listing pages */
@media (max-width: 960px) {
  body[data-page-kind="vendor"]   .results-main #gridResults.cards-grid,
  body[data-page-kind="rental"]   .results-main #gridResults.cards-grid,
  body[data-page-kind="catering"] .results-main #gridResults.cards-grid,
  body[data-page-kind="venue"]    .results-main #gridResults.cards-grid {
    display: grid !important;
    overflow-x: visible;
    scroll-snap-type: none;
    scrollbar-width: auto;
  }

  body[data-page-kind="vendor"]   .results-main #gridResults.cards-grid > *,
  body[data-page-kind="rental"]   .results-main #gridResults.cards-grid > *,
  body[data-page-kind="catering"] .results-main #gridResults.cards-grid > *,
  body[data-page-kind="venue"]    .results-main #gridResults.cards-grid > * {
    flex: none;
    max-width: none;
    scroll-snap-align: none;
  }
}

/* Venues + Map view — make footer responsive and prevent clipping */
body[data-page-kind="venue"].map-on #gridResults.cards-grid .card-footer {
  flex-direction: column;
  align-items: flex-start;
  gap: 4px;
}

/* Allow wrapping of price + rating text on narrow cards */
body[data-page-kind="venue"].map-on #gridResults.cards-grid .price,
body[data-page-kind="venue"].map-on #gridResults.cards-grid .rating {
  white-space: normal;
}

/* Venues + Map view — drop the "From" label to save horizontal space */
body[data-page-kind="venue"].map-on #gridResults.cards-grid .price .from {
  display: none;
}

/* =========================================================
   Deal / discount badge — keep visible even on hover
   (covers .deal-badge, .card-badge, [data-deal-badge], .deal-pill)
========================================================= */

/* Keep deal/discount pill visible even on hover
   (override any generic .card-badge hover rules) */
.cards-grid [data-deal-badge],
.cards-grid .deal-pill,
.cards-grid .deal-badge,
.cards-grid .card-badge {
  opacity: 1;
  visibility: visible;
  transform: none;
}

/* Match the same specificity as the base hover rules */
.cards-grid > *:hover [data-deal-badge],
.cards-grid > *:hover .deal-pill,
.cards-grid > *:hover .deal-badge,
.cards-grid > *:hover .card-badge {
  opacity: 1 !important;
  visibility: visible !important;
  transform: none !important;
}

/* Mobile: single-column grid on main listing pages */
@media (max-width: 640px) {
  body[data-page-kind="vendor"]   .results-main #gridResults.cards-grid,
  body[data-page-kind="rental"]   .results-main #gridResults.cards-grid,
  body[data-page-kind="catering"] .results-main #gridResults.cards-grid,
  body[data-page-kind="venue"]    .results-main #gridResults.cards-grid {
    grid-template-columns: 1fr;
  }
}
