/* ==========================================================================
   Family Profile Layout
   Modern card-based design for team/family member profiles
   ========================================================================== */

/* Family Grid Container */
.family-profiles {
  margin: var(--space-3xl) 0;
}

.family-profiles__title {
  margin: 0 0 var(--space-xl);
  font-size: var(--font-size-3xl);
  font-family: var(--font-serif);
  font-weight: 700;
  text-align: center;
  color: var(--color-primary);
}

/* Quick Navigation */
.family-profiles__nav {
  display: flex;
  justify-content: center;
  gap: var(--space-lg);
  flex-wrap: nowrap;
  margin: 0 0 var(--space-3xl);
  padding: var(--space-xl);
  background: var(--color-bg-alt);
  border-radius: var(--radius-lg);
  border: 1px solid var(--color-border-light);
}

.family-profiles__nav-item {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-sm);
  text-decoration: none;
  transition: all var(--transition-base);
}

.family-profiles__nav-item:hover {
  transform: translateY(-4px);
}

.family-profiles__nav-image {
  width: 80px;
  height: 80px;
  border-radius: var(--radius-full);
  overflow: hidden;
  border: 3px solid var(--color-border);
  box-shadow: var(--shadow-sm);
  background: var(--color-bg);
  transition: all var(--transition-base);
}

.family-profiles__nav-item:hover .family-profiles__nav-image {
  border-color: var(--color-primary);
  box-shadow: var(--shadow-md);
  transform: scale(1.05);
}

.family-profiles__nav-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.family-profiles__nav-placeholder {
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(135deg, var(--color-bg-alt) 0%, var(--color-bg) 100%);
  font-size: var(--font-size-xl);
  color: var(--color-text-light);
  font-family: var(--font-serif);
  font-weight: 700;
}

.family-profiles__nav-name {
  font-size: var(--font-size-sm);
  font-family: var(--font-sans);
  font-weight: 600;
  color: var(--color-text);
  text-align: center;
}

.family-profiles__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-2xl);
  max-width: 900px;
  margin: 0 auto;
}

/* Individual Profile Section - No box styling, flows like an essay */
.family-profile {
  max-width: 900px;
  margin: 0 auto var(--space-3xl);
  padding: 0;
}

/* Profile Image - Scaled up version of nav image (reuses nav-image styles) */
.family-profile__image-placeholder {
  /* Inherit all nav-image styles */
  width: 180px;
  height: 180px;
  border-radius: var(--radius-full);
  overflow: hidden;
  border: 4px solid var(--color-border);
  box-shadow: var(--shadow-md);
  background: var(--color-bg);
  margin: 0 auto var(--space-lg);
  /* Scroll anchor adjustment to prevent cutting off top of image */
  scroll-margin-top: calc(var(--space-3xl) * 2);
}

/* Image styles - same as nav */
.family-profile__image-placeholder img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

/* Initial placeholder - same as nav but larger text */
.family-profile__image-placeholder:empty::before {
  content: attr(data-initial);
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(135deg, var(--color-bg-alt) 0%, var(--color-bg) 100%);
  font-size: var(--font-size-3xl);
  color: var(--color-text-light);
  font-family: var(--font-serif);
  font-weight: 700;
}

/* Profile role/subtitle */
.family-profile__role {
  color: var(--color-text-secondary);
  /* Inherits margin-bottom: 2rem from base p style */
  text-align: center !important;
  padding-left: 0 !important;
  padding-right: 0 !important;
  text-indent: 0 !important;
}

/* Visual divider between profiles */
.family-divider {
  margin: var(--space-3xl) auto;
  max-width: 200px;
  border-color: var(--color-border);
  opacity: 0.5;
}

/* Fix button centering in centered paragraphs */
.has-text-align-center .btn {
  display: inline-block;
  margin-left: auto;
  margin-right: auto;
}

/* Override text-indent from essay paragraph styles */
.family-profile p.has-text-align-center,
.family-profile .has-text-align-center p {
  text-indent: 0 !important;
}


/* ==========================================================================
   Responsive Breakpoints
   Mobile-first approach
   ========================================================================== */

/* Responsive adjustments - maintains single column at all breakpoints */

/* Responsive adjustments for profile images */
@media (min-width: 640px) {
  .family-profile__image-placeholder {
    width: 160px;
    height: 160px;
  }
}

@media (min-width: 900px) {
  .family-profile__image-placeholder {
    width: 180px;
    height: 180px;
  }
}

/* Mobile Adjustments */
@media (max-width: 640px) {
  .family-profiles {
    margin: var(--space-2xl) 0;
  }

  .family-profiles__title {
    font-size: var(--font-size-2xl);
    margin-bottom: var(--space-lg);
  }

  /* Navigation: Scale down but stay horizontal */
  .family-profiles__nav {
    gap: var(--space-sm);
    padding: var(--space-md);
    margin-bottom: var(--space-2xl);
  }

  .family-profiles__nav-image {
    width: 60px;
    height: 60px;
    border-width: 2px;
  }

  .family-profiles__nav-placeholder {
    font-size: var(--font-size-lg);
  }

  .family-profiles__nav-name {
    font-size: var(--font-size-xs);
  }

  /* Profile images smaller on mobile */
  .family-profile__image-placeholder {
    width: 120px;
    height: 120px;
    border-width: 3px;
  }

  /* Smaller initial text on mobile */
  .family-profile__image-placeholder:empty::before {
    font-size: var(--font-size-2xl);
  }
}

