@import"https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@400;500;600;700&family=Inter:wght@400;500;600;700&family=JetBrains+Mono:wght@400;500&display=swap";:root{--cf-primary: #46A0D0;--cf-primary-dark: #2984AD;--cf-secondary: #1B577E;--cf-deep: #23435F;--cf-bg: #020b1b;--cf-fg: #E2E8F0;--cf-muted: #94A3B8;--cf-border: rgba(255, 255, 255, .15);--cf-card: rgba(255, 255, 255, .07);--cf-code-bg: rgba(255, 255, 255, .1);--cf-success: #059669;--cf-error: #BE123C;--cf-warning: #D97706;--font-brand: "Space Grotesk", system-ui, sans-serif;--font-sans: "Inter", system-ui, -apple-system, sans-serif;--font-mono: "JetBrains Mono", "Fira Code", monospace;--content-max: 48rem;--nav-height: 3.5rem}[data-theme=light]{--cf-bg: #ffffff;--cf-fg: #0f172a;--cf-primary: #2984AD;--cf-border: rgba(0, 0, 0, .1);--cf-card: rgba(0, 0, 0, .03);--cf-code-bg: rgba(0, 0, 0, .06);--cf-muted: #64748b}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-family:var(--font-sans);color:var(--cf-fg);background:var(--cf-bg);line-height:1.7;-webkit-font-smoothing:antialiased;transition:background-color .2s,color .2s}:root .astro-code{background-color:var(--shiki-dark-bg, #24292e)!important;color:var(--shiki-dark, #e1e4e8)!important}:root .astro-code span{color:var(--shiki-dark)!important}[data-theme=light] .astro-code{background-color:var(--shiki-light-bg, #fff)!important;color:var(--shiki-light, #24292e)!important}[data-theme=light] .astro-code span{color:var(--shiki-light)!important}a{color:var(--cf-primary);text-decoration:none}a:hover{text-decoration:underline}img{max-width:100%}.prose{max-width:var(--content-max);margin:0 auto}.prose h1,.prose h2,.prose h3,.prose h4{font-family:var(--font-brand);font-weight:600;line-height:1.3;margin-top:2em;margin-bottom:.5em}.prose h1{font-size:2rem;margin-top:0}.prose h2{font-size:1.5rem;margin-top:2.5em;letter-spacing:-.01em}.prose h3{font-size:1.15rem;color:var(--cf-fg);opacity:.85}.prose p{margin-bottom:1em}.prose ul,.prose ol{padding-left:1.5em;margin-bottom:1em}.prose li{margin-bottom:.25em}.prose blockquote{border-left:3px solid var(--cf-primary);padding:.75em 1.25em;margin:1.5em 0;background:var(--cf-card);border-radius:0 6px 6px 0;font-size:1.05em;font-style:italic;color:var(--cf-fg)}.prose blockquote p:last-child{margin-bottom:0}.prose table{width:100%;border-collapse:collapse;margin:1em 0;font-size:.9rem}.prose th,.prose td{border:1px solid var(--cf-border);padding:.5em .75em;text-align:left}.prose th{background:var(--cf-card);font-weight:600}.prose code{font-family:var(--font-mono);font-size:.875em;background:var(--cf-code-bg);padding:.15em .4em;border-radius:4px;border:1px solid var(--cf-border)}.prose pre{margin:1em 0;padding:1em;border-radius:8px;overflow-x:auto;border:1px solid var(--cf-border);position:relative}.prose pre[data-language]:before{content:attr(data-language);position:absolute;top:0;right:0;padding:.15em .6em;font-size:.7rem;font-family:var(--font-mono);color:var(--cf-muted);background:var(--cf-card);border-bottom-left-radius:6px;border-top-right-radius:7px;text-transform:uppercase;letter-spacing:.03em;opacity:.7}.prose pre code{background:none;padding:0;font-size:.85rem;border:none}.code-copy-btn{position:absolute;top:1.8em;right:.5em;background:var(--cf-card);border:1px solid var(--cf-border);border-radius:4px;padding:.3em;cursor:pointer;color:var(--cf-muted);display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .15s,color .15s,border-color .15s}.prose pre:hover .code-copy-btn{opacity:1}.code-copy-btn:hover{color:var(--cf-fg);border-color:var(--cf-primary)}.code-copy-btn .icon-check{display:none}.code-copy-btn .icon-clipboard{display:block}.code-copy-btn.copied .icon-check{display:block;color:var(--cf-success)}.code-copy-btn.copied .icon-clipboard{display:none}.prose hr{border:none;border-top:1px solid var(--cf-border);margin:2em 0}.callout{padding:1em 1.25em;margin:1em 0;border-radius:8px;border-left:4px solid}.callout-note{border-color:var(--cf-primary);background:#46a0d014}.callout-tip{border-color:var(--cf-success);background:#05966914}.callout-warning{border-color:var(--cf-warning);background:#d9770614}.callout-danger{border-color:var(--cf-error);background:#be123c14}.callout-title{font-weight:600;margin-bottom:.25em}.mermaid{margin:1.5em 0;text-align:center;cursor:zoom-in;border-radius:8px;padding:1em;transition:background .15s}.mermaid:hover{background:var(--cf-card)}.diagram-lightbox{position:fixed;inset:0;z-index:1000;background:#000000bf;backdrop-filter:blur(8px);display:flex;flex-direction:column;opacity:0;transition:opacity .2s ease}.diagram-lightbox.active{opacity:1}.diagram-lightbox-toolbar{display:flex;align-items:center;justify-content:center;gap:.75rem;padding:.75rem 1rem;background:#0006}.diagram-lightbox-toolbar button{background:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:6px;padding:.4em .6em;color:#fff;cursor:pointer;display:flex;align-items:center;transition:background .15s}.diagram-lightbox-toolbar button:hover{background:#fff3}.diagram-zoom-level{color:#ffffffb3;font-size:.85rem;min-width:3.5em;text-align:center;font-variant-numeric:tabular-nums}.diagram-lightbox-content{flex:1;display:flex;align-items:center;justify-content:center;overflow:auto;padding:2rem}.diagram-lightbox-content svg{transition:transform .15s ease;transform-origin:center center}.pdf-viewer{margin:1.5em 0}.pdf-toolbar{display:flex;justify-content:space-between;align-items:center;padding:.5em .75em;background:var(--cf-card);border:1px solid var(--cf-border);border-radius:8px 8px 0 0;font-size:.85rem;gap:1rem}.pdf-nav,.pdf-actions{display:flex;align-items:center;gap:.5rem}.pdf-toolbar button,.pdf-download{background:none;border:1px solid var(--cf-border);border-radius:4px;padding:.3em .5em;color:var(--cf-muted);cursor:pointer;display:flex;align-items:center;transition:color .15s,border-color .15s}.pdf-toolbar button:hover:not(:disabled),.pdf-download:hover{color:var(--cf-fg);border-color:var(--cf-primary)}.pdf-toolbar button:disabled{opacity:.3;cursor:default}#pdf-page-info,#pdf-zoom-level{color:var(--cf-muted);font-variant-numeric:tabular-nums;min-width:4em;text-align:center}#pdf-container{border:1px solid var(--cf-border);border-top:none;border-radius:0 0 8px 8px;overflow:auto;background:#525659;display:flex;justify-content:center;padding:1em;height:85vh}#pdf-container canvas{box-shadow:0 2px 8px #0000004d;background:#fff;max-width:100%;height:auto;width:auto}.pdf-viewer:fullscreen{background:#525659}.pdf-viewer:fullscreen .pdf-toolbar{border-radius:0}.pdf-viewer:fullscreen #pdf-container{height:calc(100vh - 3rem);border-radius:0;border:none}.toc{position:sticky;top:calc(var(--nav-height) + 1.5rem)}.toc ul{list-style:none;padding-left:0;font-size:.85rem}.toc li{margin-bottom:.4em}.toc a{color:var(--cf-muted);transition:color .15s,border-color .15s;border-left:2px solid transparent;padding-left:.5em;margin-left:-.5em;display:inline-block}.toc a:hover{color:var(--cf-primary);text-decoration:none}.toc a.toc-active{color:var(--cf-primary);border-left-color:var(--cf-primary);font-weight:500}.toc .depth-3{padding-left:1em}.site-header{height:var(--nav-height);border-bottom:1px solid var(--cf-border);display:flex;align-items:center;padding:0 1.5rem;position:sticky;top:0;background:var(--cf-bg);z-index:100;backdrop-filter:blur(12px)}.site-header a{color:var(--cf-fg);font-family:var(--font-brand);font-weight:600}.site-header nav{margin-left:auto;display:flex;gap:1.5rem;font-size:.9rem;align-items:center}.site-header nav a{color:var(--cf-muted)}.site-header nav a:hover{color:var(--cf-fg);text-decoration:none}.site-logo{display:flex;align-items:center;gap:.5em;text-decoration:none!important}.site-logo img{height:22px;width:auto}.site-logo:hover{text-decoration:none}.logo-label{font-family:var(--font-brand);font-size:.85rem;font-weight:500;color:var(--cf-muted);border-left:1px solid var(--cf-border);padding-left:.5em}.logo-light{display:none}.logo-dark,[data-theme=light] .logo-light{display:block}[data-theme=light] .logo-dark{display:none}.theme-toggle{background:none;border:1px solid var(--cf-border);border-radius:6px;padding:.3em;cursor:pointer;color:var(--cf-muted);display:flex;align-items:center;justify-content:center;transition:color .15s,border-color .15s}.theme-toggle:hover{color:var(--cf-fg);border-color:var(--cf-primary)}.icon-moon{display:block}.icon-sun,[data-theme=light] .icon-moon{display:none}[data-theme=light] .icon-sun{display:block}.page-layout{display:grid;grid-template-columns:1fr min(var(--content-max),100%) 14rem;gap:2rem;padding:2rem 1.5rem;max-width:76rem;margin:0 auto}.page-layout>.prose{grid-column:2}.page-layout>.toc-wrapper{grid-column:3}@media(max-width:1024px){.page-layout{grid-template-columns:1fr}.page-layout>.toc-wrapper{display:none}}body{min-height:100vh;display:flex;flex-direction:column}body>.site-header{flex-shrink:0}body>.page-layout,body>div{flex:1}body>.site-footer{flex-shrink:0}.site-footer{border-top:1px solid var(--cf-border);padding:1.5rem;text-align:center;font-size:.8rem;color:var(--cf-muted)}.doc-meta{display:flex;align-items:center;gap:.6rem;flex-wrap:wrap;font-size:.8rem;color:var(--cf-muted);margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:1px solid var(--cf-border)}.doc-meta .meta-group{display:flex;align-items:center;gap:.5rem}.doc-meta .meta-sep{color:var(--cf-border);font-size:.7rem}.doc-meta .tags-group{margin-left:auto;display:flex;gap:.35rem;flex-wrap:wrap}.doc-meta .tag{background:var(--cf-card);border:1px solid var(--cf-border);padding:.1em .5em;border-radius:4px;font-size:.7rem}.role-badge{font-size:.65rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;padding:.2em .6em;border-radius:4px}.role-team{background:#46a0d026;color:var(--cf-primary)}.role-client{background:#05966926;color:var(--cf-success)}.role-public{background:#d9770626;color:var(--cf-warning)}.copy-md-btn{display:inline-flex;align-items:center;gap:.3em;margin-left:auto;background:var(--cf-card);border:1px solid var(--cf-border);border-radius:4px;padding:.2em .5em;font-size:.7rem;font-family:var(--font-mono);color:var(--cf-muted);cursor:pointer;transition:color .15s,border-color .15s;white-space:nowrap}.copy-md-btn:hover{color:var(--cf-fg);border-color:var(--cf-primary)}@media(max-width:640px){.doc-meta{font-size:.75rem}.doc-meta .tags-group{margin-left:0;width:100%}}.section-heading{font-family:var(--font-brand);font-size:1.1rem;font-weight:600;display:flex;align-items:center;gap:.6em;margin-bottom:1rem;padding-bottom:.5rem;border-bottom:1px solid var(--cf-border);text-transform:uppercase;letter-spacing:.04em;color:var(--cf-muted)}.section-heading .role-badge{font-size:.65rem}.project-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(18rem,1fr));gap:1rem;margin:0 0 1.5rem}.project-card{border:1px solid var(--cf-border);border-radius:10px;padding:1.25rem 1.5rem;transition:border-color .2s,box-shadow .2s,transform .2s;display:flex;flex-direction:column;gap:.4em}.project-card:hover{border-color:var(--cf-primary);box-shadow:0 4px 16px #00000014;transform:translateY(-2px)}.project-card h3{margin:0;font-family:var(--font-brand);font-size:1.1rem}.project-card .count{font-size:.8rem;color:var(--cf-muted);display:inline-flex;align-items:center;gap:.3em}.project-card .count:before{content:"";display:inline-block;width:4px;height:4px;border-radius:50%;background:var(--cf-muted);opacity:.5}.project-card .card-desc{margin:0;font-size:.85rem;color:var(--cf-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.project-card .card-footer{display:flex;justify-content:space-between;align-items:center;margin-top:auto}.project-card .card-date{font-size:.75rem;color:var(--cf-muted);opacity:.7}.doc-list{list-style:none;padding:0}.doc-list li{padding:.75em 0;border-bottom:1px solid var(--cf-border);display:flex;justify-content:space-between;align-items:baseline;gap:1rem}.doc-list li:last-child{border-bottom:none}.doc-list .doc-title{font-weight:500}.doc-list .doc-date{font-size:.8rem;color:var(--cf-muted);white-space:nowrap}@media(max-width:640px){.doc-list li{flex-direction:column;gap:.2em}.doc-list .doc-date{font-size:.75rem}}@media print{.site-header,.site-footer,.toc-wrapper{display:none!important}.page-layout{display:block;padding:0}.prose{max-width:100%}.prose pre{white-space:pre-wrap}a{color:inherit}a[href]:after{content:" (" attr(href) ")";font-size:.8em;color:#666}}
