@font-face{font-family:"Jetbrains Mono";font-style:normal;font-weight:400;src:url("fonts/JetbrainsMono/JetBrainsMono-Regular.ttf"),local("ttf");font-display:swap}@font-face{font-family:"Jetbrains Mono";font-style:normal;font-weight:700;src:url("fonts/JetbrainsMono/JetBrainsMono-Bold.ttf"),local("ttf");font-display:swap}@font-face{font-family:"Space Grotesk";font-style:normal;font-weight:400;src:url("fonts/SpaceGrotesk/SpaceGrotesk-Regular.ttf"),local("ttf");font-display:swap}@font-face{font-family:"Space Grotesk";font-style:normal;font-weight:700;src:url("fonts/SpaceGrotesk/SpaceGrotesk-Bold.ttf"),local("ttf");font-display:swap}@font-face{font-family:"ZedTextFtl";src:url(fonts/zed-fonts/ZedTextL-Regular.woff2) format("woff2");font-weight:400;font-style:normal;font-display:swap}@font-face{font-family:"ZedTextFtl";src:url(fonts/zed-fonts/ZedTextL-Bold.woff2) format("woff2");font-weight:700;font-style:normal;font-display:swap}@font-face{font-family:"ZedDisplayFtl";src:url(fonts/zed-fonts/ZedDisplayL-Heavy.woff2) format("woff2");font-weight:400;font-style:normal;font-display:swap}nav{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;padding:0}nav .root{font-size:1.5rem}nav .routes{display:flex;align-items:center;flex-wrap:wrap;font-size:1.5rem}nav .routes a{margin-left:1.5rem}@media (max-width: 768px){nav{flex-direction:column;align-items:flex-start}.routes{flex-direction:column;align-items:flex-start;width:100%}.routes a{margin:.5rem 0}}.note{display:flex;flex-direction:column;border-left:4px solid var(--secondary-color);background-color:var(--bg-1)}.note .header{background-color:var(--bg-2)}.note .header .title{margin:.5rem;font-weight:600;color:var(--text-0)}.note .header .title h1{color:var(--secondary-color)}.note .header .title h1::before{content:none}.note .content{color:var(--text-0)}.note .content p{margin:.5em 0}.note .content p:first-child{margin-top:0}.note .content p:last-child{margin-bottom:0}.pin{background:var(--bg-1);border:1px solid var(--border-color);border-radius:8px;padding:1.5rem;text-decoration:none;transition:all .2s}.pin:hover{transform:translateY(-4px);box-shadow:0 8px 16px rgba(0,0,0,.1);border-color:var(--text-2);background:var(--bg-2)}.pin .header h1{font-size:1rem;color:var(--text-0)}.pin .header h1::before{color:var(--primary-color);content:"# "}.pin .description{color:var(--text-1);font-size:.9rem;margin-top:1rem}.home-hero{text-align:center;margin-top:6rem}.home-hero .title{font-size:3rem;margin-bottom:1rem}.home-hero .subtitle{font-size:1.25rem}.jj-repo-info{width:100%;margin-top:6rem;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem}.jj-repo-info h1{margin:0}.jj-repo-info .stats{display:flex;flex-wrap:wrap;justify-content:center}.jj-repo-info .stats .item{display:flex;align-items:center;margin-right:1rem}.jj-repo-info .stats .item svg{margin-right:.25rem}.jj-repo-info .actions{display:flex;flex-wrap:wrap;justify-content:center;gap:.75rem}.jj-repo-info .actions button{width:4rem;padding:.5rem .75rem;background:var(--bg-1);border:1px solid var(--border-color);border-radius:6px;color:var(--text-0);font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s;white-space:nowrap}.jj-repo-info .actions button:hover{background:var(--bg-2);border-color:var(--text-2)}@media (max-width: 768px){.jj-repo-info{flex-direction:column;align-items:flex-start}.actions{width:100%}}.explorer{margin-top:3rem;overflow:hidden;font-family:var(--mono-text-font, monospace);font-size:.85rem}.explorer .breadcrumb{padding:.5rem 1rem;background:var(--bg-1);color:var(--fg-muted, #888);border-bottom:1px solid var(--border, #333)}.explorer .breadcrumb a{color:var(--accent, #7aa2f7);text-decoration:none;cursor:pointer}.explorer .breadcrumb a:hover{text-decoration:underline;background-color:rgba(0,0,0,0)}.explorer .table{width:100%;border-collapse:collapse;background:var(--bg-1)}.explorer .table .dir{cursor:pointer}.explorer .table .dir td{padding:.4rem 1rem;width:1.5rem;color:var(--fg-muted, #666)}.explorer .table .dir td:hover{text-decoration:underline}.explorer .table .file{cursor:pointer}.explorer .table .file td{padding:.4rem 1rem;width:1.5rem;color:var(--fg-muted, #666)}.explorer .table .file td:hover{text-decoration:underline}.explorer .viewer{background:var(--bg-1);border-top:1px solid var(--border, #333);padding:1rem}.explorer .viewer .header{color:var(--fg-muted, #888);margin-bottom:.75rem;font-size:.8rem}.explorer .viewer pre{background:var(--bg-1);margin:0;overflow-x:auto}.explorer .viewer pre code{margin:0;padding:0;background:var(--bg-1);font-family:var(--mono-text-font, monospace);font-size:.85rem}.explorer .viewer pre code .hljs-ln-numbers{-webkit-touch-callout:none;-webkit-user-select:none;-khtml-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;text-align:center;color:#ccc;border-right:1px solid #ccc;vertical-align:top;padding-right:5px}.explorer .viewer pre code .hljs-ln-code{padding-left:10px}.jj-hero{text-align:center;margin-top:6rem}.jj-hero .title{font-size:3rem;margin-bottom:1rem}.jj-hero .subtitle{font-size:1.25rem}.jj{margin:3rem 0 3rem 0;display:grid;grid-template-columns:repeat(auto-fill, minmax(250px, 1fr));gap:1.5rem}.jj .repo{background:var(--bg-1);border:1px solid var(--border-color);border-radius:8px;padding:1.5rem;text-decoration:none;transition:all .2s}.jj .repo:hover{transform:translateY(-4px);box-shadow:0 8px 16px rgba(0,0,0,.1);border-color:var(--text-2);background:var(--bg-2)}.jj .repo .header h1{font-size:1rem;color:var(--text-0)}.jj .repo .header h1::before{color:var(--primary-color);content:"# "}.jj .repo .description{color:var(--text-1);font-size:.9rem;margin-top:1rem;margin-bottom:1.5rem}.jj .repo .meta{display:flex;flex-direction:row;flex-wrap:wrap;justify-content:left;gap:1rem}.jj .repo .meta .item{display:flex;align-items:center;gap:.4rem;color:var(--text-1);font-size:.85rem}.jj .repo .meta .item svg{flex-shrink:0;opacity:.7}.blog-hero{text-align:center;margin-top:6rem}.blog-hero .title{font-size:3rem;margin-bottom:1rem}.blog-hero .subtitle{font-size:1.25rem}:root{--border-color: var(--border-color);--font-size-base: 13.5px;--mono-text-font: "Jetbrains Mono";--text-font: "ZedTextFtl";--header-font: "ZedDisplayFtl" "Space Grotesk", "Helvetica", sans-serif;--code-font: "Jetbrains Mono";--line-height: 1.5;--page-width: 920px}html{background-color:var(--bg-0);color:var(--text-0);font-family:var(--text-font);line-height:var(--line-height)}html body{display:flex;flex-grow:1;padding:.9rem;padding-bottom:1.5rem;margin-bottom:1.5rem;min-height:calc(100vh - 150px)}html body ::selection{background:var(--primary-color);color:var(--hover-color)}html body a{cursor:pointer;color:inherit;text-decoration:none}html body a:hover{background-color:var(--primary-color);color:var(--hover-color)}html body p{color:var(--text-1);margin:0}html body .content{width:100%;max-width:var(--page-width);flex-shrink:0}html body .content h1,html body .content h2,html body .content h3,html body .content h4,html body .content h5,html body .content h6{margin:0;font-family:monospace var(--header-font)}html body .content h1::before,html body .content h2::before,html body .content h3::before,html body .content h4::before,html body .content h5::before,html body .content h6::before{color:var(--primary-color);content:"# "}html body .left-content{width:100%}html body .right-content{width:100%}