/* =====================================================
   ORCA — Membros (lista + perfil individual)
===================================================== */

/* ════════════════════════════════════════════════════
   CABEÇALHO DA PÁGINA
════════════════════════════════════════════════════ */

.membros-header {
  background:    var(--navy);
  padding:       var(--space-16) 0 var(--space-12);
  margin-bottom: var(--space-12);
}

.membros-header__title {
  font-family:    var(--font-display);
  font-size:      clamp(2.4rem, 5vw, 3.6rem);
  letter-spacing: 0.04em;
  color:          var(--white);
  margin-bottom:  var(--space-3);
  line-height: 1;
}

.membros-header__sub {
  font-family: var(--font-body);
  font-size:   var(--text-base);
  color:       var(--beige);
  opacity:     0.65;
  max-width: 520px;
}

/* ════════════════════════════════════════════════════
   LISTA DE MEMBROS
════════════════════════════════════════════════════ */

.membros-content {
  padding-bottom: var(--space-24);
  display:        flex;
  flex-direction: column;
  gap: var(--space-16); /* ↑ era --space-14, mais respiro entre grupos */
}

.membros-loading,
.membros-erro,
.membros-empty {
  font-family: var(--font-body);
  font-size:   var(--text-sm);
  color:       var(--text-muted);
  padding: var(--space-8) 0;
  text-align: center;
}

/* ── Grupo por área ─────────────────────────────── */

.membros-grupo__titulo {
  font-family:    var(--font-heading);
  font-size:      var(--text-xs);
  font-weight:    700;
  letter-spacing: 0.14em; /* ↑ levemente mais arejado */
  text-transform: uppercase;
  color:          var(--text-muted);
  opacity:        0.6;
  margin-bottom:  var(--space-6);
  padding-top:    var(--space-6); /* ← NOVO: respiro acima do título */
  padding-bottom: var(--space-3);
  border-bottom:  1px solid var(--border);
}

/* Grid de cards */
.membros-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  gap: var(--space-5);
}

/* ── Card de membro ─────────────────────────────── */

.membro-card-wrap {
  display:        flex;
  flex-direction: column;
  background:     var(--surface);
  border:         1px solid var(--border);
  border-radius:  var(--radius-lg);
  overflow:       hidden;
  transition: box-shadow 200ms ease,
              transform  200ms ease,
              border-color 200ms ease;
}

.membro-card-wrap:hover {
  box-shadow:   0 4px 24px -4px rgba(0, 0, 0, 0.10); /* ↑ mais suave e difusa */
  transform:    translateY(-3px);                      /* ↑ levemente mais pronunciado */
  border-color: var(--beige-dark);
}

.membro-card {
  display:         flex;
  flex-direction:  column;
  align-items:     center;
  text-align:      center;
  text-decoration: none;
  padding:         var(--space-6) var(--space-4) var(--space-4);
  gap:             var(--space-3);
}

/* ── Avatar ─────────────────────────────────────── */

.membro-card__foto-wrap {
  width:       80px;
  height:      80px;
  flex-shrink: 0;
}

.membro-card__foto {
  width:         100%;
  height:        100%;
  border-radius: 50%;
  object-fit:    cover;
  border:        2px solid var(--border);
}

.membro-card__foto--placeholder {
  display:         flex;
  align-items:     center;
  justify-content: center;
  width:           100%;
  height:          100%;
  border-radius:   50%;
  /* ↓ gradiente sutil no lugar do navy sólido */
  background:      linear-gradient(135deg, var(--navy) 0%, color-mix(in srgb, var(--navy) 80%, var(--red)) 100%);
  color:           var(--white);
  font-family:     var(--font-heading);
  font-size:       1.25rem;
  font-weight:     700;
  letter-spacing:  0.04em;
}

/* ── Corpo do card ──────────────────────────────── */

.membro-card__body {
  display:        flex;
  flex-direction: column;
  align-items:    center;
  gap:            4px;
}

.membro-card__nome {
  font-family: var(--font-heading);
  font-size:   var(--text-sm);
  font-weight: 700;
  color:       var(--navy);
  line-height: 1.3;
}

.membro-card__cargo--gestao {
  font-family:    var(--font-heading);
  font-size:      var(--text-xs);
  font-weight:    700;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  color:          var(--red);
}

.membro-card__cargo--producao {
  font-family:    var(--font-heading);
  font-size:      var(--text-xs);
  font-weight:    600;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color:          var(--text-muted);
}

