/* ═══════════════════════════════════════════════
   BIMhub — Homepage styles
═══════════════════════════════════════════════ */

/* ─── Shared container ───────────────────────── */
.bh-container {
  max-width: var(--container-max);
  margin-inline: auto;
  padding-inline: 0;
}
@media (max-width: 1290px) { .bh-container { padding-inline: var(--space-md); } }
@media (max-width: 768px)  { .bh-container { padding-inline: var(--space-sm); } }

/* ─── Buttons ────────────────────────────────── */
.bh-btn {
  display: inline-flex;
  align-items: center;
  gap: var(--space-xs);
  padding: 0.75rem 1.5rem;
  border-radius: var(--radius-sm);
  font-family: var(--font-body);
  font-weight: var(--weight-regular);
  font-size: var(--font-size-base);
  text-decoration: none;
  transition: background var(--transition-fast), color var(--transition-fast), border-color var(--transition-fast);
  cursor: pointer;
  border: 2px solid transparent;
  line-height: 1;
}
.bh-btn--primary { background: var(--color-yellow); color: var(--color-black); border-color: var(--color-yellow); }
.bh-btn--primary:hover { background: #e0b800; border-color: #e0b800; color: var(--color-black); }
.bh-btn--outline { background: transparent; color: var(--color-white); border-color: var(--color-white); }
.bh-btn--outline:hover { background: var(--color-white); color: var(--color-black); }
.bh-btn--ghost { background: transparent; color: var(--color-black); border-color: var(--color-black); }
.bh-btn--ghost:hover { background: var(--color-black); color: var(--color-white); }
.bh-btn--black { background: var(--color-black); color: var(--color-white); border-color: var(--color-black); }
.bh-btn--black:hover { background: #333; border-color: #333; color: var(--color-white); }

/* ─── Section title ──────────────────────────── */
.bh-section-title {
  font-family: var(--font-heading);
  font-size: var(--font-size-2xl);
  font-weight: var(--weight-semibold);
  color: var(--color-black);
  margin-bottom: var(--space-lg);
}

/* ─────────────────────────────────────────────
   1. HERO — two-col, video right, light grey bg
───────────────────────────────────────────── */
.bh-hero {
  background: #f8f8f6;
}

.bh-hero__inner {
  max-width: var(--container-max);
  margin-inline: auto;
  padding: 1.5rem 0 3rem;
  display: grid;
  grid-template-columns: 1fr 3fr;
  align-items: end;
  gap: 3rem;
}

.bh-hero__text {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 1.25rem;
  padding-bottom: 0.5rem;
}

.bh-hero__title {
  font-family: var(--font-heading);
  font-size: clamp(2rem, 3.5vw, 2.75rem);
  font-weight: var(--weight-semibold);
  line-height: var(--line-height-head);
  color: var(--color-black);
  margin: 0;
}

.bh-hero__sub {
  font-family: var(--font-body);
  font-size: var(--font-size-lg);
  font-weight: var(--weight-regular);
  color: var(--color-text);
  line-height: var(--line-height-body);
  margin: 0;
}

.bh-hero__video {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 1rem 0 0;
}

.bh-hero__video video {
  width: 100%;
  height: auto;
  display: block;
}

@media (max-width: 900px) {
  .bh-hero__inner { grid-template-columns: 1fr; padding: 3rem 0 2rem; }
  .bh-hero__video { display: none; }
  .bh-hero__title { font-size: var(--font-size-3xl); }
}

/* ─────────────────────────────────────────────
   2. AI TEASER — two-col, small video right
───────────────────────────────────────────── */
.bh-ai-teaser {
  background: var(--color-black);
  padding-block: 0;
  overflow: hidden;
}

.bh-ai-teaser__inner {
  max-width: var(--container-max);
  margin-inline: auto;
  padding: var(--space-2xl) 0;
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: space-between;
  gap: 8rem;
}

.bh-ai-teaser__text {
  display: flex;
  flex-direction: column;
  gap: var(--space-md);
  max-width: 480px;
  flex-shrink: 0;
  align-items: flex-start;
}

.bh-ai-teaser__label {
  font-family: var(--font-body);
  font-size: var(--font-size-base);
  font-weight: var(--weight-regular);
  letter-spacing: 0.05em;
  color: var(--color-yellow);
}

.bh-ai-teaser__title {
  font-family: var(--font-heading);
  font-size: var(--font-size-3xl);
  font-weight: var(--weight-semibold);
  color: var(--color-white);
  margin: 0;
  line-height: var(--line-height-head);
}

.bh-ai-teaser__body {
  font-family: var(--font-body);
  font-size: var(--font-size-lg);
  font-weight: var(--weight-regular);
  color: #cccccc;
  line-height: var(--line-height-body);
  margin: 0;
}

.bh-ai-teaser__video {
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: flex-end;
  align-self: stretch;
  margin-right: 0;
}

.bh-ai-teaser__video video {
  width: 480px;
  height: 100%;
  object-fit: contain;
  display: block;
}

@media (max-width: 900px) {
  .bh-ai-teaser__inner { flex-direction: column; gap: var(--space-lg); padding: var(--space-xl) 0; }
  .bh-ai-teaser__video { display: none; }
}

/* ─────────────────────────────────────────────
   3. SERVICES — folder tab cards
───────────────────────────────────────────── */
.bh-services {
  background: #f8f8f6;
  padding-block: var(--space-2xl);
}

.bh-services__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-md);
}

