/* API documentation page — extends public/style.css. */ body { display: grid; grid-template-columns: 240px 1fr; grid-template-rows: auto 1fr auto; grid-template-areas: "header header" "toc main" "footer footer"; min-height: 100vh; } .topbar { grid-area: header; } .toc { grid-area: toc; } .docs { grid-area: main; } .footer { grid-area: footer; } .docs-nav { display: flex; gap: 18px; flex: 1; justify-content: center; } .docs-nav a { color: var(--text-muted); font-size: 13px; font-weight: 500; } .docs-nav a:hover { color: var(--text); text-decoration: none; } /* TOC sticky sidebar */ .toc { position: sticky; top: 60px; align-self: start; padding: 24px 16px 24px 24px; font-size: 13px; max-height: calc(100vh - 60px); overflow-y: auto; border-right: 1px solid var(--border); } .toc h4 { margin: 0 0 10px; text-transform: uppercase; letter-spacing: 0.5px; font-size: 11px; color: var(--text-muted); font-weight: 600; } .toc ul { list-style: none; padding: 0; margin: 0; } .toc li { margin: 4px 0; } .toc ul ul { margin-left: 14px; font-size: 12px; } .toc a { color: var(--text-muted); text-decoration: none; display: block; padding: 3px 8px; border-radius: 4px; border-left: 2px solid transparent; } .toc a:hover { color: var(--text); background: var(--bg-3); text-decoration: none; } /* Main content */ .docs { max-width: 900px; padding: 32px 32px 80px; } .docs h1 { font-size: 32px; margin: 0 0 8px; color: var(--text); } .docs h2 { font-size: 22px; margin: 48px 0 16px; padding-top: 16px; border-top: 1px solid var(--border); color: var(--text); } .docs h2:first-of-type { border-top: 0; padding-top: 0; } .docs h3 { font-size: 16px; margin: 24px 0 10px; color: var(--text); } .docs h4 { font-size: 12px; margin: 20px 0 8px; text-transform: uppercase; letter-spacing: 0.5px; color: var(--text-muted); font-weight: 600; } .docs p { line-height: 1.65; color: var(--text); } .docs .lead { font-size: 17px; color: var(--text-muted); line-height: 1.5; } .docs ul { line-height: 1.7; } .docs code { background: var(--bg-2); padding: 2px 6px; border-radius: 4px; font-family: "SF Mono", "Monaco", "Courier New", monospace; font-size: 0.92em; color: #e0e7ff; } .docs .hint { font-size: 13px; color: var(--text-muted); border-left: 3px solid var(--accent-2); padding: 8px 14px; background: rgba(96, 165, 250, 0.06); border-radius: 0 6px 6px 0; margin: 12px 0; } /* Code blocks */ .block { background: #020617; border: 1px solid var(--border); border-radius: 8px; padding: 14px 16px; overflow-x: auto; margin: 10px 0; } .block code { background: transparent; padding: 0; color: #cbd5e1; font-size: 12.5px; line-height: 1.6; white-space: pre; } /* Endpoint cards */ .endpoint { background: var(--bg-3); border-radius: var(--radius); padding: 22px 24px; margin: 24px 0; border: 1px solid var(--border); scroll-margin-top: 80px; } .endpoint header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; padding-bottom: 12px; border-bottom: 1px solid var(--border); } .method { display: inline-block; padding: 4px 9px; border-radius: 4px; font-size: 11px; font-weight: 700; letter-spacing: 0.5px; } .method.get { background: #1d4ed8; color: white; } .method.post { background: #047857; color: white; } .path { background: transparent; padding: 0; font-size: 14px; color: var(--text); word-break: break-all; } /* Param table */ .params { width: 100%; border-collapse: collapse; font-size: 13px; margin: 8px 0 14px; } .params th, .params td { padding: 8px 12px; border-bottom: 1px solid var(--border); text-align: left; } .params th { background: var(--bg-2); color: var(--text-muted); font-weight: 600; font-size: 11px; text-transform: uppercase; letter-spacing: 0.5px; } /* Footer */ .footer { text-align: center; padding: 16px; color: var(--text-dim); font-size: 12px; border-top: 1px solid var(--border); } /* Sections — anchor offset for sticky topbar */ section { scroll-margin-top: 80px; } @media (max-width: 900px) { body { grid-template-columns: 1fr; grid-template-areas: "header" "main" "footer"; } .toc { display: none; } .docs { padding: 24px 18px 60px; } .docs-nav { display: none; } }