/* ── Tags de área ───────────────────────────────── */

.membro-card__areas-sec {
  display:         flex;
  flex-wrap:       wrap;
  justify-content: center;
  gap:             4px;
  margin-top:      var(--space-1);
}

.membro-card__area-tag {
  font-family:    var(--font-heading);
  font-size:      0.6rem;
  font-weight:    600;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color:          var(--navy);
  opacity:        0.55;
  background:     var(--bg);
  border:         1px solid var(--border);
  border-radius:  var(--radius-sm);
  padding:        2px 6px;
  line-height:    1.5;
  transition:     opacity 150ms ease, border-color 150ms ease; /* ← NOVO: hover suave */
}

.membro-card-wrap:hover .membro-card__area-tag {
  opacity: 0.75; /* ← tags ganham presença quando o card é hovered */
  border-color: color-mix(in srgb, var(--border) 60%, var(--navy));
}

/* ── Redes sociais ──────────────────────────────── */

.membro-card__redes {
  display:         flex;
  justify-content: center;
  gap:             var(--space-2);
  padding:         var(--space-3) var(--space-4);
  border-top:      1px solid var(--border);
  width:           100%;
}

.membro-card__rede {
  display:         flex;
  align-items:     center;
  justify-content: center;
  width:           28px;
  height:          28px;
  border-radius:   var(--radius-sm);
  border:          1px solid var(--border);
  color:           var(--navy);
  transition: background 150ms ease,
              border-color 150ms ease,
              color 150ms ease,
              transform 150ms ease; /* ← NOVO */
}

.membro-card__rede:hover {
  background:   var(--navy);
  border-color: var(--navy);
  color:        var(--white);
  transform:    scale(1.1); /* ← NOVO: pequeno pop no hover */
}

.membro-card__rede svg {
  width:  13px;
  height: 13px;
}

/* ════════════════════════════════════════════════════
   PERFIL INDIVIDUAL
════════════════════════════════════════════════════ */

.perfil-layout {
  display:     grid;
  grid-template-columns: 280px 1fr;
  gap:         var(--space-10);
  align-items: flex-start;
  padding-top:    var(--space-10);
  padding-bottom: var(--space-24);
}

/* ── Aside esquerda ─────────────────────────────── */

.perfil-aside {
  position: sticky;
  top: calc(56px + var(--space-6));
  display:        flex;
  flex-direction: column;
  gap: var(--space-4);
}

.perfil-back {
  font-family:    var(--font-heading);
  font-size:      var(--text-xs);
  font-weight:    600;
  letter-spacing: 0.06em;
  color:          var(--text-muted);
  text-decoration: none;
  transition: color 150ms ease, letter-spacing 150ms ease; /* ← NOVO */
}
.perfil-back:hover {
  color:          var(--navy);
  letter-spacing: 0.08em; /* ← sutil expansão na volta */
}

.perfil-card {
  background:    var(--surface);
  border:        1px solid var(--border);
  border-radius: var(--radius-lg);
  padding:       var(--space-6);
  display:       flex;
  flex-direction: column;
  align-items:   center;
  text-align:    center;
  gap: var(--space-3);
}

.perfil-foto-wrap { margin-bottom: var(--space-1); }

.perfil__foto {
  width:         96px;
  height:        96px;
  border-radius: 50%;
  object-fit:    cover;
  border:        3px solid var(--border);
}

.perfil__foto--placeholder {
  display:         flex;
  align-items:     center;
  justify-content: center;
  width:           96px;
  height:          96px;
  border-radius:   50%;
  /* ↓ mesmo gradiente dos cards, consistência */
  background:      linear-gradient(135deg, var(--navy) 0%, color-mix(in srgb, var(--navy) 80%, var(--red)) 100%);
  color:           var(--white);
  font-family:     var(--font-heading);
  font-size:       1.6rem;
  font-weight:     700;
}

.perfil-nome {
  font-family:    var(--font-heading);
  font-size:      var(--text-lg);
  font-weight:    700;
  color:          var(--navy);
  line-height:    1.25;
  letter-spacing: -0.01em;
}

.perfil-cargo--gestao {
  font-family:    var(--font-heading);
  font-size:      var(--text-xs);
  font-weight:    700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color:          var(--red);
}

.perfil-cargo--producao {
  font-family:    var(--font-heading);
  font-size:      var(--text-xs);
  font-weight:    600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color:          var(--text-muted);
}

