/* ==========================================================================
   Page — Person Profile
   ========================================================================== */

.person-wrapper {
  width: 100%;
}

.person-wrapper .person-info {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  justify-content: center;
  gap: var(--space-xl);
}

.person-wrapper .left {
  flex-shrink: 0;

  img {
    border-radius: var(--radius-md);
  }
}

.person-wrapper .info {
  flex: 1;
  min-width: 250px;
}

/* --- Categories --- */
.categories {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-xs);
  margin-block-start: var(--space-sm);
}

.category-badge {
  display: inline-block;
  padding: var(--space-xs) var(--space-sm);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-full);
  background: color-mix(in srgb, var(--color-primary) 5%, var(--color-bg));
  font-size: var(--font-size-xs);
  font-weight: 500;
  color: var(--color-text);
  transition: background var(--transition-fast);

  &:hover {
    background: color-mix(in srgb, var(--color-primary) 10%, var(--color-bg));
  }
}

/* --- Lead-in / Rank Text --- */
.lead-in {
  font-size: var(--font-size-sm);
  color: var(--color-text-muted);
  margin-block-end: var(--space-sm);
}

/* --- CTA --- */
.cta {
  text-align: center;
  line-height: 1.5;
  margin-block: var(--space-xl);
  font-size: var(--font-size-lg);

  a {
    font-size: var(--font-size-xl);
    text-decoration: none;
  }
}

/* --- About Person --- */
.about-person {
  font-size: var(--font-size-sm);
  line-height: 1.8;
  color: var(--color-text-muted);
}

/* --- Neighborhood (more/less famous) --- */
.neighborhood {
  width: 100%;
  margin-block-start: var(--space-xl);
}

.celeb-wrapper {
  margin-block-end: var(--space-lg);

  h3 {
    text-align: center;
    margin-block-end: var(--space-md);
  }
}

.celebs {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: var(--space-sm);
}

.celeb {
  .person-image-frame {
    width: 100px;
    height: 120px;
  }

  img {
    border-radius: var(--radius-md);
    transition: transform var(--transition-fast);
  }

  &:hover img {
    transform: scale(1.05);
  }
}

/* --- Country Flag Row --- */
.country-flag-row {
  margin-block: var(--space-md);

  h3 {
    font-size: var(--font-size-sm);
    color: var(--color-text-muted);
    margin-block-end: var(--space-xs);
  }
}

/* --- Most Famous In --- */
.most-famous-in {
  font-size: var(--font-size-sm);
  font-weight: 600;
  margin-block: var(--space-sm);
  color: var(--color-text);
}

/* --- Fame Gap Bar --- */
.fame-gap-bar {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  margin-block-start: var(--space-xs);
  height: 1.5rem;
  background: var(--color-border);
  border-radius: var(--radius-full);
  overflow: hidden;
  position: relative;
}

.fame-gap-bar__fill {
  height: 100%;
  border-radius: var(--radius-full);
  transition: width var(--transition-base);

  &--positive {
    background: var(--color-accent);
  }

  &--negative {
    background: var(--color-danger);
  }
}

.fame-gap-bar__label {
  position: absolute;
  right: var(--space-sm);
  font-size: var(--font-size-xs);
  font-weight: 700;
  color: var(--color-text);
}

/* --- Fame Gap Text Colors --- */
.fame-gap--positive {
  color: var(--color-success);
  font-weight: 600;
}

.fame-gap--negative {
  color: var(--color-danger);
  font-weight: 600;
}

.fame-gap--neutral {
  color: var(--color-text-muted);
}

/* --- Country Vote Breakdown --- */
.country-vote-breakdown {
  width: 100%;
  margin-block: var(--space-xl);

  h3 {
    text-align: center;
    margin-block-end: var(--space-md);
  }
}

/* --- Mobile single column --- */
@media (max-width: 600px) {
  .person-wrapper .person-info {
    flex-direction: column;
    align-items: center;
  }

  .person-wrapper .info {
    min-width: 0;
    width: 100%;
  }
}
