/* ============================================
   FAQ ACCORDION — <details>/<summary> based
   ============================================ */

.faq-accordion {
  display: flex;
  flex-direction: column;
  gap: var(--sp-2);
  max-width: 860px;
  margin-inline: auto;
  padding-block: var(--sp-4);
}

/* ---- Item ---- */
.faq-accordion__item {
  border-radius: var(--radius-lg);
  border: 1px solid rgba(209,194,176,0.13);
  overflow: hidden;
  transition: border-color var(--duration) var(--ease),
              box-shadow var(--duration) var(--ease);
}

.faq-accordion__item:hover {
  border-color: rgba(209,194,176,0.30);
  box-shadow: 0 0 24px rgba(143,112,50,0.10);
}

.faq-accordion__item[open] {
  border-color: rgba(209,194,176,0.28);
  box-shadow: 0 0 28px rgba(143,112,50,0.12);
}

/* ---- Summary / trigger ---- */
.faq-accordion__q {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--sp-5);
  padding: var(--sp-5) var(--sp-6);
  cursor: pointer;
  list-style: none;
  font-family: var(--font-display);
  font-size: var(--text-md);
  font-weight: 400;
  color: var(--gold-light);
  line-height: var(--leading-tight);
  user-select: none;
  transition: color var(--duration) var(--ease);
  -webkit-tap-highlight-color: transparent;
}

/* Remove native triangle (all browsers) */
.faq-accordion__q::-webkit-details-marker { display: none; }
.faq-accordion__q::marker { content: ''; }

.faq-accordion__q:hover { color: #fff; }

/* ---- Gold metallic icon (+ / ×) ---- */
.faq-accordion__q::after {
  content: '';
  flex-shrink: 0;
  width: 28px;
  height: 28px;
  border-radius: var(--radius-full);
  background:
    linear-gradient(145deg, rgba(209,194,176,0.18) 0%, rgba(143,112,50,0.08) 100%);
  border: 1px solid rgba(209,194,176,0.28);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.12),
    inset 0 -1px 0 rgba(0,0,0,0.20),
    0 2px 6px rgba(0,0,0,0.35);
  background-image:
    linear-gradient(145deg, rgba(209,194,176,0.18) 0%, rgba(143,112,50,0.08) 100%),
    /* Plus icon via SVG mask */
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath d='M6 1v10M1 6h10' stroke='%23d1c2b0' stroke-width='1.5' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat, no-repeat;
  background-position: center, center;
  background-size: cover, 12px 12px;
  transition: transform var(--duration-lg) var(--ease),
              box-shadow var(--duration) var(--ease),
              background-image var(--duration) var(--ease);
}

.faq-accordion__item[open] .faq-accordion__q::after {
  transform: rotate(45deg);
  background-image:
    linear-gradient(145deg, rgba(143,112,50,0.30) 0%, rgba(209,194,176,0.10) 100%),
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath d='M6 1v10M1 6h10' stroke='%23ddca86' stroke-width='1.5' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat, no-repeat;
  background-position: center, center;
  background-size: cover, 12px 12px;
  border-color: rgba(209,194,176,0.45);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.18),
    inset 0 -1px 0 rgba(0,0,0,0.15),
    0 0 12px rgba(143,112,50,0.25),
    0 2px 6px rgba(0,0,0,0.30);
}

/* ---- Separator line below summary when open ---- */
.faq-accordion__item[open] .faq-accordion__q {
  border-bottom: 1px solid rgba(209,194,176,0.10);
}

/* ---- Answer panel ---- */
.faq-accordion__a {
  padding: var(--sp-5) var(--sp-6) var(--sp-6);
  color: var(--text-muted);
  font-size: var(--text-sm);
  line-height: var(--leading-body);
  max-width: unset;
}

.faq-accordion__a p { margin-bottom: var(--sp-3); max-width: unset; }
.faq-accordion__a p:last-child { margin-bottom: 0; }
.faq-accordion__a a { color: var(--gold); text-decoration: underline; text-underline-offset: 2px; }

/* ---- Mobile ---- */
@media (max-width: 600px) {
  .faq-accordion__q {
    padding: var(--sp-4) var(--sp-4);
    font-size: var(--text-base);
    gap: var(--sp-3);
  }
  .faq-accordion__a { padding: var(--sp-4); }
}
