/* ══════════════════════════════════════════════════════════════════
   STOBOX — FAQ v3 (page-specific)
   Loads AFTER v3-system.css. Page-only patterns:
   FAQ filter pills, search input, accordion, category headings.
   ══════════════════════════════════════════════════════════════════ */

/* ── HERO H1 — accommodate centered alignment ── */
.hero h1{ max-width: 22ch }

/* ── FAQ SEARCH ──────────────────────────────────────────────────── */
.faq-search-wrap{
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: 14px;
  margin-top: 36px;
  max-width: 580px;
}
.faq-search{
  position: relative;
  display: flex;
  align-items: center;
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.18);
  border-radius: 1px;
  transition: border-color var(--t-base) var(--ease);
}
.faq-search:focus-within{
  border-color: var(--accent-hi);
  background: rgba(255,255,255,0.06);
}
.faq-search-icon{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 44px; height: 44px;
  color: rgba(255,255,255,0.55);
  flex-shrink: 0;
}
.faq-search:focus-within .faq-search-icon{ color: var(--accent-hi) }
.faq-search-input{
  flex: 1;
  background: transparent;
  border: 0;
  outline: 0;
  font-family: var(--body);
  font-size: 14px;
  color: var(--bg);
  padding: 12px 8px;
  letter-spacing: -0.005em;
}
.faq-search-input::placeholder{ color: rgba(255,255,255,0.42) }
.faq-search-kbd{
  font-family: var(--mono);
  font-size: 11px;
  font-weight: 500;
  color: rgba(255,255,255,0.55);
  border: 1px solid rgba(255,255,255,0.20);
  padding: 3px 8px;
  margin-right: 12px;
  border-radius: 1px;
}
.faq-search-clear{
  display: none;
  background: transparent;
  border: 0;
  color: rgba(255,255,255,0.55);
  font-size: 18px;
  width: 36px; height: 36px;
  cursor: pointer;
  margin-right: 4px;
  transition: color var(--t-fast);
}
.faq-search-clear.show{ display: inline-flex; align-items: center; justify-content: center }
.faq-search-clear:hover{ color: var(--accent-hi) }
.faq-search-count{
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.55);
}

/* ── FILTER BAR (sticky-ish below nav) ───────────────────────────── */
.faq-filters{
  background: var(--bg);
  border-bottom: 1px solid var(--rule);
  position: sticky;
  top: 51px;
  z-index: 50;
  padding: 14px var(--gutter);
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}
.faq-filters-inner{
  max-width: var(--maxw);
  margin: 0 auto;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  white-space: nowrap;
}
.faq-cat-pill{
  font-family: var(--body);
  font-size: 13px;
  font-weight: 500;
  letter-spacing: -0.005em;
  color: var(--ink-2);
  background: var(--bg);
  border: 1px solid var(--rule-hard);
  padding: 8px 14px;
  border-radius: 1px;
  cursor: pointer;
  transition: background var(--t-fast), color var(--t-fast), border-color var(--t-fast);
}
.faq-cat-pill:hover{
  border-color: var(--accent);
  color: var(--accent);
}
.faq-cat-pill.active{
  background: var(--ink);
  border-color: var(--ink);
  color: var(--bg);
}

/* ── FAQ CATEGORY SECTION ────────────────────────────────────────── */
.faq-category{
  margin-bottom: 56px;
}
.faq-category:last-child{ margin-bottom: 0 }
.faq-cat-heading{
  display: flex;
  align-items: center;
  gap: 14px;
  padding-bottom: 18px;
  margin-bottom: 18px;
  border-bottom: 1px solid var(--rule);
}
.faq-cat-icon{
  width: 34px; height: 34px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 1px solid var(--rule);
  border-radius: 1px;
  color: var(--accent);
  flex-shrink: 0;
}
.faq-cat-icon svg{
  width: 18px; height: 18px;
  stroke-width: 1.6;
}
.faq-cat-heading h3{
  font-family: var(--display);
  font-weight: 800;
  font-size: clamp(26px, 2.8vw, 36px);
  text-transform: uppercase;
  letter-spacing: -0.018em;
  line-height: 1;
  color: var(--ink);
}

/* ── FAQ ITEM (accordion) ────────────────────────────────────────── */
.faq-item{
  border-bottom: 1px solid var(--rule);
}
.faq-item:first-child{ border-top: 1px solid var(--rule) }
.faq-q{
  width: 100%;
  background: transparent;
  border: 0;
  padding: 22px 0;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
  font-family: var(--display);
  font-weight: 700;
  font-size: clamp(18px, 1.6vw, 22px);
  text-transform: uppercase;
  letter-spacing: -0.012em;
  color: var(--ink);
  text-align: left;
  cursor: pointer;
  line-height: 1.15;
  transition: color var(--t-fast);
}
.faq-q:hover{ color: var(--accent) }
.faq-q svg{
  flex-shrink: 0;
  color: var(--ink-3);
  transition: transform var(--t-base) var(--ease), color var(--t-fast);
  width: 18px; height: 18px;
}
.faq-q[aria-expanded="true"]{ color: var(--accent) }
.faq-q[aria-expanded="true"] svg{
  transform: rotate(180deg);
  color: var(--accent);
}
.faq-a{
  overflow: hidden;
  transition: max-height var(--t-slow) var(--ease);
}
.faq-a-inner{
  font-family: var(--body);
  font-size: 14.5px;
  line-height: 1.65;
  color: var(--ink-2);
  padding: 0 0 26px 0;
  max-width: 80ch;
}

.faq-empty{
  padding: 48px 0;
  text-align: center;
  font-family: var(--mono);
  font-size: 12px;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--ink-3);
}

/* ── FAQ Anchor offset for sticky bar ── */
.faq-category{ scroll-margin-top: 120px }

@media (max-width: 720px){
  .faq-q{ font-size: 16px; padding: 18px 0 }
  .faq-a-inner{ font-size: 13.5px }
  .faq-filters{ top: 51px }
}
