/* ============================================================
   DevCo · Section 08b — FAQ
   Light ground. Hairline accordion — mono index, serif question,
   category tag, +/- toggle that rotates to × when open.
   ============================================================ */
.faq{
  border-top:var(--hair) solid var(--ink-hair);
}

/* — Heading row: aside index + intro / main headline — */
.faq__head{
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(0,1.7fr);
  gap:clamp(40px,5vw,80px);
  align-items:start;
  margin-bottom:clamp(56px,8vh,104px);
}
.faq__head-aside{padding-top:6px;}
.faq__intro{
  margin-top:clamp(36px,6vh,64px);
  max-width:30ch;
  line-height:1.7;
  letter-spacing:.05em;
  text-transform:none;
}
.faq__headline{
  margin:0;
  max-width:20ch;
}
.faq__headline em{font-style:italic;}

/* — Accordion list — */
.faq__list{
  border-top:var(--hair) solid var(--ink-hair);
}
.faq__item{
  border-bottom:var(--hair) solid var(--ink-hair);
}
.faq__heading{margin:0;font:inherit;}

/* row trigger — a real button spanning the whole row */
.faq__trigger{
  width:100%;
  display:grid;
  grid-template-columns:auto minmax(0,1fr) 132px 28px;
  gap:clamp(18px,2.4vw,36px);
  align-items:baseline;
  padding:clamp(26px,3.4vh,38px) 0;
  background:transparent;
  border:0;
  color:inherit;
  text-align:left;
  cursor:pointer;
}

/* mono index */
.faq__idx{
  color:var(--ink-faint);
  letter-spacing:.16em;
  transition:color .3s var(--ease);
}
.faq__item.is-open .faq__idx{color:var(--accent);}

/* the question — serif */
.faq__question{
  display:block;
  letter-spacing:-.012em;
  transition:font-style .2s var(--ease);
}
.faq__item.is-open .faq__question{font-style:italic;}

/* category tag */
.faq__tag{
  text-align:right;
  align-self:baseline;
}

/* +/- toggle — rotates 45deg to read as × when open */
.faq__toggle{
  position:relative;
  justify-self:end;
  width:28px;
  height:28px;
  flex:none;
  border:var(--hair) solid var(--ink-hair);
  border-radius:50%;
  transition:border-color .3s var(--ease),transform .42s var(--ease);
}
.faq__item.is-open .faq__toggle{
  border-color:var(--accent);
  transform:rotate(45deg);
}
.faq__toggle-bar{
  position:absolute;
  top:50%;
  left:50%;
  background:var(--ink);
  transition:background .3s var(--ease);
}
.faq__toggle-bar--h{
  width:11px;
  height:var(--hair);
  transform:translate(-50%,-50%);
}
.faq__toggle-bar--v{
  width:var(--hair);
  height:11px;
  transform:translate(-50%,-50%);
}
.faq__item.is-open .faq__toggle-bar{background:var(--accent);}

/* — Answer panel — smooth max-height collapse — */
.faq__panel{
  overflow:hidden;
  max-height:0;
  transition:max-height .6s var(--ease-inout);
}
.faq__panel[hidden]{
  display:block;       /* override default — JS drives visibility via max-height */
  max-height:0;
}
.faq__item.is-open .faq__panel{
  /* max-height set inline by faq.js to the measured height */
}
.faq__panel-inner{
  display:grid;
  grid-template-columns:auto minmax(0,1fr);
  gap:clamp(18px,2.4vw,36px);
  padding-bottom:clamp(30px,4vh,46px);
}
.faq__panel-spacer{
  width:0;
  /* aligns the answer with the question column on wide screens */
}
.faq__answer{
  margin:0;
  max-width:62ch;
  font-size:var(--fs-body-sm);
  line-height:1.74;
}

