@import url("/assets/site.css?v=6");
/* LongMem docs — shared styles. Consumes the brand design system from /assets/site.css
   (design tokens + brand fonts + base reset); only docs-specific layout/components live
   here, so the docs can't drift from the rest of the site. */
body{font-size:16.5px;line-height:1.7}
a{color:var(--accent);text-decoration:none}
a:hover{text-decoration:underline}

/* header */
.dochead{position:sticky;top:0;z-index:20;display:flex;align-items:center;gap:1rem;
  padding:.7rem 1.2rem;background:var(--nav-bg);backdrop-filter:blur(10px);
  border-bottom:1px solid var(--border)}
.dochead a[href="/"]{color:var(--ink)!important}
.dochead a span{font-family:var(--display);font-weight:700;letter-spacing:-.02em}
.dochead a span i{color:var(--cobalt);font-style:normal}
.dochead .navlinks{margin-left:auto;display:flex;gap:1.1rem}
.dochead .navlinks a{color:var(--muted);font-size:.88rem}
.dochead .navlinks a:hover{color:var(--text);text-decoration:none}

/* layout */
.layout{display:flex;max-width:1240px;margin:0 auto}
.docnav-toggle{display:none}  /* mobile only — opens the sidebar drawer */
.sidebar{width:250px;flex-shrink:0;position:sticky;top:64px;height:calc(100vh - 64px);
  overflow-y:auto;padding:1.4rem 1rem 3rem;border-right:1px solid var(--border)}
.sidebar h4{font-family:var(--mono);font-size:.68rem;letter-spacing:.1em;text-transform:uppercase;
  color:var(--muted);margin:1.3rem 0 .4rem;padding-left:.6rem}
.sidebar h4:first-child{margin-top:0}
.sidebar a,.sidebar span.soon{display:block;padding:.34rem .6rem;border-radius:7px;
  color:var(--text);font-size:.9rem}
.sidebar a:hover{background:var(--surface);text-decoration:none}
.sidebar a.active{background:var(--surface2);color:var(--accent)}
.sidebar span.soon{color:var(--faint);cursor:default}
.sidebar span.soon::after{content:"soon";font-family:var(--mono);font-size:.6rem;margin-left:.45rem;
  border:1px solid var(--border);border-radius:4px;padding:0 .3rem;vertical-align:1px}
/* nav search */
#docsearch{width:100%;margin-bottom:.6rem;padding:.42rem .6rem;font:inherit;font-size:.86rem;
  color:var(--text);background:var(--surface);border:1px solid var(--border);border-radius:8px;
  outline:none;-webkit-appearance:none;appearance:none}
#docsearch::placeholder{color:var(--faint)}
#docsearch:focus{border-color:var(--accent)}
.sidebar .navsec[hidden],.sidebar a[hidden],.sidebar span.soon[hidden]{display:none}
.nores{color:var(--faint);font-size:.86rem;padding:.34rem .6rem}
/* full-text search results palette */
.docsearch-results{margin:.4rem 0 .3rem;background:var(--surface);border:1px solid var(--border);
  border-radius:9px;overflow:hidden;max-height:60vh;overflow-y:auto}
.dsr{display:block;padding:.5rem .65rem;border-bottom:1px solid var(--border)}
.dsr:last-child{border-bottom:none}
.dsr.on,.dsr:hover{background:var(--surface2);text-decoration:none}
.dsr-t{display:block;color:var(--text);font-size:.86rem;font-weight:500}
.dsr-x{display:block;color:var(--muted);font-size:.75rem;line-height:1.35;margin-top:.15rem;
  white-space:normal;word-break:break-word}
.dsr-x mark{background:var(--cobalt-soft);color:var(--accent);padding:0 1px;border-radius:2px}

/* content */
.content{flex:1;min-width:0;padding:2.4rem 3rem 5rem;max-width:820px}
.content h1{font-family:var(--display);font-weight:700;letter-spacing:-.025em;font-size:2.1rem;line-height:1.2;margin-bottom:.6rem}
.content .lead{color:var(--muted);font-size:1.06rem;margin-bottom:2rem}
.content h2{font-family:var(--display);font-weight:700;letter-spacing:-.015em;font-size:1.4rem;margin:2.4rem 0 .8rem;padding-top:.6rem}
.content h3{font-family:var(--display);font-weight:600;font-size:1.08rem;margin:1.8rem 0 .6rem}
.content p{margin-bottom:1rem}
.content ul,.content ol{margin:0 0 1rem 1.4rem}
.content li{margin-bottom:.4rem}
.content code{background:var(--surface2);border:1px solid var(--border);color:var(--accent2);
  padding:1px 6px;border-radius:5px;font-family:var(--mono);font-size:.85em}
.content pre{background:var(--base2);border:1px solid var(--border);border-radius:10px;
  padding:1rem 1.1rem;overflow-x:auto;margin:0 0 1.2rem;font-size:.84rem;line-height:1.55}
