/* ============================================================================
   ATIVE-FAQ-GERAL.CSS
   Refino premium + remoção de hardcode (tokens) + accordion acessível (details)
   VERSÃO: 1.1 - Janeiro 2026
   ============================================================================ */

/* ============================================================================
   1. SEÇÃO FAQ
   - NÃO definir background/padding aqui: a seção já usa page-section + ative-surface-*
   ============================================================================ */

#faq .ative-section-header {
  margin-bottom: calc(var(--section-header-gap) + 0.75rem);
}

/* ============================================================================
   2. CATEGORIA
   ============================================================================ */

.faq-category {
  position: relative;
  background: var(--surface-1);
  border: 1px solid var(--border);
  border-radius: var(--radius-xl);
  padding: 2.25rem 2rem;
  margin-bottom: 2rem;
  box-shadow: var(--shadow-layered-sm);
  transition: var(--transicao-suave);
  overflow: hidden;
}

/* Barra premium no topo */
.faq-category::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 3px;
  background: linear-gradient(90deg, transparent 0%, var(--dourado) 15%, var(--cobre) 85%, transparent 100%);
  opacity: 0;
  transition: var(--transicao-media);
}

.faq-category:hover::before {
  opacity: 0.7;
}

.faq-category:hover {
  border-color: rgba(var(--dourado-rgb), 0.2);
  box-shadow: var(--shadow-layered-md);
}

.faq-category-title {
  display: flex;
  align-items: center;
  gap: 0.85rem;

  margin: 0 0 1.25rem;
  padding-bottom: 0.9rem;

  font-family: 'Inter', sans-serif;
  font-weight: 700;
  font-size: 1.15rem;
  line-height: 1.3;
  letter-spacing: 0.01em;
  color: var(--text-primary);

  border-bottom: 1px solid rgba(var(--dourado-rgb), 0.22);
}

.faq-category-title i {
  color: var(--cta-secondary);
  font-size: 1.15rem;
  flex-shrink: 0;
}

/* Separação visual entre categorias */
.faq-category + .faq-category {
  margin-top: 2.5rem;
}

/* ============================================================================
   3. ACCORDION (DETAILS)
   ============================================================================ */

.faq-accordion {
  display: flex;
  flex-direction: column;
  gap: 0.85rem;
}

details.faq-item {
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  background: var(--surface-1);
  overflow: clip;
  transition: var(--transicao-suave);
}

details.faq-item:hover {
  border-color: rgba(var(--dourado-rgb), 0.34);
  box-shadow: var(--shadow-soft);
}

details.faq-item[open] {
  border-color: rgba(var(--dourado-rgb), 0.6);
  box-shadow: var(--shadow-soft);
}

/* Remover marker padrão do summary */
details.faq-item > summary {
  list-style: none;
}
details.faq-item > summary::-webkit-details-marker {
  display: none;
}
details.faq-item > summary::marker {
  content: '';
}

/* ============================================================================
   4. PERGUNTA (SUMMARY)
   ============================================================================ */

summary.faq-question {
  width: 100%;
  cursor: pointer;

  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;

  padding: 1.1rem 1.25rem;
  background: transparent;
  transition: var(--transicao-media);

  border-radius: calc(var(--radius-md) - 2px);
}

summary.faq-question:hover {
  background: rgba(var(--dourado-rgb), 0.06);
}

details.faq-item[open] > summary.faq-question {
  background: rgba(var(--dourado-rgb), 0.08);
}

summary.faq-question:focus {
  outline: none;
}

summary.faq-question:focus-visible {
  outline: none;
  box-shadow: var(--focus-ring);
}

/* Texto da pergunta */
.faq-question-text {
  flex: 1;
  color: var(--text-primary);
  font-family: 'Inter', sans-serif;
  font-weight: 650;
  font-size: 1.03rem;
  line-height: 1.35;
}

