@import"https://fonts.googleapis.com/css2?family=IBM+Plex+Mono:ital,wght@0,400;0,600;0,700;1,400&family=Noto+Serif+SC:wght@400;700&display=swap";:root{--c-bg: #0a0e17;--c-bg-raised: #111827;--c-bg-card: #151c2c;--c-surface: #1c2538;--c-border: #2a3548;--c-text: #e2e8f0;--c-text-dim: #8896ab;--c-accent: #f0b429;--c-accent-dim: #c49a22;--c-code-bg: #0d1321;--c-hero-strong: #ffffff;--font-mono: "IBM Plex Mono", "Menlo", "Consolas", monospace;--font-serif: "Noto Serif SC", "Songti SC", "SimSun", serif;--font-sans: -apple-system, "Helvetica Neue", "PingFang SC", sans-serif;--s-xs: .25rem;--s-sm: .5rem;--s-md: 1rem;--s-lg: 1.5rem;--s-xl: 2rem;--s-2xl: 3rem;--s-3xl: 4rem;--s-4xl: 6rem;--max-w: 720px;--max-w-wide: 1100px;--nav-h: 60px;--grain-opacity: .035;--grid-opacity: .15;--glow-opacity: .06}[data-theme=light]{--c-bg: #faf9f6;--c-bg-raised: #ffffff;--c-bg-card: #ffffff;--c-surface: #f0ede6;--c-border: #d8d3c9;--c-text: #1c1917;--c-text-dim: #78716c;--c-accent: #b45309;--c-accent-dim: #92400e;--c-code-bg: #f5f0e8;--c-code-text: #7c2d12;--c-hero-strong: #1c1917;--grain-opacity: .015;--grid-opacity: .06;--glow-opacity: .03}[data-theme=light] .prose code{color:var(--c-code-text);background:var(--c-code-bg);border-color:#e7e0d4}[data-theme=light] .prose pre{background:#1c1917;border-color:#292524}[data-theme=light] .prose pre code{color:#e7e5e4;background:none;border:none}[data-theme=light] .prose blockquote{background:#b453090a;border-left-color:var(--c-accent)}[data-theme=light] .prose strong{color:#1c1917}[data-theme=light] .prose a{color:var(--c-accent);border-bottom-color:transparent}[data-theme=light] .prose a:hover{border-bottom-color:var(--c-accent)}[data-theme=light] .prose hr{background:var(--c-border)}[data-theme=light] .prose table{border-color:var(--c-border)}[data-theme=light] .post-card:hover{border-color:var(--c-accent-dim)}[data-theme=light] .hero-cta{color:var(--c-accent);border-color:var(--c-accent)}[data-theme=light] .hero-cta:hover{background:var(--c-accent);color:#fff}[data-theme=light] .tag,[data-theme=light] .stack-item{color:var(--c-text-dim);border-color:var(--c-border)}[data-theme=light] .reading-progress,[data-theme=light] #reading-progress{background:var(--c-accent);box-shadow:0 0 6px #b453094d}[data-theme=light] .article-header{border-bottom-color:var(--c-border)}[data-theme=light] .article-title{color:var(--c-hero-strong)}[data-theme=light] ::selection{background:#b4530926;color:#1c1917}[data-theme=light] .footer{border-top-color:var(--c-border)}[data-theme=light] .about-section h2{border-bottom-color:var(--c-border)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:17px;scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-serif);color:var(--c-text);background-color:var(--c-bg);line-height:1.8;min-height:100vh;position:relative;transition:background-color .3s ease,color .3s ease}body:before{content:"";position:fixed;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:9999;opacity:var(--grain-opacity);background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)'/%3E%3C/svg%3E");background-repeat:repeat;background-size:256px 256px}#reading-progress{position:fixed;top:0;left:0;width:0%;height:2px;background:var(--c-accent);z-index:10001;transition:width .1s linear;box-shadow:0 0 8px #f0b42966}.theme-toggle{background:none;border:1px solid var(--c-border);cursor:pointer;padding:4px 8px;border-radius:4px;color:var(--c-text-dim);font-family:var(--font-mono);font-size:.75rem;letter-spacing:.03em;transition:all .2s;display:flex;align-items:center;gap:6px}.theme-toggle:hover{border-color:var(--c-accent);color:var(--c-accent)}.theme-toggle-icon{font-size:.9rem;line-height:1}.nav{position:sticky;top:0;z-index:1000;height:var(--nav-h);display:flex;align-items:center;justify-content:space-between;padding:0 var(--s-xl);background:#0a0e17bf;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid var(--c-border);transition:background .3s,border-color .3s}[data-theme=light] .nav{background:#f8f6f1cc}.nav-logo{font-family:var(--font-mono);font-size:1rem;font-weight:700;color:var(--c-text);text-decoration:none;letter-spacing:-.02em;transition:color .2s}.nav-logo:hover,.nav-logo span{color:var(--c-accent)}.nav-links{display:flex;gap:var(--s-lg);list-style:none;align-items:center}.nav-link{font-family:var(--font-mono);font-size:.8rem;font-weight:400;color:var(--c-text-dim);text-decoration:none;text-transform:uppercase;letter-spacing:.08em;padding:var(--s-xs) 0;position:relative;transition:color .2s}.nav-link:after{content:"";position:absolute;bottom:-2px;left:0;width:0;height:1px;background:var(--c-accent);transition:width .25s ease}.nav-link:hover,.nav-link.active{color:var(--c-text)}.nav-link.active:after,.nav-link:hover:after{width:100%}.nav-toggle{display:none;background:none;border:none;cursor:pointer;padding:var(--s-sm)}.nav-toggle span{display:block;width:20px;height:1.5px;background:var(--c-text);margin:4px 0;transition:all .3s}@media(max-width:640px){.nav-toggle{display:block}.nav-links{display:none;position:absolute;top:var(--nav-h);left:0;right:0;flex-direction:column;padding:var(--s-lg) var(--s-xl);gap:var(--s-md);border-bottom:1px solid var(--c-border)}.nav-links.open{display:flex}.nav{background:var(--c-bg)}}main{min-height:calc(100vh - var(--nav-h) - 80px)}.hero{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:calc(100vh - var(--nav-h));text-align:center;padding:var(--s-4xl) var(--s-xl);position:relative;overflow:hidden}.hero:before{content:"";position:absolute;top:0;left:0;width:100%;height:100%;background-image:linear-gradient(var(--c-border) 1px,transparent 1px),linear-gradient(90deg,var(--c-border) 1px,transparent 1px);background-size:60px 60px;opacity:var(--grid-opacity);animation:gridDrift 20s linear infinite;transition:opacity .3s}@keyframes gridDrift{0%{transform:translate(0)}to{transform:translate(60px,60px)}}.hero:after{content:"";position:absolute;top:50%;left:50%;width:600px;height:600px;transform:translate(-50%,-50%);background:radial-gradient(circle,rgba(240,180,41,var(--glow-opacity)) 0%,transparent 70%);pointer-events:none}.hero-title{font-family:var(--font-serif);font-size:3.5rem;font-weight:700;line-height:1.2;letter-spacing:.02em;margin-bottom:var(--s-lg);position:relative;z-index:1}.hero-subtitle{font-family:var(--font-mono);font-size:.95rem;color:var(--c-text-dim);max-width:500px;line-height:1.8;margin-bottom:var(--s-2xl);position:relative;z-index:1}.hero-cta{font-family:var(--font-mono);font-size:.85rem;color:var(--c-accent);text-decoration:none;border:1px solid var(--c-accent);padding:var(--s-sm) var(--s-xl);letter-spacing:.05em;text-transform:uppercase;transition:all .25s;position:relative;z-index:1}.hero-cta:hover{background:var(--c-accent);color:var(--c-bg)}@media(max-width:640px){.hero-title{font-size:2.2rem}.hero{min-height:70vh}}.blog-listing{max-width:var(--max-w-wide);margin:0 auto;padding:var(--s-3xl) var(--s-xl)}.blog-listing-header{margin-bottom:var(--s-3xl)}.blog-listing-title{font-family:var(--font-mono);font-size:.8rem;color:var(--c-text-dim);text-transform:uppercase;letter-spacing:.15em}.post-card{display:grid;grid-template-columns:1fr;gap:var(--s-sm);padding:var(--s-xl) 0;border-bottom:1px solid var(--c-border);text-decoration:none;color:inherit;transition:all .25s;animation:fadeSlideUp .5s ease both}.post-card:nth-child(2){animation-delay:.05s}.post-card:nth-child(3){animation-delay:.1s}.post-card:nth-child(4){animation-delay:.15s}.post-card:nth-child(5){animation-delay:.2s}.post-card:nth-child(6){animation-delay:.25s}.post-card:first-child{border-top:1px solid var(--c-border)}.post-card:hover{padding-left:var(--s-md);border-color:var(--c-accent-dim)}.post-card-date{font-family:var(--font-mono);font-size:.75rem;color:var(--c-text-dim);letter-spacing:.05em}.post-card-title{font-family:var(--font-serif);font-size:1.5rem;font-weight:700;line-height:1.4;margin:var(--s-xs) 0;transition:color .2s}.post-card:hover .post-card-title{color:var(--c-accent)}.post-card-desc{font-size:.95rem;color:var(--c-text-dim);line-height:1.6}.post-card-tags{display:flex;gap:var(--s-sm);flex-wrap:wrap;margin-top:var(--s-sm)}.tag{font-family:var(--font-mono);font-size:.7rem;color:var(--c-text-dim);border:1px solid var(--c-border);padding:2px 8px;letter-spacing:.03em}.article{max-width:var(--max-w);margin:0 auto;padding:var(--s-3xl) var(--s-xl) var(--s-4xl)}.article-header{margin-bottom:var(--s-3xl);padding-bottom:var(--s-xl);border-bottom:1px solid var(--c-border)}.article-title{font-family:var(--font-serif);font-size:2.4rem;font-weight:700;line-height:1.3;letter-spacing:.01em;margin-bottom:var(--s-md)}.article-meta{display:flex;align-items:center;gap:var(--s-md);flex-wrap:wrap}.article-date{font-family:var(--font-mono);font-size:.8rem;color:var(--c-text-dim);letter-spacing:.03em}.article-desc{font-size:1.05rem;color:var(--c-text-dim);margin-top:var(--s-md);line-height:1.7}.article-tags{display:flex;gap:var(--s-sm);flex-wrap:wrap;margin-top:var(--s-md)}.prose{font-size:1.05rem;line-height:1.85;color:var(--c-text)}.prose h2{font-family:var(--font-serif);font-size:1.6rem;font-weight:700;margin-top:var(--s-3xl);margin-bottom:var(--s-md);padding-top:var(--s-md);border-top:1px solid var(--c-border)}.prose h2:first-child{border-top:none;padding-top:0}.prose h3{font-family:var(--font-serif);font-size:1.3rem;font-weight:700;margin-top:var(--s-xl);margin-bottom:var(--s-sm)}.prose h4{font-family:var(--font-mono);font-size:.9rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;margin-top:var(--s-xl);margin-bottom:var(--s-sm);color:var(--c-accent)}.prose p{margin-bottom:var(--s-lg)}.prose a{color:var(--c-accent);text-decoration:none;border-bottom:1px solid transparent;transition:border-color .2s}.prose a:hover{border-bottom-color:var(--c-accent)}.prose strong{color:var(--c-hero-strong);font-weight:700}.prose em{font-style:italic;color:var(--c-text)}.prose ul,.prose ol{margin-bottom:var(--s-lg);padding-left:1.5rem}.prose ul{list-style:none}.prose ul li{position:relative;padding-left:1.2rem;margin-bottom:var(--s-sm)}.prose ul li:before{content:"—";position:absolute;left:0;color:var(--c-accent);font-weight:700}.prose ol li{margin-bottom:var(--s-sm)}.prose ol li::marker{font-family:var(--font-mono);color:var(--c-accent);font-weight:600}.prose code{font-family:var(--font-mono);font-size:.88em;background:var(--c-code-bg);border:1px solid var(--c-border);padding:2px 6px;border-radius:3px;color:var(--c-accent)}.prose pre{background:var(--c-code-bg);border:1px solid var(--c-border);border-radius:6px;padding:var(--s-lg);margin-bottom:var(--s-lg);overflow-x:auto;font-size:.88rem;line-height:1.7}.prose pre code{background:none;border:none;padding:0;color:var(--c-text)}.prose blockquote{border-left:3px solid var(--c-accent);padding:var(--s-sm) var(--s-lg);margin:var(--s-lg) 0;background:#f0b42908;border-radius:0 4px 4px 0}[data-theme=light] .prose blockquote{background:#c4841d0a}.prose blockquote p:last-child{margin-bottom:0}.prose table{width:100%;border-collapse:collapse;margin:var(--s-lg) 0;font-size:.92rem}.prose thead{border-bottom:2px solid var(--c-accent)}.prose th{font-family:var(--font-mono);font-size:.78rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;text-align:left;padding:var(--s-sm) var(--s-md);color:var(--c-text-dim)}.prose td{padding:var(--s-sm) var(--s-md);border-bottom:1px solid var(--c-border)}.prose tbody tr:hover{background:#f0b42905}.prose hr{border:none;height:1px;background:var(--c-border);margin:var(--s-3xl) 0}.prose img{max-width:100%;border-radius:6px;border:1px solid var(--c-border);margin:var(--s-lg) 0}.about{max-width:var(--max-w);margin:0 auto;padding:var(--s-3xl) var(--s-xl)}.about-title{font-family:var(--font-serif);font-size:2.4rem;font-weight:700;margin-bottom:var(--s-2xl)}.about-section{margin-bottom:var(--s-2xl)}.about-section h2{font-family:var(--font-mono);font-size:.8rem;text-transform:uppercase;letter-spacing:.15em;color:var(--c-accent);margin-bottom:var(--s-md);padding-bottom:var(--s-sm);border-bottom:1px solid var(--c-border)}.about-section p{line-height:1.85;color:var(--c-text);margin-bottom:var(--s-md)}.about-stack{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:var(--s-sm);margin-top:var(--s-md)}.stack-item{font-family:var(--font-mono);font-size:.82rem;color:var(--c-text-dim);padding:var(--s-sm) var(--s-md);border:1px solid var(--c-border);border-radius:4px;display:flex;align-items:center;gap:var(--s-sm)}.stack-item:before{content:"›";color:var(--c-accent);font-weight:700}.footer{max-width:var(--max-w-wide);margin:0 auto;padding:var(--s-xl);border-top:1px solid var(--c-border);display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:var(--s-sm)}.footer-text{font-family:var(--font-mono);font-size:.72rem;color:var(--c-text-dim);letter-spacing:.03em}.footer-link{font-family:var(--font-mono);font-size:.72rem;color:var(--c-text-dim);text-decoration:none;transition:color .2s}.footer-link:hover{color:var(--c-accent)}@keyframes fadeSlideUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.fade-in{animation:fadeSlideUp .5s ease both}@media(max-width:1024px){.hero-title{font-size:2.8rem}.about-stack{grid-template-columns:repeat(auto-fill,minmax(160px,1fr))}}@media(max-width:768px){.hero-title{font-size:2.4rem}.hero-subtitle{font-size:.9rem}.post-card-title{font-size:1.3rem}.article-title{font-size:2rem}.blog-listing{padding:var(--s-2xl) var(--s-lg)}}@media(max-width:640px){html{font-size:15px}.nav{padding:0 var(--s-lg)}.nav-links{display:none;position:absolute;top:var(--nav-h);left:0;right:0;flex-direction:column;padding:var(--s-lg) var(--s-xl);gap:var(--s-md);border-bottom:1px solid var(--c-border)}.nav-links.open{display:flex}.nav{background:var(--c-bg)}.hero{padding:var(--s-3xl) var(--s-lg);min-height:60vh}.hero-title{font-size:2rem}.hero-subtitle{font-size:.85rem;max-width:100%}.hero-cta{padding:var(--s-sm) var(--s-lg);font-size:.8rem}.article-title{font-size:1.7rem}.article{padding:var(--s-xl) var(--s-lg) var(--s-3xl)}.article-header{margin-bottom:var(--s-2xl);padding-bottom:var(--s-lg)}.blog-listing{padding:var(--s-xl) var(--s-lg)}.post-card{padding:var(--s-lg) 0}.post-card-title{font-size:1.2rem}.post-card-desc{font-size:.88rem}.about{padding:var(--s-xl) var(--s-lg)}.about-title{font-size:2rem}.about-stack{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:var(--s-xs)}.footer{padding:var(--s-lg);flex-direction:column;text-align:center}.prose h2{font-size:1.35rem}.prose h3{font-size:1.15rem}.prose pre{padding:var(--s-md);font-size:.82rem}.prose table{font-size:.85rem;display:block;overflow-x:auto}.prose ul,.prose ol{padding-left:1.2rem}.theme-toggle{padding:3px 6px;font-size:.7rem}}@media(max-width:380px){html{font-size:14px}.hero-title{font-size:1.8rem}.hero-cta{width:100%;text-align:center}.post-card-title{font-size:1.1rem}.tag{font-size:.65rem;padding:1px 6px}.stack-item{font-size:.75rem;padding:var(--s-xs) var(--s-sm)}}::selection{background:#f0b42940;color:#fff}[data-theme=light] ::selection{background:#c4841d33;color:#1a1a1a}.related-posts{margin-top:var(--s-3xl);padding-top:var(--s-2xl);border-top:1px solid var(--c-border)}.related-posts h2{font-size:1.2rem;margin-bottom:var(--s-lg);color:var(--c-text)}.related-list{display:flex;flex-direction:column;gap:var(--s-md)}.related-card{display:block;padding:var(--s-lg);border:1px solid var(--c-border);border-radius:6px;text-decoration:none;transition:border-color .2s}.related-card:hover{border-color:var(--c-accent)}.related-title{display:block;font-size:.95rem;font-weight:500;color:var(--c-text);margin-bottom:var(--s-xs)}.related-desc{display:block;font-size:.82rem;color:var(--c-text-dim);line-height:1.5}.latest{max-width:var(--max-w-wide);margin:0 auto;padding:var(--s-3xl) var(--s-xl) var(--s-4xl)}.latest-header{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:var(--s-2xl);padding-bottom:var(--s-md);border-bottom:1px solid var(--c-border)}.latest-title{font-family:var(--font-mono);font-size:.85rem;text-transform:uppercase;letter-spacing:.1em;color:var(--c-text-dim)}.latest-more{font-family:var(--font-mono);font-size:.8rem;color:var(--c-accent);text-decoration:none;transition:opacity .2s}.latest-more:hover{opacity:.7}.latest-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--s-lg)}.latest-card{display:flex;flex-direction:column;padding:var(--s-lg);border:1px solid var(--c-border);border-radius:6px;text-decoration:none;transition:border-color .25s,transform .25s}.latest-card:hover{border-color:var(--c-accent);transform:translateY(-2px)}.latest-card-date{font-family:var(--font-mono);font-size:.72rem;color:var(--c-text-dim);margin-bottom:var(--s-sm)}.latest-card-title{font-family:var(--font-serif);font-size:1rem;font-weight:600;color:var(--c-text);line-height:1.4;margin-bottom:var(--s-sm)}.latest-card-desc{font-size:.82rem;color:var(--c-text-dim);line-height:1.6;flex:1;margin-bottom:var(--s-md);display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.latest-card-tags{display:flex;flex-wrap:wrap;gap:var(--s-xs)}@media(max-width:1024px){.latest-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:640px){.latest{padding:var(--s-2xl) var(--s-lg) var(--s-3xl)}.latest-grid{grid-template-columns:1fr}.latest-card-title{font-size:.95rem}}.hero-label{font-family:var(--font-mono);font-size:.75rem;text-transform:uppercase;letter-spacing:.15em;color:var(--c-accent);margin-bottom:var(--s-md);position:relative;z-index:1}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:var(--c-bg)}::-webkit-scrollbar-thumb{background:var(--c-border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--c-text-dim)}.prose pre::-webkit-scrollbar{height:4px}.prose pre::-webkit-scrollbar-track{background:transparent}.prose pre::-webkit-scrollbar-thumb{background:#ffffff1f;border-radius:2px}.prose pre::-webkit-scrollbar-thumb:hover{background:#ffffff40}[data-theme=light] .prose pre::-webkit-scrollbar-thumb{background:#0000001f}[data-theme=light] .prose pre::-webkit-scrollbar-thumb:hover{background:#00000040}
