/* doc.css — reading layout for legal pages (terms, privacy) */

.doc-hero { padding: 40px 0 36px; background: linear-gradient(180deg, var(--brand-tint), var(--cream)); border-bottom: 1px solid var(--line-soft); }
.doc-back { display: inline-flex; align-items: center; gap: 7px; font-size: 14px; color: var(--muted); margin-bottom: 22px; }
.doc-back:hover { color: var(--brand-deep); }
.doc-hero h1 { font-size: clamp(30px, 4.5vw, 44px); font-weight: 800; margin-top: 16px; }
.doc-upd { margin-top: 14px; font-size: 14px; color: var(--muted); display: inline-flex; align-items: center; gap: 8px; }

.doc-layout { display: grid; grid-template-columns: 240px 1fr; gap: 56px; padding: 48px 28px 80px; align-items: start; }

.doc-toc { position: sticky; top: 96px; }
.doc-toc .toc-title { font-size: 12px; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; color: var(--muted); margin-bottom: 14px; }
.doc-toc nav { display: flex; flex-direction: column; gap: 2px; border-left: 2px solid var(--line); }
.doc-toc a { font-size: 14px; color: var(--ink-2); padding: 8px 0 8px 16px; margin-left: -2px; border-left: 2px solid transparent; transition: color .15s, border-color .15s; line-height: 1.35; }
.doc-toc a:hover { color: var(--brand-deep); border-color: var(--brand); }

.doc-body { max-width: 720px; }
.doc-body section { margin-bottom: 38px; scroll-margin-top: 96px; }
.doc-body h2 { font-size: 22px; font-weight: 700; display: flex; align-items: center; gap: 14px; margin-bottom: 16px; }
.doc-body h2 span { width: 32px; height: 32px; border-radius: 9px; background: var(--brand-tint); color: var(--brand-deep); font-size: 15px; font-weight: 700; display: grid; place-items: center; flex-shrink: 0; }
.doc-body p { font-size: 16px; line-height: 1.65; color: var(--ink-2); margin-bottom: 14px; text-wrap: pretty; }
.doc-body a { color: var(--sky-deep); font-weight: 500; }
.doc-body a:hover { text-decoration: underline; }
.doc-body ul { margin: 0 0 16px; padding: 0; list-style: none; display: flex; flex-direction: column; gap: 11px; }
.doc-body li { display: flex; gap: 12px; font-size: 15.5px; line-height: 1.55; color: var(--ink-2); }
.doc-body li::before { content: ""; width: 7px; height: 7px; border-radius: 50%; background: var(--brand); flex-shrink: 0; margin-top: 9px; }

.callout { display: flex; gap: 14px; align-items: flex-start; background: var(--sky-soft); border-radius: 16px; padding: 18px 20px; margin-bottom: 34px; }
.callout svg { color: var(--sky-deep); flex-shrink: 0; margin-top: 1px; }
.callout p { margin: 0; font-size: 15px; line-height: 1.55; color: var(--ink); }
.callout.soft { background: var(--brand-tint); margin: 4px 0 0; }
.callout.soft svg { color: var(--brand-deep); }

.doc-foot { margin-top: 12px; }
.doc-foot-link { display: flex; align-items: center; justify-content: space-between; gap: 16px; padding: 20px 24px; border: 1px solid var(--line); border-radius: 16px; background: var(--surface); transition: border-color .15s, box-shadow .15s; }
.doc-foot-link:hover { border-color: var(--brand); box-shadow: var(--shadow-sm); }
.doc-foot-link b { font-size: 16px; display: block; }
.doc-foot-link span { font-size: 13.5px; color: var(--muted); }
.doc-foot-link svg { color: var(--brand); flex-shrink: 0; }

@media (max-width: 820px) {
  .doc-layout { grid-template-columns: 1fr; gap: 28px; }
  .doc-toc { position: static; }
  .doc-toc nav { flex-flow: row wrap; border-left: 0; gap: 8px; }
  .doc-toc a { padding: 7px 12px; border: 1px solid var(--line); border-left: 1px solid var(--line); border-radius: 999px; margin-left: 0; }
}
