/**
 * listings.css — Meadow Lane Park
 * Styles for home listing cards, listing page, and detail view.
 */

/* ── Listing card ────────────────────────────────────── */
.listing-card {
  background: white;
  border: 1px solid rgba(0,0,0,0.08);
  border-radius: var(--radius-lg);
  overflow: hidden;
  transition: box-shadow var(--transition-base), transform var(--transition-base);
  text-decoration: none;
  color: inherit;
  display: flex;
  flex-direction: column;
}

.listing-card:hover {
  box-shadow: var(--shadow-lg);
  transform: translateY(-2px);
  text-decoration: none;
}

/* ── Listing image ───────────────────────────────────── */
.listing-card__image {
  position: relative;
  height: 200px;
  overflow: hidden;
  background: linear-gradient(135deg, var(--clr-water-light), var(--clr-teal-pale));
}

.listing-card__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform var(--transition-slow);
}

.listing-card:hover .listing-card__image img {
  transform: scale(1.04);
}

.listing-card__badge {
  position: absolute;
  top: 12px;
  left: 12px;
  background: var(--clr-gold);
  color: white;
  font-size: 0.6875rem;
  font-weight: 500;
  padding: 4px 10px;
  border-radius: var(--radius-sm);
  letter-spacing: 0.04em;
}

.listing-card__badge--new   { background: var(--clr-teal); }
.listing-card__badge--reduced { background: var(--clr-gold); }
.listing-card__badge--pending { background: var(--clr-text-light); }
.listing-card__badge--sold  { background: var(--clr-text-dark); }

/* ── Listing info ────────────────────────────────────── */
.listing-card__body {
  padding: var(--space-5);
  flex: 1;
  display: flex;
  flex-direction: column;
}

.listing-card__price {
  font-family: var(--font-serif);
  font-size: var(--text-2xl);
  font-weight: 500;
  color: var(--clr-slate);
  margin-bottom: var(--space-1);
  line-height: 1.1;
}

.listing-card__address {
  font-size: var(--text-sm);
  color: var(--clr-text-light);
  margin-bottom: var(--space-4);
}

.listing-card__details {
  display: flex;
  gap: var(--space-4);
  font-size: 0.8125rem;
  color: var(--clr-text-mid);
  border-top: 1px solid var(--clr-stone);
  padding-top: var(--space-3);
  margin-top: auto;
}

.listing-card__detail {
  display: flex;
  align-items: center;
  gap: var(--space-1);
}

.listing-card__detail svg {
  width: 14px;
  height: 14px;
  flex-shrink: 0;
  color: var(--clr-text-light);
}

/* ── Listings grid ───────────────────────────────────── */
.listings-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-5);
}

/* ── Listings section header ─────────────────────────── */
.listings-header {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  margin-bottom: var(--space-10);
}

.listings-header__view-all {
  font-size: var(--text-sm);
  font-weight: 500;
  color: var(--clr-teal);
}

/* ── Single listing (detail page) ────────────────────── */
.listing-detail__gallery {
  display: grid;
  grid-template-columns: 2fr 1fr;
  grid-template-rows: 280px 180px;
  gap: var(--space-2);
  border-radius: var(--radius-lg);
  overflow: hidden;
  margin-bottom: var(--space-8);
}

.listing-detail__gallery-main {
  grid-row: 1 / 3;
  background: var(--clr-stone);
}

.listing-detail__gallery-thumb {
  background: var(--clr-stone-light);
}

.listing-detail__gallery img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.listing-detail__price-row {
  display: flex;
  align-items: baseline;
  gap: var(--space-4);
  margin-bottom: var(--space-2);
}

.listing-detail__price {
  font-family: var(--font-serif);
  font-size: var(--text-5xl);
  font-weight: 500;
  color: var(--clr-slate);
}

.listing-detail__specs {
  display: flex;
  gap: var(--space-6);
  padding: var(--space-5) 0;
  border-top: 1px solid var(--clr-stone);
  border-bottom: 1px solid var(--clr-stone);
  margin: var(--space-5) 0;
}

.listing-detail__spec-item {
  text-align: center;
}

.listing-detail__spec-value {
  font-family: var(--font-serif);
  font-size: var(--text-2xl);
  font-weight: 500;
  color: var(--clr-slate);
  display: block;
}

.listing-detail__spec-label {
  font-size: var(--text-xs);
  color: var(--clr-text-light);
  letter-spacing: 0.06em;
  text-transform: uppercase;
  display: block;
  margin-top: var(--space-1);
}

@media (max-width: 1023px) {
  .listings-grid { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 560px) {
  .listings-grid { grid-template-columns: 1fr; }
  .listing-detail__gallery {
    grid-template-columns: 1fr;
    grid-template-rows: 260px;
  }
  .listing-detail__gallery-thumb { display: none; }
  .listing-detail__gallery-main  { grid-row: 1; }
}
