:root{--bg-color:#0d0d0d;--text-primary:#e0e0e0;--text-secondary:#888;--accent-color:#8bb4f7;--border-color:#333;--link-hover:#fff;--font-mono:"JetBrains Mono", "Fira Code", "Courier New", monospace;--font-sans:"Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen, Ubuntu, Cantarell, sans-serif;--container-width:900px}:root.light-theme{--bg-color:#f9f9f9;--text-primary:#111;--text-secondary:#555;--accent-color:#4a2cb5;--border-color:#ddd;--link-hover:#000}*{box-sizing:border-box;margin:0;padding:0}body{background-color:var(--bg-color);color:var(--text-primary);font-family:var(--font-mono);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;line-height:1.6}a{color:var(--accent-color);text-decoration:none;transition:color .2s}a:hover{color:var(--link-hover)}.container{max-width:var(--container-width);margin:0 auto;padding:2rem 1.5rem}h1,h2,h3,h4{color:var(--text-primary);margin-bottom:1rem;font-weight:500}p{font-family:var(--font-sans);color:#d4d4d4;margin-bottom:1rem}:root.light-theme p{color:#333}.site-header{border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;margin-bottom:3rem;padding-bottom:1rem;display:flex}.nav-links{gap:1rem;display:flex}.nav-link{color:var(--accent-color);font-weight:400}.nav-link.active{color:var(--text-primary);text-underline-offset:4px;text-decoration:underline}.social-links{gap:1rem;display:flex}.social-link{color:var(--text-primary);align-items:center;display:flex}.social-link:hover{color:var(--accent-color)}.page-title{font-size:1.5rem;font-family:var(--font-mono);margin-bottom:1.5rem}ul,ol{font-family:var(--font-sans);color:#d4d4d4;margin-bottom:1.5rem;padding-left:1.5rem;list-style-type:disc}:root.light-theme ul,:root.light-theme ol{color:#333}li{margin-bottom:.5rem}.post-list{flex-direction:column;gap:1rem;display:flex}.post-item{align-items:baseline;gap:2rem;display:flex}.post-meta{min-width:150px;color:var(--text-secondary);gap:1.5rem;display:flex}.post-title{color:var(--accent-color);font-size:1.15rem;font-weight:400}.post-title:hover{text-underline-offset:4px;text-decoration:underline}.work-item{margin-bottom:2.5rem}.work-title{align-items:center;gap:.5rem;margin-bottom:.5rem;font-size:1.1rem;display:flex}.work-title span{color:var(--text-secondary);font-size:.9rem;font-style:italic}.work-desc{color:#a8a8a8;margin-bottom:.5rem}:root.light-theme .work-desc{color:#555}.tools-section{grid-template-columns:150px 1fr;gap:.5rem 1rem;margin-bottom:1.5rem;display:grid}.tool-category{color:var(--text-primary);font-weight:600}.tool-list{font-family:var(--font-sans);color:var(--text-secondary)}.back-link{font-family:var(--font-mono);margin-bottom:2rem;font-size:.9rem;display:inline-block}.article-header{margin-bottom:2.5rem}.article-title{margin-bottom:.5rem;font-size:2rem;line-height:1.2}.article-meta{color:var(--text-secondary);font-family:var(--font-mono);gap:.5rem;font-size:.9rem;display:flex}.article-content{max-width:720px}.article-content h2{margin-top:2.5rem;margin-bottom:1rem;font-size:1.5rem}.article-content h3{margin-top:3.2rem;margin-bottom:.75rem;font-size:1.25rem}.article-content p{color:#d4d4d4;max-width:70ch;margin-bottom:1.5rem;font-size:1.05rem;line-height:1.7}.article-content ul,.article-content ol{color:#d4d4d4;max-width:70ch;margin-bottom:1.5rem;padding-left:1.5rem;line-height:1.7}.article-content blockquote{border-left:4px solid var(--accent-color);color:var(--text-secondary);max-width:70ch;margin-bottom:1.5rem;margin-left:0;margin-right:0;padding-left:1rem;font-style:italic}.article-content pre{border:1px solid var(--border-color);background-color:#1a1a1a;border-radius:4px;margin-bottom:1.5rem;padding:1rem;overflow-x:auto}:root.light-theme .article-content p,:root.light-theme .article-content ul,:root.light-theme .article-content ol{color:#333}:root.light-theme .article-content pre{background-color:#f1f1f1}.article-content code{font-family:var(--font-mono);font-size:.9em}.article-content p code,.article-content li code{background-color:#222;border-radius:3px;padding:.2rem .4rem}:root.light-theme .article-content p code,:root.light-theme .article-content li code{background-color:#eee}.token.comment{color:#7c7c7c;font-style:italic}.token.punctuation{color:var(--text-primary);opacity:.8}.token.keyword{color:var(--accent-color);font-weight:600}.token.operator{color:var(--text-primary)}.token.string{color:#81c995}:root.light-theme .token.string{color:#137333}.token.function{color:#ffc107}:root.light-theme .token.function{color:#d84315}.token.number,.token.boolean{color:#f28b82}:root.light-theme .token.number,:root.light-theme .token.boolean{color:#c5221f}@media (width<=600px){.post-item{flex-direction:column;gap:.2rem}.tools-section{grid-template-columns:1fr}.site-header{flex-direction:column;align-items:flex-start;gap:1rem}.article-title{font-size:1.5rem}}.article-meta{flex-wrap:wrap;align-items:center}.like-button{color:var(--text-secondary);font-family:var(--font-mono);cursor:pointer;background:0 0;border:none;align-items:center;gap:.3rem;padding:0;font-size:.9rem;transition:color .2s,transform .1s;display:inline-flex}.like-button:hover{color:var(--accent-color)}.like-button:active{transform:scale(.95)}.like-button .heart-icon{stroke-width:2px;transition:fill .2s,stroke .2s}.like-button.liked{color:var(--accent-color)}.like-button.liked .heart-icon{fill:var(--accent-color);stroke:var(--accent-color)}.like-button-large{border:1px solid var(--border-color);background:var(--bg-secondary,#ffffff0d);color:var(--text-primary);cursor:pointer;border-radius:2rem;align-items:center;gap:.75rem;padding:.75rem 1.5rem;font-size:1rem;font-weight:500;transition:all .2s;display:inline-flex}.like-button-large:hover{border-color:var(--accent-color);background:color-mix(in srgb, var(--accent-color) 8%, transparent)}.like-button-large:active{transform:scale(.95)}.like-button-large.liked{border-color:var(--accent-color);background:color-mix(in srgb, var(--accent-color) 8%, transparent);color:var(--accent-color)}.diagram-container{border:1px solid var(--border-color);background-color:var(--bg-secondary,#00000005);background-image:radial-gradient(var(--border-color) 1px, transparent 1px);background-size:20px 20px;border-radius:8px;flex-direction:column;gap:2rem;margin:2.5rem 0;padding:2rem;display:flex}:root.light-theme .diagram-container{background-color:#00000005}.diagram-row{align-items:stretch;gap:2rem;display:flex}@media (width<=768px){.diagram-row{flex-direction:column}}.diagram-panel{background:var(--bg-color);border:1px solid var(--border-color);border-radius:6px;flex-direction:column;flex:1;align-items:center;gap:1.5rem;padding:1.5rem;display:flex;box-shadow:0 4px 6px #0000000d}.diagram-title{font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary);border-bottom:1px solid var(--border-color);text-align:center;width:100%;margin-bottom:.5rem;padding-bottom:.5rem;font-size:.95rem}.diagram-box{border:1px solid var(--border-color);background:var(--bg-color);font-family:var(--font-mono);text-align:center;z-index:2;border-radius:4px;padding:.85rem 1.5rem;font-size:1rem}.diagram-box.accent{border-color:var(--accent-color);background:color-mix(in srgb, var(--accent-color) 10%, transparent);color:var(--accent-color)}.diagram-arrow{color:var(--text-secondary);font-size:.9rem;font-family:var(--font-mono);flex-direction:column;align-items:center;display:flex}.diagram-arrow:after{content:"↓";margin-top:-.2rem;font-size:1.4rem}.diagram-arrow.horizontal{flex-direction:row;gap:.5rem}.diagram-arrow.horizontal:after{content:"→";margin-top:0}.diagram-customer-block{border:1px solid var(--border-color);background:var(--bg-color);border-radius:4px;width:28px;height:28px;transition:all .3s}.diagram-customer-block.active{border-color:var(--accent-color);background:color-mix(in srgb, var(--accent-color) 20%, transparent)}.diagram-progression{justify-content:space-between;align-items:center;width:100%;padding:1rem 0;display:flex;position:relative}.progression-step{z-index:1;flex-direction:column;flex:1;align-items:center;gap:1rem;display:flex}.progression-blocks{flex-wrap:wrap;place-content:center;gap:4px;width:100px;min-height:52px;display:flex}.progression-label{color:var(--text-secondary);font-size:.95rem;font-family:var(--font-mono);text-align:center;background:var(--bg-color);border-radius:4px;padding:.2rem .5rem}.progression-line{background:var(--border-color);z-index:0;height:1px;position:absolute;bottom:12px;left:10%;right:10%}.progression-line:after{content:"";border-top:4px solid #0000;border-bottom:4px solid #0000;border-left:5px solid var(--border-color);position:absolute;top:-4px;right:-5px}.github-mention{font-family:var(--font-mono);background-color:color-mix(in srgb, var(--text-secondary) 15%, transparent);color:var(--text-secondary);border:1px solid var(--border-color);white-space:nowrap;border-radius:4px;padding:.15em .4em;font-size:.85em;text-decoration:none;transition:all .2s}.github-mention:hover{color:var(--text-primary);border-color:var(--text-primary)}.post-tag{font-family:var(--font-mono);color:var(--text-secondary);border:1px solid var(--border-color);white-space:nowrap;background-color:#0000;border-radius:0;padding:.1em .5em;font-size:.9em}.subscribe-container{border-left:2px solid var(--border-color);flex-direction:column;gap:.8rem;max-width:450px;margin:3rem 0 1rem;padding-left:1rem;display:flex}.subscribe-label{font-family:var(--font-mono);color:var(--text-secondary);font-size:.85rem}.subscribe-form{gap:.4rem;display:flex}.subscribe-input{border:1px solid var(--border-color);color:var(--text-primary);font-family:var(--font-mono);background:0 0;border-radius:4px;outline:none;flex:1;padding:.5rem .75rem;font-size:.85rem;transition:border-color .2s}.subscribe-input:focus{border-color:var(--accent-color)}.subscribe-input.error{background:#d16b6b14;border-color:#d16b6b}:root.light-theme .subscribe-input.error{background:#ab30300d;border-color:#ab3030}.subscribe-button{color:var(--text-primary);border:1px solid var(--border-color);font-family:var(--font-mono);cursor:pointer;background:0 0;border-radius:4px;padding:.5rem 1rem;font-size:.85rem;transition:all .2s}.subscribe-button:hover:not(:disabled){border-color:var(--accent-color);color:var(--accent-color);background:color-mix(in srgb, var(--accent-color) 10%, transparent)}.subscribe-button:disabled{opacity:.5;cursor:not-allowed}.subscribe-error-text{color:#d16b6b;margin:0;font-size:.8rem}:root.light-theme .subscribe-error-text{color:#ab3030}.subscribe-success{font-family:var(--font-mono);color:var(--text-secondary);margin:0;font-size:.85rem}@media (width<=600px){.subscribe-form{flex-direction:column}}
