/* ============================================================
   Legal / long-form document pages (Terms, Privacy)
   ============================================================ */
.legal-hero{
  padding:64px 0 40px;
  background:var(--bg-soft);
  border-bottom:1px solid var(--line);
}
.legal-hero .wrap{max-width:860px;}
.legal-hero .back{display:inline-flex;align-items:center;gap:7px;font-size:14px;font-weight:700;color:var(--muted);margin-bottom:22px;transition:color .15s;}
.legal-hero .back:hover{color:var(--primary-700);}
.legal-hero .back svg{width:16px;height:16px;flex:none;}
.legal-hero .back span{line-height:1;}
.legal-hero .eyebrow{display:flex;margin-bottom:14px;}
.legal-hero h1{
  font-size:clamp(32px,4.2vw,50px);letter-spacing:-.03em;line-height:1.06;
}
.legal-hero .updated{
  margin-top:18px;display:inline-flex;align-items:center;gap:9px;
  font-size:14px;font-weight:600;color:var(--muted);
}
.legal-hero .updated::before{
  content:"";width:8px;height:8px;border-radius:50%;background:var(--green);
}

.legal-body{padding:56px 0 88px;}
.legal-body .wrap{max-width:860px;display:grid;grid-template-columns:220px 1fr;gap:56px;align-items:start;}

/* sticky table of contents */
.legal-toc{position:sticky;top:96px;align-self:start;}
.legal-toc h4{
  font-size:12px;text-transform:uppercase;letter-spacing:.1em;color:var(--muted);
  margin:0 0 14px;font-weight:700;
}
.legal-toc ol{list-style:none;margin:0;padding:0;counter-reset:toc;display:flex;flex-direction:column;gap:2px;}
.legal-toc a{
  display:block;padding:7px 10px;border-radius:8px;font-size:14px;font-weight:600;
  color:var(--ink-2);line-height:1.35;transition:background .14s,color .14s;
}
.legal-toc a:hover{background:var(--bg-tint);color:var(--ink);}
.legal-toc a.active{background:var(--bg-tint);color:var(--primary-700);}

/* article body */
.legal-doc{min-width:0;}
.legal-doc .intro{font-size:17.5px;color:var(--ink-2);line-height:1.7;margin-bottom:40px;}
.legal-doc section{margin-bottom:40px;scroll-margin-top:96px;}
.legal-doc h2{
  font-size:21px;letter-spacing:-.01em;margin:0 0 14px;font-weight:800;
  display:flex;align-items:baseline;gap:12px;
}
.legal-doc h2 .n{
  font-size:14px;font-weight:800;color:var(--primary-700);
  flex:none;min-width:24px;
}
.legal-doc h3{font-size:16.5px;margin:24px 0 10px;font-weight:700;}
.legal-doc p{margin:0 0 14px;color:var(--ink-2);font-size:15.5px;line-height:1.72;}
.legal-doc ul{margin:0 0 14px;padding-left:22px;color:var(--ink-2);font-size:15.5px;line-height:1.72;}
.legal-doc li{margin-bottom:7px;}
.legal-doc a.inline{color:var(--primary-700);font-weight:600;border-bottom:1px solid color-mix(in srgb,var(--primary) 35%,transparent);}
.legal-doc a.inline:hover{border-bottom-color:var(--primary);}
.legal-doc strong{color:var(--ink);font-weight:700;}

.legal-callout{
  background:var(--bg-soft);border:1px solid var(--line);border-radius:var(--r);
  padding:20px 22px;margin:0 0 14px;
}
.legal-callout p:last-child{margin-bottom:0;}

.legal-contact{
  margin-top:8px;background:#fff;border:1px solid var(--line);border-radius:var(--r);
  padding:22px 24px;
}
.legal-contact b{display:block;font-size:15px;margin-bottom:4px;}
.legal-contact a{color:var(--primary-700);font-weight:600;}

/* ============ FAQ accordion ============ */
.faq-body .wrap{max-width:820px;display:block;}
.faq-list{display:flex;flex-direction:column;gap:14px;}
.faq-item{
  background:#fff;border:1px solid var(--line);border-radius:var(--r);
  box-shadow:var(--shadow-sm);overflow:hidden;
}
.faq-item summary{
  list-style:none;cursor:pointer;display:flex;align-items:center;gap:16px;
  padding:22px 24px;font-size:17px;font-weight:700;color:var(--ink);line-height:1.4;
}
.faq-item summary::-webkit-details-marker{display:none;}
.faq-item summary > span:first-child{flex:1;}
.faq-ic{position:relative;width:16px;height:16px;flex:none;}
.faq-ic::before,.faq-ic::after{
  content:"";position:absolute;background:var(--primary);border-radius:2px;transition:transform .22s var(--ease);
}
.faq-ic::before{top:7px;left:0;width:16px;height:2px;}
.faq-ic::after{left:7px;top:0;width:2px;height:16px;}
.faq-item[open] .faq-ic::after{transform:rotate(90deg) scaleX(0);}
.faq-item[open] summary{color:var(--primary-700);}
.faq-a{padding:0 24px 22px;}
.faq-a p{margin:0 0 12px;color:var(--ink-2);font-size:15.5px;line-height:1.7;}
.faq-a p:last-child{margin-bottom:0;}
.faq-a a.inline{color:var(--primary-700);font-weight:600;border-bottom:1px solid color-mix(in srgb,var(--primary) 35%,transparent);}