.perfil-area-wrap {
  display:        flex;
  flex-direction: column;
  align-items:    center;
  gap:            3px;
  padding-top:    var(--space-2);
  border-top:     1px solid var(--border);
  width:          100%;
}

.perfil-area-label {
  font-family:    var(--font-heading);
  font-size:      0.6rem;
  font-weight:    700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color:          var(--text-muted);
  opacity:        0.55;
}

.perfil-area {
  font-family: var(--font-body);
  font-size:   var(--text-sm);
  color:       var(--text-muted);
}

.perfil-areas-sec {
  display:        flex;
  flex-direction: column;
  align-items:    center;
  gap:            var(--space-2);
  width:          100%;
  padding-top:    var(--space-2);
  border-top:     1px solid var(--border);
}

.perfil-areas-sec__label {
  font-family:    var(--font-heading);
  font-size:      0.6rem;
  font-weight:    700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color:          var(--text-muted);
  opacity:        0.55;
}

.perfil-areas-sec__tags {
  display:   flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 5px;
}

.perfil-area-tag {
  font-family:    var(--font-heading);
  font-size:      var(--text-xs);
  font-weight:    600;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color:          var(--navy);
  background:     var(--bg);
  border:         1px solid var(--border);
  border-radius:  var(--radius-sm);
  padding:        3px 8px;
  opacity:        0.75;
}

.perfil-curso {
  display:     flex;
  align-items: center;
  gap:         5px;
  font-family: var(--font-body);
  font-size:   var(--text-xs);
  color:       var(--text-muted);
  opacity:     0.7;
}

.perfil-bio {
  font-family:  var(--font-body);
  font-size:    var(--text-sm);
  color:        var(--text-muted);
  line-height:  1.7;          /* ↑ era 1.65, levemente mais arejado */
  text-align:   left;
  padding-top:  var(--space-2);
  border-top:   1px solid var(--border);
  width:        100%;
}

.perfil-redes {
  display:   flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: var(--space-2);
  padding-top: var(--space-2);
  border-top:  1px solid var(--border);
  width: 100%;
}

.perfil-rede {
  display:     inline-flex;
  align-items: center;
  gap: 5px;
  font-family: var(--font-heading);
  font-size:   var(--text-xs);
  font-weight: 600;
  color:       var(--navy);
  text-decoration: none;
  padding: 5px 10px;
  border:        1px solid var(--border);
  border-radius: var(--radius-sm);
  transition: background 150ms ease,
              border-color 150ms ease,
              color 150ms ease;
}
.perfil-rede:hover {
  background:   var(--navy);
  border-color: var(--navy);
  color:        var(--white);
}
.perfil-rede svg {
  width:  14px;
  height: 14px;
  flex-shrink: 0;
}

/* ── Conteúdos (coluna direita) ─────────────────── */

.perfil-conteudos {
  display:        flex;
  flex-direction: column;
  gap: var(--space-12);
}

.perfil-secao__titulo {
  font-family:    var(--font-heading);
  font-size:      var(--text-base);
  font-weight:    700;
  color:          var(--navy);
  margin-bottom:  var(--space-5);
  padding-bottom: var(--space-3);
  border-bottom:  1px solid var(--border);
  display:        flex;
  align-items:    center;
  gap: var(--space-3);
}

.perfil-secao__count {
  font-family:    var(--font-heading);
  font-size:      var(--text-xs);
  font-weight:    700;
  letter-spacing: 0.06em;
  background:     var(--bg);
  color:          var(--text-muted);
  border:         1px solid var(--border);
  border-radius:  var(--radius-sm);
  padding: 2px 8px;
}

.perfil-lista {
  display:        flex;
  flex-direction: column;
  gap: var(--space-3);
}

.perfil-item {
  display:         flex;
  align-items:     center;
  gap:             var(--space-4);
  text-decoration: none;
  background:      var(--surface);
  border:          1px solid var(--border);
  border-radius:   var(--radius-md);
  padding:         var(--space-3);
  transition: box-shadow 200ms ease,
              border-color 200ms ease,
              transform 200ms ease; /* ← NOVO */
}
.perfil-item:hover {
  box-shadow:   0 4px 16px -4px rgba(0, 0, 0, 0.08); /* ↑ mais refinada */
  border-color: var(--beige-dark);
  transform:    translateX(2px); /* ← NOVO: desliza levemente para a direita */
}

.perfil-item__img-wrap {
  width:        72px;
  height:       54px;
  flex-shrink:  0;
  border-radius: var(--radius-sm);
  overflow:     hidden;
}

