

.faq-page {
  --fq-ink: #1a1a1a;
  --fq-body: #444;
  --fq-muted: #6e6e6e;
  --fq-line: rgba(0, 0, 0, 0.08);
  --fq-beige: #faf8f3;
  --fq-beige-deep: #f3efe6;
  --fq-accent: var(--color-accent, #d3c6a6);
  --fq-radius: var(--radius-m, 12px);
  --fq-ease: cubic-bezier(.2, .8, .2, 1);
  color: var(--fq-body);
  background: #fff;
}

.faq-page #faq-main p {
  margin: 0 0 1.2em;
  font-size: clamp(14px, 1.6vw, 15px);
  line-height: 2;
  letter-spacing: .03em;
  color: var(--fq-body);
}
.faq-page #faq-main p:last-child { margin-bottom: 0; }
.faq-page #faq-main ul,
.faq-page #faq-main ol {
  margin: 0 0 1.2em;
  padding-left: 1.25em;
}
.faq-page #faq-main li {
  font-size: clamp(14px, 1.6vw, 15px);
  line-height: 1.9;
  margin-bottom: .45em;
}
.faq-page #faq-main li:last-child { margin-bottom: 0; }

.faq-hero {
  background: var(--fq-beige);
  border-bottom: 1px solid var(--fq-line);
}
.faq-hero__inner {
  width: min(92%, 720px);
  margin: 0 auto;
  padding-block: calc(var(--s-header-h, 56px) + clamp(52px, 11vh, 96px)) clamp(48px, 9vh, 80px);
  text-align: center;
}
.faq-hero__eyebrow {
  display: inline-block;
  font-size: 10px;
  font-weight: 600;
  letter-spacing: .42em;
  text-transform: uppercase;
  color: var(--fq-muted);
  margin-bottom: clamp(18px, 3vw, 24px);
  padding-left: .42em;
}
.faq-hero__title {
  font-size: clamp(28px, 6vw, 46px);
  line-height: 1.35;
  letter-spacing: .12em;
  padding-left: .12em;
  color: var(--fq-ink);
  line-break: strict;
  word-break: keep-all;
}
.faq-hero__title::after {
  content: "";
  display: block;
  width: 34px;
  height: 1px;
  background: var(--fq-accent);
  margin: clamp(20px, 3.5vw, 28px) auto;
}
.faq-page #faq-main .faq-hero__lead {
  max-width: 36em;
  margin: 0 auto;
  font-size: clamp(13px, 1.5vw, 15px);
  line-height: 2;
  color: var(--fq-muted);
}

.faq-index {
  padding-block: 20px 28px;
  background: #fff;
  border-bottom: 1px solid var(--fq-line);
}
.faq-index__list {
  list-style: none;
  margin: 0 auto;
  padding: 0;
  width: min(92%, 720px);
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 10px 24px;
}
.faq-index__link {
  font-size: 13px;
  letter-spacing: .1em;
  color: var(--fq-ink);
  text-decoration: none;
  padding: 6px 0;
  border-bottom: 1px solid transparent;
  transition: border-color .2s var(--fq-ease), color .2s var(--fq-ease);
}
.faq-index__link:hover,
.faq-index__link:focus-visible {
  border-bottom-color: var(--fq-accent);
}

.faq-body {
  padding-block: clamp(48px, 9vw, 88px);
}
.faq-body__inner {
  width: min(92%, 780px);
  margin: 0 auto;
}
.faq-category {
  scroll-margin-top: calc(var(--s-header-h, 56px) + 16px);
}
.faq-category + .faq-category {
  margin-top: clamp(56px, 10vw, 88px);
  padding-top: clamp(48px, 8vw, 72px);
  border-top: 1px solid var(--fq-line);
}
.faq-category:first-child {
  margin-top: 0;
  padding-top: 0;
  border-top: 0;
}
.faq-category__head {
  text-align: center;
  margin-bottom: clamp(28px, 5vw, 40px);
}
.faq-category__eyebrow {
  display: block;
  font-size: 10px;
  font-weight: 600;
  letter-spacing: .28em;
  text-transform: uppercase;
  color: var(--fq-muted);
  margin-bottom: 10px;
  padding-left: .28em;
}
.faq-category__title {
  font-size: clamp(20px, 4vw, 28px);
  line-height: 1.5;
  letter-spacing: .06em;
  color: var(--fq-ink);
}

