.snays-faq{
  position: relative;
  background: var(--snays-surface);
  padding-block: clamp(48px, 6vw, 80px);
  isolation: isolate;
}

.snays-faq-head{
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: 14px;
  margin-bottom: 36px;
}
.snays-faq-title{
  font-size: clamp(28px, 3.4vw, 42px);
  font-weight: 700;
  line-height: 1.12;
  letter-spacing: -.8px;
  color: var(--snays-text);
  max-width: 720px;
}
.snays-faq-title em{
  font-style: normal;
  color: var(--snays-accent);
}
.snays-faq-sub{
  font-size: var(--snays-fs-15);
  line-height: 1.65;
  color: var(--snays-text-soft);
  max-width: 620px;
}

.snays-faq-layout{
  display: grid;
  grid-template-columns: minmax(0, 1.6fr) minmax(0, 1fr);
  gap: 28px;
  align-items: start;
}

.snays-faq-list{
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.snays-faq-item{
  background: var(--snays-bg);
  border: 1px solid var(--snays-border);
  border-radius: var(--snays-radius-md);
  overflow: hidden;
  transition: border-color var(--snays-fast) var(--snays-ease), box-shadow var(--snays-fast) var(--snays-ease);
}
.snays-faq-item[open]{
  background: var(--snays-surface);
  border-color: var(--snays-border-strong);
  box-shadow: var(--snays-shadow-1);
}
.snays-faq-q{
  display: flex;
  align-items: center;
  gap: 16px;
  padding: 18px 22px;
  font-size: var(--snays-fs-15);
  font-weight: 600;
  letter-spacing: -.01em;
  color: var(--snays-text);
  cursor: pointer;
  list-style: none;
  user-select: none;
  transition: color var(--snays-fast) var(--snays-ease);
}
.snays-faq-q::-webkit-details-marker{ display: none; }
.snays-faq-q::marker{ content: ''; }
.snays-faq-q:hover{
  color: var(--snays-accent);
}
.snays-faq-q-num{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 28px;
  height: 28px;
  font-size: var(--snays-fs-12);
  font-weight: 700;
  letter-spacing: .3px;
  color: var(--snays-accent);
  background: var(--snays-accent-soft);
  border-radius: var(--snays-radius-sm);
  flex: 0 0 auto;
}
.snays-faq-q-text{
  flex: 1 1 auto;
  min-width: 0;
}
.snays-faq-q-toggle{
  position: relative;
  width: 28px;
  height: 28px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: var(--snays-radius-sm);
  background: var(--snays-surface);
  border: 1px solid var(--snays-border);
  color: var(--snays-text-soft);
  flex: 0 0 auto;
  transition: background var(--snays-fast) var(--snays-ease), color var(--snays-fast) var(--snays-ease), transform var(--snays-mid) var(--snays-ease);
}
.snays-faq-q-toggle .snays-ico{
  width: 14px;
  height: 14px;
  transition: transform var(--snays-mid) var(--snays-ease);
}
.snays-faq-item[open] .snays-faq-q-toggle{
  background: var(--snays-text);
  color: var(--snays-on-primary);
  border-color: var(--snays-text);
}
.snays-faq-item[open] .snays-faq-q-toggle .snays-ico{
  transform: rotate(180deg);
}
.snays-faq-a{
  padding: 0 22px 20px 66px;
  font-size: var(--snays-fs-14);
  line-height: 1.65;
  color: var(--snays-text-soft);
}
.snays-faq-a p + p{
  margin-top: 8px;
}

.snays-faq-side{
  position: sticky;
  top: 90px;
  display: flex;
  flex-direction: column;
  gap: 14px;
  padding: 26px 24px;
  background: var(--snays-bg);
  border: 1px solid var(--snays-border);
  border-radius: var(--snays-radius-md);
}
.snays-faq-side-ico{
  width: 52px;
  height: 52px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: var(--snays-radius-md);
  background: var(--snays-accent-soft);
  color: var(--snays-accent);
}
.snays-faq-side-ico .snays-ico{
  width: 26px;
  height: 26px;
}
.snays-faq-side h3{
  font-size: var(--snays-fs-18);
  font-weight: 700;
  line-height: 1.3;
  letter-spacing: -.01em;
  color: var(--snays-text);
}
.snays-faq-side p{
  font-size: var(--snays-fs-14);
  line-height: 1.6;
  color: var(--snays-text-soft);
}
.snays-faq-side-actions{
  display: flex;
  flex-direction: column;
  gap: 10px;
  margin-top: 8px;
}
.snays-faq-side-btn{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  height: 44px;
  padding: 0 18px;
  font-size: var(--snays-fs-14);
  font-weight: 500;
  border-radius: var(--snays-radius-sm);
  transition: background var(--snays-fast) var(--snays-ease), color var(--snays-fast) var(--snays-ease), border-color var(--snays-fast) var(--snays-ease);
}
.snays-faq-side-btn .snays-ico{
  width: 16px;
  height: 16px;
}
.snays-faq-side-btn-primary{
  background: var(--snays-text);
  color: var(--snays-on-primary);
}
.snays-faq-side-btn-primary:hover{
  background: var(--snays-primary);
}
.snays-faq-side-btn-ghost{
  background: var(--snays-surface);
  color: var(--snays-text);
  border: 1px solid var(--snays-border);
}
.snays-faq-side-btn-ghost:hover{
  background: var(--snays-surface-2);
  border-color: var(--snays-border-strong);
}

@media (max-width: 1100px){
  .snays-faq-layout{
    grid-template-columns: minmax(0, 1fr);
    gap: 18px;
  }
  .snays-faq-side{
    position: static;
  }
}
@media (max-width: 720px){
  .snays-faq{ padding-block: 40px; }
  .snays-faq-head{ margin-bottom: 24px; }
  .snays-faq-title{ font-size: clamp(24px, 6.4vw, 30px); }
  .snays-faq-sub{ font-size: var(--snays-fs-14); }
  .snays-faq-q{
    padding: 14px 16px;
    gap: 12px;
    font-size: var(--snays-fs-14);
  }
  .snays-faq-q-num{ width: 24px; height: 24px; }
  .snays-faq-a{
    padding: 0 16px 16px 52px;
    font-size: var(--snays-fs-13);
  }
  .snays-faq-side{ padding: 22px 20px; }
}

[data-theme="dark"] .snays-faq{ background: var(--snays-surface); }
[data-theme="dark"] .snays-faq-item{
  background: var(--snays-surface-2);
  border-color: var(--snays-border);
}
[data-theme="dark"] .snays-faq-item[open]{
  background: var(--snays-surface);
}
[data-theme="dark"] .snays-faq-q-toggle{
  background: var(--snays-surface);
  border-color: var(--snays-border);
}
[data-theme="dark"] .snays-faq-side{
  background: var(--snays-surface-2);
  border-color: var(--snays-border);
}
[data-theme="dark"] .snays-faq-side-btn-ghost{
  background: var(--snays-surface);
  border-color: var(--snays-border);
}
