/* Illustmaker — FAQ page */

.faq-page{padding:32px 0 80px;min-height:60vh;background:var(--bg)}
.faq-container{max-width:1100px;margin:0 auto;padding:0 24px}

.faq-bc{font-size:12px;color:var(--muted);margin-bottom:24px}
.faq-bc ol{list-style:none;padding:0;margin:0;display:flex;flex-wrap:wrap;gap:6px;align-items:center}
.faq-bc li:not(:last-child)::after{content:"›";margin-left:6px;color:var(--muted)}
.faq-bc a{color:var(--txt2)}
.faq-bc a:hover{color:var(--accent)}
.faq-bc [aria-current]{color:var(--txt)}

.faq-hero{text-align:center;margin-bottom:56px;padding:0 8px}
.faq-hero h1{font-size:34px;font-weight:800;margin:0 0 16px;letter-spacing:-.02em;color:var(--txt);font-family:"Plus Jakarta Sans",-apple-system,sans-serif}
.faq-hero p{font-size:15px;color:var(--txt2);margin:0;line-height:1.85}
.faq-hero a{color:var(--accent2);text-decoration:underline;text-underline-offset:3px}
.faq-hero a:hover{color:var(--accent)}

.faq-layout{display:grid;grid-template-columns:220px minmax(0,1fr);gap:48px;align-items:start}

/* TOC */
.faq-toc{position:sticky;top:96px;align-self:start;background:#fff;border:1px solid var(--line);border-radius:10px;padding:18px}
.faq-toc-title{font-size:12px;font-weight:700;color:var(--muted);letter-spacing:.06em;text-transform:uppercase;margin:0 0 10px}
.faq-toc-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:2px;counter-reset:faqtoc}
.faq-toc-list li{counter-increment:faqtoc}
.faq-toc-list a{display:block;padding:7px 8px;font-size:12.5px;color:var(--txt2);text-decoration:none;border-radius:6px;line-height:1.5;transition:all .15s}
.faq-toc-list a::before{content:counter(faqtoc) ". ";color:var(--muted);font-weight:600}
.faq-toc-list a:hover{background:var(--bg-alt);color:var(--accent)}
.faq-toc-list a.active{background:var(--hl);color:var(--accent2);font-weight:600}

/* Main */
.faq-main{min-width:0}
.faq-section{margin-bottom:56px}
.faq-section h2{font-size:22px;font-weight:800;margin:0 0 24px;padding-bottom:10px;border-bottom:2px solid var(--accent);color:var(--txt);letter-spacing:-.01em}

/* FAQ item (details/summary) */
.faq-item{background:#fff;border:1px solid var(--line);border-radius:10px;margin-bottom:12px;overflow:hidden;transition:border-color .15s,box-shadow .15s}
.faq-item[open]{border-color:var(--accent);box-shadow:0 4px 14px rgba(0,0,0,.04)}
.faq-item summary{position:relative;display:block;padding:18px 52px 18px 22px;font-size:15px;font-weight:600;color:var(--txt);cursor:pointer;list-style:none;line-height:1.6;user-select:none;transition:background .15s}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::before{content:"Q.";display:inline-block;color:var(--accent);font-weight:800;margin-right:8px;font-family:"Plus Jakarta Sans",sans-serif}
.faq-item summary::after{content:"";position:absolute;right:22px;top:50%;width:10px;height:10px;border-right:2px solid var(--txt2);border-bottom:2px solid var(--txt2);transform:translateY(-70%) rotate(45deg);transition:transform .2s ease}
.faq-item[open] summary::after{transform:translateY(-30%) rotate(-135deg);border-color:var(--accent)}
.faq-item summary:hover{background:var(--bg-alt)}
.faq-item[open] summary{background:var(--hl)}
.faq-answer{padding:0 22px 20px 40px;font-size:14px;line-height:1.95;color:var(--txt2);position:relative}
.faq-answer::before{content:"A.";position:absolute;left:22px;top:0;color:var(--accent2);font-weight:800;font-family:"Plus Jakarta Sans",sans-serif;font-size:15px}
.faq-answer p{margin:0 0 12px}
.faq-answer p:last-child{margin-bottom:0}
.faq-answer ol,.faq-answer ul{margin:8px 0 12px 22px}
.faq-answer li{margin-bottom:4px}
.faq-answer a{color:var(--accent2);text-decoration:underline;text-underline-offset:3px}
.faq-answer a:hover{color:var(--accent)}
.faq-answer code{font-family:"SF Mono",Menlo,Consolas,monospace;font-size:12.5px;background:var(--bg-alt);padding:2px 6px;border-radius:4px;color:#5a3a00}
.faq-answer pre{background:#1a1714;color:#f0ede6;padding:14px 18px;border-radius:8px;font-family:"SF Mono",Menlo,Consolas,monospace;font-size:12.5px;line-height:1.7;overflow-x:auto;margin:12px 0}
.faq-answer pre code{background:transparent;padding:0;color:inherit;font-size:inherit}
.faq-answer strong{color:var(--txt);font-weight:700}

/* Contact box */
.faq-contact{margin-top:56px;padding:28px 28px;background:var(--hl);border-radius:12px}
.faq-contact h2{font-size:18px;font-weight:800;margin:0 0 12px;padding:0;border:0;color:var(--txt)}
.faq-contact p{margin:0 0 10px;font-size:14px;line-height:1.85;color:var(--txt2)}
.faq-contact p:last-child{margin-bottom:0}
.faq-contact a{color:var(--accent2);text-decoration:underline;text-underline-offset:3px}
.faq-contact a:hover{color:var(--accent)}
.faq-contact strong{color:var(--txt);font-weight:700}

/* Responsive */
@media(max-width:900px){
  .faq-layout{grid-template-columns:1fr;gap:32px}
  .faq-toc{position:static;display:none}
}
@media(max-width:760px){
  .faq-page{padding:24px 0 60px}
  .faq-container{padding:0 16px}
  .faq-hero h1{font-size:26px}
  .faq-hero p{font-size:14px}
  .faq-section h2{font-size:19px}
  .faq-item summary{padding:16px 44px 16px 18px;font-size:14px}
  .faq-item summary::after{right:18px;width:8px;height:8px}
  .faq-answer{padding:0 18px 18px 36px;font-size:13.5px}
  .faq-answer::before{left:18px;font-size:14px}
  .faq-contact{padding:22px}
}