.faq-list {
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.faq-item {
  border: 1px solid var(--fq-line);
  border-radius: var(--fq-radius);
  background: #fff;
  box-shadow: 0 4px 20px rgba(0, 0, 0, .03);
  overflow: hidden;
}
.faq-category:nth-child(even) .faq-item,
.faq-body__inner > .faq-category:nth-of-type(even) .faq-item {
  background: rgba(250, 248, 243, .5);
}
.faq-item__question {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  padding: clamp(16px, 3vw, 20px) clamp(18px, 3.5vw, 24px);
  cursor: pointer;
  list-style: none;
  font-size: clamp(14px, 1.7vw, 15px);
  font-weight: 500;
  line-height: 1.75;
  letter-spacing: .04em;
  color: var(--fq-ink);
  line-break: strict;
  word-break: keep-all;
}
.faq-item__question::-webkit-details-marker { display: none; }
.faq-item__question::after {
  content: "";
  flex-shrink: 0;
  width: 8px;
  height: 8px;
  margin-top: .55em;
  margin-left: auto;
  border-right: 1.5px solid var(--fq-muted);
  border-bottom: 1.5px solid var(--fq-muted);
  transform: rotate(45deg);
  transition: transform .25s var(--fq-ease);
}
.faq-item[open] .faq-item__question::after {
  transform: rotate(-135deg);
  margin-top: .75em;
}
.faq-item__q {
  flex-shrink: 0;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .12em;
  color: var(--fq-accent);
  padding-top: .15em;
}
.faq-item__answer {
  padding: clamp(22px, 3.5vw, 30px) clamp(18px, 3.5vw, 24px) clamp(20px, 3.5vw, 28px);
  padding-left: clamp(42px, 7vw, 52px);
  border-top: 1px solid var(--fq-line);
}
.faq-item__answer-inner > :first-child { margin-top: 0; }

.faq-item__text {
  flex: 1;
  min-width: 0;
}

.faq-page #faq-main .faq-subhead,
.faq-page #faq-main .selection-points h3 {
  font-size: 13px;
  font-weight: 600;
  color: var(--fq-ink);
  margin: 1.4em 0 .6em;
}
.faq-page #faq-main .selection-points p {
  margin-bottom: .6em;
}

.faq-related {
  margin-top: 1.4em;
  padding-top: 1em;
  border-top: 1px dashed var(--fq-line);
}
.faq-related__label {
  display: block;
  font-size: 10px;
  font-weight: 600;
  letter-spacing: .14em;
  color: var(--fq-muted);
  margin-bottom: 8px;
}
.faq-related__list {
  display: flex;
  flex-wrap: wrap;
  gap: 6px 16px;
  list-style: none;
  margin: 0;
  padding: 0;
}
.faq-related__list a {
  font-size: 12px;
  color: var(--fq-ink);
  text-decoration: underline;
  text-underline-offset: 3px;
  text-decoration-color: var(--fq-accent);
}
.faq-related__list a:hover { opacity: .65; }

.faq-table-wrap {
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  margin: 1em 0 1.2em;
  border: 1px solid var(--fq-line);
  border-radius: 8px;
}
.faq-table {
  width: 100%;
  min-width: 520px;
  border-collapse: collapse;
  font-size: 12px;
  line-height: 1.65;
}
.faq-table th,
.faq-table td {
  padding: 10px 12px;
  border-bottom: 1px solid var(--fq-line);
  vertical-align: top;
  text-align: left;
}
.faq-table thead th {
  background: var(--fq-beige-deep);
  font-weight: 600;
  color: var(--fq-ink);
  white-space: nowrap;
}
.faq-table tbody th[scope="row"] {
  background: rgba(250, 248, 243, .6);
  font-weight: 600;
  color: var(--fq-ink);
  min-width: 88px;
}
.faq-table tbody tr:last-child th,
.faq-table tbody tr:last-child td { border-bottom: 0; }
.faq-table small {
  display: block;
  font-size: 10px;
  font-weight: 400;
  color: var(--fq-muted);
  margin-top: 4px;
}
.faq-table ul {
  margin: 0;
  padding-left: 1em;
}
.faq-table li {
  font-size: 12px;
  line-height: 1.6;
  margin-bottom: .25em;
}

