@import"https://fonts.googleapis.com/css2?family=Barlow:ital,wght@0,300;0,400;0,500;0,600;0,700;1,400&family=JetBrains+Mono:wght@400;500&display=swap";.astro-route-announcer{position:absolute;left:0;top:0;clip:rect(0 0 0 0);clip-path:inset(50%);overflow:hidden;white-space:nowrap;width:1px;height:1px}.theme-toggle-wrapper[data-astro-cid-x3pjskd3]{position:relative;margin-left:auto}.theme-icon[data-astro-cid-x3pjskd3]{display:none;align-items:center;justify-content:center}.theme-icon[data-astro-cid-x3pjskd3].visible{display:flex}#theme-toggle-btn[data-astro-cid-x3pjskd3][aria-expanded=true]{color:var(--color-accent);background:var(--color-accent-subtle)}.theme-menu[data-astro-cid-x3pjskd3]{position:fixed;min-width:136px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);padding:.25rem;z-index:200;opacity:0;transform:translateY(-6px) scale(.97);pointer-events:none;transition:opacity .15s ease,transform .15s ease;transform-origin:top right}.theme-menu[data-astro-cid-x3pjskd3].open{opacity:1;transform:translateY(0) scale(1);pointer-events:auto}.theme-menu-item[data-astro-cid-x3pjskd3]{display:flex;align-items:center;gap:.5rem;width:100%;padding:.4375rem .625rem;background:transparent;border:none;border-radius:var(--radius-sm);color:var(--color-text-secondary);font-size:.8125rem;font-family:var(--font-sans);cursor:pointer;text-align:left;transition:background .12s ease,color .12s ease}.theme-menu-item[data-astro-cid-x3pjskd3]:hover{background:var(--color-surface-hover);color:var(--color-text)}.theme-menu-item[data-astro-cid-x3pjskd3].active{color:var(--color-accent)}.check-icon[data-astro-cid-x3pjskd3]{margin-left:auto;opacity:0;flex-shrink:0;color:var(--color-accent)}.theme-menu-item[data-astro-cid-x3pjskd3].active .check-icon[data-astro-cid-x3pjskd3]{opacity:1}:root{--color-bg: #f7f7f5;--color-bg-secondary: #efefed;--color-surface: #ffffff;--color-surface-hover: #f2f2f0;--color-border: #e3e3df;--color-border-subtle: #eaeae6;--color-text: #1a1a18;--color-text-secondary: #52524f;--color-text-muted: #8f8f8c;--color-accent: #4f6d1a;--color-accent-hover: #3d5514;--color-accent-light: #8aaa40;--color-accent-subtle: #e6f0cc;--color-accent-muted: #c8dc90;--color-code-bg: #f0f0ec;--color-selection: #c8dc90;--font-sans: "Barlow", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--font-mono: "JetBrains Mono", "Fira Code", "Cascadia Code", Consolas, monospace;--sidebar-width: 264px;--content-max-width: 700px;--toc-width: 220px;--transition-fast: .12s ease;--transition-normal: .22s ease;--transition-slow: .36s ease;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .05), 0 1px 3px rgba(0, 0, 0, .04);--shadow-md: 0 4px 8px rgba(0, 0, 0, .06), 0 2px 4px rgba(0, 0, 0, .04);--shadow-lg: 0 12px 24px rgba(0, 0, 0, .08), 0 4px 8px rgba(0, 0, 0, .04);--shadow-focus: 0 0 0 3px rgba(79, 109, 26, .25)}[data-theme=dark]{--color-bg: #0d0d0b;--color-bg-secondary: #141412;--color-surface: #1a1a18;--color-surface-hover: #222220;--color-border: #2a2a27;--color-border-subtle: #202020;--color-text: #f0f0ee;--color-text-secondary: #a8a8a5;--color-text-muted: #6a6a67;--color-accent: #8ab040;--color-accent-hover: #9cc048;--color-accent-light: #b8d870;--color-accent-subtle: #182208;--color-accent-muted: #2e4510;--color-code-bg: #161614;--color-selection: #2e4510;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .3), 0 1px 3px rgba(0, 0, 0, .2);--shadow-md: 0 4px 8px rgba(0, 0, 0, .3), 0 2px 4px rgba(0, 0, 0, .2);--shadow-lg: 0 12px 24px rgba(0, 0, 0, .35), 0 4px 8px rgba(0, 0, 0, .25);--shadow-focus: 0 0 0 3px rgba(138, 176, 64, .3)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;scroll-behavior:smooth;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-sans);font-size:1rem;line-height:1.6;color:var(--color-text);background-color:var(--color-bg);transition:background-color var(--transition-normal),color var(--transition-normal);overflow-x:hidden}::selection{background-color:var(--color-selection);color:var(--color-text)}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--color-accent-muted)}.app-layout{display:flex;min-height:100vh}.sidebar{width:var(--sidebar-width);flex-shrink:0;position:sticky;top:0;height:100vh;overflow-y:auto;overflow-x:hidden;border-right:1px solid var(--color-border);background-color:var(--color-bg);display:flex;flex-direction:column;transition:transform var(--transition-normal);z-index:100}.sidebar-header{padding:1.5rem 1.25rem 1rem;border-bottom:1px solid var(--color-border-subtle)}.sidebar-logo{display:flex;flex-direction:row;align-items:center;gap:.15rem;text-decoration:none;color:var(--color-text);font-weight:700;font-size:1rem;letter-spacing:.2em;transition:color var(--transition-fast)}.sidebar-logo:hover{color:var(--color-accent)}.sidebar-logo-icon{width:28px;height:28px;background:var(--color-accent);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background var(--transition-fast);color:#fff;font-family:Barlow,sans-serif;font-weight:700;font-size:1rem;line-height:1;letter-spacing:-.02em}.sidebar-logo:hover .sidebar-logo-icon{background:var(--color-accent-hover)}.sidebar-tagline{font-size:.7rem;color:var(--color-text-muted);margin-top:.25rem;font-weight:400;letter-spacing:.02em}.sidebar-nav{padding:.75rem .75rem .5rem;border-bottom:1px solid var(--color-border-subtle)}.nav-link{display:flex;align-items:center;gap:.5rem;padding:.375rem .5rem;border-radius:var(--radius-sm);font-size:.8125rem;font-weight:500;color:var(--color-text-secondary);text-decoration:none;transition:background var(--transition-fast),color var(--transition-fast)}.nav-link:hover{background:var(--color-surface-hover);color:var(--color-text)}.nav-link.active{background:var(--color-accent-subtle);color:var(--color-accent)}.nav-link svg{flex-shrink:0;opacity:.7}.nav-link.active svg{opacity:1}.sidebar-social{display:flex;align-items:center;gap:.25rem;padding:.625rem 1rem;border-bottom:1px solid var(--color-border-subtle)}.social-link{display:flex;align-items:center;justify-content:center;width:30px;height:30px;border:none;background:transparent;padding:0;border-radius:var(--radius-sm);color:var(--color-text-muted);text-decoration:none;cursor:pointer;transition:color var(--transition-fast),background var(--transition-fast)}.social-link:hover{color:var(--color-accent);background:var(--color-accent-subtle)}.social-link:focus-visible{outline:none;box-shadow:var(--shadow-focus)}.sidebar-section{padding:.5rem .75rem;flex:1;overflow-y:auto}.sidebar-section-label{font-size:.6875rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--color-text-muted);padding:.5rem .5rem .375rem}.sidebar-footer{padding:.625rem 1rem;border-top:1px solid var(--color-border-subtle)}.sidebar-footer-meta{font-size:.6875rem;color:var(--color-text-muted)}.tree{list-style:none;font-size:.8125rem}.tree-item{animation:treeItemIn var(--transition-normal) ease both}.tree-folder-toggle{display:flex;align-items:center;gap:.375rem;width:100%;padding:.3125rem .5rem;border:none;background:transparent;color:var(--color-text-secondary);font-size:.8125rem;font-family:var(--font-sans);font-weight:500;cursor:pointer;border-radius:var(--radius-sm);text-align:left;transition:background var(--transition-fast),color var(--transition-fast)}.tree-folder-toggle:hover{background:var(--color-surface-hover);color:var(--color-text)}.tree-folder-toggle.has-active{color:var(--color-accent)}.folder-chevron{transition:transform var(--transition-fast);flex-shrink:0;color:var(--color-text-muted)}.folder-children{list-style:none;margin-left:1rem;border-left:1px solid var(--color-border-subtle);padding-left:.5rem;overflow:hidden;transition:max-height var(--transition-normal),opacity var(--transition-fast)}.folder-children.closed{max-height:0;opacity:0}.folder-children.open{max-height:9999px;opacity:1}.folder-chevron.open{transform:rotate(90deg)}.file-link{display:flex;align-items:center;gap:.375rem;padding:.3125rem .5rem;border-radius:var(--radius-sm);color:var(--color-text-secondary);text-decoration:none;font-size:.8125rem;transition:background var(--transition-fast),color var(--transition-fast);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.file-link:hover{background:var(--color-surface-hover);color:var(--color-text)}.file-link.active{background:var(--color-accent-subtle);color:var(--color-accent);font-weight:500}.file-icon{flex-shrink:0;opacity:.5}.file-link.active .file-icon{opacity:1}.main-content{flex:1;min-width:0;display:flex;flex-direction:column}.page-wrapper{flex:1;padding:3rem 2rem 4rem;max-width:var(--content-max-width);margin:0 auto;width:100%}.post-page-wrapper{flex:1;display:grid;grid-template-columns:1fr var(--toc-width);gap:3rem;padding:3rem 2rem 4rem;max-width:calc(var(--content-max-width) + var(--toc-width) + 3rem);margin:0 auto;width:100%;align-items:start}.post-page-wrapper>aside{align-self:stretch}.mobile-header{display:none;align-items:center;justify-content:space-between;padding:.875rem 1rem;border-bottom:1px solid var(--color-border);background:var(--color-bg);position:sticky;top:0;z-index:99}.mobile-menu-btn{background:transparent;border:none;cursor:pointer;color:var(--color-text);padding:.25rem;border-radius:var(--radius-sm);display:flex;align-items:center;transition:color var(--transition-fast)}.mobile-menu-btn:hover{color:var(--color-accent)}.sidebar-overlay{display:none;position:fixed;inset:0;background:#00000080;z-index:99;opacity:0;transition:opacity var(--transition-normal)}.reading-progress{position:fixed;top:0;left:0;width:100%;height:2px;z-index:9999;background:transparent;pointer-events:none}.reading-progress-bar{height:100%;background:var(--color-accent);width:0%;transition:width 50ms linear;border-radius:0 2px 2px 0}.blog-card{display:block;padding:1.5rem;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);text-decoration:none;color:inherit;transition:transform var(--transition-normal),box-shadow var(--transition-normal),border-color var(--transition-normal);position:relative;overflow:hidden}.blog-card:before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--color-accent);transform:scaleY(0);transform-origin:bottom;transition:transform var(--transition-normal);border-radius:0 2px 2px 0}.blog-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);border-color:var(--color-accent-muted)}.blog-card:hover:before{transform:scaleY(1)}.blog-card-header{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;margin-bottom:.625rem}.blog-card-title{font-size:1.0625rem;font-weight:600;color:var(--color-text);letter-spacing:-.02em;line-height:1.35}.blog-card:hover .blog-card-title{color:var(--color-accent)}.blog-card-description{font-size:.875rem;color:var(--color-text-secondary);line-height:1.55;margin-bottom:1rem;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.blog-card-meta{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.meta-item{display:flex;align-items:center;gap:.25rem;font-size:.75rem;color:var(--color-text-muted)}.tag-list{display:flex;flex-wrap:wrap;gap:.375rem;margin-top:auto;padding-top:.25rem}.tag{display:inline-block;padding:.125rem .5rem;background:var(--color-accent-subtle);color:var(--color-accent);font-size:.6875rem;font-weight:600;letter-spacing:.03em;border-radius:999px;transition:background var(--transition-fast)}.hero{margin-bottom:3.5rem;padding-bottom:3rem;position:relative}.hero:after{content:"";position:absolute;bottom:0;left:0;right:0;height:1px;background:linear-gradient(to right,transparent,var(--color-accent),transparent);opacity:.5}.hero-label{display:inline-flex;align-items:center;gap:.375rem;font-size:.75rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--color-accent);margin-bottom:1rem}.hero-label:before{content:"";display:block;width:20px;height:2px;background:var(--color-accent);border-radius:1px}.hero-title{font-size:clamp(2rem,5vw,3rem);font-weight:700;letter-spacing:-.04em;line-height:1.1;color:var(--color-text);margin-bottom:1.25rem}.hero-title span{color:var(--color-accent)}.hero-description{font-size:1.0625rem;color:var(--color-text-secondary);line-height:1.65;max-width:520px}.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.5rem}.section-title{font-size:.75rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--color-text-muted)}.view-all-link{font-size:.8125rem;font-weight:500;color:var(--color-accent);text-decoration:none;display:flex;align-items:center;gap:.25rem;transition:gap var(--transition-fast)}.view-all-link:hover{gap:.5rem}.posts-grid{display:flex;flex-direction:column;gap:1rem}.toc-container{position:sticky;top:2rem;max-height:calc(100vh - 4rem);overflow-y:auto}.toc-title{font-size:.6875rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--color-text-muted);margin-bottom:.75rem}.toc-list{list-style:none;border-left:1px solid var(--color-border)}.toc-item{padding:0}.toc-link{display:block;padding:.25rem .75rem;font-size:.8rem;color:var(--color-text-muted);text-decoration:none;border-left:2px solid transparent;margin-left:-1px;line-height:1.4;transition:color var(--transition-fast),border-color var(--transition-fast)}.toc-link:hover{color:var(--color-text-secondary)}.toc-link.active{color:var(--color-accent);border-left-color:var(--color-accent);font-weight:600}.toc-link[data-depth="3"]{padding-left:1.375rem;font-size:.75rem}.toc-link[data-depth="4"]{padding-left:2rem;font-size:.75rem}.post-header{margin-bottom:2.5rem;padding-bottom:2rem;position:relative}.post-header:after{content:"";position:absolute;bottom:0;left:0;right:0;height:1px;background:linear-gradient(to right,transparent,var(--color-accent),transparent);opacity:.5}.post-back-link{display:inline-flex;align-items:center;gap:.375rem;font-size:.8125rem;font-weight:500;color:var(--color-text-muted);text-decoration:none;margin-bottom:1.5rem;transition:color var(--transition-fast),gap var(--transition-fast)}.post-back-link:hover{color:var(--color-accent);gap:.5rem}.post-tags{display:flex;flex-wrap:wrap;gap:.375rem;margin-bottom:1rem}.post-title{font-size:clamp(1.625rem,4vw,2.25rem);font-weight:700;letter-spacing:-.03em;line-height:1.2;color:var(--color-text);margin-bottom:1rem}.post-meta{display:flex;align-items:center;gap:1rem;flex-wrap:wrap;color:var(--color-text-muted);font-size:.8125rem}.post-meta-divider{width:3px;height:3px;border-radius:50%;background:var(--color-border);flex-shrink:0}@keyframes fadeInUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes treeItemIn{0%{opacity:0;transform:translate(-4px)}to{opacity:1;transform:translate(0)}}.animate-fade-in-up{animation:fadeInUp .4s ease both}.animate-fade-in{animation:fadeIn .3s ease both}.stagger>*:nth-child(1){animation-delay:0ms}.stagger>*:nth-child(2){animation-delay:60ms}.stagger>*:nth-child(3){animation-delay:.12s}.stagger>*:nth-child(4){animation-delay:.18s}.stagger>*:nth-child(5){animation-delay:.24s}.stagger>*:nth-child(6){animation-delay:.3s}.stagger>*:nth-child(n+7){animation-delay:.36s}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}[data-theme=dark] .astro-code,[data-theme=dark] .astro-code span{color:var(--shiki-dark)!important;background-color:var(--shiki-dark-bg)!important;font-style:var(--shiki-dark-font-style)!important;font-weight:var(--shiki-dark-font-weight)!important;text-decoration:var(--shiki-dark-text-decoration)!important}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}@media(max-width:1100px){.post-page-wrapper{grid-template-columns:1fr}.toc-container{display:none}}@media(max-width:768px){.sidebar{position:fixed;top:0;left:0;height:100%;transform:translate(-100%);box-shadow:var(--shadow-lg)}.sidebar.open{transform:translate(0)}.sidebar-overlay.visible{display:block;opacity:1}.mobile-header{display:flex}.page-wrapper,.post-page-wrapper{padding:1.5rem 1.25rem 3rem;max-width:100%}.post-page-wrapper{grid-template-columns:1fr}.hero-title{font-size:1.75rem}}.prose{color:var(--color-text);font-size:1rem;line-height:1.75;max-width:100%}.prose h1,.prose h2,.prose h3,.prose h4,.prose h5,.prose h6{color:var(--color-text);font-weight:700;letter-spacing:-.02em;line-height:1.25;margin-top:2em;margin-bottom:.75em;scroll-margin-top:2rem}.prose h1{font-size:2rem;margin-top:0}.prose h2{font-size:1.5rem}.prose h3{font-size:1.25rem}.prose h4{font-size:1.0625rem}.prose h5{font-size:.9375rem}.prose h6{font-size:.875rem;color:var(--color-text-secondary)}.prose h2 a,.prose h3 a,.prose h4 a{color:inherit;text-decoration:none;position:relative}.prose h2 a:after,.prose h3 a:after,.prose h4 a:after{content:" #";opacity:0;color:var(--color-accent);font-size:.8em;transition:opacity var(--transition-fast)}.prose h2:hover a:after,.prose h3:hover a:after,.prose h4:hover a:after{opacity:1}.prose p{margin-bottom:1.25em;color:var(--color-text-secondary)}.prose a{color:var(--color-accent);text-decoration:underline;text-decoration-color:var(--color-accent-muted);text-underline-offset:3px;transition:text-decoration-color var(--transition-fast),color var(--transition-fast)}.prose a:hover{color:var(--color-accent-hover);text-decoration-color:var(--color-accent)}.prose ul,.prose ol{padding-left:1.5rem;margin-bottom:1.25em;color:var(--color-text-secondary)}.prose li{margin-bottom:.375em;padding-left:.375rem}.prose ul>li::marker{color:var(--color-accent)}.prose ol>li::marker{color:var(--color-accent);font-weight:600;font-size:.9em}.prose ul ul,.prose ol ol,.prose ul ol,.prose ol ul{margin-top:.375em;margin-bottom:0}.prose blockquote{border-left:3px solid var(--color-accent);margin:1.75em 0;padding:.875rem 1.25rem;background:var(--color-accent-subtle);border-radius:0 var(--radius-md) var(--radius-md) 0;font-style:italic;color:var(--color-text-secondary)}.prose blockquote p{margin:0;color:inherit}.prose blockquote strong{color:var(--color-accent);font-style:normal}.prose code:not(pre code){font-family:var(--font-mono);font-size:.875em;background:var(--color-code-bg);color:var(--color-accent);padding:.125em .375em;border-radius:var(--radius-sm);border:1px solid var(--color-border);font-weight:500}.prose pre{font-family:var(--font-mono);font-size:.875rem;line-height:1.6;padding:1.25rem 1.5rem;border-radius:var(--radius-md);border:1px solid var(--color-border);overflow-x:auto;margin:1.75em 0;position:relative}.prose pre code{font-family:inherit;font-size:inherit;background:transparent;padding:0;border:none;color:inherit}.code-block-wrapper{position:relative;margin:1.75em 0}.code-block-wrapper pre{margin:0}.copy-btn{position:absolute;top:.625rem;right:.625rem;padding:.25rem .625rem;font-size:.6875rem;font-family:var(--font-sans);font-weight:500;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text-muted);cursor:pointer;opacity:0;transition:opacity var(--transition-fast),color var(--transition-fast),background var(--transition-fast)}.code-block-wrapper:hover .copy-btn{opacity:1}.copy-btn:hover{color:var(--color-accent);background:var(--color-accent-subtle);border-color:var(--color-accent-muted)}.copy-btn.copied{opacity:1;color:var(--color-accent)}.prose table{width:100%;border-collapse:collapse;font-size:.9rem;margin:1.75em 0;overflow-x:auto;display:block}.prose thead{background:var(--color-surface)}.prose th{padding:.625rem .875rem;text-align:left;font-weight:600;font-size:.8125rem;color:var(--color-text);border:1px solid var(--color-border);white-space:nowrap}.prose td{padding:.5rem .875rem;border:1px solid var(--color-border);color:var(--color-text-secondary);vertical-align:top}.prose tr:hover td{background:var(--color-surface-hover)}.prose img{max-width:100%;height:auto;border-radius:var(--radius-md);border:1px solid var(--color-border);margin:1.5em 0}.prose hr{border:none;border-top:1px solid var(--color-border);margin:2.5em 0}.prose strong{font-weight:600;color:var(--color-text)}.prose em{font-style:italic}.prose p:has(strong:first-child){background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:.875rem 1rem;margin:1.5em 0}.prose dt{font-weight:600;color:var(--color-text);margin-top:1em}.prose dd{margin-left:1.5rem;color:var(--color-text-secondary)}
