/**
 * Composants Profile - PERENNITY
 * Profils complexes élégants (LOT 6)
 */

/* ============================================
   PROFILE CARD (Composant Base)
   ============================================ */

.profile-card {
  background: var(--perennity-bg-primary);
  border: 1px solid var(--perennity-border-subtle);
  border-radius: var(--perennity-radius-sm);
  padding: var(--perennity-space-2xl);
  box-shadow: var(--perennity-shadow-sm);
  transition: all var(--perennity-transition-normal);
  position: relative;
  overflow: hidden;
}

.profile-card::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 4px;
  background: linear-gradient(90deg, var(--perennity-accent), var(--perennity-accent-light));
  opacity: 0;
  transition: opacity var(--perennity-transition-normal);
}

.profile-card:hover {
  box-shadow: var(--perennity-shadow-elegant);
  border-color: var(--perennity-border);
}

.profile-card:hover::before {
  opacity: 1;
}

/* Header */
.profile-header {
  margin-bottom: var(--perennity-space-2xl);
  padding-bottom: var(--perennity-space-xl);
  border-bottom: 1px solid var(--perennity-border-subtle);
}

.profile-title {
  font-family: var(--perennity-font-elegant);
  font-size: var(--perennity-text-3xl);
  font-weight: var(--perennity-weight-semibold);
  color: var(--perennity-text-primary);
  margin-bottom: var(--perennity-space-xs);
  line-height: var(--perennity-line-tight);
}

.profile-type {
  display: inline-block;
  padding: var(--perennity-space-xs) var(--perennity-space-md);
  background: var(--perennity-accent-subtle);
  color: var(--perennity-accent);
  border-radius: var(--perennity-radius-sm);
  font-size: var(--perennity-text-sm);
  font-weight: var(--perennity-weight-semibold);
  font-family: var(--perennity-font-body);
  border: 1px solid var(--perennity-border-subtle);
}

/* Sections */
.profile-sections {
  display: grid;
  gap: var(--perennity-space-xl);
}

.profile-section {
  padding: var(--perennity-space-lg);
  background: var(--perennity-accent-subtle);
  border-radius: var(--perennity-radius-sm);
  border-left: 3px solid var(--perennity-accent);
}

.profile-section h4 {
  font-family: var(--perennity-font-elegant);
  font-size: var(--perennity-text-xl);
  font-weight: var(--perennity-weight-semibold);
  color: var(--perennity-text-primary);
  margin-bottom: var(--perennity-space-md);
  line-height: var(--perennity-line-tight);
}

/* Details (DL) */
.profile-details {
  display: grid;
  gap: var(--perennity-space-sm);
  margin: var(--perennity-space-md) 0;
}

.profile-details dt {
  font-size: var(--perennity-text-sm);
  font-weight: var(--perennity-weight-semibold);
  color: var(--perennity-text-primary);
  font-family: var(--perennity-font-body);
  margin-bottom: var(--perennity-space-xs);
}

.profile-details dd {
  font-size: var(--perennity-text-base);
  color: var(--perennity-text-secondary);
  font-family: var(--perennity-font-body);
  margin: 0 0 var(--perennity-space-sm) var(--perennity-space-md);
  line-height: var(--perennity-line-relaxed);
}

/* List */
.profile-list {
  list-style: none;
  padding: 0;
  margin: var(--perennity-space-md) 0;
}

.profile-list li {
  font-size: var(--perennity-text-base);
  color: var(--perennity-text-secondary);
  line-height: var(--perennity-line-relaxed);
  font-family: var(--perennity-font-body);
  padding: var(--perennity-space-sm) 0;
  padding-left: var(--perennity-space-lg);
  position: relative;
}

.profile-list li::before {
  content: '→';
  position: absolute;
  left: 0;
  color: var(--perennity-accent);
  font-weight: var(--perennity-weight-bold);
}

/* Offres (Service Detail) */
.profile-offres {
  display: grid;
  gap: var(--perennity-space-lg);
  margin-top: var(--perennity-space-md);
}

.offre-item {
  padding: var(--perennity-space-md);
  background: var(--perennity-bg-primary);
  border-radius: var(--perennity-radius-sm);
  border: 1px solid var(--perennity-border-subtle);
}

.offre-title {
  font-family: var(--perennity-font-elegant);
  font-size: var(--perennity-text-lg);
  font-weight: var(--perennity-weight-semibold);
  color: var(--perennity-text-primary);
  margin-bottom: var(--perennity-space-sm);
  line-height: var(--perennity-line-tight);
}

