:root{--bg-primary: #0a0a0b;--bg-secondary: #111113;--bg-tertiary: #1a1a1e;--border: #2a2a2e;--border-light: #333338;--text-primary: #eeeeef;--text-secondary: #8e8e93;--text-tertiary: #636366;--accent: #d4a843;--accent-dim: #b8922e;--accent-glow: rgba(212, 168, 67, .15);--font-sans: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-mono: "JetBrains Mono", "Fira Code", monospace;--max-width: 680px;--transition: .15s ease}*{margin:0;padding:0;box-sizing:border-box}html{font-size:16px;scroll-behavior:smooth;-webkit-font-smoothing:antialiased}body{background:var(--bg-primary);color:var(--text-primary);font-family:var(--font-sans);line-height:1.7;min-height:100vh}a{color:var(--accent);text-decoration:none;transition:color var(--transition)}a:hover{color:var(--text-primary)}.container{max-width:var(--max-width);margin:0 auto;padding:0 1.5rem}.site-header{border-bottom:1px solid var(--border);padding:1.5rem 0;margin-bottom:3rem}.site-header nav{display:flex;align-items:center;justify-content:space-between;max-width:var(--max-width);margin:0 auto;padding:0 1.5rem}.site-title{font-size:1rem;font-weight:600;color:var(--text-primary);letter-spacing:-.02em}.site-title .fairy{color:var(--accent)}.nav-links{display:flex;gap:1.5rem;list-style:none;font-size:.875rem}.nav-links a{color:var(--text-secondary);transition:color var(--transition)}.nav-links a:hover{color:var(--text-primary)}.lang-switch{font-size:.75rem;padding:.25rem .5rem;border:1px solid var(--border);border-radius:4px;color:var(--text-secondary);transition:all var(--transition)}.lang-switch:hover{border-color:var(--accent);color:var(--accent)}.post-list{list-style:none;display:flex;flex-direction:column;gap:.25rem}.post-item{display:flex;align-items:baseline;gap:1rem;padding:.75rem 0;border-bottom:1px solid var(--border);transition:background var(--transition)}.post-item:last-child{border-bottom:none}.post-date{font-size:.8125rem;color:var(--text-tertiary);font-family:var(--font-mono);flex-shrink:0;min-width:5.5rem}.post-title-link{color:var(--text-primary);font-weight:500;font-size:.9375rem;letter-spacing:-.01em}.post-title-link:hover{color:var(--accent)}.post-lang-badge{font-size:.6875rem;color:var(--text-tertiary);border:1px solid var(--border);border-radius:3px;padding:.1rem .35rem;flex-shrink:0}.post-header{margin-bottom:2.5rem}.post-header h1{font-size:1.75rem;font-weight:700;letter-spacing:-.03em;line-height:1.3;margin-bottom:.75rem}.post-meta{font-size:.8125rem;color:var(--text-tertiary);font-family:var(--font-mono)}.prose h2{font-size:1.25rem;font-weight:600;margin-top:2.5rem;margin-bottom:.75rem;letter-spacing:-.02em}.prose h3{font-size:1.0625rem;font-weight:600;margin-top:2rem;margin-bottom:.5rem}.prose p{margin-bottom:1.25rem;color:var(--text-primary)}.prose ul,.prose ol{margin-bottom:1.25rem;padding-left:1.5rem}.prose li{margin-bottom:.375rem}.prose blockquote{border-left:2px solid var(--accent);padding-left:1rem;color:var(--text-secondary);font-style:italic;margin:1.5rem 0}.prose code{font-family:var(--font-mono);font-size:.875em;background:var(--bg-tertiary);padding:.15rem .4rem;border-radius:4px;color:var(--accent)}.prose pre{background:var(--bg-secondary);border:1px solid var(--border);border-radius:6px;padding:1.25rem;overflow-x:auto;margin:1.5rem 0;font-size:.875rem;line-height:1.6}.prose pre code{background:none;padding:0;color:var(--text-primary)}.prose hr{border:none;border-top:1px solid var(--border);margin:2.5rem 0}.prose img{max-width:100%;border-radius:6px;border:1px solid var(--border);margin:1.5rem 0}.prose strong{color:var(--text-primary);font-weight:600}.prose em{color:var(--text-secondary)}.site-footer{margin-top:4rem;padding:2rem 0;border-top:1px solid var(--border);text-align:center;font-size:.8125rem;color:var(--text-tertiary)}.site-footer .fairy-sig{color:var(--accent)}.page-title{font-size:1.5rem;font-weight:700;letter-spacing:-.03em;margin-bottom:.5rem}.page-desc{color:var(--text-secondary);font-size:.9375rem;margin-bottom:2.5rem}.back-link{display:inline-block;margin-bottom:2rem;font-size:.8125rem;color:var(--text-tertiary)}.back-link:hover{color:var(--accent)}@media(max-width:640px){.post-item{flex-direction:column;gap:.25rem}.post-date{min-width:auto}.post-header h1{font-size:1.5rem}}
