/* Adapted from the Peekaboo documentation site template.
   Original source: https://peekaboo.sh/
   Original project license: MIT, https://github.com/openclaw/Peekaboo/blob/main/LICENSE */
:root{
  --bg0:#07080a;
  --bg1:#0a0b0f;
  --bg2:#0e1020;
  --panel:rgba(255,255,255,0.045);
  --panel2:rgba(255,255,255,0.075);
  --line:rgba(255,255,255,0.10);
  --line-soft:rgba(255,255,255,0.05);
  --ink:rgba(255,255,255,0.96);
  --text:rgba(255,255,255,0.86);
  --muted:rgba(255,255,255,0.62);
  --subtle:rgba(255,255,255,0.42);
  --ecto:#00f5a0;
  --ecto2:#00c08f;
  --moon:#ffd24a;
  --hot:#ff3d78;
  --accent:var(--ecto);
  --accent-soft:rgba(0,245,160,0.14);
  --accent-strong:#3affba;
  --paper:rgba(255,255,255,0.03);
  --code-bg:#06080d;
  --code-fg:#e6edf3;
  --code-border:rgba(255,255,255,0.08);
  --code-comment:var(--muted);
  --code-keyword:var(--ecto);
  --code-type:var(--accent-strong);
  --code-string:var(--moon);
  --code-number:#ffb86c;
  --code-name:#8fd3ff;
  --code-operator:#9fb0c4;
  --shadow-card:0 18px 40px rgba(0,0,0,0.55);
  --glow-primary:rgba(0,245,160,0.10);
  --glow-secondary:rgba(255,210,74,0.07);
  --chrome-bg:rgba(7,8,10,0.85);
  --chrome-bg-solid:rgba(7,8,10,0.96);
  --toggle-bg:rgba(7,8,10,0.8);
  --selection-fg:#04130c;
  --mark-core:#04130c;
  --mark-glint:rgba(255,255,255,0.2);
  --pre-scrollbar:#334155;
  --copy-bg:rgba(255,255,255,.06);
  --copy-border:rgba(255,255,255,.16);
  --mobile-shadow:0 18px 40px rgba(0,0,0,.45);
  --serif:"Fraunces",ui-serif,Georgia,serif;
  --sans:"Recursive",ui-sans-serif,system-ui,-apple-system,"Segoe UI",sans-serif;
  --mono:"JetBrains Mono",ui-monospace,SFMono-Regular,Menlo,monospace;
  color-scheme:dark;
}
html[data-theme="light"]{
  --bg0:#f7faf8;
  --bg1:#eef5f1;
  --bg2:#e8eef8;
  --panel:rgba(8,24,20,0.055);
  --panel2:rgba(8,24,20,0.085);
  --line:rgba(8,24,20,0.14);
  --line-soft:rgba(8,24,20,0.07);
  --ink:#08120f;
  --text:rgba(8,18,15,0.84);
  --muted:rgba(8,18,15,0.60);
  --subtle:rgba(8,18,15,0.42);
  --ecto:#007f61;
  --ecto2:#006f59;
  --moon:#b67800;
  --hot:#c83264;
  --accent:var(--ecto);
  --accent-soft:rgba(0,127,97,0.12);
  --accent-strong:#00684f;
  --paper:rgba(8,24,20,0.035);
  --code-bg:#f3f7f5;
  --code-fg:#102118;
  --code-border:rgba(8,24,20,0.12);
  --code-comment:#5f6f68;
  --code-keyword:#007f61;
  --code-type:#0f766e;
  --code-string:#9a5d00;
  --code-number:#b45309;
  --code-name:#005f99;
  --code-operator:#4b5563;
  --shadow-card:0 18px 40px rgba(8,24,20,0.14);
  --glow-primary:rgba(0,127,97,0.13);
  --glow-secondary:rgba(182,120,0,0.10);
  --chrome-bg:rgba(247,250,248,0.88);
  --chrome-bg-solid:rgba(247,250,248,0.97);
  --toggle-bg:rgba(247,250,248,0.82);
  --selection-fg:#ffffff;
  --mark-core:#edfdf6;
  --mark-glint:rgba(8,18,15,0.24);
  --pre-scrollbar:#94a3b8;
  --copy-bg:rgba(255,255,255,.08);
  --copy-border:rgba(255,255,255,.18);
  --mobile-shadow:0 18px 40px rgba(8,24,20,.18);
  color-scheme:light;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth;scroll-padding-top:24px}
