:root{--bg: #ffffff;--fg: #19191c;--muted: #6c707e;--border: #ebecf0;--accent: #3574f0;--sidebar-bg: #f7f8fa;--sidebar-active: #e7effd;--card-border: #d3d5db;--code-bg: #f5f5f7;--font-sans: -apple-system, BlinkMacSystemFont, "Inter", "Segoe UI", sans-serif;--font-mono: "JetBrains Mono", ui-monospace, SFMono-Regular, Menlo, monospace}*{box-sizing:border-box}html,body{margin:0;padding:0;font-family:var(--font-sans);color:var(--fg);background:var(--bg);font-size:15px;line-height:1.6}a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}.layout{display:grid;grid-template-columns:280px minmax(0,1fr) 240px;grid-template-rows:56px 1fr;grid-template-areas:"header header header" "sidebar content toc";min-height:100vh}@media(max-width:1100px){.layout{grid-template-columns:240px minmax(0,1fr);grid-template-areas:"header header" "sidebar content"}.toc{display:none}}@media(max-width:720px){.layout{grid-template-columns:1fr;grid-template-areas:"header" "content"}.sidebar{position:fixed;top:56px;left:0;width:280px;max-width:85vw;height:calc(100vh - 56px);z-index:60;transform:translate(-100%);transition:transform .2s ease;box-shadow:2px 0 16px #00000014}.sidebar.open{transform:translate(0)}.content{padding:24px 20px}}.sidebar-backdrop{display:none}@media(max-width:720px){.sidebar-backdrop{display:block;position:fixed;top:56px;right:0;bottom:0;left:0;background:#0f121c59;z-index:55}}.app-header{grid-area:header;position:sticky;top:0;z-index:50;background:var(--bg);border-bottom:1px solid var(--border);height:56px}.app-header-inner{display:grid;grid-template-columns:280px minmax(0,1fr) 280px;align-items:center;height:100%;padding:0 16px;gap:16px}@media(max-width:1100px){.app-header-inner{grid-template-columns:240px minmax(0,1fr) 0}}@media(max-width:720px){.app-header-inner{grid-template-columns:36px minmax(0,1fr) 36px;gap:8px;padding:0 12px}.app-header-brand{text-align:center;padding-left:0}.app-header-spacer{display:none}.search-trigger{width:36px;height:36px;padding:0;justify-content:center;margin:0}.search-trigger-label,.search-kbd{display:none}}.nav-toggle{display:none;align-items:center;justify-content:center;width:36px;height:36px;padding:0;border:1px solid var(--border);border-radius:8px;background:var(--bg);cursor:pointer;flex-direction:column;gap:4px}.nav-toggle:hover{border-color:var(--card-border);background:var(--sidebar-bg)}.nav-toggle-bar{display:block;width:16px;height:2px;background:var(--fg);border-radius:1px}@media(max-width:720px){.nav-toggle{display:flex}}.app-header-brand{font-size:14px;font-weight:600;color:var(--fg);padding-left:8px}.app-header-spacer{height:1px}.search-trigger{display:flex;align-items:center;gap:8px;width:100%;max-width:520px;margin:0 auto;padding:0 12px;height:36px;background:var(--sidebar-bg);border:1px solid var(--border);border-radius:8px;color:var(--muted);cursor:pointer;font:inherit;font-size:13px;text-align:left;transition:border-color .15s,background .15s}.search-trigger:hover{border-color:var(--card-border);background:var(--bg)}.search-trigger-label{flex:1}.search-icon{font-size:16px;color:var(--muted)}.search-kbd{font-family:var(--font-mono);font-size:11px;padding:2px 6px;border:1px solid var(--border);border-radius:4px;background:var(--bg);color:var(--muted)}.sidebar{grid-area:sidebar;background:var(--sidebar-bg);border-right:1px solid var(--border);padding:24px 16px;position:sticky;top:56px;height:calc(100vh - 56px);overflow-y:auto}.sidebar h2{font-size:14px;font-weight:600;margin:0 0 16px 8px;color:var(--fg)}.sidebar nav{display:flex;flex-direction:column;gap:2px}.nav-link{display:block;padding:6px 10px;border-radius:6px;color:var(--fg);font-size:14px;text-decoration:none}.nav-link:hover{background:#0000000a;text-decoration:none}.nav-link.active{background:var(--sidebar-active);color:var(--accent);font-weight:500}.nav-group{display:flex;flex-direction:column;margin-top:4px}.nav-group-header{display:flex;align-items:center;gap:6px;background:none;border:none;cursor:pointer;padding:6px 10px;font:inherit;font-size:14px;color:var(--fg);text-align:left;border-radius:6px;font-weight:500}.nav-group-header:hover{background:#0000000a}.caret{display:inline-block;font-size:10px;color:var(--muted);transition:transform .15s}.caret.open{transform:rotate(90deg)}.nav-children{display:flex;flex-direction:column;gap:2px;padding-left:18px;margin:2px 0 4px 14px;border-left:1px solid var(--border)}.content{grid-area:content;max-width:880px;padding:48px 64px;min-width:0}.content h1{font-size:40px;line-height:1.15;font-weight:600;margin:0 0 24px;letter-spacing:-.02em}.content h2,.content h3{scroll-margin-top:24px;position:relative}.content h2{font-size:24px;font-weight:600;margin:40px 0 16px}.content h3{font-size:18px;font-weight:600;margin:28px 0 12px}.heading-anchor{opacity:0;margin-left:8px;color:var(--muted);text-decoration:none;font-weight:400;transition:opacity .15s}.content h2:hover .heading-anchor,.content h3:hover .heading-anchor{opacity:1}.heading-anchor:hover{color:var(--accent);text-decoration:none}.content p{margin:0 0 16px}.content ul,.content ol{margin:0 0 16px;padding-left:24px}.content li{margin-bottom:4px}.content table{width:100%;border-collapse:collapse;margin:16px 0 24px;font-size:14px;display:block;overflow-x:auto}.content table thead{background:var(--code-bg)}.content table th,.content table td{text-align:left;padding:10px 14px;border-bottom:1px solid var(--border);vertical-align:top}.content table th{font-weight:600;color:var(--fg);border-bottom:2px solid var(--card-border)}.content table tbody tr:hover{background:#3574f00a}.content table code{white-space:nowrap}.content blockquote{border-left:3px solid var(--accent);margin:16px 0;padding:8px 16px;background:var(--code-bg);color:var(--muted);border-radius:0 6px 6px 0}.content blockquote p{margin:0}.content :not(pre)>code{font-family:var(--font-mono);background:var(--code-bg);padding:2px 6px;border-radius:4px;font-size:.9em}.content pre.shiki,.content pre{background:var(--code-bg)!important;padding:16px;border-radius:8px;overflow-x:auto;font-family:var(--font-mono);font-size:13px;line-height:1.55;border:1px solid var(--border)}.content pre code{background:none;padding:0;font-size:inherit}.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:16px;margin:24px 0}.screenshot{margin:28px 0;padding:0}.screenshot img{display:block;max-width:100%;border-radius:8px;border:1px solid var(--border)}.screenshot-placeholder{display:flex;align-items:center;justify-content:center;min-height:220px;border:2px dashed var(--card-border);border-radius:8px;background:var(--code-bg);color:var(--muted);font-size:13px;font-style:italic;text-align:center;padding:24px;line-height:1.5}.screenshot-placeholder:before{content:"📸  ";font-style:normal;margin-right:6px;filter:grayscale(1) opacity(.6)}.screenshot figcaption{margin-top:8px;font-size:13px;color:var(--muted);text-align:center}.card{border:1px solid var(--card-border);border-radius:8px;padding:20px;display:block;color:var(--fg);transition:border-color .15s}.card:hover{border-color:var(--accent);text-decoration:none}.card h3{margin:0 0 8px;font-size:16px}.card p{margin:0;color:var(--muted);font-size:14px}.toc{grid-area:toc;position:sticky;top:56px;height:calc(100vh - 56px);overflow-y:auto;padding:48px 24px 48px 16px;border-left:1px solid var(--border);font-size:13px}.search-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f121c73;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:100;display:flex;justify-content:center;padding-top:12vh;padding-left:16px;padding-right:16px}.search-modal{width:100%;max-width:640px;max-height:70vh;background:var(--bg);border:1px solid var(--card-border);border-radius:12px;box-shadow:0 24px 60px #0000002e;display:flex;flex-direction:column;overflow:hidden}.search-input-row{display:flex;align-items:center;gap:10px;padding:12px 16px;border-bottom:1px solid var(--border)}.search-input{flex:1;border:none;outline:none;font:inherit;font-size:16px;color:var(--fg);background:transparent}.search-body{overflow-y:auto;overflow-x:hidden;padding:8px}.search-empty{padding:24px 16px;text-align:center;color:var(--muted);font-size:14px}.search-results{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:2px}.search-result{display:block;width:100%;max-width:100%;text-align:left;background:none;border:none;padding:10px 12px;border-radius:8px;cursor:pointer;font:inherit;color:var(--fg);overflow:hidden}.search-result:hover,.search-result.active{background:var(--sidebar-active)}.search-result.search-sub{margin-left:16px}.search-result-title{font-size:14px;font-weight:500;margin-bottom:2px}.search-result-excerpt{font-size:12px;color:var(--muted);line-height:1.5;overflow-wrap:anywhere;word-break:break-word}.search-result-excerpt mark{background:#3574f02e;color:var(--fg);padding:0 2px;border-radius:2px}.toc-title{font-weight:600;font-size:12px;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);margin-bottom:12px}.toc ul{list-style:none;padding:0;margin:0;border-left:1px solid var(--border)}.toc-item a{display:block;padding:4px 12px;color:var(--muted);border-left:2px solid transparent;margin-left:-1px;line-height:1.4;text-decoration:none}.toc-item a:hover{color:var(--fg);text-decoration:none}.toc-item a.active{color:var(--accent);border-left-color:var(--accent);font-weight:500}.toc-l3 a{padding-left:24px;font-size:12px}