.offre-items {
  list-style: none;
  padding: 0;
  margin: 0;
}

.offre-items li {
  font-size: var(--perennity-text-sm);
  color: var(--perennity-text-secondary);
  padding: var(--perennity-space-xs) 0;
  padding-left: var(--perennity-space-md);
  position: relative;
  font-family: var(--perennity-font-body);
  line-height: var(--perennity-line-relaxed);
}

.offre-items li::before {
  content: '•';
  position: absolute;
  left: 0;
  color: var(--perennity-accent);
  font-size: var(--perennity-text-lg);
}

/* Footer */
.profile-footer {
  margin-top: var(--perennity-space-2xl);
  padding-top: var(--perennity-space-xl);
  border-top: 1px solid var(--perennity-border-subtle);
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  gap: var(--perennity-space-md);
}

.profile-budget,
.profile-timeline {
  padding: var(--perennity-space-sm) var(--perennity-space-lg);
  background: var(--perennity-accent-subtle);
  border-radius: var(--perennity-radius-sm);
  font-size: var(--perennity-text-base);
  font-weight: var(--perennity-weight-semibold);
  font-family: var(--perennity-font-body);
  color: var(--perennity-accent);
}

.profile-kpi {
  margin-top: var(--perennity-space-lg);
  padding: var(--perennity-space-md);
  background: var(--perennity-accent-subtle);
  border-left: 3px solid var(--perennity-accent);
  border-radius: var(--perennity-radius-sm);
  font-size: var(--perennity-text-sm);
  color: var(--perennity-text-secondary);
  font-family: var(--perennity-font-body);
  font-style: italic;
}

.profile-kpi strong {
  color: var(--perennity-accent);
  font-weight: var(--perennity-weight-semibold);
}

/* ============================================
   VARIANTES PAR TYPE
   ============================================ */

/* Avatar */
.profile-card[data-profile-type="avatar"] .profile-section[data-section="entreprise"] {
  background: transparent;
  border-left: none;
  padding: 0;
  margin-bottom: var(--perennity-space-lg);
}

.profile-card[data-profile-type="avatar"] .profile-section[data-section="triggers"],
.profile-card[data-profile-type="avatar"] .profile-section[data-section="problems"],
.profile-card[data-profile-type="avatar"] .profile-section[data-section="aspirations"] {
  background: var(--perennity-accent-subtle);
}

/* Service */
.profile-card[data-profile-type="service"] .profile-section[data-section="objective"] {
  background: transparent;
  border-left: 3px solid var(--perennity-accent);
  padding: var(--perennity-space-lg);
  margin-bottom: var(--perennity-space-xl);
}

.profile-card[data-profile-type="service"] .profile-section[data-section="offres"] {
  background: transparent;
  border-left: none;
  padding: 0;
}

/* ============================================
   DARK MODE
   ============================================ */

[data-theme="dark"] .profile-card,
.dark-mode .profile-card {
  background: var(--perennity-primary);
  border-color: var(--perennity-border-subtle);
}

[data-theme="dark"] .profile-card:hover,
.dark-mode .profile-card:hover {
  background: var(--perennity-bg-primary);
  border-color: var(--perennity-border);
}

[data-theme="dark"] .profile-section,
.dark-mode .profile-section {
  background: var(--perennity-primary);
  border-left-color: var(--perennity-accent-light);
}

[data-theme="dark"] .offre-item,
.dark-mode .offre-item {
  background: var(--perennity-primary);
  border-color: var(--perennity-border-subtle);
}

[data-theme="dark"] .profile-budget,
[data-theme="dark"] .profile-timeline,
.dark-mode .profile-budget,
.dark-mode .profile-timeline {
  background: var(--perennity-primary);
  color: var(--perennity-accent-light);
}

[data-theme="dark"] .profile-kpi,
.dark-mode .profile-kpi {
  background: var(--perennity-primary);
  border-left-color: var(--perennity-accent-light);
}

/* ============================================
   RESPONSIVE
   ============================================ */

@media (max-width: 768px) {
  .profile-card {
    padding: var(--perennity-space-xl);
  }
  
  .profile-footer {
    flex-direction: column;
    align-items: flex-start;
  }
  
  .profile-details {
    grid-template-columns: 1fr;
  }
  
  .profile-details dd {
    margin-left: 0;
  }
}

