:root{--font-serif:"Playfair Display", serif;--font-sans:"Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-mono:"SFMono-Regular", Consolas, "Liberation Mono", Menlo, Courier, monospace;--color-text:#1a1a1a;--color-text-secondary:#3d3d3d;--color-text-muted:#767676;--color-bg:#f5f5f4;--color-bg-code:#fafaf9;--color-border:#e5e5e5;--color-border-light:#d4d4d4;--color-nav-bg:rgba(245, 245, 244, 0.88);--max-width:1080px;--min-width:368px;--content-padding:3.5rem}[data-theme=dark]{--color-text:#e5e5e5;--color-text-secondary:#b0b0b0;--color-text-muted:#808080;--color-bg:#111111;--color-bg-code:#1a1a1a;--color-border:#2a2a2a;--color-border-light:#3a3a3a;--color-nav-bg:rgba(17, 17, 17, 0.88)}[data-theme=dark] .giallo-l::before{color:#555}[data-theme=dark] .post-content code:not(pre code){background:rgba(255,255,255,8%)}*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth}body{font-family:var(--font-sans);background-color:var(--color-bg);margin:0;min-height:100vh;color:var(--color-text);overflow-x:hidden;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body::after{content:"";position:fixed;top:-50%;left:-50%;width:200%;height:200%;z-index:-1;filter:url(#grain);opacity:.08;pointer-events:none;animation:grain-shift .5s steps(2)infinite}@keyframes grain-shift{0%{transform:translate(0,0)}50%{transform:translate(-2%,-1%)}100%{transform:translate(1%,2%)}}a{color:inherit;text-decoration:none}main{--grid-system-width:calc(100cqw);max-width:var(--max-width);min-width:var(--min-width);margin:0 auto;container-type:inline-size}.site-nav{display:flex;justify-content:space-between;align-items:center;padding:1rem 8vw;padding-top:max(1rem,env(safe-area-inset-top));border-bottom:1px solid var(--color-border)}.nav-logo{font-family:var(--font-serif);font-size:1.15rem;font-weight:600;letter-spacing:.02em}.nav-logo a{color:inherit}.nav-right{display:flex;align-items:center;gap:1.5rem}.nav-link{font-size:.72rem;font-weight:500;letter-spacing:.1em;text-transform:uppercase;color:var(--color-text-muted);transition:color .25s}.nav-link:hover{color:var(--color-text)}.nav-github{display:flex;align-items:center;gap:.4rem}.theme-toggle{display:flex;align-items:center;justify-content:center;background:0 0;border:none;padding:.35rem;cursor:pointer;color:var(--color-text-muted);transition:color .25s;border-radius:4px}.theme-toggle:hover{color:var(--color-text)}.icon-moon{display:none}[data-theme=dark] .icon-sun{display:none}[data-theme=dark] .icon-moon{display:block}.blog-container{position:relative;width:var(--grid-system-width);margin-top:3rem;border:1px solid var(--color-border);border-top:none}.blog-container::before{content:"";position:absolute;top:0;left:0;right:0;height:14rem;background-image:linear-gradient(to right,var(--color-border-light) 1px,transparent 1px),linear-gradient(to bottom,var(--color-border-light) 1px,transparent 1px);background-size:4rem 4rem;mask-image:linear-gradient(to bottom,rgba(0,0,0,.5) 0%,transparent 100%);-webkit-mask-image:linear-gradient(to bottom,rgba(0,0,0,.5) 0%,transparent 100%);pointer-events:none}.blog-header{position:relative;padding:5rem var(--content-padding)2rem;text-align:center}.blog-title{font-family:var(--font-serif);font-size:2.6rem;font-weight:700;letter-spacing:-.02em;margin-bottom:.5rem}.blog-subtitle{font-size:.95rem;color:var(--color-text-muted);line-height:1.6}.post-list{padding:1rem var(--content-padding)4rem}.post-item{padding:1.8rem 0}.post-item+.post-item{border-top:1px solid var(--color-border)}.post-date{display:block;font-size:.78rem;color:var(--color-text-muted);letter-spacing:.04em;margin-bottom:.35rem}.post-item-title{font-family:var(--font-serif);font-size:1.45rem;font-weight:600;line-height:1.35;margin-bottom:.35rem}.post-item-title a{color:inherit;text-decoration:none;transition:color .2s}.post-item-title a:hover{color:var(--color-text-secondary)}.post-item-summary{font-size:.92rem;line-height:1.7;color:var(--color-text-secondary)}.pagination{display:flex;justify-content:space-between;padding-top:2rem;border-top:1px solid var(--color-border)}.pagination-link{font-size:.85rem;font-weight:500;color:var(--color-text-muted);transition:color .2s}.pagination-link:hover{color:var(--color-text)}.post{position:relative;width:var(--grid-system-width);margin-top:3rem;padding:5rem var(--content-padding)4rem;border:1px solid var(--color-border);border-top:none}.post::before{content:"";position:absolute;top:0;left:0;right:0;height:15rem;background-image:linear-gradient(to right,var(--color-border-light) 1px,transparent 1px),linear-gradient(to bottom,var(--color-border-light) 1px,transparent 1px);background-size:4rem 4rem;mask-image:linear-gradient(to bottom,rgba(0,0,0,.5) 0%,transparent 100%);-webkit-mask-image:linear-gradient(to bottom,rgba(0,0,0,.5) 0%,transparent 100%);pointer-events:none}.post-header{position:relative;text-align:center;margin-bottom:3rem}.post-title{font-family:var(--font-serif);font-size:2.2rem;font-weight:700;line-height:1.25;letter-spacing:-.01em;margin-bottom:1rem}.post-meta{font-size:.82rem;color:var(--color-text-muted);letter-spacing:.04em}.post-author{font-size:.82rem;color:var(--color-text-secondary);font-weight:500;margin-top:.5rem}.post-content{font-size:1.05rem;line-height:1.85;color:var(--color-text-secondary)}.post-content h2{font-family:var(--font-serif);font-size:1.85rem;font-weight:600;color:var(--color-text);margin-top:3rem;margin-bottom:.8rem;line-height:1.3}.post-content h3{font-family:var(--font-serif);font-size:1.48rem;font-weight:600;color:var(--color-text);margin-top:2.4rem;margin-bottom:.6rem;line-height:1.35}.post-content h4{font-family:var(--font-sans);font-size:1rem;font-weight:600;color:var(--color-text);margin-top:1.8rem;margin-bottom:.5rem}.post-content p{margin-bottom:1.3rem}.post-content a{color:var(--color-text);text-decoration:underline;text-underline-offset:3px;text-decoration-color:var(--color-border-light);transition:text-decoration-color .2s}.post-content a:hover{text-decoration-color:var(--color-text)}.post-content strong{color:var(--color-text);font-weight:600}.post-content ul,.post-content ol{padding-left:1.4rem;margin-bottom:1.3rem}.post-content li{margin-bottom:.4rem;line-height:1.8}.post-content li::marker{color:var(--color-text-muted)}.post-content blockquote{border-left:3px solid var(--color-border-light);padding:.6rem 1.2rem;margin:1.5rem 0;color:var(--color-text-muted);font-style:italic}.post-content blockquote p{margin-bottom:0}.post-content img{max-width:100%;height:auto;border-radius:6px;margin:1.5rem 0}.post-content hr{border:none;border-top:1px solid var(--color-border);margin:2.5rem 0}.post-content table{width:100%;border-collapse:collapse;margin:1.5rem 0;font-size:.92rem}.post-content th,.post-content td{padding:.6rem .8rem;text-align:left;border-bottom:1px solid var(--color-border)}.post-content th{font-weight:600;color:var(--color-text)}.post-meta-line{display:flex;align-items:center;justify-content:center;gap:.75rem}.reading-time{font-size:.82rem;color:var(--color-text-muted)}.reading-time::before{content:"·";margin-right:.75rem}.toc{margin:0 0 2rem;font-size:.85rem;line-height:1.6}.toc-heading{font-weight:600;font-size:.75rem;letter-spacing:.08em;text-transform:uppercase;color:var(--color-text-muted);cursor:pointer;list-style:none;user-select:none}.toc-heading::-webkit-details-marker{display:none}.toc-heading::before{content:"▸ ";display:inline-block;transition:transform .15s}details[open]>.toc-heading::before{transform:rotate(90deg)}.toc-list{margin-top:.5rem;padding-left:1rem;list-style:none;columns:2;column-gap:2rem}.toc-list li{margin-bottom:.15rem;break-inside:avoid}.toc-list a{color:var(--color-text-muted);transition:color .2s}.toc-list a:hover{color:var(--color-text)}.toc-list ul{padding-left:1rem;margin-top:.1rem;list-style:none}.toc-list ul a{font-size:.82rem}.post-content code{font-family:var(--font-mono);font-size:.85em;background:rgba(0,0,0,5%);padding:.15em .4em;border-radius:4px}.post-content pre{margin:1.6rem 0;padding:1.2rem 1.4rem;border-radius:8px;overflow-x:auto;font-size:.875rem;line-height:1.65;background:var(--color-bg-code);border:1px solid var(--color-border)}.post-content pre code{background:0 0;padding:0;border-radius:0;font-size:inherit}.post-content pre.giallo code{counter-reset:line}.giallo-l{display:inline-block;min-height:1lh;width:100%;counter-increment:line;background:0 0!important}pre.giallo{background-color:var(--color-bg-code)!important}.giallo-l::before{content:counter(line);display:inline-block;width:2.5ch;margin-right:1.2em;text-align:right;color:#b0b0b0;font-size:.85em;user-select:none;pointer-events:none}.giallo-ln{display:inline-block;user-select:none;margin-right:.4em;padding:.4em;min-width:3ch;text-align:right;opacity:.8}.post-content .mermaid{margin:1.6rem 0;padding:1.2rem 1.4rem;border-radius:8px;background:var(--color-bg-code);border:1px solid var(--color-border);text-align:center;overflow-x:auto}.post-content .mermaid svg{min-width:540px}.post-footer{margin-top:4rem;padding-top:2rem;border-top:1px solid var(--color-border)}.back-link{font-size:.88rem;font-weight:500;color:var(--color-text-muted);transition:color .2s}.back-link:hover{color:var(--color-text)}.post-nav{display:flex;justify-content:space-between;gap:2rem;margin-top:2rem;padding-top:1.5rem;border-top:1px solid var(--color-border)}.post-nav-link{display:flex;flex-direction:column;gap:.25rem;max-width:48%;transition:color .2s}.post-nav-link:hover{color:var(--color-text)}.post-nav-prev{align-items:flex-end;text-align:right;margin-left:auto}.post-nav-label{font-size:.75rem;font-weight:500;letter-spacing:.08em;text-transform:uppercase;color:var(--color-text-muted)}.post-nav-title{font-family:var(--font-serif);font-size:.95rem;font-weight:500;line-height:1.4;color:var(--color-text-secondary)}.post-nav-link:hover .post-nav-title{color:var(--color-text)}footer{padding:2.5rem 8vw;display:flex;justify-content:space-between;align-items:center}.footer-logo{font-family:var(--font-serif);font-size:1rem;font-weight:700}.footer-copy{font-size:.72rem;color:var(--color-text-muted);letter-spacing:.05em;margin-top:.25rem}.footer-links{display:flex;gap:1.5rem}.footer-links a{font-size:.78rem;color:var(--color-text-muted);letter-spacing:.04em;transition:color .25s}.footer-links a:hover{color:var(--color-text)}@media(max-width:600px){:root{--content-padding:1.5rem}main{padding:0 1rem}.site-nav{padding:.85rem 5vw;flex-direction:column;gap:.5rem;text-align:center}.nav-logo{font-size:1.05rem;justify-content:center}.nav-right{gap:1.2rem;justify-content:center;flex-wrap:wrap}.blog-header{padding-top:3rem}.blog-title{font-size:2rem}.post-list{padding-bottom:4rem}.post{padding-top:3rem;padding-bottom:3rem}.post-title{font-size:1.7rem}.post-content{font-size:1rem}.post-content pre{padding:1rem 1.1rem;font-size:.82rem;border-radius:6px}.toc-list{columns:1}footer{flex-direction:column;gap:1.5rem;text-align:center}.footer-links{justify-content:center}}