.perfil-item__img {
  width:      100%;
  height:     100%;
  object-fit: cover;
}

.perfil-item__img--placeholder {
  display:         flex;
  align-items:     center;
  justify-content: center;
  width:           100%;
  height:          100%;
  background:      var(--bg);
}
.perfil-item__img--placeholder span {
  font-family:    var(--font-display);
  font-size:      0.7rem;
  letter-spacing: 0.1em;
  color:          var(--beige-dark);
  opacity: 0.5;
}

.perfil-item__body {
  display:        flex;
  flex-direction: column;
  gap: 5px;
  min-width: 0;
}

.perfil-item__meta {
  display:   flex;
  flex-wrap: wrap;
  gap: var(--space-1);
}

.perfil-item__titulo {
  font-family:  var(--font-heading);
  font-size:    var(--text-sm);
  font-weight:  700;
  color:        var(--navy);
  line-height:  1.3;
  white-space:  nowrap;
  overflow:     hidden;
  text-overflow: ellipsis;
}

.perfil-item__data {
  font-family: var(--font-body);
  font-size:   var(--text-xs);
  color:       var(--text-muted);
  opacity:     0.65;
}

.perfil-vazio {
  font-family: var(--font-body);
  font-size:   var(--text-sm);
  color:       var(--text-muted);
  padding: var(--space-8) 0;
}

/* ── Links de autores na página de publicação ───── */

.perfil-item__badge-sep {
  color: var(--text-muted);
  font-size: 0.7rem;
  opacity: 0.5;
  margin: 0 2px;
}

.post-header__autor-link {
  color:           var(--navy);
  font-weight:     600;
  text-decoration: none;
  border-bottom:   1px solid var(--border);
  transition: color 150ms ease, border-color 150ms ease;
}
.post-header__autor-link:hover {
  color:        var(--red);
  border-color: var(--red);
}
.post-header__autor-sep {
  color: var(--text-muted);
}

/* ════════════════════════════════════════════════════
   BADGES
════════════════════════════════════════════════════ */

.badge {
  display: inline-block;
  font-family: var(--font-heading);
  font-size: 0.65rem;
  font-weight: 600;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  padding: 3px 8px;
  border-radius: var(--radius-sm);
  line-height: 1.4;
  white-space: nowrap;
}

.badge--tipo {
  background: var(--beige);
  color: var(--navy);
  border: 1px solid var(--beige-dark);
}

.badge--area-economia      { background: #e0e7ff; color: #3730a3; border: 1px solid #c7d2fe; }
.badge--area-internacional { background: #dbeafe; color: #1e40af; border: 1px solid #bfdbfe; }
.badge--area-saude         { background: #dcfce7; color: #166534; border: 1px solid #bbf7d0; }
.badge--area-trabalho      { background: #fef3c7; color: #92400e; border: 1px solid #fde68a; }
.badge--area-politica      { background: #f3e8ff; color: #6b21a8; border: 1px solid #e9d5ff; }
.badge--area-infraestrutura{ background: #e0f2fe; color: #075985; border: 1px solid #bae6fd; }
.badge--area-sociedade     { background: #fce7f3; color: #9d174d; border: 1px solid #fbcfe8; }

/* ════════════════════════════════════════════════════
   RESPONSIVIDADE
════════════════════════════════════════════════════ */

@media (max-width: 900px) {
  .perfil-layout {
    grid-template-columns: 1fr;
  }

  .perfil-aside {
    position: static;
  }

  .perfil-card {
    flex-direction: row;
    text-align:     left;
    align-items:    flex-start;
    flex-wrap: wrap;
  }

  .perfil-foto-wrap { flex-shrink: 0; }

  .perfil-bio,
  .perfil-redes,
  .perfil-area-wrap,
  .perfil-areas-sec {
    width:      100%;
    text-align: left;
    justify-content: flex-start;
    align-items: flex-start;
  }

  .perfil-areas-sec__tags {
    justify-content: flex-start;
  }
}

@media (max-width: 600px) {
  .membros-grid {
    grid-template-columns: repeat(auto-fill, minmax(150px, 1fr));
  }

  .perfil-card {
    flex-direction: column;
    align-items:    center;
    text-align:     center;
  }

  .perfil-bio,
  .perfil-redes,
  .perfil-area-wrap,
  .perfil-areas-sec {
    text-align: center;
    align-items: center;
  }

  .perfil-areas-sec__tags {
    justify-content: center;
  }

  .perfil-item__img-wrap { display: none; }
}