/* — Responsive — */
@media (max-width:960px){
  .faq__head{
    grid-template-columns:1fr;
    gap:clamp(24px,4vh,40px);
  }
  .faq__head-aside{padding-top:0;}
  .faq__intro{margin-top:0;max-width:42ch;}
  .faq__headline{max-width:24ch;}
  .faq__trigger{
    grid-template-columns:auto minmax(0,1fr) 28px;
    column-gap:clamp(14px,3vw,24px);
    row-gap:8px;
  }
  /* tag drops under the question, aligned to its column */
  .faq__tag{
    grid-column:2;
    grid-row:2;
    text-align:left;
  }
  .faq__toggle{grid-column:3;grid-row:1;}
  .faq__panel-inner{
    grid-template-columns:auto minmax(0,1fr);
  }
}
@media (max-width:640px){
  .faq__trigger{
    grid-template-columns:1fr auto;
    column-gap:16px;
  }
  .faq__idx{grid-column:1;grid-row:1;}
  .faq__question{grid-column:1 / -1;grid-row:2;}
  .faq__tag{grid-column:1;grid-row:3;}
  .faq__toggle{grid-column:2;grid-row:1;align-self:start;}
  .faq__panel-inner{grid-template-columns:1fr;}
  .faq__panel-spacer{display:none;}
}

/* — Reduced motion — instant expand, no rotation tween — */
@media (prefers-reduced-motion:reduce){
  .faq__panel{transition:none;}
  .faq__toggle,
  .faq__toggle-bar,
  .faq__idx,
  .faq__question{transition:none;}
}

/* ============================================================
   ELEMENTOR COMPAT — Section 09 FAQ
   ------------------------------------------------------------
   The FAQ is rebuilt as native Elementor content: flexbox
   Containers for the heading row + the native Accordion widget
   for the list. This block bridges the Elementor structure to
   the realistica accordion look (numbered items, hairline top-
   borders, big soft-grey questions, thin circular +/- icon
   that rotates to x when open). Scoped to .devco-site.
   ============================================================ */

/* — section shell — */
.devco-site #faq.faq { position: relative; }

/* — heading row: aside (eyebrow + intro) | main (headline) — */
.devco-site #faq .faq__head.e-con {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1.7fr);
  gap: clamp(40px, 5vw, 80px);
  align-items: start;
  margin-bottom: clamp(56px, 8vh, 104px);
}
.devco-site #faq .faq__head-aside.e-con {
  display: flex;
  flex-direction: column;
  padding-top: 6px;
}
.devco-site #faq .faq__head-main.e-con { display: block; }

/* eyebrow row */
.devco-site #faq .dc-eyebrow.e-con {
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: 14px;
}
.devco-site #faq .dc-eyebrow__rule { flex: none; }
.devco-site #faq .dc-eyebrow__idx > span,
.devco-site #faq .dc-eyebrow__label > span,
.devco-site #faq .dc-eyebrow__rule > span { display: inline; }

/* intro line */
.devco-site #faq .faq__intro p {
  margin: 0;
  font-family: var(--font-mono);
  font-size: var(--fs-mono-sm);
  line-height: 1.7;
  letter-spacing: .05em;
  text-transform: none;
  color: inherit;
}
.devco-site #faq .faq__intro {
  margin-top: clamp(36px, 6vh, 64px);
  max-width: 34ch;
}

/* headline */
.devco-site #faq .faq__headline .elementor-heading-title {
  font: inherit;
  letter-spacing: inherit;
  line-height: inherit;
  color: inherit;
  margin: 0;
  max-width: 20ch;
}
.devco-site #faq .faq__headline em { font-style: italic; }

/* — the native Accordion, restyled to the hairline pattern — */
.devco-site #faq .faq__list .elementor-accordion { text-align: start; }

/* each item — hairline rule top + bottom, no box border */
.devco-site #faq .faq__list .elementor-accordion-item {
  border: 0;
  border-top: var(--hair) solid var(--ink-hair);
}
.devco-site #faq .faq__list .elementor-accordion-item:last-child {
  border-bottom: var(--hair) solid var(--ink-hair);
}
.devco-site #faq .faq__list .elementor-accordion-item + .elementor-accordion-item {
  border-block-start: var(--hair) solid var(--ink-hair);
}

/* the title row — a wide click target carrying the +/- toggle */
.devco-site #faq .faq__list .elementor-tab-title {
  position: relative;
  margin: 0;
  padding: clamp(26px, 3.4vh, 38px) 56px clamp(26px, 3.4vh, 38px) 0;
  background: transparent;
  font-weight: 400;
  line-height: 1;
  cursor: pointer;
  transition: opacity .3s var(--ease);
}
.devco-site #faq .faq__list .elementor-tab-title .elementor-accordion-title {
  display: block;
  color: inherit;
  text-decoration: none;
}
.devco-site #faq .faq__list .elementor-tab-title:hover { opacity: .7; }
.devco-site #faq .faq__list .elementor-tab-title.elementor-active:hover { opacity: 1; }

