:root{--brand: #3ECF8E;--brand-dark: #006239;--bg: #fafafa;--bg-secondary: #f5f5f5;--text: #1c1c1c;--text-secondary: #6b6b6b;--border: #e6e6e6;--sidebar-bg: #f8f8f8;--sidebar-active: #006239;--sidebar-active-bg: rgba(62, 207, 142, .08);--code-bg: #1c1c1c;--link: #006239;--link-hover: #3ECF8E;--shadow: rgba(0, 0, 0, .04)}[data-theme=dark]{--brand: #3ECF8E;--brand-dark: #85e0ba;--bg: #121212;--bg-secondary: #1c1c1c;--text: #fafafa;--text-secondary: #a0a0a0;--border: #2e2e2e;--sidebar-bg: #171717;--sidebar-active: #3ECF8E;--sidebar-active-bg: rgba(62, 207, 142, .1);--code-bg: #0d0d0d;--link: #3ECF8E;--link-hover: #85e0ba;--shadow: rgba(0, 0, 0, .4)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;background:var(--bg);color:var(--text);line-height:1.7;display:flex;flex-direction:column;min-height:100vh}a{color:var(--link);text-decoration:none;transition:color .15s}a:hover{color:var(--link-hover);text-decoration:underline}img{max-width:100%;height:auto}.prose{max-width:720px;margin:0 auto;padding:2rem 1.5rem 4rem}.prose h1{font-size:2rem;font-weight:700;margin:0 0 1.5rem;line-height:1.2;color:var(--brand)}.prose h2{font-size:1.4rem;font-weight:600;margin:2.5rem 0 1rem;color:var(--text)}.prose h3{font-size:1.15rem;font-weight:600;margin:2rem 0 .75rem}.prose p{margin:0 0 1.25rem}.prose blockquote{border-left:3px solid var(--brand);padding:.5rem 1rem;margin:1.5rem 0;color:var(--text-secondary);font-style:italic;background:var(--bg-secondary);border-radius:0 4px 4px 0}.prose blockquote p{margin:0}.prose hr{border:none;border-top:1px solid var(--border);margin:2rem 0}.prose pre{background:var(--code-bg);border-radius:8px;padding:1rem 1.25rem;overflow-x:auto;margin:1.5rem 0;font-size:.875rem;line-height:1.5}.prose code{font-family:SF Mono,Fira Code,Cascadia Code,Menlo,Consolas,monospace;font-size:.9em}.prose :not(pre)>code{background:var(--bg-secondary);padding:.15em .4em;border-radius:3px;font-size:.85em}.prose table{width:100%;border-collapse:collapse;margin:1.5rem 0;font-size:.9rem}.prose th,.prose td{border:1px solid var(--border);padding:.5rem .75rem;text-align:left}.prose th{background:var(--bg-secondary);font-weight:600}.prose figure{margin:1.5rem 0}.prose figcaption{font-size:.85rem;color:var(--text-secondary);margin-top:.5rem;text-align:center;font-style:italic}.prose figure img{border-radius:8px;display:block;margin:0 auto}.prose iframe{width:100%;border:1px solid var(--border);border-radius:8px;display:block}.prose ul,.prose ol{margin:1rem 0 1.25rem;padding-left:1.5rem}.prose li{margin:.3rem 0}.prose .callout{border-left:3px solid var(--brand);padding:.75rem 1rem;margin:1.5rem 0;background:var(--bg-secondary);border-radius:0 4px 4px 0}.prose .callout p{margin:0}.post-byline{font-family:EB Garamond,Georgia,serif;font-style:italic;font-size:.95rem;color:var(--text-secondary);margin-bottom:.25rem;text-align:center}.post-byline a{color:var(--text-secondary);text-decoration:none}.post-byline a:hover{color:var(--brand)}.post-meta{display:flex;align-items:center;justify-content:space-between;margin-bottom:2rem;padding-bottom:1rem;border-bottom:1px solid var(--border)}.post-series{font-size:.85rem;color:var(--text-secondary)}.devto-link{margin:2.5rem 0 0;font-size:.9rem;color:var(--text-secondary)}.devto-link a{color:var(--text-secondary);text-decoration:underline;text-underline-offset:2px}.devto-link a:hover{color:var(--brand)}.post-nav{display:flex;justify-content:space-between;margin-top:3rem;padding-top:2rem;border-top:1px solid var(--border);gap:1rem}.post-nav a{display:flex;flex-direction:column;padding:.75rem 1rem;border:1px solid var(--border);border-radius:8px;max-width:48%;transition:border-color .15s,background .15s}.post-nav a:hover{border-color:var(--brand);background:var(--bg-secondary);text-decoration:none}.post-nav .label{font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary);margin-bottom:.25rem}.post-nav .title{font-size:.9rem;font-weight:500}.post-nav .next{margin-left:auto;text-align:right}.site-body{display:flex;flex:1;min-height:0}.sidebar{width:280px;min-width:280px;background:var(--sidebar-bg);border-right:1px solid var(--border);padding:1.5rem 0;overflow-y:auto;position:sticky;top:0;height:calc(100vh - var(--brand-bar-height, 44px));display:flex;flex-direction:column}.sidebar-header{padding:0 1.25rem 1rem;border-bottom:1px solid var(--border);margin-bottom:1rem}.sidebar-title{font-size:1.1rem;font-weight:700;color:var(--brand)}.sidebar-nav{flex:1;overflow-y:auto;padding:0 .75rem}.part-group{margin-bottom:.5rem}.part-title{font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--text-secondary);padding:.5rem;margin:0}.post-link{display:block;padding:.4rem .5rem;border-radius:6px;font-size:.85rem;color:var(--text);line-height:1.3;transition:background .15s}.post-link:hover{background:var(--sidebar-active-bg);text-decoration:none}.post-link.active{background:var(--sidebar-active-bg);color:var(--sidebar-active);font-weight:600}.post-link .post-num{color:var(--text-secondary);font-size:.75rem;margin-right:.25rem}.main-content{flex:1;min-width:0;overflow-y:auto}.sidebar-overlay{display:none}@media (max-width: 768px){.sidebar{position:fixed;top:var(--brand-bar-height, 44px);left:-300px;height:calc(100vh - var(--brand-bar-height, 44px));z-index:99;transition:left .25s ease;box-shadow:4px 0 20px var(--shadow)}.sidebar.open{left:0}.sidebar-overlay.open{display:block;position:fixed;top:var(--brand-bar-height, 44px);left:0;right:0;bottom:0;background:#0000004d;z-index:98}.main-content{padding-top:1rem}}:root{--brand-bar-height: 44px}.brand-bar{background-color:#f5f0e8;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='4' viewBox='0 0 200 4'%3E%3Cpath d='M0 2 Q10 0.5 20 2 Q30 3.5 40 2 Q50 0.8 60 2 Q70 3.2 80 2 Q90 1 100 2 Q110 3 120 2 Q130 0.5 140 2 Q150 3.5 160 2 Q170 1 180 2 Q190 3 200 2' stroke='%232c2418' stroke-width='0.8' fill='none' opacity='0.4'/%3E%3C/svg%3E"),url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.7' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.05'/%3E%3C/svg%3E");background-position:bottom center,0 0;background-size:200px 4px,256px 256px;background-repeat:repeat-x,repeat;padding:.6rem 1.25rem;display:flex;justify-content:space-between;align-items:center;z-index:200}.brand-name{font-family:EB Garamond,Georgia,serif;font-size:1.05rem;font-weight:400;color:#1a1612;letter-spacing:-.01em;opacity:.85;transition:opacity .2s;text-decoration:none}.brand-name:hover{opacity:1;color:#1a1612;text-decoration:none}.brand-bar-left{display:flex;align-items:center;gap:.75rem;overflow:hidden}.brand-site-name{display:none}.brand-controls{display:flex;gap:.5rem;align-items:center}.brand-lang-btn{font-family:JetBrains Mono,monospace;font-size:.75rem;font-weight:500;padding:.35rem .65rem;border:1px solid #d4cab5;border-radius:2px;color:#5c4f3d;background:transparent;cursor:pointer;transition:all .2s ease;text-transform:uppercase;letter-spacing:.05em;text-decoration:none}.brand-lang-btn:hover{border-color:#c47a7a;color:#c47a7a;background:#c47a7a14;text-decoration:none}.brand-theme-btn{font-size:.85rem;padding:.3rem .55rem;border:1px solid #d4cab5;border-radius:2px;color:#5c4f3d;background:transparent;cursor:pointer;transition:all .2s ease;line-height:1}.brand-theme-btn:hover{border-color:#c47a7a;color:#c47a7a;background:#c47a7a14}.brand-hamburger{display:none;background:none;border:none;font-size:1.3rem;cursor:pointer;color:#1a1612;padding:.2rem;line-height:1}.brand-footer{text-align:center;padding:3rem 0 2rem}.brand-footer-rule{width:120px;height:4px;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='4' viewBox='0 0 200 4'%3E%3Cpath d='M0 2 Q10 0.5 20 2 Q30 3.5 40 2 Q50 0.8 60 2 Q70 3.2 80 2 Q90 1 100 2 Q110 3 120 2 Q130 0.5 140 2 Q150 3.5 160 2 Q170 1 180 2 Q190 3 200 2' stroke='%232c2418' stroke-width='0.8' fill='none' opacity='0.4'/%3E%3C/svg%3E");background-repeat:no-repeat;background-size:120px 4px;background-color:transparent;margin:0 auto 2rem;border:none}.brand-footer-copy{font-family:EB Garamond,Georgia,serif;font-size:.85rem;font-style:italic;color:#7a6e5c}.brand-footer-author{color:#7a6e5c;text-decoration:none}.brand-footer-author:hover{color:#c47a7a}@media (max-width: 768px){.brand-bar{position:sticky;top:0}.brand-hamburger{display:block}.brand-site-name{display:inline;font-family:EB Garamond,Georgia,serif;font-size:.95rem;color:#5c4f3d;opacity:.7;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}}