body{
  margin:0;
  background:radial-gradient(1200px 600px at 70% -10%,var(--glow-primary),transparent 60%),
             radial-gradient(900px 500px at 0% 110%,var(--glow-secondary),transparent 55%),
             var(--bg0);
  color:var(--text);
  font-family:var(--sans);
  line-height:1.65;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  font-feature-settings:"ss02","ss03";
}
::selection{background:var(--ecto);color:var(--selection-fg)}
a{color:var(--ecto);text-decoration:none;transition:color .12s,opacity .12s}
a:hover{opacity:.85;text-decoration:underline;text-underline-offset:.2em}
.shell{display:grid;grid-template-columns:280px minmax(0,1fr);min-height:100vh}
.sidebar{position:sticky;top:0;height:100vh;overflow:auto;padding:24px 22px;background:var(--chrome-bg);backdrop-filter:saturate(140%) blur(8px);border-right:1px solid var(--line);scrollbar-width:thin;scrollbar-color:var(--line) transparent}
.sidebar::-webkit-scrollbar{width:6px}
.sidebar::-webkit-scrollbar-thumb{background:var(--line);border-radius:6px}
.sidebar-head{display:flex;align-items:center;gap:10px;margin-bottom:24px}
.brand{display:flex;align-items:center;color:var(--ink);text-decoration:none;flex:1;min-width:0}
.brand:hover{text-decoration:none;opacity:1}
.brand strong{display:block;font-family:var(--serif);font-size:1.15rem;line-height:1;font-weight:600;letter-spacing:.01em;color:var(--ink)}
.brand small{display:block;color:var(--muted);font-size:.74rem;margin-top:4px;font-weight:400}
.search{display:block;margin:0 0 22px}
.search span{display:block;color:var(--muted);font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:0.06em;margin-bottom:7px}
.search input{width:100%;border:1px solid var(--line);background:var(--panel);border-radius:8px;padding:9px 12px;font:inherit;font-size:.9rem;color:var(--text);outline:none;transition:border-color .15s,box-shadow .15s}
.search input::placeholder{color:var(--subtle)}
.search input:focus{border-color:var(--ecto);box-shadow:0 0 0 3px var(--accent-soft)}
nav section{margin:0 0 18px}
nav h2{font-size:.66rem;color:var(--muted);text-transform:uppercase;letter-spacing:0.10em;margin:0 0 6px;font-weight:600}
.nav-link{display:block;color:var(--text);text-decoration:none;border-radius:6px;padding:5px 10px;margin:1px 0;font-size:.9rem;line-height:1.4;transition:background .12s,color .12s}
.nav-link:hover{background:var(--panel);color:var(--ink);text-decoration:none;opacity:1}
.nav-link.active{background:var(--accent-soft);color:var(--ecto);font-weight:600}
main{min-width:0;padding:32px clamp(20px,4.5vw,56px) 80px;max-width:1180px;margin:0 auto;width:100%}
.hero{display:flex;align-items:flex-end;justify-content:space-between;gap:22px;border-bottom:1px solid var(--line);padding:8px 0 22px;margin-bottom:8px;flex-wrap:wrap}
.hero-text{min-width:0;flex:1 1 320px}
.eyebrow{margin:0 0 8px;color:var(--ecto);font-weight:600;text-transform:uppercase;letter-spacing:0.10em;font-size:.7rem}
.hero h1{font-family:var(--serif);font-size:2.4rem;line-height:1.05;letter-spacing:0;margin:0;font-weight:600;color:var(--ink)}
.hero-meta{display:flex;gap:8px;flex:0 0 auto;flex-wrap:wrap}
.repo,.edit,.btn-ghost{border:1px solid var(--line);color:var(--text);text-decoration:none;border-radius:8px;padding:7px 12px;font-weight:500;font-size:.83rem;background:var(--panel);transition:border-color .15s,color .15s,background .15s}
.repo:hover,.edit:hover,.btn-ghost:hover{border-color:var(--ecto);color:var(--ink);text-decoration:none;opacity:1}
.edit{color:var(--muted)}
.doc-grid{display:grid;grid-template-columns:minmax(0,1fr);gap:48px;margin-top:24px}
@media(min-width:1180px){.doc-grid{grid-template-columns:minmax(0,72ch) 220px;justify-content:start}}
.doc{min-width:0;max-width:72ch;overflow-wrap:break-word}
.doc h1{font-family:var(--serif);font-size:2.6rem;line-height:1.08;letter-spacing:0;margin:0 0 .4em;font-weight:600;color:var(--ink)}
body:not(.home) .doc>h1:first-child{display:none}
.doc h2{font-family:var(--serif);font-size:1.55rem;line-height:1.2;margin:2em 0 .5em;font-weight:600;letter-spacing:0;color:var(--ink);position:relative}
.doc h3{font-family:var(--serif);font-size:1.2rem;margin:1.7em 0 .35em;position:relative;font-weight:600;color:var(--ink);letter-spacing:0}
.doc h4{font-size:1rem;margin:1.4em 0 .25em;color:var(--ink);position:relative;font-weight:600}
.doc h2:first-child,.doc h3:first-child,.doc h4:first-child{margin-top:.2em}
.doc :is(h2,h3,h4) .anchor{position:absolute;left:-1.05em;top:0;color:var(--subtle);opacity:0;text-decoration:none;font-weight:400;padding-right:.3em;transition:opacity .12s,color .12s}
.doc :is(h2,h3,h4):hover .anchor{opacity:.7}
.doc :is(h2,h3,h4) .anchor:hover{opacity:1;color:var(--ecto);text-decoration:none}
.doc p{margin:0 0 1.05em}
.page-summary{margin:0 0 1.4em;color:var(--muted);font-size:1rem;max-width:62ch}
.doc ul,.doc ol{padding-left:1.3rem;margin:0 0 1.15em}
.doc li{margin:.25em 0}
.doc li>p{margin:0 0 .4em}
.doc strong{font-weight:600;color:var(--ink)}
.doc em{font-style:italic;color:var(--ink)}
.doc code{font-family:var(--mono);font-size:.84em;background:var(--panel);border:1px solid var(--line);border-radius:5px;padding:.08em .35em;color:var(--ink)}
.doc pre{position:relative;overflow:auto;background:var(--code-bg);color:var(--code-fg);border-radius:10px;padding:14px 18px;margin:1.3em 0;font-size:.85em;line-height:1.6;scrollbar-width:thin;scrollbar-color:var(--pre-scrollbar) transparent;border:1px solid var(--code-border)}
.doc pre::-webkit-scrollbar{height:8px;width:8px}
.doc pre::-webkit-scrollbar-thumb{background:var(--pre-scrollbar);border-radius:8px}
.doc .codehilite{background:transparent;color:var(--code-fg)}
.doc pre code{display:block;background:transparent;border:0;color:inherit;padding:0;font-size:1em;white-space:pre}
.doc .codehilite .tok-c,.doc .codehilite .tok-c1,.doc .codehilite .tok-cm,.doc .codehilite .tok-cp,.doc .codehilite .tok-cpf,.doc .codehilite .tok-ch,.doc .codehilite .tok-cs{color:var(--code-comment);font-style:italic}
.doc .codehilite .tok-err,.doc .codehilite .tok-gr{color:var(--hot)}
.doc .codehilite .tok-k,.doc .codehilite .tok-kc,.doc .codehilite .tok-kd,.doc .codehilite .tok-kn,.doc .codehilite .tok-kp,.doc .codehilite .tok-kr,.doc .codehilite .tok-ow{color:var(--code-keyword);font-weight:600}
.doc .codehilite .tok-kt,.doc .codehilite .tok-nc,.doc .codehilite .tok-ne,.doc .codehilite .tok-nf,.doc .codehilite .tok-nn{color:var(--code-type)}
.doc .codehilite .tok-s,.doc .codehilite .tok-sa,.doc .codehilite .tok-sb,.doc .codehilite .tok-sc,.doc .codehilite .tok-sd,.doc .codehilite .tok-s1,.doc .codehilite .tok-s2,.doc .codehilite .tok-se,.doc .codehilite .tok-sh,.doc .codehilite .tok-si,.doc .codehilite .tok-sr,.doc .codehilite .tok-ss,.doc .codehilite .tok-sx,.doc .codehilite .tok-dl{color:var(--code-string)}
.doc .codehilite .tok-m,.doc .codehilite .tok-mb,.doc .codehilite .tok-mf,.doc .codehilite .tok-mh,.doc .codehilite .tok-mi,.doc .codehilite .tok-mo,.doc .codehilite .tok-il{color:var(--code-number)}
.doc .codehilite .tok-n,.doc .codehilite .tok-na,.doc .codehilite .tok-nb,.doc .codehilite .tok-bp,.doc .codehilite .tok-no,.doc .codehilite .tok-nd,.doc .codehilite .tok-ni,.doc .codehilite .tok-nl,.doc .codehilite .tok-nr,.doc .codehilite .tok-nt,.doc .codehilite .tok-nv,.doc .codehilite .tok-vc,.doc .codehilite .tok-vg,.doc .codehilite .tok-vi,.doc .codehilite .tok-vm{color:var(--code-name)}
.doc .codehilite .tok-o,.doc .codehilite .tok-p,.doc .codehilite .tok-w{color:var(--code-operator)}
.doc pre .copy{position:absolute;top:8px;right:8px;display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;background:var(--copy-bg);color:var(--code-fg);border:1px solid var(--copy-border);border-radius:8px;padding:0;cursor:pointer;opacity:0;transition:opacity .15s,background .15s,border-color .15s,color .15s}
.doc pre .copy svg{width:16px;height:16px;fill:currentColor}
.doc pre:hover .copy,.doc pre .copy:focus{opacity:1}
.doc pre .copy:hover{background:rgba(255,255,255,.12)}
.doc pre .copy.copied{background:var(--ecto);border-color:var(--ecto);color:var(--selection-fg);opacity:1}
.doc pre .copy.failed{background:var(--hot);border-color:var(--hot);color:var(--selection-fg);opacity:1}
.doc blockquote{margin:1.4em 0;padding:10px 16px;border-left:3px solid var(--ecto);background:var(--accent-soft);border-radius:0 8px 8px 0;color:var(--text)}
.doc blockquote p:last-child{margin-bottom:0}
.doc table{width:100%;border-collapse:collapse;margin:1.2em 0;font-size:.92em}
.doc th,.doc td{border-bottom:1px solid var(--line);padding:9px 10px;text-align:left;vertical-align:top}
.doc th{font-weight:600;color:var(--ink);background:var(--panel);border-bottom:1px solid var(--line)}
.doc hr{border:0;border-top:1px solid var(--line);margin:2.2em 0}
.doc-card-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px;margin:1.2em 0 1.6em}
.doc-card{border:1px solid var(--line);background:var(--panel);border-radius:10px;padding:16px 18px}
.doc-card h3{margin-top:0}
.doc-card p:last-child{margin-bottom:0}
.toc{position:sticky;top:24px;align-self:start;font-size:.84rem;padding-left:14px;border-left:1px solid var(--line);max-height:calc(100vh - 48px);overflow:auto;scrollbar-width:thin;scrollbar-color:var(--line) transparent}
.toc::-webkit-scrollbar{width:5px}
.toc::-webkit-scrollbar-thumb{background:var(--line);border-radius:5px}
.toc h2{font-size:.66rem;color:var(--muted);text-transform:uppercase;letter-spacing:0.10em;margin:0 0 10px;font-weight:600}
.toc a{display:block;color:var(--muted);text-decoration:none;padding:4px 0 4px 10px;line-height:1.35;border-left:2px solid transparent;margin-left:-12px;transition:color .12s,border-color .12s}
.toc a:hover{color:var(--ink);text-decoration:none;opacity:1}
.toc a.active{color:var(--ecto);border-left-color:var(--ecto);font-weight:500}
.toc-l3{padding-left:22px!important;font-size:.94em}
@media(max-width:1179px){.toc{display:none}}
.page-nav{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:48px;border-top:1px solid var(--line);padding-top:20px}
.page-nav>a{display:block;border:1px solid var(--line);background:var(--panel);border-radius:10px;padding:13px 16px;text-decoration:none;color:var(--text);transition:border-color .15s,transform .15s,background .18s}
.page-nav>a:hover{border-color:var(--ecto);text-decoration:none;color:var(--ink);opacity:1}
.page-nav small{display:block;color:var(--muted);font-size:.7rem;text-transform:uppercase;letter-spacing:0.10em;margin-bottom:5px;font-weight:600}
.page-nav span{display:block;font-weight:600;line-height:1.3;color:var(--ink)}
.page-nav-prev{text-align:left}
.page-nav-next{text-align:right;grid-column:2}
.page-nav-prev:only-child{grid-column:1}
.nav-toggle{display:none;position:fixed;top:14px;right:14px;top:calc(14px + env(safe-area-inset-top, 0px));right:calc(14px + env(safe-area-inset-right, 0px));z-index:20;width:42px;height:42px;border-radius:10px;background:var(--toggle-bg);backdrop-filter:blur(10px);border:1px solid var(--line);color:var(--ink);cursor:pointer;padding:11px 10px;flex-direction:column;align-items:stretch;justify-content:space-between}
.nav-toggle span{display:block;width:100%;height:2px;flex:0 0 2px;background:currentColor;border-radius:2px;transition:transform .2s,opacity .2s}
.nav-toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(8px) rotate(45deg)}
.nav-toggle[aria-expanded="true"] span:nth-child(2){opacity:0}
.nav-toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-8px) rotate(-45deg)}
@media(max-width:900px){
  .shell{display:block}
  .sidebar{position:fixed;inset:0 30% 0 0;max-width:320px;height:100vh;z-index:15;transform:translateX(-100%);transition:transform .25s ease;box-shadow:var(--mobile-shadow);background:var(--chrome-bg-solid);pointer-events:none}
  .sidebar.open{transform:translateX(0);pointer-events:auto}
  .nav-toggle{display:flex}
  main{padding:64px 18px 56px}
  .hero{padding-top:6px}
  .hero h1{font-size:1.9rem}
  .doc h1{font-size:2.1rem}
  .hero-meta{width:100%;justify-content:flex-start}
  .doc{padding:0}
  .doc-grid{margin-top:18px;gap:24px}
  .doc-card-grid{grid-template-columns:1fr}
  .doc :is(h2,h3,h4) .anchor{display:none}
}
@media(max-width:520px){
  main{padding:60px 14px 48px}
  .doc pre{margin-left:-14px;margin-right:-14px;border-radius:0;border-left:0;border-right:0}
}
