// ============================================================
// Directory / Annuaire
// Uses CSS custom properties for theme compatibility
// ============================================================

.directory-section {
  min-height: 60vh;
}

// Search
.directory-search {
  .form-control {
    border-color: var(--border);
    border-radius: var(--radius) 0 0 var(--radius);

    &:focus {
      border-color: var(--primary);
      box-shadow: 0 0 0 0.2rem color-mix(in srgb, var(--primary) 20%, transparent);
    }
  }

  .btn {
    border-radius: 0 var(--radius) var(--radius) 0;
  }
}

// Filters (same pattern as portfolio)
.directory-filters {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;

  &__pill {
    display: inline-flex;
    align-items: center;
    padding: 0.375rem 1rem;
    border-radius: 2rem;
    font-size: 0.875rem;
    font-weight: 500;
    color: var(--text-muted);
    background: var(--surface);
    border: 1px solid var(--border);
    text-decoration: none;
    transition: all 0.2s ease;

    &:hover {
      color: var(--primary);
      border-color: var(--primary);
    }

    &--active {
      color: #fff;
      background: var(--primary);
      border-color: var(--primary);

      &:hover {
        color: #fff;
      }
    }
  }
}

// Tag filters (familles dynamiques) — pattern pills colore par famille
.directory-tag-filters {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;

  &__group {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.5rem;
  }

  &__label {
    display: inline-block;
    padding: 0.25rem 0.625rem;
    border-radius: 0.375rem;
    font-size: 0.75rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.03em;
    color: #fff;
    background: var(--tg-color, var(--primary));
  }

  &__pill {
    display: inline-flex;
    align-items: center;
    padding: 0.25rem 0.875rem;
    border-radius: 2rem;
    font-size: 0.8125rem;
    font-weight: 500;
    color: var(--tg-color, var(--text-muted));
    background: transparent;
    border: 1px solid var(--tg-color, var(--border));
    text-decoration: none;
    transition: all 0.2s ease;

    &:hover {
      color: #fff;
      background: var(--tg-color, var(--primary));
    }

    &--active {
      color: #fff;
      background: var(--tg-color, var(--primary));
    }
  }

  &__clear {
    align-self: flex-start;
    margin-top: 0.25rem;
    font-size: 0.8125rem;
    color: var(--text-muted);
    text-decoration: underline;

    &:hover {
      color: var(--primary);
    }
  }
}

// Grid
.directory-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.5rem;

  @media (max-width: 991.98px) {
    grid-template-columns: repeat(2, 1fr);
  }

  @media (max-width: 575.98px) {
    grid-template-columns: 1fr;
  }
}

// Card
.directory-card {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  padding: 1.5rem 1.25rem;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  text-decoration: none;
  color: var(--text);
  transition: transform 0.2s ease, box-shadow 0.2s ease;
  position: relative;

  &:hover {
    transform: translateY(-4px);
    box-shadow: 0 8px 24px color-mix(in srgb, var(--text) 8%, transparent);
    color: var(--text);
  }

  &__avatar {
    max-width: 120px;
    border-radius: var(--radius);
    overflow: hidden;
    margin-bottom: 1rem;
    flex-shrink: 0;

    img {
      width: 100%;
      height: auto;
      display: block;
    }
  }

  &__initials {
    width: 80px;
    height: 80px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: color-mix(in srgb, var(--primary) 12%, transparent);
    color: var(--primary);
    font-weight: 700;
    font-size: 1.25rem;
    font-family: var(--font-display, var(--font-family));
    border-radius: var(--radius);
  }

  &__badge {
    position: absolute;
    top: 0.75rem;
    right: 0.75rem;
    font-size: 0.6875rem;
    font-weight: 600;
    padding: 0.2rem 0.5rem;
    border-radius: 1rem;
    background: color-mix(in srgb, var(--primary) 10%, transparent);
    color: var(--primary);
  }

  &__body {
    min-width: 0;
  }

  &__company {
    font-family: var(--font-display, var(--font-family));
    font-size: 1.0625rem;
    font-weight: 700;
    margin: 0 0 0.25rem;
    color: var(--text);
  }

  &__name {
    font-size: 0.875rem;
    color: var(--text-muted);
    margin: 0 0 0.25rem;
  }

  &__city {
    font-size: 0.8125rem;
    color: var(--text-muted);
    margin: 0 0 0.5rem;
  }

  &__cta {
    display: inline-block;
    margin-top: 0.75rem;
    font-size: 0.8125rem;
    font-weight: 600;
    color: var(--primary);
    transition: color 0.2s ease;
  }

  &:hover &__cta {
    text-decoration: underline;
  }
}