.faq-tag{
  display:inline-block;font-size:12px;font-weight:800;letter-spacing:.02em;
  color:var(--c-form);background:var(--c-form-100);border-radius:999px;
  padding:3px 10px;margin-right:8px;vertical-align:middle;
}
.faq-tag.tag-wf{color:var(--c-workflow);background:var(--c-workflow-100);}

.faq-contact{
  margin-top:40px;text-align:center;background:var(--bg-soft);
  border:1px solid var(--line);border-radius:var(--r-2xl);padding:40px 28px;
}
.faq-contact h3{font-size:22px;letter-spacing:-.02em;margin:0 0 8px;}
.faq-contact p{color:var(--muted);font-size:15.5px;margin:0 0 22px;}

/* OAuth scope groups (privacy policy) */
.scope-group{margin:0 0 26px;}
.scope-group > h3{font-size:16px;margin:0 0 12px;font-weight:800;color:var(--ink);}
.scope-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:12px;}
.scope-list li{
  background:var(--bg-soft);border:1px solid var(--line);border-radius:12px;padding:13px 15px;
}
.scope-list code{
  display:block;font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;
  font-size:12.5px;color:var(--primary-700);word-break:break-all;line-height:1.5;margin-bottom:5px;
}
.scope-list .desc{font-size:14px;color:var(--ink-2);line-height:1.6;}

/* ============ Guide / article ============ */
.guide-doc figure{margin:8px 0 22px;}
.guide-doc code{
  font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;
  font-size:.88em;background:var(--accent-100,var(--c-form-100));
  color:var(--accent,var(--c-form));padding:1px 6px;border-radius:6px;
}
.guide-doc figure img{
  display:block;width:100%;border-radius:14px;border:1px solid var(--line);
  background:var(--bg-soft);box-shadow:var(--shadow-sm);
}
.guide-doc figcaption{
  margin-top:9px;font-size:13.5px;color:var(--muted);text-align:center;line-height:1.5;
}
.guide-step{
  position:relative;padding-left:52px;margin-bottom:30px;scroll-margin-top:96px;
}
.guide-step .step-n{
  position:absolute;left:0;top:0;width:34px;height:34px;border-radius:50%;
  background:var(--accent,var(--c-form));color:#fff;font-weight:800;font-size:15px;
  display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-sm);
}
.guide-step h2{margin-top:3px;}
.guide-cta{
  margin:8px 0 34px;background:var(--accent-100,var(--c-form-100));border:1px solid var(--line);
  border-radius:var(--r-2xl);padding:28px 28px;display:flex;align-items:center;
  justify-content:space-between;gap:22px;flex-wrap:wrap;
}
.guide-cta .gc-txt b{display:block;font-size:18px;color:var(--ink);margin-bottom:4px;letter-spacing:-.01em;}
.guide-cta .gc-txt span{font-size:14.5px;color:var(--ink-2);}
.guide-key{
  display:flex;flex-wrap:wrap;gap:8px;margin:0 0 28px;list-style:none;padding:0;
}
.guide-key li{
  font-size:13px;font-weight:700;color:var(--accent,var(--c-form));background:var(--accent-100,var(--c-form-100));
  border-radius:999px;padding:6px 13px;
}
.guide-meta{
  display:flex;align-items:center;gap:14px;flex-wrap:wrap;
  font-size:13.5px;color:var(--muted);margin-top:16px;
}
.guide-meta span{display:inline-flex;align-items:center;gap:6px;}
.guide-meta .dot{width:4px;height:4px;border-radius:50%;background:var(--line-2);}

.guide-settings{margin:4px 0 26px;display:flex;flex-direction:column;gap:0;}
.guide-settings .gs-row{
  display:grid;grid-template-columns:1fr auto;gap:6px 16px;align-items:start;
  padding:16px 0;border-bottom:1px solid var(--line);
}
.guide-settings .gs-row:first-child{border-top:1px solid var(--line);}
.guide-settings .gs-name{font-weight:700;color:var(--ink);font-size:15.5px;}
.guide-settings .gs-desc{grid-column:1;font-size:14.5px;color:var(--ink-2);line-height:1.55;margin-top:2px;}
.guide-settings .gs-tag{
  grid-row:1;grid-column:2;align-self:center;white-space:nowrap;
  font-size:12px;font-weight:700;border-radius:999px;padding:4px 11px;
  background:var(--accent-100,var(--c-form-100));color:var(--accent,var(--c-form));
}
.guide-settings .gs-tag.off{background:var(--bg-soft);color:var(--muted);}
.guide-settings .gs-tag.num{background:var(--bg-soft);color:var(--ink-2);font-variant-numeric:tabular-nums;}
.guide-settings .gs-note{
  display:block;margin-top:8px;font-size:13.5px;line-height:1.5;color:var(--accent,var(--c-form));
  background:var(--accent-100,var(--c-form-100));border-radius:10px;padding:9px 12px;
}
.guide-settings .gs-note strong{color:inherit;}

@media (max-width:820px){
  .legal-body .wrap{grid-template-columns:1fr;gap:8px;}
  .legal-toc{position:static;margin-bottom:32px;border-bottom:1px solid var(--line);padding-bottom:24px;}
  .legal-toc ol{flex-direction:row;flex-wrap:wrap;gap:6px;}
  .legal-toc a{background:var(--bg-soft);}
  .guide-cta{flex-direction:column;align-items:flex-start;}
}
