/* ===== DETALHAMENTO DO PROJETO ===== */

/* Reutiliza .page-hero e .breadcrumb definidos em galeria.css */

/* ===== LAYOUT PRINCIPAL ===== */
.detalhe-wrapper {
  background: var(--light-gray);
  padding: 48px 0 80px;
}

.detalhe-layout {
  display: grid;
  grid-template-columns: 1fr 320px;
  gap: 28px;
  align-items: start;
}

/* ===== COLUNA PRINCIPAL ===== */
.detalhe-main {
  display: flex;
  flex-direction: column;
  gap: 0;
}

/* Capa / imagem principal */
.projeto-capa {
  position: relative;
  border-radius: 12px;
  overflow: hidden;
  box-shadow: 0 4px 20px rgba(0,0,0,.12);
  margin-bottom: 28px;
}

.capa-img {
  width: 100%;
  height: 380px;
  object-fit: cover;
  display: block;
}

.capa-badge {
  position: absolute;
  top: 16px;
  left: 16px;
  padding: 6px 14px;
  border-radius: 20px;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: .5px;
  text-transform: uppercase;
}

.capa-badge.tipo1 { background: var(--primary); color: var(--white); }
.capa-badge.tipo2 { background: #3b82f6; color: var(--white); }
.capa-badge.tipo3 { background: #f59e0b; color: var(--white); }

/* Bloco de título */
.projeto-titulo-bloco {
  background: var(--white);
  border-radius: 10px;
  padding: 24px 28px;
  box-shadow: 0 2px 10px rgba(0,0,0,.07);
  margin-bottom: 20px;
}

.projeto-titulo {
  font-size: 22px;
  font-weight: 800;
  color: var(--dark);
  line-height: 1.35;
  margin-bottom: 14px;
}

.projeto-meta-inline {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.meta-chip {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font-size: 12px;
  color: var(--text-muted);
  background: var(--light-gray);
  padding: 4px 10px;
  border-radius: 20px;
}

.meta-chip.status-ativo { background: #d1fae5; color: #065f46; }

/* Seções internas */
.detalhe-section {
  background: var(--white);
  border-radius: 10px;
  padding: 28px;
  box-shadow: 0 2px 10px rgba(0,0,0,.07);
  margin-bottom: 20px;
}

.section-label {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 15px;
  font-weight: 700;
  color: var(--dark);
  margin-bottom: 20px;
  padding-bottom: 12px;
  border-bottom: 2px solid var(--light-gray);
}

.section-label svg { color: var(--primary); flex-shrink: 0; }

/* Descrição */
.projeto-descricao p {
  font-size: 15px;
  color: var(--text-muted);
  line-height: 1.75;
  margin-bottom: 14px;
}

.projeto-descricao p:last-child { margin-bottom: 0; }

/* Equipe */
.equipe-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
}

.membro-card {
  display: flex;
  align-items: flex-start;
  gap: 14px;
  padding: 16px;
  border: 1px solid var(--border);
  border-radius: 8px;
  transition: border-color .2s, box-shadow .2s;
}

.membro-card:hover {
  border-color: var(--primary);
  box-shadow: 0 2px 10px rgba(0,180,180,.12);
}

.membro-foto {
  width: 52px;
  height: 52px;
  border-radius: 50%;
  object-fit: cover;
  flex-shrink: 0;
}

.membro-info {
  display: flex;
  flex-direction: column;
  gap: 3px;
}

.membro-foto-link { display: contents; text-decoration: none; }
.membro-foto-link:hover .membro-foto { opacity: .82; outline: 2px solid var(--primary); }

.membro-nome-link { text-decoration: none; color: inherit; }
.membro-nome-link:hover strong { color: var(--primary); }

.membro-info strong { font-size: 14px; color: var(--dark); }

.membro-papel {
  font-size: 12px;
  color: var(--text-muted);
  line-height: 1.4;
}

.lattes-link {
  font-size: 11px;
  color: var(--primary);
  font-weight: 600;
  margin-top: 4px;
  text-decoration: none;
}

.lattes-link:hover { text-decoration: underline; }

/* Galeria de imagens */
.galeria-imgs {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 10px;
}

.galeria-thumb {
  position: relative;
  border-radius: 8px;
  overflow: hidden;
  cursor: pointer;
  aspect-ratio: 3/2;
}

.galeria-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform .3s;
}

.thumb-overlay {
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,.45);
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  transition: opacity .25s;
  color: var(--white);
}

.galeria-thumb:hover img { transform: scale(1.05); }
.galeria-thumb:hover .thumb-overlay { opacity: 1; }

/* Galeria de vídeos */
.galeria-videos {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 14px;
}

.video-card { display: flex; flex-direction: column; gap: 8px; }

.video-thumb {
  position: relative;
  border-radius: 8px;
  overflow: hidden;
  cursor: pointer;
  aspect-ratio: 16/9;
}

.video-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform .3s;
}

.video-play-btn {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(0,0,0,.4);
  color: var(--white);
  transition: background .25s;
}