/* Ícone */
.faq-icon {
  color: var(--text-muted);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.faq-icon i {
  font-size: 0.95rem;
  transition:
    transform 0.35s cubic-bezier(0.34, 1.56, 0.64, 1),
    color 0.25s ease;
  transform-origin: center;
}

details.faq-item[open] .faq-icon {
  color: var(--cta-secondary);
}

details.faq-item[open] .faq-icon i {
  transform: rotate(180deg);
}

/* ============================================================================
   5. RESPOSTA (animação sem JS usando grid)
   ============================================================================ */

.faq-answer {
  display: grid;
  grid-template-rows: 0fr;
  transition: grid-template-rows 0.32s ease;
  background: rgba(var(--dourado-rgb), 0.035);
}

details.faq-item[open] .faq-answer {
  grid-template-rows: 1fr;
}

.faq-answer-inner {
  overflow: hidden;
  padding: 0.25rem 1.25rem 1.15rem;
}

/* Tipografia do conteúdo */
.faq-answer p,
.faq-answer ul,
.faq-answer ol {
  font-family: 'Inter', sans-serif;
  color: var(--text-secondary);
  font-size: 0.98rem;
  line-height: 1.7;
  margin: 0 0 0.9rem;
}

.faq-answer p:last-child,
.faq-answer ul:last-child,
.faq-answer ol:last-child {
  margin-bottom: 0;
}

.faq-answer strong {
  color: var(--text-primary);
  font-weight: 650;
}

/* Meta/observação (linha curta) */
.faq-meta {
  color: var(--text-muted);
  font-size: 0.93rem;
}

/* Listas */
.faq-answer ul,
.faq-answer ol {
  padding-left: 1.2rem;
}

.faq-answer li {
  margin: 0 0 0.6rem;
}

.faq-answer li::marker {
  color: var(--cta-secondary);
}

/* Links dentro do conteúdo */
.faq-answer a,
.faq-inline-link {
  color: var(--cta-secondary);
  text-decoration: underline;
  text-decoration-thickness: 1px;
  text-underline-offset: 0.16em;
  font-weight: 650;
  transition: var(--transicao-rapida);
}

.faq-answer a:hover,
.faq-inline-link:hover {
  color: var(--cta-secondary-hover);
  text-decoration: none;
}

/* Link “como chegar” (botão discreto) */
.faq-link {
  display: inline-flex;
  align-items: center;
  gap: 0.55rem;

  padding: 0.65rem 0.95rem;
  border-radius: var(--radius-md);

  background: rgba(var(--dourado-rgb), 0.08);
  border: 1px solid rgba(var(--dourado-rgb), 0.22);

  color: var(--text-primary);
  text-decoration: none;
  font-weight: 650;
  transition: var(--transicao-media);
}

.faq-link i {
  color: var(--cta-secondary);
}

.faq-link:hover {
  background: rgba(var(--dourado-rgb), 0.12);
  border-color: rgba(var(--dourado-rgb), 0.35);
  transform: translateY(-1px);
}

/* ============================================================================
   6. CTA FINAL
   ============================================================================ */

.faq-cta-box {
  margin-top: 2.5rem;
  padding: 2.5rem 2rem;

  border-radius: var(--radius-xl);
  background: var(--surface-1);
  border: 1px solid rgba(var(--dourado-rgb), 0.28);
  box-shadow: var(--shadow-soft);

  text-align: center;
}

.faq-cta-box h3 {
  margin: 0 0 0.75rem;
  color: var(--text-primary);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.75rem;
}

.faq-cta-box h3 i {
  color: var(--cta-secondary);
}

.faq-cta-box p {
  max-width: 62ch;
  margin: 0 auto 1.5rem;
  color: var(--text-secondary);
}

/* ============================================================================
   7. RESPONSIVIDADE
   ============================================================================ */

@media (max-width: 991px) {
  .faq-category {
    padding: 2rem 1.5rem;
  }

  .faq-category-title {
    font-size: 1.08rem;
  }

  summary.faq-question {
    padding: 1rem 1.1rem;
  }

  .faq-question-text {
    font-size: 1rem;
  }

  .faq-answer-inner {
    padding: 0.2rem 1.1rem 1rem;
  }
}

@media (max-width: 767px) {
  .faq-category {
    padding: 1.6rem 1.1rem;
    border-radius: var(--radius-lg);
  }

  .faq-category-title {
    align-items: flex-start;
    font-size: 1.03rem;
  }

  summary.faq-question {
    padding: 0.95rem 1rem;
  }

  .faq-question-text {
    font-size: 0.98rem;
    line-height: 1.35;
  }

  .faq-cta-box {
    padding: 2rem 1rem;
  }
}

/* ============================================================================
   8. REDUZIR ANIMAÇÕES (acessibilidade)
   ============================================================================ */

@media (prefers-reduced-motion: reduce) {
  .faq-category,
  details.faq-item,
  summary.faq-question,
  .faq-icon i,
  .faq-answer,
  .faq-link {
    transition: none;
  }
}