/* numeral — mono, faint, turns rust when open */
.devco-site #faq .faq__list .faq__idx {
  display: inline-block;
  width: 3.6em;
  font-family: var(--font-mono);
  font-size: var(--fs-mono);
  letter-spacing: .16em;
  vertical-align: middle;
  color: var(--ink-faint);
  transition: color .3s var(--ease);
}
.devco-site #faq .faq__list .elementor-active .faq__idx { color: var(--accent); }

/* the question — big serif, soft grey, italic when open */
.devco-site #faq .faq__list .faq__q {
  display: inline;
  font-family: var(--font-display);
  font-weight: 400;
  font-size: clamp(1.5rem, 1.1rem + 1.5vw, 2.5rem);
  line-height: 1.16;
  letter-spacing: -.012em;
  color: var(--ink-soft);
  transition: color .3s var(--ease), font-style .2s var(--ease);
}
.devco-site #faq .faq__list .elementor-tab-title:hover .faq__q { color: var(--ink); }
.devco-site #faq .faq__list .elementor-active .faq__q {
  color: var(--ink);
  font-style: italic;
}

/* the circular +/- toggle — drawn as CSS, rotates to x when open */
.devco-site #faq .faq__list .elementor-tab-title::before {
  content: "";
  position: absolute;
  top: 50%;
  right: 0;
  width: 30px;
  height: 30px;
  margin-top: -15px;
  border: var(--hair) solid var(--ink-hair);
  border-radius: 50%;
  transition: border-color .3s var(--ease), transform .42s var(--ease);
}
.devco-site #faq .faq__list .elementor-tab-title::after {
  content: "";
  position: absolute;
  top: 50%;
  right: 15px;
  width: 11px;
  height: 11px;
  margin: -6px -6px 0 0;
  background:
    linear-gradient(var(--ink), var(--ink)) center / 11px var(--hair) no-repeat,
    linear-gradient(var(--ink), var(--ink)) center / var(--hair) 11px no-repeat;
  transition: background .3s var(--ease);
}
/* open state — circle rotates 45deg so the cross reads as x; bars go rust */
.devco-site #faq .faq__list .elementor-tab-title.elementor-active::before {
  border-color: var(--accent);
  transform: rotate(45deg);
}
.devco-site #faq .faq__list .elementor-tab-title.elementor-active::after {
  background:
    linear-gradient(var(--accent), var(--accent)) center / 11px var(--hair) no-repeat,
    linear-gradient(var(--accent), var(--accent)) center / var(--hair) 11px no-repeat;
}

/* — answer panel — */
.devco-site #faq .faq__list .elementor-tab-content {
  border: 0;
  padding: 0 56px clamp(30px, 4vh, 46px) 0;
}
.devco-site #faq .faq__list .elementor-tab-content p {
  margin: 0;
  max-width: 62ch;
  font-family: var(--font-sans);
  font-size: var(--fs-body-sm);
  line-height: 1.74;
  color: var(--ink-soft);
}
.devco-site #faq .faq__list .elementor-tab-content em { font-style: italic; }
.devco-site #faq .faq__list .elementor-tab-content p + p { margin-top: 1em; }

/* — responsive — */
@media (max-width: 960px) {
  .devco-site #faq .faq__head.e-con {
    grid-template-columns: 1fr;
    gap: clamp(24px, 4vh, 40px);
  }
  .devco-site #faq .faq__head-aside.e-con { padding-top: 0; }
  .devco-site #faq .faq__intro { margin-top: 0; max-width: 42ch; }
}
@media (max-width: 640px) {
  .devco-site #faq .faq__list .faq__idx {
    display: block;
    width: auto;
    margin-bottom: 10px;
  }
  .devco-site #faq .faq__list .elementor-tab-title { padding-right: 46px; }
  .devco-site #faq .faq__list .elementor-tab-content { padding-right: 0; }
}

/* — reduced motion — */
@media (prefers-reduced-motion: reduce) {
  .devco-site #faq .faq__list .elementor-tab-title,
  .devco-site #faq .faq__list .elementor-tab-title::before,
  .devco-site #faq .faq__list .elementor-tab-title::after,
  .devco-site #faq .faq__list .faq__idx,
  .devco-site #faq .faq__list .faq__q { transition: none; }
}