.bh-services__card {
  background: var(--color-white);
  padding: var(--space-lg);
  position: relative;
  overflow: visible;
  display: flex;
  flex-direction: column;
  gap: var(--space-sm);
  border: 3px solid #555;
  margin-top: 32px;
}

.bh-services__card::before {
  content: '';
  position: absolute;
  top: -32px;
  left: -3px;
  width: 180px;
  height: 32px;
  background: var(--color-white);
  border: 3px solid #555;
  border-bottom: none;
  border-radius: 4px 4px 0 0;
}

.bh-services__card-image {
  width: calc(100% + 2 * var(--space-lg));
  margin: calc(-1 * var(--space-lg)) calc(-1 * var(--space-lg)) 0;
  overflow: hidden;
  height: 160px;
  background: var(--color-white);
}

.bh-services__card-image img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  object-position: left center;
  display: block;
  padding: 0.5rem var(--space-lg);
  box-sizing: border-box;
  transition: transform var(--transition-base);
}

.bh-services__card:hover .bh-services__card-image img { transform: scale(1.04); }

.bh-services__card-title {
  font-family: var(--font-heading);
  font-size: var(--font-size-xl);
  font-weight: var(--weight-semibold);
  color: var(--color-black);
  margin: 0;
}

.bh-services__body {
  font-family: var(--font-body);
  font-size: var(--font-size-base);
  font-weight: var(--weight-regular);
  color: var(--color-text);
  line-height: var(--line-height-body);
  margin: 0;
  flex: 1;
}

.bh-services__link {
  display: inline-flex;
  align-items: center;
  align-self: flex-end;
  margin-left: auto;
  font-family: var(--font-body);
  font-size: var(--font-size-sm);
  font-weight: var(--weight-regular);
  color: var(--color-black);
  text-decoration: none;
  margin-top: auto;
  background: var(--color-yellow);
  border: 2px solid var(--color-yellow);
  padding: 0.5rem 1rem;
  border-radius: var(--radius-sm);
  transition: background var(--transition-fast);
}
.bh-services__link:hover {
  background: #e0b800;
  border-color: #e0b800;
  color: var(--color-black);
}

@media (max-width: 900px) { .bh-services__grid { grid-template-columns: 1fr; } }

/* ─────────────────────────────────────────────
   4. ABOUT
───────────────────────────────────────────── */
.bh-about { background: var(--color-white); padding-block: var(--space-2xl); }
.bh-about__inner { display: grid; grid-template-columns: 1fr auto; align-items: center; gap: var(--space-xl); }
.bh-about__text { display: flex; flex-direction: column; align-items: flex-start; gap: var(--space-md); max-width: 560px; }
.bh-about__label { font-family: var(--font-body); font-size: var(--font-size-base); font-weight: var(--weight-regular); letter-spacing: 0.05em; color: var(--color-text-muted); }
.bh-about__name { font-family: var(--font-heading); font-size: var(--font-size-2xl); font-weight: var(--weight-semibold); color: var(--color-black); margin: 0; }
.bh-about__bio { font-family: var(--font-body); font-size: var(--font-size-lg); font-weight: var(--weight-regular); color: var(--color-text); line-height: var(--line-height-body); margin: 0; }
.bh-about__photo img { width: 340px; height: auto; border-radius: var(--radius-md); display: block; object-fit: cover; }
@media (max-width: 900px) { .bh-about__inner { grid-template-columns: 1fr; } .bh-about__photo { display: none; } }

/* ─────────────────────────────────────────────
   5. BLOG PUSH
───────────────────────────────────────────── */
.bh-blog-push {
  background: #b0b0b0;
  padding-block: var(--space-xl);
  border-top: 1px solid #999;
}

.bh-blog-push__inner { display: flex; align-items: center; justify-content: space-between; gap: var(--space-lg); }

.bh-blog-push__title {
  font-family: var(--font-heading);
  font-size: var(--font-size-3xl);
  font-weight: var(--weight-semibold);
  color: var(--color-black);
  margin: 0;
}

.bh-blog-push__sub {
  font-family: var(--font-body);
  font-size: var(--font-size-base);
  font-weight: var(--weight-regular);
  color: var(--color-text-muted);
  margin: var(--space-xs) 0 0;
}

@media (max-width: 768px) { .bh-blog-push__inner { flex-direction: column; align-items: flex-start; } }

/* Footer copyright */
.ct-footer-copyright-bar,
.ct-footer [data-row="bottom"],
.ct-footer [data-row="bottom"] .ct-container {
  background: #1a1a1a !important;
}
.ct-footer-copyright,
.ct-footer [data-row="bottom"] {
  background: #1a1a1a !important;
  color: #888 !important;
}
.ct-footer-copyright a { color: #888 !important; }

/* Hero corner link (kept for compatibility) */
.bh-hero__corner-link { display: none; }
