:root{color-scheme:light;--bg: #f8f7f3;--panel: #ffffff;--text: #1f2937;--muted: #6b7280;--accent: #0f766e;--line: #e5e7eb;--code-bg: #111827;--code-header: #1f2937;--code-text: #e5e7eb}*{box-sizing:border-box}body{margin:0;font-family:Avenir Next,Segoe UI,Helvetica,Arial,sans-serif;background:radial-gradient(circle at top right,#d1fae5 0%,var(--bg) 45%);color:var(--text)}.shell{max-width:1460px;margin:0 auto;padding:1.5rem}header{margin-bottom:1.25rem}.brand{display:inline-block;text-decoration:none;line-height:0}.brand img{display:block;height:auto;width:clamp(150px,23vw,220px)}.tagline{margin:.35rem 0 0;color:var(--muted)}main{background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:1.6rem}h1,h2,h3,h4{line-height:1.2}a{color:var(--accent)}.meta{color:var(--muted);font-size:.95rem}.tags{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:1rem}.tag{border:1px solid var(--line);border-radius:999px;padding:.2rem .6rem;text-decoration:none}article{max-width:100%}article>h1{margin:0;font-size:clamp(1.9rem,3.5vw,2.35rem)}article>h1+.meta{margin-top:.5rem;margin-bottom:1.3rem;border-bottom:1px solid var(--line);padding-bottom:.9rem}.post-content{font-size:1.05rem;line-height:1.75}.post-shell{display:grid;grid-template-columns:minmax(0,1fr) 270px;gap:1.4rem;align-items:start}.post-main{min-width:0;max-width:1120px}.post-toc{position:sticky;top:1rem;border:1px solid var(--line);border-radius:10px;padding:.85rem;background:#fbfbfb}.post-toc h2{margin:0;font-size:.95rem}.post-toc-header{display:flex;align-items:center;justify-content:space-between;gap:.5rem}.post-toc-toggle{border:1px solid var(--line);background:#fff;color:var(--muted);border-radius:6px;font-size:.73rem;padding:.18rem .42rem;cursor:pointer}.post-toc-toggle:hover{color:var(--text)}.post-toc ul{list-style:none;margin:.75rem 0 0;padding:0;display:flex;flex-direction:column;gap:.35rem}.post-toc li{margin:0}.post-toc a{color:var(--muted);font-size:.87rem;text-decoration:none}.post-toc a:hover{color:var(--accent)}.post-toc .toc-depth-3{padding-left:.7rem}.post-toc a.is-active{color:var(--accent);font-weight:650}.post-toc.toc-collapsed li.toc-overflow{display:none}.post-toc.toc-collapsed li.toc-overflow.toc-contains-active{display:block}.post-content>h1:first-child{display:none}.post-content h2,.post-content h3,.post-content h4{margin-top:1.8rem;margin-bottom:.7rem}.post-content p,.post-content ul,.post-content ol,.post-content blockquote,.post-content pre,.post-content table{margin-top:1rem;margin-bottom:1rem}.post-content img{display:block;width:min(100%,1080px);margin:1.2rem auto;border-radius:10px;border:1px solid var(--line);background:#f3f4f6}.post-content figure{margin:1.25rem 0}.post-content figure>img{margin:0 auto}.post-content figcaption{margin-top:.5rem;text-align:center;font-size:.86rem;color:var(--muted);line-height:1.4}.post-content table{width:100%;border-collapse:collapse;display:block;overflow-x:auto;white-space:nowrap;border:1px solid var(--line);border-radius:10px}.post-content th,.post-content td{border-bottom:1px solid var(--line);padding:.65rem .75rem;text-align:left;vertical-align:top}.post-content thead th{background:#f9fafb;font-weight:650}.post-content tr:last-child td{border-bottom:none}.post-content :not(pre)>code{background:#f3f4f6;border:1px solid var(--line);border-radius:6px;padding:.15rem .35rem;font-size:.93em;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-variant-ligatures:none}.post-content pre{margin:0;overflow:auto;padding:1rem;background:var(--code-bg);color:var(--code-text);border-radius:0 0 10px 10px;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-size:.9rem;line-height:1.38;tab-size:2;font-variant-ligatures:none}.post-content pre code{background:transparent;border:none;padding:0;color:inherit;font-size:inherit;line-height:inherit;display:block;font-family:inherit;white-space:pre}.post-content .code-window{margin:1rem 0;border:1px solid #374151;border-radius:12px;overflow:hidden}.post-content .code-window-header{display:flex;align-items:center;justify-content:space-between;background:var(--code-header);color:var(--code-text);font-size:.8rem;padding:.45rem .6rem}.post-content .code-window-language{opacity:.9;text-transform:lowercase}.post-content .code-copy-btn{border:1px solid #4b5563;border-radius:6px;background:#111827;color:#f9fafb;font-size:.75rem;padding:.2rem .45rem;cursor:pointer}.post-content .code-copy-btn:hover{background:#374151}.post-content .code-wrap-btn{border:1px solid #4b5563;border-radius:6px;background:#111827;color:#f9fafb;font-size:.75rem;padding:.2rem .45rem;cursor:pointer}.post-content .code-wrap-btn:hover{background:#374151}.post-content .code-window-controls{display:flex;align-items:center;gap:.4rem}.post-content .code-window.wrap-enabled pre{overflow-x:hidden}.post-content .code-window.wrap-enabled pre code>.line{white-space:pre-wrap;word-break:break-word}.post-content .code-window.wrap-enabled pre code{white-space:pre-wrap;word-break:break-word}.copy-toast{position:fixed;right:1rem;bottom:1rem;background:#0f172a;color:#f9fafb;padding:.55rem .8rem;border-radius:8px;border:1px solid #334155;font-size:.83rem;opacity:0;transform:translateY(8px);pointer-events:none;transition:opacity .18s ease,transform .18s ease;z-index:40}.copy-toast.visible{opacity:1;transform:translateY(0)}.post-content blockquote{border-left:4px solid #6ee7b7;margin-left:0;margin-right:0;padding:.4rem .9rem;background:#f9fafb}@media(max-width:768px){.shell{padding:1rem}.post-shell{display:block}.post-toc{position:static;margin-top:1rem}.post-main{max-width:100%}main{padding:1rem;border-radius:10px}.post-content{font-size:1rem;line-height:1.7}.brand img{width:clamp(132px,44vw,180px)}}
