/* ===================================== */
/* FAQ SECTION STYLES */
/* ===================================== */

.faq-section {
  background: var(--primary-subtle) !important;
}

.faq-zen-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-sm);
  max-width: 800px;
  margin: var(--space-xl) auto 0;
  text-align: left;
}

.faq-zen-item {
  background: var(--card-bg);
  border: 1.5px solid var(--border);
  border-radius: var(--radius-md);
  padding: var(--space-md);
  transition: all 200ms ease;
  cursor: pointer;
  box-shadow: var(--shadow-paper-sm);
  position: relative;
}

/* Paper texture */
.faq-zen-item::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='paper'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='2' numOctaves='2' /%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23paper)'/%3E%3C/svg%3E");
  opacity: 0.02;
  border-radius: var(--radius-md);
  pointer-events: none;
}

.faq-zen-item:hover {
  border-color: var(--primary);
  box-shadow: var(--shadow-paper-md);
}

.faq-zen-item[open] {
  border-color: var(--primary);
  background: var(--primary-subtle);
}

.faq-zen-question {
  font-size: var(--font-sm);
  font-weight: 600;
  color: var(--text-primary);
  font-family: var(--font-display);
  cursor: pointer;
  list-style: none;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0;
  margin: 0;
  position: relative;
  z-index: 1;
}

.faq-zen-question::after {
  content: '+';
  font-size: var(--font-lg);
  color: var(--primary);
  font-weight: 400;
  transition: transform 200ms ease;
  flex-shrink: 0;
  margin-left: var(--space-sm);
}

.faq-zen-item[open] .faq-zen-question::after {
  content: '−';
  transform: rotate(0deg);
}

.faq-zen-question::-webkit-details-marker {
  display: none;
}

.faq-zen-answer {
  padding-top: var(--space-sm);
  position: relative;
  z-index: 1;
}

.faq-zen-answer p {
  font-size: var(--font-xs);
  color: var(--text-secondary);
  line-height: 1.6;
  margin: 0;
}

/* RESPONSIVE - DESKTOP */
@media (min-width: 1024px) {
  .faq-zen-grid {
    grid-template-columns: repeat(2, 1fr);
    max-width: 1000px;
  }
}
