.faq-hero { display: grid; grid-template-columns: 1.2fr .8fr; gap: 40px; padding: 30px 0 40px; align-items: start; }
.faq-hero h1 { font-size: clamp(34px, 5vw, 64px); font-weight: 800; letter-spacing: -.03em; line-height: 1; margin: 0; text-transform: uppercase; }
.faq-hero p { color: #a8a8a8; font-size: 16px; line-height: 1.7; margin-top: 24px; max-width: 640px; }
.faq-deco { position: relative; height: 160px; }
.faq-deco::before { content: ''; position: absolute; right: 140px; top: 10px; width: 140px; height: 140px; border: 1px solid var(--line); border-radius: 140px 0 0 0; }
.faq-deco::after { content: ''; position: absolute; right: 0; top: 10px; width: 140px; height: 140px; border: 1px solid var(--line); }

.faq-body { display: grid; grid-template-columns: 340px 1fr; gap: 40px; padding: 40px 0 60px; }
.faq-cat { background: linear-gradient(180deg, #262626, #1a1a1a); border-radius: 28px; padding: 36px 30px; }
.faq-cat h2 { font-size: clamp(24px, 2.2vw, 34px); text-transform: uppercase; font-weight: 800; margin: 0 0 28px; letter-spacing: -.02em; }
.faq-cat ul { list-style: none; padding: 0; margin: 0; display: grid; gap: 18px; }
.faq-cat li { display: flex; gap: 14px; align-items: center; color: #ddd; font-size: 15px; cursor: pointer; }
.faq-cat .box { flex-shrink: 0; color: #ddd; }
[data-faq-categories] li.active .box { color: var(--primary); }

.faq-list { display: flex; flex-direction: column; }
.faq-item { border-bottom: 1px solid var(--primary); padding: 18px 0; }
.faq-item summary { list-style: none; display: flex; justify-content: space-between; align-items: center; cursor: pointer; gap: 16px; }
.faq-item summary::-webkit-details-marker { display: none; }
.faq-item h3 { margin: 0; font-size: clamp(22px, 2vw, 30px); font-weight: 800; letter-spacing: -.02em; }
.faq-item .chev { width: 20px; height: 20px; transition: .2s; flex-shrink: 0; }
.faq-item[open] .chev { transform: rotate(180deg); }
.faq-item p { color: #c8c8c8; font-size: 15px; line-height: 1.7; margin: 16px 0 0; max-width: 860px; }

@media (max-width: 960px) {
    .faq-hero, .faq-body { grid-template-columns: 1fr; }
    .faq-deco { display: none; }
    .faq-cat { padding: 24px; }
    .faq-item h3 { font-size: 20px; }
}
@media (max-width: 640px) {
    .faq-hero h1 { font-size: clamp(28px, 8vw, 40px); }
    .faq-hero p { font-size: 14px; margin-top: 16px; }
}
@media (max-width: 560px) {
    .faq-body { gap: 24px; padding: 30px 0 40px; }
    .faq-cat { padding: 22px 18px; }
    .faq-cat h2 { font-size: 22px; margin-bottom: 16px; }
    .faq-item { padding: 14px 0; }
    .faq-item h3 { font-size: 17px; }
    .faq-item p { font-size: 13px; }
}
