:root,[data-theme=light]{--bg: #f8f9fc;--bg-card: #ffffff;--text: #1a1d24;--text-muted: #5c6370;--border: #e2e6ee;--accent: #2563eb;--accent-hover: #1d4ed8;--accent-soft: #eef2ff;--tag-bg: #eef2ff;--tag-text: #3730a3;--shadow: 0 1px 3px rgba(0,0,0,.06);--shadow-lg: 0 4px 20px rgba(0,0,0,.08)}[data-theme=dark]{--bg: #0d0e12;--bg-card: #16181d;--text: #e6e9ef;--text-muted: #8b92a0;--border: #2a2d36;--accent: #60a5fa;--accent-hover: #93c5fd;--accent-soft: #1e293b;--tag-bg: #1e293b;--tag-text: #93c5fd;--shadow: 0 1px 3px rgba(0,0,0,.3);--shadow-lg: 0 4px 20px rgba(0,0,0,.4)}[data-theme=sepia]{--bg: #f4ecd8;--bg-card: #fdfbf7;--text: #2c2416;--text-muted: #6b5d4a;--border: #e5dcc8;--accent: #b45309;--accent-hover: #92400e;--accent-soft: #fef3c7;--tag-bg: #fef3c7;--tag-text: #92400e;--shadow: 0 1px 3px rgba(44,36,22,.08);--shadow-lg: 0 4px 20px rgba(44,36,22,.12)}[data-theme=terminal]{--bg: #0c0e0f;--bg-card: #131617;--text: #a8b5a0;--text-muted: #6b7a63;--border: #252a2d;--accent: #7ec699;--accent-hover: #9dd4b0;--accent-soft: #1a2320;--tag-bg: #1a2320;--tag-text: #7ec699;--shadow: 0 1px 3px rgba(0,0,0,.5);--shadow-lg: 0 4px 20px rgba(0,0,0,.5)}html{scroll-behavior:smooth}body{font-family:DM Sans,system-ui,sans-serif;background:var(--bg);color:var(--text);line-height:1.7;margin:0;min-height:100vh;display:flex;flex-direction:column}.page-wrap{flex:1;max-width:680px;margin:0 auto;width:100%;padding:0 1.25rem 3rem;box-sizing:border-box}.site-header{background:var(--bg-card);border-bottom:1px solid var(--border);padding:.75rem 1.25rem;position:sticky;top:0;z-index:10;box-shadow:var(--shadow)}.site-header-inner{max-width:680px;margin:0 auto;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:.75rem}.site-title{font-size:1.1rem;font-weight:700;margin:0}.site-title a{color:var(--text);text-decoration:none;letter-spacing:-.02em}.site-title a:hover{color:var(--accent)}.nav-links{display:flex;gap:.25rem;align-items:center}.nav-links a{color:var(--text-muted);text-decoration:none;font-size:.95rem;padding:.4rem .65rem;border-radius:6px;transition:color .15s,background .15s}.nav-links a:hover{color:var(--accent);background:var(--accent-soft)}.theme-picker{position:relative}.theme-picker-btn{display:flex;align-items:center;gap:.35rem;padding:.4rem .65rem;font-size:.9rem;color:var(--text-muted);background:transparent;border:1px solid var(--border);border-radius:6px;cursor:pointer;font-family:inherit;transition:color .15s,background .15s,border-color .15s}.theme-picker-btn:hover{color:var(--text);background:var(--accent-soft);border-color:var(--accent)}.theme-picker-btn svg{width:1em;height:1em;opacity:.8}.theme-dropdown{position:absolute;top:100%;right:0;margin-top:.25rem;min-width:140px;background:var(--bg-card);border:1px solid var(--border);border-radius:8px;box-shadow:var(--shadow-lg);padding:.35rem;display:none}.theme-picker.open .theme-dropdown{display:block}.theme-option{display:flex;align-items:center;gap:.5rem;width:100%;padding:.5rem .65rem;border:none;border-radius:6px;background:transparent;color:var(--text);font-size:.9rem;font-family:inherit;cursor:pointer;text-align:left;transition:background .15s}.theme-option:hover{background:var(--accent-soft)}.theme-option[aria-pressed=true]{background:var(--accent-soft);color:var(--accent);font-weight:500}.theme-option .swatch{width:14px;height:14px;border-radius:50%;flex-shrink:0}.theme-option[data-theme=light] .swatch{background:linear-gradient(135deg,#f8f9fc 50%,#e2e6ee 50%)}.theme-option[data-theme=dark] .swatch{background:#16181d;border:1px solid #2a2d36}.theme-option[data-theme=sepia] .swatch{background:#f4ecd8;border:1px solid #e5dcc8}.theme-option[data-theme=terminal] .swatch{background:#131617;border:1px solid #7ec699}main{padding-top:2rem}.hero{margin-bottom:.5rem}.hero .hero-desc{font-size:1.05rem;color:var(--text-muted);margin:0;max-width:32em}h1{font-size:1.85rem;font-weight:700;letter-spacing:-.02em;margin:0 0 .5rem;line-height:1.3}h2{font-size:1.35rem;font-weight:600;margin:2rem 0 .75rem}h3{font-size:1.15rem;font-weight:600;margin:1.5rem 0 .5rem}p{margin:0 0 1rem}a{color:var(--accent);text-decoration:none}a:hover{color:var(--accent-hover);text-decoration:underline}.muted,time,.text-muted{color:var(--text-muted);font-size:.9rem}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:10px;padding:1.25rem;box-shadow:var(--shadow)}.post-list{list-style:none;padding:0;margin:0}.post-list>li{margin-bottom:0}.post-item{padding:1rem 0;border-bottom:1px solid var(--border);display:flex;flex-wrap:wrap;align-items:baseline;gap:.5rem}.post-item:last-child{border-bottom:none}.post-item[hidden]{display:none}.post-item a{font-weight:600;color:var(--text)}.post-item a:hover{color:var(--accent);text-decoration:none}.post-item time{flex-shrink:0}.tag{font-size:.8rem;padding:.2rem .55rem;border-radius:999px;background:var(--tag-bg);color:var(--tag-text);text-decoration:none;font-weight:500}.tag:hover{opacity:.9;text-decoration:none}.tags{display:flex;flex-wrap:wrap;gap:.25rem}.search-box{margin-bottom:1.5rem}.search-box input{width:100%;max-width:340px;padding:.6rem .9rem;border:1px solid var(--border);border-radius:8px;background:var(--bg-card);color:var(--text);font-size:1rem;font-family:inherit;transition:border-color .15s,box-shadow .15s}.search-box input::placeholder{color:var(--text-muted)}.search-box input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.search-results{margin-top:.5rem;color:var(--text-muted);font-size:.9rem}.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.toc{margin:1.5rem 0;padding:1.25rem;background:var(--accent-soft);border:1px solid var(--border);border-radius:10px}.toc-title{font-size:.85rem;margin:0 0 .6rem;color:var(--text-muted);font-weight:600;text-transform:uppercase;letter-spacing:.04em}.toc-list{list-style:none;padding:0;margin:0;font-size:.9rem}.toc-list li{margin-bottom:.4rem}.toc-list a{color:var(--text)}.toc-list a:hover{color:var(--accent);text-decoration:none}.toc-level-3{padding-left:1rem}code{font-family:JetBrains Mono,ui-monospace,monospace;font-size:.9em}:not(pre)>code{padding:.15em .45em;border-radius:5px;background:var(--tag-bg);color:var(--tag-text)}pre{overflow-x:auto;padding:1rem 1.25rem;border-radius:8px;border:1px solid var(--border);font-size:.875rem;line-height:1.5;background:var(--bg-card);box-shadow:var(--shadow)}pre code{padding:0;background:none;color:inherit}.site-footer{margin-top:auto;padding:1.5rem 1.25rem;border-top:1px solid var(--border);color:var(--text-muted);font-size:.9rem;background:var(--bg-card)}.site-footer a{color:var(--accent)}.site-footer a:hover{text-decoration:underline}.article-card{padding:1.5rem 1.5rem 2rem}.article-header{margin-bottom:1rem}.article-header h1{margin-bottom:.35rem}.article-meta{margin:0 0 .5rem}.article-tags{margin:0}.article-card [itemprop=articleBody]{margin-top:1.5rem}.article-card [itemprop=articleBody] h2{padding-top:.25rem}.article-card [itemprop=articleBody] ul{padding-left:1.5rem;margin:0 0 1rem}.article-card [itemprop=articleBody] li{margin-bottom:.35rem}
