/* ===================================================================
   File: render-business-listing-basic.css
   Description: Basic business-listing styles only.
   Notes:
   - Shared cards, owner preview, gallery wrappers, and other cross-tier rules live in
     render-business-business-listing-shared.css.
   =================================================================== */

/* =========================
   HEADER
   ========================= */

.ll-basic-header {
  margin-bottom: 1.25rem;
}

.ll-basic-header__row {
  display: flex;
  align-items: stretch;
  gap: 1rem;
}

.ll-basic-header__logo {
  flex: 0 0 auto;
  display: flex;
  align-items: stretch;
}

.ll-basic-logo-img {
  display: block;
  width: auto;
  height: auto;
  max-width: 180px;
  max-height: 120px;
  object-fit: contain;
  padding: 8px;
  background: #fff;
  border: 1px solid #e2e8f0;
  border-radius: 12px;
}

.ll-basic-header__titles {
  display: flex;
  flex-direction: column;
  justify-content: center;
  min-width: 0;
}

.ll-basic-title {
  margin: 0;
  color: #0f172a;
  font-size: clamp(2rem, 4vw, 3.25rem);
  line-height: 1.08;
  font-weight: 800;
}

.ll-basic-primary-category {
  margin: 0.35rem 0 0;
  color: #64748b;
  font-size: 1.05rem;
  line-height: 1.4;
  font-weight: 600;
}

/* =========================
   BODY LAYOUT
   ========================= */

.ll-basic-body.ll-section-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.18fr) minmax(340px, 0.92fr);
  gap: 1.5rem;
  align-items: start;
}

.ll-post-surface.ll-basic .ll-basic-body__side {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

/* =========================
   FEATURED IMAGE
   ========================= */

.ll-basic-primary-image,
.ll-basic-featured {
  overflow: hidden;
  width: 100%;
  background: #f8fafc;
  border: 1px solid #e2e8f0;
  border-radius: 16px;
}

.ll-basic-primary-image__img,
.ll-basic-featured__img {
  display: block;
  width: 100%;
  height: auto;
  object-fit: contain;
}

/* =========================
   INTRO + TEXT CARDS
   ========================= */

.ll-post-surface.ll-basic .ll-basic-intro-text,
.ll-post-surface.ll-basic .ll-basic-service-areas-text,
.ll-post-surface.ll-basic .ll-basic-contact-text,
.ll-post-surface.ll-basic .ll-basic-contact-link {
  color: #0f172a;
  font-size: 1rem;
  line-height: 1.7;
}

.ll-post-surface.ll-basic .ll-basic-intro-text p {
  margin: 0 0 0.9rem;
}

.ll-post-surface.ll-basic .ll-basic-intro-text p:last-child {
  margin-bottom: 0;
}

/* =========================
   CONTACT CARD
   ========================= */

.ll-basic-contact-list {
  display: grid;
  gap: 0.85rem;
  margin: 0;
  padding: 0;
  list-style: none;
}

.ll-basic-contact-item {
  display: flex;
  align-items: flex-start;
  gap: 0.7rem;
}

.ll-basic-icon {
  width: 20px;
  height: 20px;
  flex: 0 0 20px;
  margin-top: 0.18rem;
  color: #0ea5e9;
}

.ll-basic-contact-text,
.ll-basic-contact-link {
  display: block;
  min-width: 0;
  overflow-wrap: anywhere;
  word-break: break-word;
}

.ll-post-surface.ll-basic .ll-basic-contact-link {
  color: #0f172a;
  text-decoration: none;
}

.ll-post-surface.ll-basic .ll-basic-contact-link:hover {
  text-decoration: underline;
}

/* =========================
   RESPONSIVE
   ========================= */

@media (max-width: 900px) {
  .ll-basic-body.ll-section-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 640px) {
  .ll-basic-header__row {
    flex-direction: column;
    align-items: flex-start;
  }
}
