:root{color-scheme:light;--mono:ui-monospace,"Cascadia Code","SF Mono","JetBrains Mono",Menlo,Consolas,monospace;--white:#fff;--fill:#f2f2f2;--fill-soft:#f7f7f7;--rule:#939393;--border:#8a8a8a;--gray:#6e6e6e;--gray-strong:#444;--ink:#111;--blue:#00e;--blue-soft:#e8eeff;--blue-hover:#456ee3;--ok:#1a7f37;--accent-bg:#faf8ea;--accent-border:#e3dcad;--shadow:0 4px 14px -4px rgba(17,17,17,.18);--radius:4px;--bp-xs:480px;--bp-sm:640px;--bp-md:768px;--bp-xl:1280px;--tok-keyword:#8959a8;--tok-function:#2f6fb0;--tok-type:#0e7c86;--tok-constant:#a3238e;--tok-literal:#c0392b;--tok-string:#357a5b;--tok-number:#9e6217;--tok-property:#5b6ea8;--tok-operator:#717171;--tok-comment:#6e6e6e}:root[data-theme=dark]{color-scheme:dark;--white:#16181c;--fill:#262a30;--fill-soft:#1d2025;--rule:#63666b;--border:#70747a;--gray:#8d939c;--gray-strong:#b9bec6;--ink:#e7e9ec;--blue:#7aa2ff;--blue-soft:#1d2740;--blue-hover:#a9c2ff;--ok:#3fb950;--accent-bg:#2b2920;--accent-border:#4d4730;--shadow:0 6px 18px -6px rgba(0,0,0,.6);--tok-keyword:#c792ea;--tok-function:#82aaff;--tok-type:#5fd0c5;--tok-constant:#f78fdf;--tok-literal:#ff8b7c;--tok-string:#9ece6a;--tok-number:#e0a458;--tok-property:#9aa9e0;--tok-operator:#8b929c;--tok-comment:#84898f}*{box-sizing:border-box}body,html{background:var(--white)}body{max-width:44rem;margin:2.5rem auto;padding:0 1.25rem;color:var(--ink);font:15px/1.6 var(--mono);min-height:calc(100vh - 5rem);min-height:calc(100dvh - 5rem);display:flex;flex-direction:column}@media(min-width:1280px){body{max-width:60rem}}a{color:var(--blue);transition:color .15s ease}a:visited{color:var(--blue)}a:hover{color:var(--blue-hover)}:focus-visible{outline:2px solid var(--card-accent,var(--blue));outline-offset:2px}h1{font-size:1.3rem;margin:0 0 1.25rem;display:flex;flex-wrap:wrap;align-items:baseline;gap:.4em}h1 a:link,h1 a:visited{color:inherit;text-decoration:underline}h1 a:focus-visible,h1 a:hover{color:var(--blue-hover)}h1 .sep{color:var(--gray);font-weight:400}h1 .crumb{color:var(--card-accent,var(--gray));font-weight:700}h1 .version{color:var(--gray);font-weight:400;font-size:.7em}.glyph-mark{width:1.15em;height:1.15em;align-self:center}:root[data-theme=dark] .glyph-mark{content:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='32' height='32' viewBox='0 0 32 32'%3E%3Crect width='32' height='32' fill='%23e7e9ec' rx='7'/%3E%3Cpath fill='none' stroke='%2316181c' stroke-linecap='round' stroke-width='2.6' d='m9.5 10.5-4 11'/%3E%3Crect width='4' height='10' x='12' y='11' fill='%2316181c' rx='1.2'/%3E%3Crect width='4' height='10' x='17.5' y='11' fill='%2316181c' opacity='.45' rx='1.2'/%3E%3Crect width='4' height='10' x='23' y='11' fill='%234d7cff' rx='1.2'/%3E%3C/svg%3E")}h2{font-size:1rem;margin:0 0 .5rem}button,input,select{font-family:var(--mono);font-size:.9rem}.bar{margin:0 0 1.25rem}.bar .origin{color:var(--gray)}.path{display:block;width:-moz-fit-content;width:fit-content;max-width:100%;margin-top:.35rem;background:var(--fill);padding:2px 6px;border-radius:var(--radius);white-space:pre;overflow:hidden}.resolving .path{background:var(--blue-soft)}nav{display:flex;flex-wrap:wrap;gap:.25rem 1.25rem;margin:0 0 .5rem}nav a.active{font-weight:700;text-decoration:none;color:inherit}.deep{display:flex;flex-wrap:wrap;gap:.25rem 1rem;margin:0 0 1.25rem;color:var(--gray);font-size:.85rem}.controls{--toolbar-bg:color-mix(in srgb,var(--card-accent,var(--blue)) 10%,var(--white));--toolbar-border:color-mix(in srgb,var(--card-accent,var(--blue)) 55%,var(--border));display:flex;flex-wrap:wrap;gap:.75rem 1.75rem;margin:0 0 1.25rem;padding:.8rem 1rem;background:var(--toolbar-bg);border:1px solid var(--toolbar-border);border-radius:var(--radius)}:root[data-theme=dark] .controls{--toolbar-bg:color-mix(in srgb,var(--card-accent,var(--blue)) 20%,var(--white));--toolbar-border:color-mix(in srgb,var(--card-accent,var(--blue)) 55%,var(--border))}.controls label{display:flex;align-items:center;gap:.5rem;font-size:.85rem;color:var(--gray-strong)}.controls label.toggle{cursor:pointer}.controls .ms{min-width:6ch;display:inline-block}.controls select{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-color:var(--white);background-image:linear-gradient(45deg,transparent 50%,var(--gray-strong) 50%),linear-gradient(135deg,var(--gray-strong) 50%,transparent 50%);background-position:calc(100% - .95rem),calc(100% - .65rem);background-size:.3rem .3rem;background-repeat:no-repeat;border:1px solid var(--border);border-radius:var(--radius);padding:.2rem 1.7rem .2rem .45rem;color:var(--ink);cursor:pointer;transition:border-color .15s ease}.controls select:hover{border-color:var(--card-accent,var(--blue))}.controls select:focus-visible{outline:2px solid var(--card-accent,var(--blue));outline-offset:1px}.controls input[type=checkbox]{width:1rem;height:1rem;accent-color:var(--card-accent,var(--blue));cursor:pointer}.controls input[type=range]{width:7.5rem;accent-color:var(--card-accent,var(--blue));cursor:pointer}.controls input[type=range]:focus-visible{outline:2px solid var(--card-accent,var(--blue));outline-offset:2px}.glyph-tooltip{position:fixed;inset:auto;margin:0;max-width:18rem;padding:.45rem .6rem;background:var(--accent-bg);color:var(--gray-strong);border:1px solid var(--accent-border);border-radius:var(--radius);overflow:visible;box-shadow:var(--shadow);font:.78rem/1.4 var(--mono);text-align:left;pointer-events:none;opacity:0;transform:translateY(3px);transition:opacity .16s ease,transform .16s ease,top .22s ease,left .22s ease,overlay allow-discrete .16s,display allow-discrete .16s}.glyph-tooltip:popover-open{opacity:1;transform:translateY(0)}.glyph-tooltip:after{content:"";position:absolute;width:7px;height:7px;left:var(--tip-arrow,50%);bottom:0;transform:translate(-50%,50%) rotate(45deg);background:var(--accent-bg);border:1px solid var(--accent-border);border-top:0;border-left:0;transition:left .22s ease}.glyph-tooltip.is-below:after{bottom:auto;top:0;transform:translate(-50%,-50%) rotate(45deg);border:1px solid var(--accent-border);border-bottom:0;border-right:0}@starting-style{.glyph-tooltip:popover-open{opacity:0;transform:translateY(3px)}}@media(prefers-reduced-motion:reduce){.glyph-tooltip{transform:none;transition:opacity 1ms,overlay allow-discrete 1ms,display allow-discrete 1ms}.glyph-tooltip:after{transition:none}}.view{border:1px solid var(--border);border-radius:var(--radius);padding:1rem 1.25rem;min-height:7.5rem}.view+.view{margin-top:1.25rem}.view.docs pre{position:relative;margin:0 0 .75rem;padding:.7rem .9rem;background:var(--fill-soft);border:1px solid var(--border);border-radius:var(--radius);font-size:.8rem;line-height:1.55}.view.docs pre code{display:block;overflow-x:auto;background:none;padding:0}.view.docs .tok-keyword{color:var(--tok-keyword)}.view.docs .tok-function{color:var(--tok-function)}.view.docs .tok-type{color:var(--tok-type)}.view.docs .tok-constant{color:var(--tok-constant)}.view.docs .tok-literal{color:var(--tok-literal)}.view.docs .tok-string{color:var(--tok-string)}.view.docs .tok-number{color:var(--tok-number)}.view.docs .tok-property{color:var(--tok-property)}.view.docs .tok-operator{color:var(--tok-operator)}.view.docs .tok-comment{color:var(--tok-comment);font-style:italic}.view header.lead{margin:0 0 1rem;color:var(--gray-strong)}.view header.lead h2{color:var(--ink)}.view figure{margin:0 0 .75rem}.view figcaption{margin:.75rem 0 .4rem}.view aside.note,.view figcaption{color:var(--gray-strong)}.view aside.note{margin:.75rem 0 0;padding-left:.75rem;border-left:2px solid var(--border)}.code-copy{position:absolute;top:.35rem;right:.35rem;display:inline-flex;align-items:center;justify-content:center;width:1.7rem;height:1.7rem;padding:0;border:1px solid var(--border);border-radius:var(--radius);background:var(--fill-soft);color:var(--gray);cursor:pointer;opacity:.55;transition:opacity .15s ease,color .15s ease,border-color .15s ease}.view.docs pre:focus-within .code-copy,.view.docs pre:hover .code-copy{opacity:1}.code-copy:hover{color:var(--blue);border-color:var(--blue)}.code-copy:focus-visible{opacity:1;outline:2px solid var(--card-accent,var(--blue));outline-offset:2px}.code-copy.copied{opacity:1;color:var(--ok);border-color:var(--ok)}.code-copy svg{width:.95rem;height:.95rem;display:block}.pm-tabs{display:flex;flex-wrap:wrap;gap:.3rem;margin-bottom:.6rem;padding-right:2rem;white-space:normal}.pm-tab{padding:.12rem .55rem;border:1px solid var(--border);border-radius:var(--radius);background:var(--white);color:var(--gray);font:.72rem var(--mono);cursor:pointer;transition:color .15s ease,border-color .15s ease,background .15s ease}.pm-tab:hover{color:var(--blue);border-color:var(--blue)}.pm-tab.active{color:var(--ink);border-color:var(--border);background:var(--fill);font-weight:700}.pm-tab:focus-visible{outline:2px solid var(--card-accent,var(--blue));outline-offset:1px}.core-demo{margin-bottom:.5rem}.glyph-stage{display:flex;align-items:center;min-height:2.2em;padding:.5rem .7rem;background:var(--fill);border-radius:var(--radius);font-family:var(--mono);font-size:1.15rem;line-height:1.35;white-space:pre-wrap;overflow-wrap:anywhere;color:var(--ink)}.core-form{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.6rem}.core-form input{flex:1 1 18rem;min-width:0;padding:.35rem .5rem;border:1px solid var(--border);border-radius:var(--radius);background:var(--white);color:var(--ink)}.core-form button{padding:.35rem .9rem;border:1px solid var(--border);border-radius:var(--radius);background:var(--fill);color:var(--ink);cursor:pointer}.core-form button:hover{border-color:var(--blue);color:var(--blue)}.pick{display:grid;grid-template-columns:repeat(2,1fr);gap:.875rem;margin:1.5rem 0;padding:0;list-style:none}.pick li{display:contents}.card{display:flex;flex-direction:column;gap:.5rem;padding:1.1rem 1.2rem;border-radius:var(--radius);border:1.5px solid var(--border);background:var(--white);text-decoration:none;color:var(--ink);position:relative;overflow:hidden;transition:border-color .22s ease,box-shadow .22s ease}.card:after{content:"";position:absolute;top:-50%;left:-80%;width:55%;height:200%;background:linear-gradient(105deg,transparent 30%,hsla(0,0%,100%,.2) 50%,transparent 70%);transform:skew(-20deg);pointer-events:none}.card:hover{border-color:var(--card-accent,var(--blue));box-shadow:0 12px 36px -10px color-mix(in srgb,var(--card-accent,var(--blue)) 28%,transparent),0 3px 10px -4px #00000014}.card:hover:after{animation:card-shimmer .55s ease forwards}.card:focus-visible{outline:2px solid var(--card-accent,var(--blue));outline-offset:3px}@keyframes card-shimmer{0%{left:-80%}to{left:120%}}:root[data-theme=dark] .card:after{background:linear-gradient(105deg,transparent 30%,hsla(0,0%,100%,.07) 50%,transparent 70%)}@media(prefers-reduced-motion:reduce){.card:after{display:none}}.card-header{display:flex;align-items:center;justify-content:space-between;gap:.5rem}.card-icon{width:1.5rem;height:1.5rem;flex-shrink:0}:root[data-theme=dark] [data-fw=core] .card-icon{content:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='32' height='32' viewBox='0 0 32 32'%3E%3Crect width='32' height='32' fill='%23e7e9ec' rx='7'/%3E%3Cpath fill='none' stroke='%2316181c' stroke-linecap='round' stroke-width='2.6' d='m9.5 10.5-4 11'/%3E%3Crect width='4' height='10' x='12' y='11' fill='%2316181c' rx='1.2'/%3E%3Crect width='4' height='10' x='17.5' y='11' fill='%2316181c' opacity='.45' rx='1.2'/%3E%3Crect width='4' height='10' x='23' y='11' fill='%234d7cff' rx='1.2'/%3E%3C/svg%3E")}.card-router{font-size:.72rem;color:var(--gray);text-align:right;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.card-name{font-size:.92rem;font-weight:700;color:var(--ink);letter-spacing:-.01em}.card-desc{font-size:.78rem;color:var(--gray);line-height:1.55;margin:0}[data-fw=vanilla]{--card-accent:#b08e00}[data-fw=core]{--card-accent:#4d7cff}[data-fw=vue-router]{--card-accent:#2e9b68}[data-fw=react-router]{--card-accent:#0891b0}[data-fw=preact-iso]{--card-accent:#673ab8}[data-fw=solid-router]{--card-accent:#3a6096}[data-fw=tanstack-react]{--card-accent:#0891b0}[data-fw=tanstack-solid]{--card-accent:#3a6096}[data-fw=angular-router]{--card-accent:#aa0026}[data-fw=next]{--card-accent:var(--ink)}[data-fw=nuxt]{--card-accent:#008f60}[data-fw=sveltekit]{--card-accent:#c23000}:root[data-theme=dark] [data-fw=vanilla]{--card-accent:#e8c000}:root[data-theme=dark] [data-fw=vue-router]{--card-accent:#4ec990}:root[data-theme=dark] [data-fw=react-router]{--card-accent:#22c4e6}:root[data-theme=dark] [data-fw=preact-iso]{--card-accent:#673ab8}:root[data-theme=dark] [data-fw=solid-router]{--card-accent:#7aaee0}:root[data-theme=dark] [data-fw=tanstack-react]{--card-accent:#22c4e6}:root[data-theme=dark] [data-fw=tanstack-solid]{--card-accent:#7aaee0}:root[data-theme=dark] [data-fw=angular-router]{--card-accent:#ff5070}:root[data-theme=dark] [data-fw=nuxt]{--card-accent:#00dc82}:root[data-theme=dark] [data-fw=sveltekit]{--card-accent:#ff5e2e}@media(max-width:768px){.pick{grid-template-columns:1fr}}.foot{margin-top:1.5rem;color:var(--gray);font-size:.8rem}.site-footer{display:flex;flex-wrap:wrap;gap:.25rem 1rem;margin-top:auto;padding-top:1rem;border-top:1px solid var(--rule);color:var(--gray);font-size:.8rem}.site-footer .stack{margin-left:auto}.site-footer .stack[data-tip]{cursor:help}#__nuxt,.app-shell,main{display:flex;flex-direction:column;flex:1 0 auto;min-width:0}code{background:var(--fill);padding:1px 4px;border-radius:3px}.theme-toggle{position:fixed;top:.85rem;right:.85rem;z-index:50;display:inline-flex;align-items:center;justify-content:center;width:2rem;height:2rem;padding:0;background:var(--white);color:var(--gray-strong);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);cursor:pointer;transition:color .15s ease,border-color .15s ease}.theme-toggle:hover{color:var(--blue);border-color:var(--blue)}.theme-toggle:focus-visible{outline:2px solid var(--card-accent,var(--blue));outline-offset:2px}.theme-toggle svg{width:1.05rem;height:1.05rem;display:block}@media(max-width:768px){body{position:relative}.theme-toggle{position:absolute;top:0;right:1.25rem}h1:has(.glyph-mark){padding-right:2.75rem}}
