/* ============================================
   Approach — Hero (BigText variant)
   ============================================ */

.approach-hero {
  padding: 60px var(--page-margin);
}

.approach-hero__heading {
  font-family: var(--font-display);
  font-size: 32px;
  line-height: var(--leading-heading);
  color: var(--color-charcoal);
  text-align: left;
}

@media (min-width: 768px) {
  .approach-hero__heading {
    font-size: var(--text-h1);
  }
}

/* ============================================
   Approach — Philosophy (TripleText)
   ============================================ */

.philosophy {
  padding: 30px var(--page-margin);
}

.philosophy__heading {
  font-family: var(--font-display);
  font-size: var(--text-h2);
  line-height: var(--leading-heading);
  text-align: left;
  margin-bottom: 60px;
}

.philosophy__columns {
  display: flex;
  flex-direction: column;
  gap: 30px;
}

@media (min-width: 768px) {
  .philosophy__columns {
    flex-direction: row;
    gap: 30px;
    justify-content: flex-start;
  }
}

.philosophy__column {
  display: flex;
  flex-direction: column;
  gap: 30px;
}

@media (min-width: 768px) {
  .philosophy__column {
    width: 370px;
    flex-shrink: 0;
  }
}

.philosophy__subtitle {
  font-family: var(--font-display-italic);
  font-size: var(--text-h3);
  line-height: var(--leading-heading);
}

.philosophy__body {
  font-family: var(--font-body);
  font-size: var(--text-body);
  line-height: var(--leading-body);
}

@media (min-width: 768px) {
  .philosophy__body {
    font-size: var(--text-body-lg);
  }
}

/* ============================================
   Approach — Bios
   ============================================ */

.bios {
  padding: 30px var(--page-margin);
}

.bios__heading {
  font-family: var(--font-display);
  font-size: var(--text-h2);
  line-height: var(--leading-heading);
  text-align: left;
  margin-bottom: 60px;
}

.bios__grid {
  display: flex;
  flex-direction: column;
  gap: 30px;
}

@media (min-width: 768px) {
  .bios__grid {
    flex-direction: row;
    gap: 30px;
    align-items: center;
  }
}

.bio-card {
  display: flex;
  flex-direction: column;
  gap: 30px;
}

@media (min-width: 768px) {
  .bio-card {
    flex-direction: row;
    gap: 30px;
    align-items: flex-start;
  }
}

.bio-card__image-wrap {
  width: 100%;
  aspect-ratio: 300 / 400;
  overflow: hidden;
}

@media (min-width: 768px) {
  .bio-card__image-wrap {
    width: 370px;
    height: 493px;
    aspect-ratio: auto;
    flex-shrink: 0;
  }
}

@media (min-width: 1024px) {
  .bio-card__image-wrap {
    width: 270px;
    height: 360px;
  }
}

.bio-card__image {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.bio-card__info {
  display: flex;
  flex-direction: column;
  gap: 15px;
}

@media (min-width: 768px) {
  .bio-card__info {
    width: 270px;
  }
}

.bio-card__name {
  font-family: var(--font-display-italic);
  font-size: var(--text-h3);
  line-height: var(--leading-heading);
}

.bio-card__title {
  font-family: var(--font-body);
  font-weight: 700;
  font-size: var(--text-body);
  line-height: var(--leading-body);
}

@media (min-width: 768px) {
  .bio-card__title {
    font-size: var(--text-body-lg);
  }
}

.bio-card__bio {
  font-family: var(--font-body);
  font-size: var(--text-body);
  line-height: var(--leading-body);
}

@media (min-width: 768px) {
  .bio-card__bio {
    font-size: var(--text-body-lg);
  }
}