.content pre code{background:none;border:none;color:var(--text);padding:0}
.content table{width:100%;border-collapse:collapse;margin:0 0 1.2rem;font-size:.9rem}
.content th,.content td{border:1px solid var(--border);padding:.5rem .7rem;text-align:left}
.content th{background:var(--surface);font-weight:600}
.content blockquote{border-left:3px solid var(--accent);background:var(--surface);
  border-radius:0 8px 8px 0;padding:.7rem 1rem;margin:0 0 1.2rem;color:var(--muted)}

/* heading anchors (deep links) */
.content h2,.content h3{scroll-margin-top:84px}
.hanchor{margin-left:.4rem;color:var(--muted);text-decoration:none;font-weight:400;opacity:0;transition:opacity .15s}
.content h2:hover .hanchor,.content h3:hover .hanchor,.hanchor:focus{opacity:1;color:var(--accent)}

/* "On this page" TOC rail */
.toc{width:210px;flex-shrink:0;position:sticky;top:64px;align-self:flex-start;
  height:calc(100vh - 64px);overflow-y:auto;padding:2.4rem 1rem 3rem}
.toc-title{font-family:var(--mono);font-size:.66rem;letter-spacing:.1em;text-transform:uppercase;
  color:var(--muted);margin-bottom:.6rem;padding-left:.65rem}
.toc ul{list-style:none;margin:0;display:flex;flex-direction:column;gap:.05rem}
.toc li{margin:0}
.toc a{display:block;padding:.3rem .65rem;border-left:2px solid var(--border);
  color:var(--muted);font-size:.82rem;line-height:1.35}
.toc a:hover{color:var(--text);text-decoration:none}
.toc a.active{color:var(--accent);border-left-color:var(--accent)}
@media(max-width:1100px){.toc{display:none}}

/* cards (next steps) */
.cards{display:grid;grid-template-columns:1fr 1fr;gap:.9rem;margin:1.2rem 0}
.card{display:block;background:var(--surface);border:1px solid var(--border);border-radius:12px;
  padding:1rem 1.1rem;color:var(--text)}
.card:hover{border-color:var(--accent);text-decoration:none}
.card b{display:block;margin-bottom:.2rem}
.card span{color:var(--muted);font-size:.86rem}

/* code tabs */
.tabs{margin:0 0 1.2rem}
.tabbar{display:flex;gap:.4rem;margin-bottom:-1px}
.tabbar button{background:var(--surface);border:1px solid var(--border);border-bottom:none;
  color:var(--muted);padding:.42rem .95rem;border-radius:9px 9px 0 0;cursor:pointer;
  font-size:.84rem;font-family:var(--sans)}
.tabbar button.on{background:var(--surface);color:var(--accent);font-weight:600}
.tabs pre{border-radius:0 10px 10px 10px;margin-bottom:0;display:none}
.tabs pre.on{display:block}

/* prev/next footer */
.pagenav{display:flex;justify-content:space-between;gap:1rem;margin-top:3.2rem;
  border-top:1px solid var(--border);padding-top:1.2rem}
.pagenav a{flex:1;background:var(--surface);border:1px solid var(--border);border-radius:10px;
  padding:.7rem .9rem;font-size:.9rem;color:var(--text)}
.pagenav a:hover{border-color:var(--accent);text-decoration:none}
.pagenav a small{display:block;color:var(--muted);font-size:.72rem}
.pagenav a.next{text-align:right}

@media(max-width:880px){
  .layout{flex-direction:column}
  /* the docs nav becomes a drawer opened by a sticky toggle button */
  .docnav-toggle{display:flex;align-items:center;gap:.55rem;position:sticky;top:64px;z-index:15;
    width:100%;padding:.8rem 1.2rem;background:var(--nav-bg);backdrop-filter:blur(10px);
    border-bottom:1px solid var(--border);color:var(--text);font:inherit;font-size:.92rem;
    font-weight:500;cursor:pointer}
  .docnav-toggle svg{stroke:var(--accent);flex-shrink:0}
  .sidebar{display:none;position:static;width:100%;height:auto;
    border-right:none;border-bottom:1px solid var(--border);padding:1rem 1.2rem 1.4rem}
  .sidebar.open{display:block}
  .content{padding:1.6rem 1.2rem 4rem}
}

/* copy-to-clipboard button on code blocks */
.content pre{position:relative}
.content pre .copybtn{position:absolute;top:8px;right:8px;background:var(--surface);border:1px solid var(--border);
  color:var(--muted,#74746C);border-radius:6px;padding:3px 9px;font-size:12px;font-family:var(--mono,monospace);
  cursor:pointer;opacity:0;transition:opacity .15s}
.content pre:hover .copybtn{opacity:1}
.content pre .copybtn:hover{color:var(--text,#16150F);border-color:var(--accent,#1B34E8)}
