/* ===== FAQ LIST ===== */
.faq-list {
  display: flex; flex-direction: column; gap: 12px;
}
.faq-item {
  background: var(--white); border: 1px solid var(--border);
  border-radius: var(--radius); overflow: hidden; transition: box-shadow 0.3s;
}
.bg-cream .faq-item { background: var(--white); }
.faq-item[open] { box-shadow: var(--shadow); }

.faq-question {
  display: flex; align-items: center; gap: 12px;
  padding: 20px 24px; font-size: 1rem; font-weight: 600;
  color: var(--primary-dark); cursor: pointer;
  list-style: none; position: relative; padding-right: 48px;
}
.faq-question::-webkit-details-marker { display: none; }
.faq-question::before {
  content: 'Q'; display: inline-flex; align-items: center; justify-content: center;
  width: 28px; height: 28px; border-radius: 50%;
  background: var(--primary); color: var(--white);
  font-size: 0.82rem; font-weight: 700; flex-shrink: 0;
}
.faq-question::after {
  content: ''; position: absolute; right: 20px; top: 50%;
  width: 10px; height: 10px;
  border-right: 2px solid var(--text-muted);
  border-bottom: 2px solid var(--text-muted);
  transform: translateY(-60%) rotate(45deg); transition: transform 0.3s;
}
.faq-item[open] .faq-question::after {
  transform: translateY(-30%) rotate(-135deg);
}

.faq-answer { padding: 0 24px 24px 64px; }
.faq-answer p {
  font-size: 0.98rem; color: var(--text-light);
  line-height: 1.9; margin-bottom: 12px;
}
.faq-answer p:last-child { margin-bottom: 0; }
.faq-answer strong { color: var(--primary-dark); font-weight: 600; }

@media (max-width: 600px) {
  .faq-question { padding: 16px 40px 16px 16px; font-size: 0.92rem; }
  .faq-answer { padding: 0 16px 20px 48px; }
  .faq-question::before { width: 24px; height: 24px; font-size: 0.78rem; }
}

/* ===== Category jump links ===== */
.faq-jump {
  display: flex; flex-wrap: wrap; gap: 10px;
  justify-content: center;
  max-width: 800px; margin: 28px auto 0;
}
.faq-jump a {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 8px 18px; border-radius: 50px;
  background: var(--white); border: 1px solid var(--border);
  font-size: 0.88rem; font-weight: 600; color: var(--primary-dark);
  text-decoration: none; transition: all 0.3s;
}
.faq-jump a:hover {
  background: var(--primary); color: var(--white);
  border-color: var(--primary);
}
.faq-jump a i { font-size: 0.8rem; }
@media (max-width: 600px) {
  .faq-jump { gap: 8px; }
  .faq-jump a { padding: 6px 14px; font-size: 0.82rem; }
}
