*,*::before,*::after{box-sizing:border-box}html,body{margin:0;padding:0}html{font-size:16px;scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility}:root{--bg:#fbfbfa;--surface:#fff;--surface-2:#f4f4f1;--fg:#15171a;--fg-mute:#5b6269;--fg-faint:#8a9098;--rule:#e6e6e2;--rule-strong:#d4d4cf;--accent:#2656ff;--accent-fg:#fff;--accent-soft:#eaf0ff;--success:#16a34a;--warn:#d97706;--danger:#dc2626;--code-bg:#f6f8fa;--code-fg:#24292f;--code-mute:#6e7781;--code-kw:#cf222e;--code-str:#0a3069;--code-num:#d2a8ff;--mono:"JetBrains Mono",ui-monospace,Menlo,monospace;--sans:"Inter",ui-sans-serif,system-ui,-apple-system,sans-serif;--serif:"Lora",Georgia,serif;--radius:6px;--radius-lg:10px;--pad:clamp(16px,3vw,40px);--rail:1280px;--shadow-sm:0 1px 2px rgba(15,23,42,.06);--shadow-md:0 4px 12px rgba(15,23,42,.08);--shadow-lg:0 8px 32px rgba(15,23,42,.12);--ease:cubic-bezier(.4,0,.2,1);--t-fast:120ms;--t-base:220ms}:root[data-theme="dark"]{--bg:#0e1013;--surface:#15181c;--surface-2:#1b1f24;--fg:#e7e9ec;--fg-mute:#9aa2ad;--fg-faint:#6a7280;--rule:#24282e;--rule-strong:#343a42;--accent:#4d7bff;--accent-fg:#0e1013;--accent-soft:#1a2540;--code-bg:#122b3b;--code-fg:#faf6e4;--code-mute:#6c8b9f;--shadow-sm:0 1px 2px rgba(0,0,0,.3);--shadow-md:0 4px 12px rgba(0,0,0,.4);--shadow-lg:0 8px 32px rgba(0,0,0,.5)}@media(prefers-color-scheme:dark){:root:not([data-theme="light"]){--bg:#0e1013;--surface:#15181c;--surface-2:#1b1f24;--fg:#e7e9ec;--fg-mute:#9aa2ad;--fg-faint:#6a7280;--rule:#24282e;--rule-strong:#343a42;--accent:#4d7bff;--accent-fg:#0e1013;--accent-soft:#1a2540;--code-bg:#122b3b;--code-fg:#faf6e4;--code-mute:#6c8b9f}}body{font-family:var(--sans);font-size:15px;line-height:1.55;background:var(--bg);color:var(--fg);transition:background .2s,color .2s}a{color:inherit;text-decoration:none}a:hover{color:var(--accent)}::selection{background:var(--accent);color:var(--accent-fg)}img{max-width:100%;height:auto;display:block}.mono{font-family:var(--mono)}.rail{max-width:var(--rail);margin:0 auto;padding:0 var(--pad)}.skip-link{position:absolute;top:-100%;left:16px;background:var(--accent);color:var(--accent-fg);padding:6px 16px;border-radius:var(--radius);font-size:.875rem;font-weight:600;z-index:1000;transition:top var(--t-fast)}.skip-link:focus{top:16px}.topbar{position:sticky;top:0;z-index:50;background:color-mix(in srgb,var(--bg) 92%,transparent);backdrop-filter:saturate(180%) blur(12px);-webkit-backdrop-filter:saturate(180%) blur(12px);border-bottom:1px solid var(--rule)}.topbar-inner{max-width:var(--rail);margin:0 auto;padding:12px var(--pad);display:flex;align-items:center;gap:20px}.logo{display:flex;align-items:center;gap:10px;font-family:var(--mono);font-weight:600;font-size:14px;white-space:nowrap;color:var(--fg)}.logo:hover{color:var(--fg)}.logo .sq{width:26px;height:26px;border-radius:6px;background:var(--fg);color:var(--bg);display:grid;place-items:center;font-family:var(--mono);font-weight:700;font-size:15px;transition:transform var(--t-fast) var(--ease),box-shadow var(--t-fast) var(--ease)}.logo:hover .sq{transform:rotate(-4deg) scale(1.05);box-shadow:0 0 0 3px color-mix(in srgb,var(--accent) 30%,transparent)}.logo .slash{color:var(--fg-faint);font-weight:400}.logo b{color:var(--accent);font-weight:600}.nav{display:flex;gap:4px;margin-left:20px}.nav a{padding:7px 12px;border-radius:var(--radius);font-size:14px;color:var(--fg-mute);font-weight:500;transition:color var(--t-fast),background var(--t-fast)}.nav a:hover{background:var(--surface-2);color:var(--fg)}.nav a.on{color:var(--fg);background:var(--surface-2)}.spacer{flex:1}.search{display:flex;align-items:center;gap:10px;height:36px;padding:0 12px;background:var(--surface-2);border:1px solid var(--rule);border-radius:var(--radius);min-width:260px;transition:border-color .15s,background .15s}.search:focus-within{border-color:var(--accent);background:var(--surface)}.search svg{width:14px;height:14px;color:var(--fg-mute);flex-shrink:0}.search input{all:unset;flex:1;font-size:13.5px;color:var(--fg);font-family:var(--sans)}.search input::placeholder{color:var(--fg-faint)}.search kbd{font-family:var(--mono);font-size:11px;color:var(--fg-mute);background:var(--surface);border:1px solid var(--rule);padding:2px 6px;border-radius:4px}.search{position:relative}.search-dropdown{position:absolute;top:calc(100% + 6px);left:0;right:0;background:var(--surface);border:1px solid var(--rule);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);max-height:380px;overflow-y:auto;z-index:100;display:none;padding:6px}.search-dropdown.open{display:block}.search-empty{padding:20px 16px;text-align:center;color:var(--fg-mute);font-size:13.5px}.search-item{display:block;padding:10px 12px;border-radius:var(--radius);text-decoration:none;color:var(--fg);transition:background var(--t-fast)}.search-item:hover,.search-item.selected{background:var(--surface-2)}.search-item-title{font-size:14px;font-weight:600;line-height:1.4;margin-bottom:4px}.search-item-meta{font-size:12.5px;color:var(--fg-mute);display:flex;align-items:center;gap:6px;flex-wrap:wrap}.search-item-meta .dot{color:var(--fg-faint)}.iconbtn{height:36px;width:36px;display:grid;place-items:center;border:1px solid var(--rule);background:var(--surface);border-radius:var(--radius);cursor:pointer;color:var(--fg);transition:background var(--t-fast),border-color var(--t-fast);text-decoration:none}.iconbtn:hover{background:var(--surface-2);border-color:var(--rule-strong);color:var(--fg)}.iconbtn svg{width:16px;height:16px}.btn{height:36px;padding:0 14px;display:inline-flex;align-items:center;gap:8px;background:var(--accent);color:var(--accent-fg);font-weight:500;font-size:13.5px;border-radius:var(--radius);border:1px solid var(--accent);cursor:pointer;text-decoration:none;transition:filter .15s}.btn:hover{filter:brightness(1.05);color:var(--accent-fg)}.btn.ghost{background:transparent;color:var(--fg);border-color:var(--rule)}.btn.ghost:hover{background:var(--surface-2);color:var(--fg)}.btn svg{width:14px;height:14px}:root[data-theme="light"] .theme-ico .moon{display:none}:root[data-theme="dark"] .theme-ico .sun{display:none}:root:not([data-theme]) .theme-ico .sun{display:none}@media(prefers-color-scheme:dark){:root:not([data-theme]) .theme-ico .moon{display:none}:root:not([data-theme]) .theme-ico .sun{display:block}}.mobile-menu-btn{display:none;width:36px;height:36px;border:1px solid var(--rule);border-radius:var(--radius);background:transparent;color:var(--fg-mute);cursor:pointer;place-items:center;font-size:0;transition:color var(--t-fast),background var(--t-fast)}.mobile-menu-btn:hover{color:var(--fg);background:var(--surface-2)}.mobile-menu-btn svg{width:20px;height:20px}.mobile-nav{display:none;position:fixed;inset:56px 0 0 0;background:var(--bg);z-index:99;padding:24px var(--pad);flex-direction:column;gap:4px;border-top:1px solid var(--rule);overflow-y:auto}.mobile-nav.open{display:flex}.mobile-nav a{padding:12px 16px;border-radius:var(--radius);font-size:1.0625rem;font-weight:500;color:var(--fg-mute);transition:color var(--t-fast),background var(--t-fast)}.mobile-nav a:hover{background:var(--surface-2);color:var(--fg)}.mobile-nav a.on{color:var(--fg)}.hero{padding:40px 0 24px;border-bottom:1px solid var(--rule)}.hero-head{display:flex;align-items:center;gap:14px;margin-bottom:22px;font-family:var(--mono);font-size:12px;color:var(--fg-mute);text-transform:uppercase;letter-spacing:.04em}.hero-head .badge{background:var(--accent-soft);color:var(--accent);padding:3px 8px;border-radius:4px;font-weight:600;letter-spacing:.02em}.hero-head .dot{width:6px;height:6px;border-radius:50%;background:var(--success);box-shadow:0 0 0 3px color-mix(in srgb,var(--success) 22%,transparent)}.hero-grid{display:grid;grid-template-columns:2fr 1fr;gap:24px;align-items:stretch}.featured{background:var(--surface);border:1px solid var(--rule);border-radius:var(--radius-lg);overflow:hidden;display:grid;grid-template-rows:220px auto;transition:border-color .15s,transform .15s;text-decoration:none;color:inherit}.featured:hover{border-color:var(--rule-strong)}.featured .cover{background:linear-gradient(135deg,color-mix(in srgb,var(--accent) 18%,var(--surface)) 0%,var(--surface) 60%),repeating-linear-gradient(45deg,transparent 0 14px,color-mix(in srgb,var(--fg) 4%,transparent) 14px 15px);position:relative;border-bottom:1px solid var(--rule);overflow:hidden}.featured .cover img{width:100%;height:100%;object-fit:cover;display:block}.featured .cover::after{content:"";position:absolute;inset:0;background-image:radial-gradient(color-mix(in srgb,var(--fg) 10%,transparent) 1px,transparent 1px);background-size:18px 18px;mask-image:radial-gradient(ellipse at 30% 30%,black,transparent 65%);-webkit-mask-image:radial-gradient(ellipse at 30% 30%,black,transparent 65%)}.featured .cover img+::after{display:none}.featured .chip-pos{position:absolute;left:16px;top:16px;z-index:2;display:flex;gap:6px}.chip{font-family:var(--mono);font-size:11px;font-weight:600;padding:3px 7px;border-radius:4px;background:var(--surface);color:var(--fg);border:1px solid var(--rule);text-transform:uppercase;letter-spacing:.04em}.chip.accent{background:var(--accent);color:var(--accent-fg);border-color:var(--accent)}.featured .body{padding:22px 24px 24px;display:flex;flex-direction:column;gap:10px}.featured h2{font-size:28px;line-height:1.2;letter-spacing:-.01em;font-weight:700;margin:4px 0 0;color:var(--fg)}.featured .excerpt{color:var(--fg-mute);font-size:15px;line-height:1.55;margin:4px 0 12px;max-width:60ch}.featured .meta{display:flex;align-items:center;gap:12px;font-size:13px;color:var(--fg-mute);flex-wrap:wrap}.featured .meta .sep{color:var(--fg-faint)}.featured .meta b{color:var(--fg);font-weight:500}.side-stack{display:flex;flex-direction:column;gap:16px}.main-grid{display:grid;grid-template-columns:minmax(0,1fr) 300px;gap:40px;padding:32px 0 80px}.filter-bar{display:flex;align-items:center;gap:10px;flex-wrap:wrap;padding-bottom:20px;margin-bottom:24px;border-bottom:1px solid var(--rule)}.filter-bar .label{font-family:var(--mono);font-size:12px;color:var(--fg-mute);text-transform:uppercase;letter-spacing:.08em;margin-right:4px}.tag{font-family:var(--mono);font-size:12px;font-weight:500;color:var(--fg-mute);background:var(--surface);border:1px solid var(--rule);padding:5px 10px;border-radius:4px;cursor:pointer;transition:all .12s;text-decoration:none}.tag:hover{color:var(--fg);border-color:var(--rule-strong)}.tag.on{background:var(--fg);color:var(--bg);border-color:var(--fg)}.tag .count{color:var(--fg-faint);margin-left:6px;font-weight:400}.tag.on .count{color:color-mix(in srgb,var(--bg) 60%,transparent)}.posts{display:flex;flex-direction:column;gap:20px}.post{display:grid;grid-template-columns:160px 1fr;gap:20px;background:var(--surface);border:1px solid var(--rule);border-radius:var(--radius-lg);padding:16px;transition:border-color .15s,transform .15s;text-decoration:none;color:inherit}.post:hover{border-color:var(--rule-strong)}.post:hover .t{color:var(--accent)}.post .thumb{height:150px;border-radius:var(--radius);border:1px solid var(--rule);background:var(--surface-2);background-image:linear-gradient(135deg,color-mix(in srgb,var(--accent) 12%,var(--surface-2)) 0%,var(--surface-2) 70%),repeating-linear-gradient(-45deg,transparent 0 10px,color-mix(in srgb,var(--fg) 4%,transparent) 10px 11px);position:relative;overflow:hidden}.post .thumb img{width:100%;height:100%;object-fit:cover;display:block}.post .thumb .glyph{position:absolute;inset:0;display:grid;place-items:center;font-family:var(--mono);font-weight:700;font-size:38px;color:color-mix(in srgb,var(--fg) 18%,transparent);letter-spacing:-.02em}.post .body{display:flex;flex-direction:column;gap:8px;min-width:0}.post .pre{display:flex;gap:6px;align-items:center;font-family:var(--mono);font-size:11.5px;color:var(--fg-mute);text-transform:uppercase;letter-spacing:.06em;margin-bottom:2px}.post .pre .dot{color:var(--fg-faint)}.post .cat{color:var(--accent);font-weight:600}.post .t{font-size:19px;font-weight:600;line-height:1.3;letter-spacing:-.005em;color:var(--fg);margin:0;transition:color .15s}.post .e{color:var(--fg-mute);font-size:14px;line-height:1.5;margin:0}.post .meta{display:flex;align-items:center;gap:14px;margin-top:auto;padding-top:8px;font-size:12.5px;color:var(--fg-mute);flex-wrap:wrap}.post .meta .m{display:inline-flex;align-items:center;gap:5px}.post .meta svg{width:12px;height:12px}.post .meta .tags-row{display:flex;gap:4px}.post .meta .mini-tag{font-family:var(--mono);font-size:11px;padding:2px 6px;border-radius:3px;background:var(--surface-2);color:var(--fg-mute);border:1px solid var(--rule)}.post.pinned{border-color:var(--accent)}.post.pinned .pin{font-family:var(--mono);font-size:11px;color:var(--accent);font-weight:700;text-transform:uppercase;letter-spacing:.08em;display:inline-flex;align-items:center;gap:4px}aside.sidebar{display:flex;flex-direction:column;gap:16px;position:sticky;top:72px;align-self:start}.side-card{background:var(--surface);border:1px solid var(--rule);border-radius:var(--radius-lg);padding:16px}.side-card h4{font-family:var(--mono);font-size:11px;text-transform:uppercase;letter-spacing:.1em;color:var(--fg-mute);margin:0 0 12px;font-weight:600;display:flex;align-items:center;gap:8px}.side-card h4::before{content:"";width:6px;height:6px;background:var(--accent);border-radius:50%}.about-me{display:flex;gap:12px;align-items:flex-start}.avatar{width:44px;height:44px;border-radius:50%;flex:0 0 44px;background:linear-gradient(135deg,var(--accent),color-mix(in srgb,var(--accent) 40%,#000));color:var(--accent-fg);display:grid;place-items:center;font-weight:700;font-family:var(--mono);font-size:16px;overflow:hidden}.avatar img{width:100%;height:100%;object-fit:cover;border-radius:50%}.about-me .who .n{font-weight:600;font-size:14px}.about-me .who .r{font-size:12.5px;color:var(--fg-mute);margin-top:2px}.about-me p{margin:10px 0 12px;font-size:13px;color:var(--fg-mute);line-height:1.55}.mini-stats{display:grid;grid-template-columns:1fr 1fr 1fr;gap:6px;text-align:left}.mini-stats .s{padding:8px;background:var(--surface-2);border-radius:6px}.mini-stats .n{font-family:var(--mono);font-size:15px;font-weight:700;color:var(--fg)}.mini-stats .l{font-size:10.5px;text-transform:uppercase;letter-spacing:.08em;color:var(--fg-mute);margin-top:2px;font-family:var(--mono)}.side-card .news-form{display:flex;flex-direction:column;gap:8px;margin-top:4px}.side-card .news-form input{all:unset;box-sizing:border-box;width:100%;padding:10px 12px;font-size:13px;background:var(--bg);border:1px solid var(--rule);border-radius:6px;color:var(--fg);font-family:var(--sans)}.side-card .news-form input:focus{border-color:var(--accent)}.side-card .news-form button{all:unset;text-align:center;cursor:pointer;padding:10px;font-size:13px;font-weight:500;background:var(--accent);color:var(--accent-fg);border-radius:6px;transition:filter .15s}.side-card .news-form button:hover{filter:brightness(1.05)}.side-card .news-form .small{font-size:11.5px;color:var(--fg-mute);text-align:center;margin-top:2px;font-family:var(--mono)}.stack-tags{display:flex;flex-wrap:wrap;gap:6px}.stack-tags a{font-family:var(--mono);font-size:12px;padding:4px 8px;border-radius:4px;background:var(--surface-2);color:var(--fg);border:1px solid var(--rule);text-decoration:none;transition:background .12s,color .12s,border-color .12s}.stack-tags a:hover{background:var(--accent-soft);color:var(--accent);border-color:color-mix(in srgb,var(--accent) 40%,var(--rule))}.trending ul{margin:0;padding:0}.trending li{display:flex;gap:12px;padding:10px 0;border-bottom:1px dashed var(--rule);list-style:none;cursor:pointer}.trending li:last-child{border-bottom:0}.trending a{text-decoration:none;color:inherit}.trending .n{font-family:var(--mono);font-size:13px;color:var(--fg-faint);font-weight:600;width:22px;flex:0 0 22px}.trending .t{font-size:14px;line-height:1.35;color:var(--fg);font-weight:500}.trending .m{font-family:var(--mono);font-size:11px;color:var(--fg-mute);margin-top:3px}.toc-list{margin:0;padding:0;list-style:none;display:flex;flex-direction:column;gap:2px}.toc-list a{display:flex;align-items:center;gap:8px;padding:7px 8px;border-radius:4px;font-size:13px;color:var(--fg);text-decoration:none}.toc-list a:hover{background:var(--surface-2);color:var(--accent)}.toc-list .c{font-family:var(--mono);font-size:11px;color:var(--fg-mute);margin-left:auto}.side-card .btn-row{display:flex;flex-direction:column;gap:8px;margin-top:4px}.side-card .btn-row .btn{width:100%;justify-content:center;height:36px}.load-more{display:flex;justify-content:center;margin-top:28px}.load-more button,.load-more a{all:unset;cursor:pointer;display:inline-flex;align-items:center;gap:6px;padding:10px 24px;font-size:13.5px;font-weight:500;background:var(--surface);border:1px solid var(--rule);color:var(--fg);border-radius:6px;font-family:var(--mono);transition:border-color .15s,color .15s;text-decoration:none}.load-more button:hover,.load-more a:hover{border-color:var(--accent);color:var(--accent)}.pagination{display:flex;align-items:center;justify-content:center;gap:8px;padding:32px 0;margin-top:0}.page-btn{display:inline-flex;align-items:center;justify-content:center;min-width:36px;height:36px;padding:0 12px;border:1px solid var(--rule);border-radius:var(--radius);font-size:14px;font-weight:500;color:var(--fg-mute);text-decoration:none;background:var(--surface);font-family:var(--mono);transition:border-color .15s,color .15s,background .15s}.page-btn:hover,.page-btn.active{border-color:var(--accent);color:var(--accent);background:var(--accent-soft)}.page-btn.active{font-weight:700}.page-btn.disabled{opacity:.4;pointer-events:none}.page-btn svg{width:14px;height:14px}footer.site-footer{border-top:1px solid var(--rule);padding:40px 0 60px;background:var(--surface)}.foot-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:30px;padding-bottom:30px}.foot-grid h5{font-family:var(--mono);font-size:11px;text-transform:uppercase;letter-spacing:.1em;color:var(--fg-mute);margin:0 0 12px;font-weight:600}.foot-grid ul{list-style:none;padding:0;margin:0;display:grid;gap:8px;font-size:13.5px}.foot-grid a:hover{color:var(--accent)}.foot-about p{font-size:13.5px;color:var(--fg-mute);margin:6px 0 14px;max-width:36ch;line-height:1.55}.foot-soc{display:flex;gap:6px}.foot-bottom{padding-top:16px;border-top:1px solid var(--rule);display:flex;justify-content:space-between;font-family:var(--mono);font-size:11.5px;color:var(--fg-mute);flex-wrap:wrap;gap:8px}.page-wrapper{min-height:calc(100vh - 56px);display:flex;flex-direction:column}.main-content{flex:1}.container{max-width:var(--rail);margin:0 auto;padding:0 var(--pad)}.container--narrow{max-width:720px;margin:0 auto;padding:0 var(--pad)}.reading-progress{position:fixed;top:56px;left:0;right:0;height:2px;background:var(--rule);z-index:99}.reading-progress-bar{height:100%;background:var(--accent);width:0;transition:width 100ms linear}.breadcrumb{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--fg-mute);margin-bottom:32px;flex-wrap:wrap}.breadcrumb a{color:var(--fg-mute);transition:color var(--t-fast)}.breadcrumb a:hover{color:var(--accent)}.breadcrumb-sep{color:var(--fg-faint);font-size:12px}.breadcrumb-current{color:var(--fg-mute);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:260px}.post-wrapper{padding:32px var(--pad) 80px;max-width:860px}.post-header{margin-bottom:40px}.post-header .post-tags{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:20px}.post-header h1{font-size:clamp(1.625rem,4vw,2.5rem);font-weight:700;letter-spacing:-.035em;line-height:1.15;color:var(--fg);margin-bottom:20px}.post-header-meta{display:flex;align-items:center;gap:16px;flex-wrap:wrap;padding-bottom:24px;border-bottom:1px solid var(--rule)}.author-chip{display:flex;align-items:center;gap:12px}.author-avatar{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,var(--accent),color-mix(in srgb,var(--accent) 40%,#000));display:grid;place-items:center;font-weight:700;font-size:14px;color:var(--accent-fg);font-family:var(--mono);flex-shrink:0;overflow:hidden}.author-avatar img{width:100%;height:100%;object-fit:cover;border-radius:50%}.author-info{display:flex;flex-direction:column}.author-name{font-size:14px;font-weight:600;color:var(--fg)}.author-role{font-size:12.5px;color:var(--fg-mute)}.post-meta-divider{color:var(--fg-faint)}.post-date-full,.post-reading-time{font-size:13px;color:var(--fg-mute);font-family:var(--mono);display:flex;align-items:center;gap:5px}.post-date-full svg,.post-reading-time svg{width:13px;height:13px}.post-tag{display:inline-flex;align-items:center;padding:3px 8px;border-radius:4px;background:var(--accent-soft);color:var(--accent);font-size:11px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;font-family:var(--mono);text-decoration:none;transition:background .12s,color .12s}.post-tag:hover{background:color-mix(in srgb,var(--accent) 20%,transparent)}.post-hero-image{margin:32px 0 40px;border-radius:var(--radius-lg);overflow:hidden;aspect-ratio:16/9}.post-hero-image img{width:100%;height:100%;object-fit:cover}.post-body{font-family:var(--serif);font-size:1.0625rem;line-height:1.85;color:var(--fg);overflow-wrap:break-word;word-break:break-word}.post-body>*+*{margin-top:1.6em}.post-body h2{font-family:var(--sans);font-size:clamp(1.25rem,3vw,1.625rem);font-weight:700;letter-spacing:-.025em;color:var(--fg);margin-top:1.5em;margin-bottom:.6em;padding-bottom:.4em;border-bottom:1px solid var(--rule)}.post-body h3{font-family:var(--sans);font-size:1.125rem;font-weight:700;letter-spacing:-.015em;color:var(--fg);margin-top:2em;margin-bottom:.5em}.post-body h4{font-family:var(--sans);font-size:1rem;font-weight:700;color:var(--fg-mute);margin-top:1.75em;margin-bottom:.4em}.post-body p{margin:1.4em 0}.post-body a{color:var(--accent);text-decoration:underline;text-decoration-color:color-mix(in srgb,var(--accent) 30%,transparent);text-underline-offset:3px;transition:text-decoration-color var(--t-fast)}.post-body a:hover{text-decoration-color:var(--accent)}.post-body strong{font-weight:700;color:var(--fg)}.post-body em{font-style:italic}.post-body code:not([class]){font-family:var(--mono);font-size:.92em;padding:1px 5px;border-radius:3px;color:var(--accent)}.post-body ul,.post-body ol{padding-left:1.5em}.post-body li{margin:.4em 0}.post-body li::marker{color:var(--accent)}.post-body blockquote{border-left:3px solid var(--accent);padding:16px 24px;margin:24px 0;background:var(--accent-soft);border-radius:0 var(--radius) var(--radius) 0;font-style:italic;color:var(--fg-mute)}.post-body blockquote p{margin:0}.post-body blockquote cite{display:block;font-size:.875rem;font-style:normal;color:var(--fg-faint);margin-top:12px}.post-body img{border-radius:var(--radius-lg);box-shadow:var(--shadow-md);margin:32px auto}.post-body figure{margin:32px 0}.post-body figcaption{text-align:center;font-family:var(--sans);font-size:13px;color:var(--fg-mute);margin-top:12px;font-style:italic}.post-body table{width:100%;border-collapse:collapse;font-family:var(--sans);font-size:.9375rem;margin:24px 0;overflow-x:auto;display:block}.post-body thead th{text-align:left;padding:12px 16px;background:var(--surface-2);border-bottom:2px solid var(--accent);font-weight:600;font-size:.875rem;letter-spacing:.02em;color:var(--fg-mute);white-space:nowrap}.post-body tbody td{padding:12px 16px;border-bottom:1px solid var(--rule);color:var(--fg-mute)}.post-body tbody tr:hover td{background:var(--surface-2)}.post-body hr{border:0;border-top:1px solid var(--rule);margin:40px 0}.highlight-wrapper{position:relative;margin:0}.code-header{display:flex;align-items:center;justify-content:space-between;padding:4px 12px;background:var(--code-bg);border:1px solid var(--rule);border-bottom:0;border-radius:var(--radius-lg) var(--radius-lg) 0 0}.code-lang{font-family:var(--mono);font-size:11px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--code-mute)}.copy-btn{display:flex;align-items:center;gap:4px;padding:3px 8px;border:1px solid rgba(255,255,255,.1);border-radius:4px;background:transparent;font-size:11px;font-weight:600;color:var(--code-mute);cursor:pointer;font-family:var(--sans);transition:color .12s,border-color .12s}.copy-btn:hover{color:var(--code-fg);border-color:rgba(255,255,255,.25)}.copy-btn.copied{color:var(--success);border-color:var(--success)}.copy-btn svg{width:11px;height:11px}.toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%) translateY(16px);padding:10px 20px;border-radius:var(--radius);background:var(--fg);color:var(--bg);font-family:var(--sans);font-size:14px;font-weight:500;opacity:0;pointer-events:none;z-index:9999;transition:opacity .2s var(--ease),transform .2s var(--ease);box-shadow:var(--shadow-lg)}.toast--visible{opacity:1;transform:translateX(-50%) translateY(0);pointer-events:auto}.post-body .highlight-wrapper{margin-top:.5em;margin-bottom:.5em}.post-body>*+.highlight-wrapper,.post-body>*+.highlighter-rouge{margin-top:.5em}.post-body .highlighter-rouge+*,.post-body .highlight-wrapper+*{margin-top:.5em}.post-body .highlight,.highlight{margin:0;border-radius:var(--radius-lg);overflow-x:auto;border:1px solid var(--rule)}.post-body .highlight-wrapper .highlight-wrapper .highlight{border-radius:0 0 var(--radius-lg) var(--radius-lg);border-top:0}.highlight-wrapper .highlighter-rouge{border-radius:0 0 var(--radius-lg) var(--radius-lg);overflow-x:auto}.highlight-wrapper .highlight{border-radius:0;border:0;overflow-x:auto}.highlight pre{margin:0;font-family:var(--mono);font-size:.875rem;line-height:1.7;color:var(--code-fg)}.highlight>pre{padding:4px 10px}.highlight .rouge-table{border-spacing:0;width:100%;margin:0}.highlight .rouge-table td{padding:0;vertical-align:top}.highlight .rouge-gutter{padding-left:12px;padding-right:0;position:sticky;left:0;z-index:1;background:var(--code-bg)}.highlight .rouge-gutter pre{margin:0;padding:4px 8px 4px 0;text-align:right;color:var(--code-mute);user-select:none;border-right:1px solid rgba(255,255,255,.08);min-width:2.5em}.highlight .rouge-code pre{margin:0;padding:4px 10px 4px 8px}.highlight .lineno{color:var(--code-mute)}:root[data-theme="light"]{--code-bg:#f6f8fa;--code-fg:#24292f;--code-mute:#6e7781}:root[data-theme="light"] .highlight,:root[data-theme="light"] .highlight>pre{background:var(--code-bg);color:var(--code-fg)}:root[data-theme="light"] .highlight .lineno{color:#6a7280}:root[data-theme="light"] .code-header{background:#e8e8e4;border-color:#d4d4cf}:root[data-theme="light"] .highlight .rouge-gutter pre{border-right-color:#d4d4cf}:root[data-theme="light"] .copy-btn{border-color:#ccc}.post-footer{margin-top:64px;padding-top:40px;border-top:1px solid var(--rule)}.post-share{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin-bottom:40px}.share-label{font-size:13px;font-weight:600;color:var(--fg-mute);font-family:var(--mono);text-transform:uppercase;letter-spacing:.06em}.share-btn{display:inline-flex;align-items:center;gap:8px;padding:7px 16px;border:1px solid var(--rule);border-radius:var(--radius);font-size:13px;font-weight:500;color:var(--fg-mute);text-decoration:none;cursor:pointer;background:transparent;transition:border-color .15s,color .15s,background .15s}.share-btn:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-soft)}.share-btn svg{width:14px;height:14px}.post-nav{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:32px}.post-nav-item{background:var(--surface);border:1px solid var(--rule);border-radius:var(--radius-lg);padding:20px;text-decoration:none;color:inherit;transition:border-color .15s,box-shadow .15s;display:flex;flex-direction:column;gap:8px}.post-nav-item:hover{border-color:var(--accent);box-shadow:var(--shadow-sm)}.post-nav-item--next{text-align:right}.post-nav-dir{font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--fg-faint);font-family:var(--mono);display:flex;align-items:center;gap:4px}.post-nav-item--next .post-nav-dir{justify-content:flex-end}.post-nav-dir svg{width:12px;height:12px}.post-nav-title{font-size:.9375rem;font-weight:600;color:var(--fg);line-height:1.4}.toc{background:var(--surface);border:1px solid var(--rule);border-radius:var(--radius-lg);padding:20px;margin-bottom:32px}.toc-title{font-family:var(--mono);font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.1em;color:var(--fg-mute);margin-bottom:12px}.toc ol{list-style:none;padding:0;counter-reset:toc}.toc li{counter-increment:toc}.toc li::before{content:counter(toc,decimal-leading-zero) ".";font-size:11px;font-family:var(--mono);color:var(--fg-faint);margin-right:8px}.toc a{font-size:.875rem;color:var(--fg-mute);transition:color var(--t-fast)}.toc a:hover{color:var(--accent)}.toc li+li{margin-top:8px}.toc .toc-h3{padding-left:16px}.toc .toc-h3 a{font-size:.8125rem;color:var(--fg-faint)}.about-wrapper{padding:48px 0 80px}.about-hero{display:grid;grid-template-columns:1fr;gap:32px;margin-bottom:64px;padding-bottom:64px;border-bottom:1px solid var(--rule);align-items:center}@media(min-width:640px){.about-hero{grid-template-columns:auto 1fr}}.about-avatar-big{width:120px;height:120px;border-radius:10px;background:linear-gradient(135deg,var(--accent) 0%,#6f42c1 100%);display:grid;place-items:center;font-size:2.5rem;font-weight:800;color:white;font-family:var(--mono);box-shadow:var(--shadow-md);flex-shrink:0;overflow:hidden}.about-avatar-big img{width:100%;height:100%;object-fit:cover}.about-intro{display:flex;flex-direction:column;gap:16px}.about-intro .status{display:inline-flex;align-items:center;gap:8px;font-size:13px;color:var(--success);font-family:var(--mono)}.about-intro .status::before{content:"";width:8px;height:8px;border-radius:50%;background:var(--success);animation:pulse 2.5s ease infinite}@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.85)}}.about-intro h1{font-size:clamp(1.75rem,4vw,2.5rem);font-weight:700;letter-spacing:-.035em;color:var(--fg)}.about-intro .title{font-size:1rem;color:var(--accent);font-weight:600;font-family:var(--mono)}.about-intro .bio{font-size:1.0625rem;color:var(--fg-mute);line-height:1.75;max-width:560px}.social-links{display:flex;flex-wrap:wrap;gap:12px;margin-top:8px}.social-link{display:inline-flex;align-items:center;gap:8px;padding:8px 16px;border:1px solid var(--rule);border-radius:var(--radius-full,9999px);font-size:.875rem;font-weight:500;color:var(--fg-mute);text-decoration:none;background:var(--surface);transition:all var(--t-fast) var(--ease)}.social-link:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-soft);transform:translateY(-2px)}.social-link svg{width:16px;height:16px}.about-section{margin-bottom:64px}.about-section-title{font-size:1.375rem;font-weight:700;letter-spacing:-.025em;color:var(--fg);margin-bottom:32px;display:flex;align-items:center;gap:12px}.about-section-title::after{content:"";flex:1;height:1px;background:var(--rule)}.tech-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:16px}.tech-item{display:flex;flex-direction:column;align-items:center;gap:12px;padding:20px 16px;background:var(--surface);border:1px solid var(--rule);border-radius:var(--radius-lg);text-align:center;cursor:default;transition:border-color var(--t-base),transform var(--t-base),box-shadow var(--t-base)}.tech-item:hover{border-color:var(--accent);transform:translateY(-3px);box-shadow:var(--shadow-md)}.tech-icon{width:44px;height:44px;border-radius:var(--radius);background:var(--surface-2);border:1px solid var(--rule);display:grid;place-items:center;font-size:1.5rem}.tech-name{font-size:.8125rem;font-weight:600;color:var(--fg-mute)}.tech-level{display:flex;gap:3px}.tech-dot{width:6px;height:6px;border-radius:50%;background:var(--rule)}.tech-dot.filled{background:var(--accent)}.timeline{display:flex;flex-direction:column;gap:0;position:relative}.timeline::before{content:"";position:absolute;left:15px;top:24px;bottom:0;width:1px;background:var(--rule)}.timeline-item{display:grid;grid-template-columns:32px 1fr;gap:20px;padding-bottom:32px}.timeline-item:last-child{padding-bottom:0}.timeline-dot{width:32px;height:32px;border-radius:50%;background:var(--surface);border:2px solid var(--accent);display:grid;place-items:center;flex-shrink:0;z-index:1}.timeline-dot svg{width:14px;height:14px;color:var(--accent)}.timeline-content{padding-top:4px}.timeline-date{font-size:12px;color:var(--fg-faint);font-family:var(--mono);margin-bottom:4px}.timeline-title{font-size:1rem;font-weight:700;color:var(--fg);margin-bottom:2px}.timeline-company{font-size:.875rem;color:var(--accent);font-weight:600;margin-bottom:12px}.timeline-desc{font-size:.9375rem;color:var(--fg-mute);line-height:1.65}.empty{padding:60px 20px;text-align:center;color:var(--fg-mute);font-family:var(--mono);font-size:13px}.fade-in{animation:fadeIn .4s var(--ease) both}@keyframes fadeIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@media(max-width:1080px){.main-grid{grid-template-columns:1fr}aside.sidebar{position:static;max-height:none;order:2}.hero-grid{grid-template-columns:1fr}}@media(max-width:760px){:root{--pad:20px}.rail,.container,.container--narrow,.post-wrapper{padding-left:20px!important;padding-right:20px!important}.nav{display:none}.spacer{display:none}.search{min-width:0;flex:1}.search kbd{display:none}.search input::placeholder{color:transparent}.search-dropdown{left:-8px;right:-8px}.topbar-inner>.btn{display:none}.topbar-inner>a.iconbtn{display:none}.mobile-menu-btn{display:grid}.post{grid-template-columns:1fr}.post .thumb{height:140px}.featured{grid-template-rows:160px auto}.featured h2{font-size:22px}.foot-grid{grid-template-columns:1fr 1fr}.post-nav{grid-template-columns:1fr}.post-nav-item--next{text-align:left}.post-nav-item--next .post-nav-dir{justify-content:flex-start}.tech-grid{grid-template-columns:repeat(auto-fill,minmax(110px,1fr))}}@media(max-width:480px){.post-header h1{font-size:1.5rem}.post-header-meta{flex-direction:column;align-items:flex-start;gap:12px}.post-meta-divider{display:none}}@media(prefers-reduced-motion:reduce){*,*::before,*::after{animation-duration:.01ms!important;transition-duration:.01ms!important}}.posts .post:nth-child(1){animation-delay:0}.posts .post:nth-child(2){animation-delay:60ms}.posts .post:nth-child(3){animation-delay:120ms}.posts .post:nth-child(4){animation-delay:180ms}.posts .post:nth-child(5){animation-delay:240ms}