body {
  background-color: #f5f7fb;
}

.page-wrapper {
  min-height: 100vh;
  display: flex;
  flex-direction: column;
}

.navbar-brand {
  letter-spacing: 0.03em;
  display: flex;
  align-items: center;
}

.logo-dot {
  width: 12px;
  height: 12px;
  border-radius: 999px;
  background: #ffc107;
  display: inline-block;
}

.hero-section {
  margin-top: 1rem;
}

.hero-card {
  border-radius: 1.25rem;
}

.badge.bg-soft-primary {
  background: rgba(13, 110, 253, 0.12);
}

.property-card {
  border-radius: 1rem;
  overflow: hidden;
  transition: transform .15s ease, box-shadow .15s ease;
}

.property-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 0.5rem 1rem rgba(15, 23, 42, 0.12);
}

.property-card-img {
  background: linear-gradient(135deg, #e0ecff, #fef3c7);
}

.property-title {
  color: #111827;
}

.property-title:hover {
  text-decoration: underline;
}

.price-text {
  color: #14532d;
}

.info-card {
  border-radius: 0.9rem;
  background: #ffffff;
  border: 1px solid rgba(148, 163, 184, 0.25);
}

.footer {
  margin-top: auto;
}

.footer-link {
  color: #e5e7eb;
  text-decoration: none;
}

.footer-link:hover {
  text-decoration: underline;
}

.object-fit-cover {
  object-fit: cover;
}