// Detail page
.directory-detail {

  &__hero-img {
    border-radius: var(--radius);
    overflow: hidden;

    img {
      width: 100%;
      height: auto;
      display: block;
    }
  }

  &__badge {
    display: inline-block;
    font-size: 0.75rem;
    font-weight: 600;
    padding: 0.25rem 0.75rem;
    border-radius: 2rem;
    background: color-mix(in srgb, var(--primary) 10%, transparent);
    color: var(--primary);
    margin-bottom: 0.75rem;
  }

  &__name {
    font-family: var(--font-display, var(--font-family));
    font-size: clamp(1.5rem, 3vw, 2.25rem);
    font-weight: 700;
    margin: 0 0 0.5rem;
    color: var(--text);
    line-height: 1.2;
  }

  &__person {
    font-size: 1rem;
    color: var(--text-muted);
    margin: 0 0 0.25rem;
  }

  &__city {
    font-size: 0.9375rem;
    color: var(--text-muted);
    margin: 0;
  }

  &__section-title {
    font-family: var(--font-display, var(--font-family));
    font-size: 1.125rem;
    font-weight: 700;
    margin-bottom: 0.75rem;
    padding-bottom: 0.5rem;
    border-bottom: 2px solid var(--primary);
    color: var(--text);
  }

  &__bio-content {
    font-size: 1.0625rem;
    line-height: 1.8;
    color: var(--text);
  }
}

// Sidebar
.directory-sidebar {
  position: sticky;
  top: 1.5rem;

  &__card {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 1.25rem;
    margin-bottom: 1rem;
  }

  &__title {
    font-family: var(--font-display, var(--font-family));
    font-size: 0.9375rem;
    font-weight: 700;
    margin: 0 0 1rem;
    padding-bottom: 0.5rem;
    border-bottom: 2px solid var(--primary);
    color: var(--text);
  }

  &__list {
    list-style: none;
    padding: 0;
    margin: 0;

    li {
      display: flex;
      align-items: center;
      gap: 0.75rem;
      padding: 0.5rem 0;
      font-size: 0.9rem;
      color: var(--text);

      &:not(:last-child) {
        border-bottom: 1px solid var(--border);
      }

      i {
        color: var(--primary);
        flex-shrink: 0;
        width: 16px;
        text-align: center;
      }

      a {
        color: var(--primary);
        text-decoration: none;

        &:hover {
          text-decoration: underline;
        }
      }
    }
  }

  &__links {
    display: flex;
    flex-direction: column;
    gap: 0;
  }

  &__link {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    padding: 0.625rem 0;
    color: var(--text);
    text-decoration: none;
    font-size: 0.9rem;
    transition: color 0.2s ease;

    &:not(:last-child) {
      border-bottom: 1px solid var(--border);
    }

    i:first-child {
      color: var(--primary);
      width: 16px;
      text-align: center;
      flex-shrink: 0;
    }

    .ms-auto {
      font-size: 0.75rem;
      color: var(--text-muted);
      opacity: 0;
      transition: opacity 0.2s ease;
    }

    &:hover {
      color: var(--primary);

      .ms-auto {
        opacity: 1;
      }
    }
  }
}

// Count
.directory-count {
  font-size: 0.875rem;
}

// Legacy classes (backward compat)
.member-card {
  display: flex;
  align-items: flex-start;
  gap: 1rem;
  padding: 1.25rem;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  transition: transform 0.2s ease, box-shadow 0.2s ease;

  &:hover {
    transform: translateY(-2px);
    box-shadow: 0 4px 12px color-mix(in srgb, var(--text) 8%, transparent);
  }
}

.member-avatar {
  flex-shrink: 0;
  width: 56px;
  height: 56px;
  border-radius: 50%;
  overflow: hidden;

  img {
    width: 100%;
    height: 100%;
    object-fit: cover;
  }
}

.member-avatar-placeholder {
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  background: color-mix(in srgb, var(--primary) 12%, transparent);
  color: var(--primary);
  font-weight: 700;
  font-size: 1.125rem;
  font-family: var(--font-display, var(--font-family));
}
