/* ==========================================================================
   SML - FAQ Block
   Файл: /wp-content/themes/sml/src/css/blocks/faq.css
   Версия: 1.0.0
   Author: NUVREN (https://nuvren.com)

   Назначение:
   - FAQ/Accordion блок;
   - Аккуратные кликабельные вопросы с хорошей читабельностью.
   ========================================================================== */

.faq {
  border: var(--border-1);
  border-radius: var(--radius-xl);
  background: var(--color-surface);
  box-shadow: none;
  overflow: hidden;
}

.faq__item + .faq__item {
  border-top: var(--border-1);
}

/* Кнопка вопроса: reset, предсказуемые состояния */
.faq__q {
  appearance: none;
  -webkit-appearance: none;
  width: 100%;
  text-align: left;
  padding: var(--space-5);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-6);
  background: transparent;
  border: 0;
  cursor: pointer;
  color: inherit;
}

@media (min-width: 1024px) {
  .faq__q {
    padding: var(--space-6);
  }
}

.faq__q:hover {
  background: rgba(16, 18, 20, 0.02);
}

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

.faq__q span:first-child {
  font-weight: var(--font-weight-semibold);
  color: var(--color-text);
  line-height: var(--line-height-snug);
}

/* Иконка: нейтральная, без "перекоса" по базовой линии */
.faq__icon {
  flex: 0 0 auto;
  width: 32px;
  height: 32px;
  border-radius: 999px;
  border: var(--border-1);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--color-muted);
  line-height: 1;
  transition: transform var(--dur-2) var(--ease),
              background var(--dur-2) var(--ease),
              border-color var(--dur-2) var(--ease),
              color var(--dur-2) var(--ease);
}

/* если JS добавляет is-open на item */
.faq__item.is-open .faq__icon {
  transform: rotate(45deg);
  border-color: rgba(31, 122, 58, 0.22);
  background: rgba(31, 122, 58, 0.08);
  color: var(--color-primary);
}

/* Панель ответа */
.faq__a {
  padding: 0 var(--space-5) var(--space-6);
}

@media (min-width: 1024px) {
  .faq__a {
    padding: 0 var(--space-6) var(--space-6);
  }
}

/* На всякий случай: hidden attribute должен точно скрывать панель */
.faq__a[hidden] {
  display: none !important;
}

.faq__a p {
  margin: 0;
  font-size: var(--font-size-sm);
  color: var(--color-text-2);
  line-height: 1.65;
}

/* ------------------------------------------------------------
   Улучшения "премиум" без ломания текущего стиля
   ------------------------------------------------------------ */

/* Чуть лучше кликабельность на мобиле и визуальный "ритм" */
@media (max-width: 520px) {
  .faq__q {
    padding: var(--space-4);
    gap: var(--space-4);
  }

  .faq__a {
    padding: 0 var(--space-4) var(--space-5);
  }
}

/* Разделитель внутри item при открытии - создаёт аккуратный "слой" */
.faq__item.is-open .faq__q {
  background: rgba(16, 18, 20, 0.015);
}

.faq__item.is-open .faq__a {
  border-top: 1px solid rgba(16, 18, 20, 0.06);
  padding-top: var(--space-4);
}

/* Если вопрос очень длинный - не "ломаем" иконку и переносим корректно */
.faq__q span:first-child {
  flex: 1 1 auto;
  min-width: 0;
}

.faq__q span:first-child {
  overflow-wrap: anywhere;
}

/* Чуть тише кавычки/текстовые блоки в ответе, но читаемо */
.faq__a p {
  max-width: 78ch;
}
