*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}:root{--color-bg:#F5F2ED;--color-bg-alt:#EBE7E0;--color-text:#1A1A1A;--color-text-secondary:#555;--color-text-muted:#888;--color-accent:#1A1A1A;--color-border:#D5D0C8;--color-border-light:#E5E1DA;--color-link:#1A1A1A;--color-link-hover:#444;--font-zh:'Noto Sans TC', sans-serif;--font-heading:'Outfit', var(--font-zh);--font-mono:'JetBrains Mono', monospace;--max-width:845px;--max-width-wide:1085px;--line-height:1.8;--spacing-unit:1rem}html{font-size:17px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-zh);line-height:var(--line-height);color:var(--color-text);background-color:var(--color-bg);max-width:100%;overflow-x:hidden}h1,h2,h3,h4,h5,h6{font-family:var(--font-heading);font-weight:600;line-height:1.3;letter-spacing:-.01em}h1{font-size:2rem;margin-bottom:1rem}h2{font-size:1.5rem;margin-top:2.5rem;margin-bottom:.75rem}h3{font-size:1.2rem;margin-top:2rem;margin-bottom:.5rem}p{margin-bottom:1rem;max-width:75ch}a{color:var(--color-link);text-decoration-thickness:1px;text-underline-offset:3px;transition:color .15s ease}a:hover{color:var(--color-link-hover)}strong{font-weight:600}code{font-family:var(--font-mono);font-size:.9em;background:var(--color-bg-alt);padding:.15em .4em;border-radius:3px}pre{background:var(--color-text);color:var(--color-bg);padding:1.25rem;overflow-x:auto;margin:1.5rem 0;border-radius:2px;font-family:var(--font-mono);font-size:.85rem;line-height:1.6}pre code{background:0 0;padding:0;color:inherit}blockquote{border-left:3px solid var(--color-text);padding-left:1.25rem;margin:1.5rem 0;color:var(--color-text-secondary);font-style:normal}hr{border:none;border-top:1px solid var(--color-border);margin:2.5rem 0}ul,ol{padding-left:1.5rem;margin-bottom:1rem}li{margin-bottom:.35rem}img{max-width:100%;height:auto;display:block}main{max-width:var(--max-width);margin:0 auto;padding:3rem 1.5rem 4rem}header[role=banner]{border-bottom:1px solid var(--color-border)}.site-nav{max-width:var(--max-width-wide);margin:0 auto;padding:1rem 1.5rem;display:flex;align-items:center;justify-content:space-between}.site-logo{font-family:var(--font-heading);font-weight:700;font-size:1.5rem;text-decoration:none;color:var(--color-text);letter-spacing:-.02em}.nav-links{list-style:none;display:flex;gap:2rem;padding:0;margin:0}.nav-links a{text-decoration:none;font-size:.9rem;color:var(--color-text-secondary);font-family:var(--font-zh)}.nav-links a:hover,.nav-links a[aria-current=page]{color:var(--color-text)}.nav-toggle{display:none;background:0 0;border:none;cursor:pointer;width:24px;height:20px;position:relative}.nav-toggle span{display:block;width:100%;height:2px;background:var(--color-text);position:absolute;left:0;transition:transform .2s ease}.nav-toggle span:first-child{top:2px}.nav-toggle span:last-child{bottom:2px}.home-intro{padding:2rem 0 3rem}.home-intro h1{font-size:2.25rem;max-width:16ch;line-height:1.35}.home-subtitle{color:var(--color-text-secondary);font-size:1.05rem;margin-top:1rem;line-height:1.9}.home-framework{padding:2.5rem 0;border-top:1px solid var(--color-border)}.home-framework h2{margin-top:0;margin-bottom:1.5rem;font-family:var(--font-heading)}.framework-list{display:grid;gap:0}.framework-item{padding:1.25rem 0;border-bottom:1px solid var(--color-border-light)}.framework-item:last-child{border-bottom:none}.framework-item dt{font-weight:600;font-size:1.05rem;margin-bottom:.35rem;font-family:var(--font-heading)}.framework-letter{font-family:var(--font-mono);font-weight:500;margin-right:.5rem;font-size:.9em}.framework-item dd{color:var(--color-text-secondary);max-width:60ch}.home-latest{padding:2.5rem 0;border-top:1px solid var(--color-border)}.home-latest h2{margin-top:0;margin-bottom:1.5rem}.view-all{margin-top:1.5rem}.view-all a{font-size:.9rem;color:var(--color-text-secondary)}.post-list{list-style:none;padding:0;margin:0}.post-item{padding:1.25rem 0;border-bottom:1px solid var(--color-border-light)}.post-item:last-child{border-bottom:none}.post-item-inner{display:flex;gap:1.25rem;align-items:flex-start}.post-thumbnail{flex-shrink:0;width:180px}.post-thumbnail a{display:block}.post-thumbnail img{width:100%;height:120px;object-fit:cover;border-radius:2px;border:1px solid var(--color-border-light)}.post-content{flex:1;min-width:0}.post-item time{font-family:var(--font-mono);font-size:.8rem;color:var(--color-text-muted)}.post-category{font-size:.8rem;color:var(--color-text-muted);margin-left:.75rem;font-family:var(--font-mono)}.post-item h2,.post-item h3{margin:.3rem 0 .25rem;font-size:1.15rem}.post-item h2 a,.post-item h3 a{text-decoration:none}.post-item h2 a:hover,.post-item h3 a:hover{text-decoration:underline;text-decoration-thickness:1px;text-underline-offset:3px}.post-item p{color:var(--color-text-secondary);font-size:.95rem;margin-bottom:0}.article-cover{margin-bottom:2rem}.article-cover img{width:100%;border-radius:2px;border:1px solid var(--color-border-light)}.tag-list,.tag-list-inline{list-style:none;padding:0;display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.75rem}.tag-list a,.tag-list-inline a{font-size:.8rem;font-family:var(--font-mono);color:var(--color-text-muted);text-decoration:none;border:1px solid var(--color-border);padding:.15rem .5rem;border-radius:2px}.tag-list a:hover,.tag-list-inline a:hover{color:var(--color-text);border-color:var(--color-text)}.tag-cloud{list-style:none;padding:0;display:flex;flex-wrap:wrap;gap:.75rem}.tag-cloud a{font-size:.95rem;text-decoration:none;border:1px solid var(--color-border);padding:.35rem .75rem;border-radius:2px}.tag-cloud a:hover{border-color:var(--color-text)}.tag-count{font-family:var(--font-mono);font-size:.8em;color:var(--color-text-muted)}.filter-nav{margin-bottom:2rem;border-bottom:1px solid var(--color-border);padding-bottom:1rem}.filter-nav ul{list-style:none;padding:0;display:flex;gap:1.5rem}.filter-nav a{text-decoration:none;font-size:.9rem;color:var(--color-text-muted)}.filter-nav a:hover,.filter-nav a[aria-current=page]{color:var(--color-text)}.article-header{margin-bottom:2.5rem;padding-bottom:1.5rem;border-bottom:1px solid var(--color-border)}.article-header time{font-family:var(--font-mono);font-size:.85rem;color:var(--color-text-muted)}.article-header h1{margin-top:.5rem;font-size:2rem;max-width:20ch}.article-description{color:var(--color-text-secondary);font-size:1.1rem;margin-top:.5rem}.article-body{font-size:1rem;line-height:var(--line-height)}.article-body h2{margin-top:3rem}.article-body h3{margin-top:2rem}.article-body ul,.article-body ol{margin-bottom:1.25rem}.article-footer{margin-top:3rem;padding-top:1.5rem;border-top:1px solid var(--color-border);font-size:.9rem;color:var(--color-text-muted)}.article-nav{display:flex;justify-content:space-between;margin-top:2rem;padding-top:1.5rem;border-top:1px solid var(--color-border-light);font-size:.9rem}.article-nav a{color:var(--color-text-secondary);text-decoration:none;max-width:45%}.article-nav a:hover{color:var(--color-text)}.page-header{margin-bottom:2rem}.page-description{color:var(--color-text-secondary);font-size:1.05rem}.page-body h2{margin-top:3rem}.page-body h3{margin-top:2rem}.list-header{margin-bottom:2rem}.list-header p{color:var(--color-text-secondary)}footer[role=contentinfo]{border-top:1px solid var(--color-border);margin-top:4rem}.footer-inner{max-width:var(--max-width-wide);margin:0 auto;padding:2.5rem 1.5rem;display:grid;grid-template-columns:1fr 1fr 1fr;gap:2rem}.footer-logo{font-family:var(--font-heading);font-weight:700;font-size:1.35rem;margin-bottom:.25rem}.footer-tagline{font-family:var(--font-mono);font-size:.85rem;color:var(--color-text-muted)}.footer-links ul{list-style:none;padding:0}.footer-links a{font-size:.9rem;color:var(--color-text-secondary);text-decoration:none}.footer-links a:hover{color:var(--color-text)}.footer-links li{margin-bottom:.4rem}.footer-meta address{font-style:normal;font-size:.9rem;margin-bottom:1rem}.footer-meta a{color:var(--color-text-secondary)}.footer-machine-links{list-style:none;padding:0;display:flex;gap:1rem}.footer-machine-links a{font-family:var(--font-mono);font-size:.8rem;color:var(--color-text-muted);text-decoration:none;border:1px solid var(--color-border);padding:.2rem .5rem;border-radius:2px}.footer-machine-links a:hover{color:var(--color-text);border-color:var(--color-text)}.footer-copyright{max-width:var(--max-width-wide);margin:0 auto;padding:0 1.5rem 2rem;font-size:.8rem;color:var(--color-text-muted)}@media(max-width:768px){html{font-size:16px}main{padding:2rem 1.25rem 3rem}.home-intro h1{font-size:1.75rem}.article-header h1{font-size:1.6rem}h1{font-size:1.6rem}h2{font-size:1.3rem}.footer-inner{grid-template-columns:1fr;gap:1.5rem}.nav-links{display:none;flex-direction:column;position:absolute;top:100%;left:0;right:0;background:var(--color-bg);padding:1rem 1.5rem 1.5rem;border-bottom:1px solid var(--color-border);gap:.75rem}.nav-links.is-open{display:flex}.nav-toggle{display:block}.site-nav{position:relative}.post-item-inner{flex-direction:column}.post-thumbnail{width:100%}.post-thumbnail img{height:180px}.article-nav{flex-direction:column;gap:1rem}.article-nav a{max-width:100%}.footer-machine-links{flex-wrap:wrap}}@media(max-width:480px){main{padding:1.5rem 1rem 2.5rem}.home-intro h1{font-size:1.5rem}.filter-nav ul{gap:1rem}}