.faq-hub {
  background: var(--fq-beige);
  border-top: 1px solid var(--fq-line);
}
.faq-hub__inner {
  width: min(92%, 780px);
  margin: 0 auto;
  padding-block: clamp(48px, 8vw, 72px);
  text-align: center;
}
.faq-hub__title {
  font-size: clamp(18px, 3.5vw, 24px);
  line-height: 1.55;
  letter-spacing: .06em;
  color: var(--fq-ink);
  margin-bottom: 10px;
}
.faq-page #faq-main .faq-hub__lead {
  max-width: 32em;
  margin: 0 auto clamp(24px, 4vw, 32px);
  font-size: 13px;
  color: var(--fq-muted);
}
.faq-hub__links {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 10px 24px;
}
.faq-hub__link {
  font-size: 13px;
  letter-spacing: .08em;
  color: var(--fq-ink);
  text-decoration: none;
  padding: 6px 0;
  border-bottom: 1px solid transparent;
  transition: border-color .2s var(--fq-ease);
}
.faq-hub__link:hover,
.faq-hub__link:focus-visible {
  border-bottom-color: var(--fq-accent);
}

.faq-page .cta-final {
  background: #fff;
  border-top: 1px solid var(--fq-line);
  padding-block: clamp(56px, 10vw, 96px);
}
.faq-page .cta-final-inner {
  width: min(92%, 640px);
  margin: 0 auto;
  text-align: center;
}
.faq-page .cta-final-eyebrow {
  font-size: 10px;
  letter-spacing: .32em;
  text-transform: uppercase;
  color: var(--fq-muted);
  margin-bottom: 16px;
}
.faq-page .cta-final-title {
  font-size: clamp(24px, 5vw, 36px);
  line-height: 1.45;
  letter-spacing: .08em;
  color: var(--fq-ink);
  margin-bottom: 16px;
}
.faq-page .cta-final-lead {
  font-size: clamp(13px, 1.5vw, 14px);
  line-height: 2;
  color: var(--fq-muted);
  margin-bottom: 28px;
}
.faq-page .cta-btn-wrap { margin-bottom: 20px; }
.faq-page .cta-final .cta-btn.main {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 240px;
  padding: 14px 24px;
  font-size: 14px;
  letter-spacing: .08em;
  color: var(--fq-ink);
  background: transparent;
  border: 1px solid var(--fq-ink);
  border-radius: 999px;
  transition: background .2s var(--fq-ease), color .2s var(--fq-ease);
}
.faq-page .cta-final .cta-btn.main:hover {
  background: var(--fq-ink);
  color: #fff;
}
.faq-page .cta-final-tel {
  display: block;
  font-size: clamp(22px, 4vw, 28px);
  letter-spacing: .06em;
  color: var(--fq-ink);
  margin-bottom: 8px;
}
.faq-page .cta-final-tel:hover { opacity: .65; }
.faq-page .cta-final-note {
  font-size: 12px;
  color: var(--fq-muted);
  margin-bottom: 24px;
}
.faq-page .cta-final-works {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 12px 20px;
}
.faq-page .cta-final-works a {
  font-size: 12px;
  letter-spacing: .04em;
  color: var(--fq-muted);
  text-decoration: underline;
  text-underline-offset: 3px;
}
.faq-page .cta-final-works a::after { content: " →"; }
.faq-page .cta-final-works a:hover { opacity: .6; }

.faq-br { display: inline; }
@media (max-width: 600px) {
  .faq-br { display: none; }
}

.faq-reveal {
  opacity: 0;
  transform: translateY(14px);
  transition: opacity .6s var(--fq-ease), transform .6s var(--fq-ease);
}
.faq-reveal.is-visible {
  opacity: 1;
  transform: translateY(0);
}

@media (min-width: 768px) {
  .faq-page .cta-final-title { font-size: 34px; }
  .faq-page .cta-final .cta-btn.main { min-width: 280px; }
}

@media (prefers-reduced-motion: reduce) {
  .faq-reveal {
    opacity: 1;
    transform: none;
    transition: none;
  }
  .faq-item__question::after { transition: none; }
}