.video-thumb:hover img { transform: scale(1.04); }
.video-thumb:hover .video-play-btn { background: rgba(0,180,180,.7); }

.video-titulo {
  font-size: 13px;
  color: var(--text-muted);
  line-height: 1.45;
}

/* Produções */
.producoes-lista { display: flex; flex-direction: column; gap: 12px; }

.producao-item {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  padding: 14px;
  border: 1px solid var(--border);
  border-radius: 8px;
  transition: border-color .2s;
}

.producao-item:hover { border-color: var(--primary); }

.producao-tipo {
  flex-shrink: 0;
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .5px;
  padding: 3px 8px;
  border-radius: 4px;
  margin-top: 2px;
}

.producao-tipo.artigo    { background: #dbeafe; color: #1d4ed8; }
.producao-tipo.congresso { background: #d1fae5; color: #065f46; }
.producao-tipo.relatorio { background: #fef3c7; color: #92400e; }
.producao-tipo.software  { background: #ede9fe; color: #5b21b6; }

.producao-info {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.producao-titulo {
  font-size: 14px;
  font-weight: 600;
  color: var(--dark);
  text-decoration: none;
  line-height: 1.4;
}

.producao-titulo:hover { color: var(--primary); }

.producao-meta {
  font-size: 12px;
  color: var(--text-muted);
}

.producao-link {
  flex-shrink: 0;
  display: flex;
  align-items: center;
  color: var(--primary);
  margin-top: 2px;
  transition: opacity .2s;
}

.producao-link:hover { opacity: .7; }

/* ===== SIDEBAR ===== */
.detalhe-sidebar {
  display: flex;
  flex-direction: column;
  gap: 16px;
  position: sticky;
  top: 96px;
}

.sidebar-card {
  background: var(--white);
  border-radius: 10px;
  box-shadow: 0 2px 10px rgba(0,0,0,.07);
  padding: 20px;
}

.sidebar-card-title {
  display: flex;
  align-items: center;
  gap: 7px;
  font-size: 13px;
  font-weight: 700;
  color: var(--dark);
  margin-bottom: 16px;
  padding-bottom: 10px;
  border-bottom: 1px solid var(--light-gray);
}

.sidebar-card-title svg { color: var(--primary); }

/* Estatísticas */
.stats-card { background: linear-gradient(135deg, var(--dark) 0%, #243447 100%); }
.stats-card .sidebar-card-title { color: var(--white); border-color: rgba(255,255,255,.12); }
.stats-card .sidebar-card-title svg { color: var(--primary); }

.stats-list {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
}

.stat-item {
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 12px 8px;
  background: rgba(255,255,255,.07);
  border-radius: 8px;
}

.stat-value {
  font-size: 22px;
  font-weight: 800;
  color: var(--primary);
  line-height: 1;
}

.stat-label {
  font-size: 10px;
  color: rgba(255,255,255,.55);
  text-transform: uppercase;
  letter-spacing: .5px;
  margin-top: 4px;
}

/* Info list (sidebar) */
.info-list {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.info-list li {
  display: flex;
  align-items: flex-start;
  gap: 8px;
  flex-wrap: wrap;
}

.info-label {
  font-size: 11px;
  font-weight: 700;
  color: var(--text-muted);
  text-transform: uppercase;
  letter-spacing: .4px;
  min-width: 90px;
  padding-top: 1px;
}

.info-val {
  font-size: 13px;
  color: var(--dark);
  flex: 1;
}

.badge-detalhe {
  font-size: 11px;
  font-weight: 700;
  padding: 2px 9px;
  border-radius: 12px;
}

.badge-detalhe.tipo1 { background: #d0f4f4; color: #00807f; }
.badge-detalhe.tipo2 { background: #dbeafe; color: #1d4ed8; }
.badge-detalhe.tipo3 { background: #fef3c7; color: #92400e; }
.badge-detalhe.ativo { background: #d1fae5; color: #065f46; }
.badge-detalhe.concluido { background: #dbeafe; color: #1d4ed8; }
.badge-detalhe.pendente { background: #fef3c7; color: #92400e; }

/* Tags */
.tags-inline {
  display: flex;
  flex-wrap: wrap;
  gap: 5px;
  margin-top: 4px;
}

.tag-chip {
  font-size: 11px;
  background: var(--light-gray);
  color: var(--text-muted);
  padding: 3px 8px;
  border-radius: 12px;
  border: 1px solid var(--border);
}

/* Contato */
.contato-lista { display: flex; flex-direction: column; gap: 10px; }

.contato-item {
  display: flex;
  align-items: center;
  gap: 10px;
  text-decoration: none;
  padding: 10px 12px;
  border-radius: 8px;
  border: 1px solid var(--border);
  transition: border-color .2s, background .2s;
  font-size: 13px;
  color: var(--dark);
  word-break: break-all;
}

.contato-item:hover { border-color: var(--primary); background: #f0fdfd; }

.contato-icon {
  width: 32px;
  height: 32px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.email-icon { background: #dbeafe; color: #1d4ed8; }
.whatsapp-icon { background: #d1fae5; color: #25d366; }

/* Mídias sociais */
.social-lista { display: flex; flex-direction: column; gap: 8px; }

.social-item {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 9px 12px;
  border-radius: 8px;
  border: 1px solid var(--border);
  font-size: 13px;
  font-weight: 500;
  text-decoration: none;
  color: var(--dark);
  transition: border-color .2s, color .2s;
}

.social-item:hover { color: var(--white); }
.social-item.instagram:hover { border-color: #e1306c; background: #e1306c; }
.social-item.youtube:hover   { border-color: #ff0000; background: #ff0000; }
.social-item.github:hover    { border-color: #24292e; background: #24292e; }
.social-item.lattes:hover    { border-color: var(--primary); background: var(--primary); }

/* Links externos */
.links-lista { display: flex; flex-direction: column; gap: 6px; }

.link-externo {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 13px;
  color: var(--primary);
  text-decoration: none;
  padding: 7px 0;
  border-bottom: 1px solid var(--light-gray);
  transition: gap .2s;
}

.link-externo:last-child { border-bottom: none; }
.link-externo:hover { gap: 12px; }
.link-externo svg { flex-shrink: 0; }

/* ===== LIGHTBOX ===== */
.lightbox-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,.92);
  z-index: 2000;
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  visibility: hidden;
  transition: opacity .25s, visibility .25s;
}

.lightbox-overlay.open {
  opacity: 1;
  visibility: visible;
}

.lightbox-img {
  max-width: 90vw;
  max-height: 85vh;
  object-fit: contain;
  border-radius: 6px;
  box-shadow: 0 8px 40px rgba(0,0,0,.6);
}

.lightbox-close {
  position: absolute;
  top: 16px;
  right: 20px;
  background: rgba(255,255,255,.12);
  border: none;
  color: var(--white);
  width: 42px;
  height: 42px;
  border-radius: 50%;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background .2s;
}

.lightbox-close:hover { background: rgba(255,255,255,.25); }

.lightbox-nav {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  background: rgba(255,255,255,.12);
  border: none;
  color: var(--white);
  width: 48px;
  height: 48px;
  border-radius: 50%;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background .2s;
}

.lightbox-nav:hover { background: rgba(255,255,255,.25); }
.lightbox-prev { left: 20px; }
.lightbox-next { right: 20px; }

.lightbox-counter {
  position: absolute;
  bottom: 20px;
  left: 50%;
  transform: translateX(-50%);
  font-size: 13px;
  color: rgba(255,255,255,.6);
}

/* ===== MODAL DE VÍDEO ===== */
.video-modal-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,.85);
  z-index: 2000;
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  visibility: hidden;
  transition: opacity .25s, visibility .25s;
}

.video-modal-overlay.open {
  opacity: 1;
  visibility: visible;
}

.video-modal-box {
  position: relative;
  width: min(860px, 94vw);
}

.video-modal-close {
  position: absolute;
  top: -44px;
  right: 0;
  background: rgba(255,255,255,.12);
  border: none;
  color: var(--white);
  width: 38px;
  height: 38px;
  border-radius: 50%;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background .2s;
}

.video-modal-close:hover { background: rgba(255,255,255,.25); }

.video-modal-embed {
  position: relative;
  padding-bottom: 56.25%;
  border-radius: 8px;
  overflow: hidden;
}

.video-modal-embed iframe {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
}

/* ===== RESPONSIVO ===== */
@media (max-width: 1024px) {
  .detalhe-layout {
    grid-template-columns: 1fr 280px;
  }

  .detalhe-sidebar { position: static; }

  .galeria-imgs { grid-template-columns: repeat(3, 1fr); }
  .galeria-videos { grid-template-columns: repeat(2, 1fr); }
  .equipe-grid { grid-template-columns: 1fr; }
}

@media (max-width: 768px) {
  .capa-img { height: 240px; }

  .detalhe-layout {
    grid-template-columns: 1fr;
  }

  .detalhe-sidebar { order: -1; }

  .stats-list { grid-template-columns: repeat(4, 1fr); }

  .equipe-grid { grid-template-columns: 1fr 1fr; }
  .galeria-imgs { grid-template-columns: repeat(2, 1fr); }
  .galeria-videos { grid-template-columns: 1fr 1fr; }

  .lightbox-prev { left: 8px; }
  .lightbox-next { right: 8px; }
}

@media (max-width: 480px) {
  .projeto-titulo { font-size: 18px; }

  .stats-list { grid-template-columns: 1fr 1fr; }
  .equipe-grid { grid-template-columns: 1fr; }
  .galeria-imgs { grid-template-columns: repeat(2, 1fr); }
  .galeria-videos { grid-template-columns: 1fr; }

  .detalhe-section { padding: 20px 16px; }
  .projeto-titulo-bloco { padding: 18px 16px; }
}
