:root{color-scheme:light;--bg: #ffffff;--title: #111111;--text: #444444;--muted: #777777;--border: #111111;--link: #2f2f2f;--card-bg: rgba(255, 255, 255, .86);--card-line: rgba(17, 17, 17, .14);--card-hover: rgba(17, 17, 17, .035);--soft: rgba(17, 17, 17, .06);--soft-strong: rgba(17, 17, 17, .14);--panel: #ffffff;--code-bg: #f4f4f4;--inline-code-bg: #eeeeee;--code-text: #1d1d1d;--grid: rgba(17, 17, 17, .035);--graph: rgba(17, 17, 17, .12);--graph-label: rgba(17, 17, 17, .12)}:root[data-mode=dark]{color-scheme:dark;--bg: #0f0f0f;--title: #f5f5f5;--text: #cfcfcf;--muted: #8d8d8d;--border: #f5f5f5;--link: #d9d9d9;--card-bg: rgba(15, 15, 15, .86);--card-line: rgba(245, 245, 245, .18);--card-hover: rgba(245, 245, 245, .045);--soft: rgba(245, 245, 245, .07);--soft-strong: rgba(245, 245, 245, .18);--panel: #0f0f0f;--code-bg: #1c1c1c;--inline-code-bg: #242424;--code-text: #f0f0f0;--grid: rgba(245, 245, 245, .045);--graph: rgba(245, 245, 245, .16);--graph-label: rgba(245, 245, 245, .16)}*{box-sizing:border-box}html{min-height:100%;scroll-behavior:smooth}body{min-height:100%;margin:0;overflow-x:hidden;background:var(--bg);color:var(--text);font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Microsoft YaHei,PingFang SC,Arial,sans-serif;letter-spacing:0;transition:background .18s ease,color .18s ease}.page{position:relative;min-height:100vh;background:var(--bg)}.page:before{position:fixed;inset:0;z-index:0;content:"";background-image:linear-gradient(var(--grid) 1px,transparent 1px),linear-gradient(90deg,var(--grid) 1px,transparent 1px);background-position:12% 0;background-size:88px 88px;mask-image:linear-gradient(90deg,transparent 0,rgba(0,0,0,.12) 8%,rgba(0,0,0,.5) 100%);pointer-events:none}.shell{position:relative;z-index:2;width:76vw;min-height:100vh;margin:0 12vw}.topbar{position:absolute;top:50px;left:0;right:0;display:flex;align-items:center;justify-content:space-between}.brand{display:inline-flex;align-items:center;color:inherit;text-decoration:none}.logo{color:var(--title);font-size:22px;font-weight:700;line-height:1}.brand:hover .logo{text-decoration:underline;text-underline-offset:5px}.top-actions{display:inline-flex;gap:8px;align-items:center}.search-icon,.mode-icon{display:inline-flex;width:38px;height:38px;align-items:center;justify-content:center;border:1px solid transparent;border-radius:999px;background:transparent;color:var(--title);cursor:pointer;transition:border-color .16s ease,background .16s ease,color .16s ease}.search-icon svg{width:18px;height:18px;fill:none;stroke:currentColor;stroke-linecap:round;stroke-linejoin:round;stroke-width:2}.mode-icon{font-size:21px;line-height:1}.search-icon:hover,.mode-icon:hover{border-color:var(--border);background:var(--title);color:var(--bg)}.hero{position:absolute;top:170px;left:0;width:min(700px,58vw)}.hero h1{margin:0 0 34px;color:var(--title);font-size:48px;font-weight:650;line-height:1.08}.tagline,.statement{margin:0 0 22px;color:var(--text);font-size:22px;font-weight:450;line-height:1.45}.statement{margin-bottom:54px}.actions{display:flex;gap:28px;align-items:center}.button{display:inline-flex;width:150px;height:54px;align-items:center;justify-content:center;gap:9px;border:1.5px solid var(--border);border-radius:40px;color:var(--title);background:transparent;font-size:17px;font-weight:520;line-height:1;text-decoration:none;transition:background .16s ease,color .16s ease,transform .16s ease}.button svg{display:block;width:18px;height:18px;flex:0 0 auto;color:currentColor}.button:hover{transform:translateY(-1px)}.github-button{border-color:var(--title);background:var(--title);color:var(--bg)}:root:not([data-mode=dark]) .button:hover{color:#fff;background:#111}:root[data-mode=dark] .button:hover{color:#111;background:#f5f5f5}.site-stats{margin:46px 0 0;color:var(--muted);font-size:14px;font-weight:520;line-height:1.6}.computer-graph{position:fixed;z-index:1;right:7.5%;top:178px;width:520px;height:470px;pointer-events:none}.computer-graph path,.computer-graph rect,.computer-graph polyline{stroke:#11111129;stroke-width:1.4;fill:none}:root[data-mode=dark] .computer-graph path,:root[data-mode=dark] .computer-graph rect,:root[data-mode=dark] .computer-graph polyline{stroke:#f5f5f533}.computer-graph circle{fill:#11111129}:root[data-mode=dark] .computer-graph circle{fill:#f5f5f533}.computer-graph text{fill:#1111111f;font-size:18px;font-weight:520}:root[data-mode=dark] .computer-graph text{fill:#f5f5f524}.notes-intro{width:min(100%,1080px);padding-top:170px}.intro-row{display:flex;gap:28px;align-items:flex-start;justify-content:space-between}.intro-copy{width:min(620px,100%);margin:0;color:var(--title);font-size:48px;font-weight:680;line-height:1.12}.intro-copy:after{display:block;width:72px;height:2px;margin-top:24px;border-radius:999px;background:var(--title);content:"";opacity:.75}.filter-control{position:relative;flex:0 0 auto;margin-top:8px}.filter-button{display:inline-flex;width:44px;height:44px;align-items:center;justify-content:center;border:1px solid var(--card-line);border-radius:999px;background:var(--card-bg);color:var(--title);cursor:pointer}.filter-button svg{width:18px;height:18px;fill:none;stroke:currentColor;stroke-linecap:round;stroke-linejoin:round;stroke-width:2}.filter-button:hover,.filter-button[aria-expanded=true]{border-color:var(--title);background:var(--title);color:var(--bg)}.filter-menu{position:absolute;top:calc(100% + 12px);right:0;z-index:8;display:grid;width:286px;gap:18px;border:1px solid var(--card-line);border-radius:18px;padding:16px;background:var(--bg);backdrop-filter:none;-webkit-backdrop-filter:none;box-shadow:0 18px 48px #00000014;opacity:0;pointer-events:none;transform:translateY(-4px);transition:opacity .16s ease,transform .16s ease}.filter-control.is-open .filter-menu{opacity:1;pointer-events:auto;transform:translateY(0)}.filter-group{display:grid;gap:10px}.filter-label{color:var(--muted);font-size:12px;font-weight:650}.filter-select{width:100%;height:38px;border:1px solid var(--card-line);border-radius:10px;padding:0 10px;background:transparent;color:var(--title);font:inherit;font-size:14px}.filter-tags{display:flex;flex-wrap:wrap;gap:8px}.filter-chip,.tag{display:inline-flex;align-items:center;border:1px solid var(--card-line);border-radius:999px;background:transparent;color:var(--title);line-height:1}.filter-chip{height:30px;padding:0 11px;cursor:pointer;font-size:12px}.filter-chip.is-active,.filter-chip:hover{border-color:var(--title);background:var(--title);color:var(--bg)}.filter-reset{justify-self:start;border:0;padding:0;background:transparent;color:var(--muted);cursor:pointer;font:inherit;font-size:13px;text-decoration:underline;text-underline-offset:4px}.masonry{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));align-items:start;gap:34px 30px;width:min(100%,1080px);margin-top:66px}.project-card{width:100%;margin:0;border-top:1px solid var(--card-line);border-radius:6px;background:transparent;color:var(--text);overflow:hidden;transition:background .18s ease,transform .16s ease}.project-card:hover{background:var(--card-hover);transform:translateY(-1px)}.project-card.is-pinned{border-top-color:var(--title)}.card-body{display:grid;grid-template-columns:78px minmax(0,1fr);gap:24px;padding:28px 12px 32px}.card-date{color:var(--title);line-height:1}.card-content{display:flex;min-width:0;flex-direction:column;align-items:flex-start}.card-heading{display:flex;width:100%;min-width:0;align-items:baseline;justify-content:space-between;gap:14px}.date-day{display:block;font-size:58px;font-weight:720}.date-month{display:block;margin-top:12px;color:var(--text);font-size:17px}.project-card h2{margin:0 0 14px;color:var(--title);font-size:27px;font-weight:650;line-height:1.18}.pin-marker{flex:0 0 auto;border:1px solid var(--soft-strong);border-radius:999px;padding:4px 9px;color:var(--title);font-size:12px;font-weight:700;line-height:1}.project-card p{margin:0;color:var(--text);font-size:16px;line-height:1.72}.card-tags{display:flex;flex-wrap:wrap;gap:8px;margin-top:28px}.tag{height:27px;padding:0 10px;font-size:12px}.card-link{display:inline-flex;min-height:38px;margin-top:26px;align-items:center;justify-content:center;border:1px solid var(--soft-strong);border-radius:999px;padding:0 18px;color:var(--title);font-size:14px;font-weight:650;text-decoration:none;transition:border-color .16s ease,background .16s ease,color .16s ease,transform .16s ease}.card-link:hover{border-color:var(--title);background:var(--title);color:var(--bg);transform:translateY(-1px)}.side-ornament,.note-ornament{position:fixed;z-index:1;display:grid;gap:16px;width:92px;color:var(--graph-label);pointer-events:none}.side-ornament.left,.note-ornament{top:206px;left:max(28px,calc(12vw - 86px))}.side-ornament.right{top:318px;right:max(28px,calc(12vw - 86px))}.ornament-label{color:var(--graph-label);font-size:11px;font-weight:650;letter-spacing:.12em;line-height:1;text-transform:uppercase}.ornament-chip{display:inline-flex;width:max-content;height:22px;align-items:center;border:1px solid var(--graph-label);border-radius:999px;padding:0 9px;color:var(--graph-label);font-size:11px;font-weight:650;letter-spacing:.08em}.ornament-lines{display:grid;gap:9px}.ornament-lines span{display:block;height:1px;border-radius:999px;background:var(--graph-label)}.ornament-lines span:nth-child(1),.ornament-lines span:nth-child(5){width:58px}.ornament-lines span:nth-child(2),.ornament-lines span:nth-child(4){width:34px}.ornament-lines span:nth-child(3){width:76px}.ornament-bits{color:var(--graph-label);font-family:SFMono-Regular,Consolas,Liberation Mono,monospace;font-size:10px;line-height:1.55;letter-spacing:.06em}.ornament-node{width:7px;height:7px;border:1px solid var(--graph-label);border-radius:50%}.ornament-cross{position:relative;width:18px;height:18px;color:var(--graph-label)}.ornament-cross:before,.ornament-cross:after{position:absolute;top:8px;left:0;width:18px;height:1px;background:currentColor;content:""}.ornament-cross:after{transform:rotate(90deg)}.ornament-port{display:grid;width:44px;gap:5px}.ornament-port span{height:4px;border:1px solid var(--graph-label);border-radius:2px}.article-shell{min-height:156px}.reading-header{position:fixed;top:0;left:0;right:0;z-index:20;display:grid;grid-template-columns:minmax(120px,1fr) minmax(0,720px) minmax(120px,1fr);align-items:center;min-height:52px;padding:0 12vw;border-bottom:1px solid transparent;background:var(--bg);opacity:0;pointer-events:none;transform:translateY(-100%);transition:opacity .22s ease,transform .24s cubic-bezier(.2,.8,.2,1),border-color .22s ease,background .22s ease}.reading-header.is-visible{border-color:var(--soft-strong);opacity:1;pointer-events:auto;transform:translateY(0)}.reading-header .brand{justify-self:start}.reading-title{justify-self:center;max-width:min(720px,52vw);overflow:hidden;color:var(--title);font-size:24px;font-weight:800;line-height:1.08;text-align:center;text-overflow:ellipsis;white-space:nowrap}.reading-header .top-actions{justify-self:end}.reading-header .logo{font-size:20px}.reading-header .search-icon,.reading-header .mode-icon{width:30px;height:30px}.reading-header .search-icon svg{width:16px;height:16px}.reading-header .mode-icon{font-size:18px}.article-layout{position:relative;z-index:3;width:min(760px,calc(100% - 48px));margin:24px auto 0}.article-header{margin-bottom:54px}.article-meta{display:flex;flex-wrap:wrap;gap:10px;align-items:center;margin-bottom:26px;color:var(--muted);font-size:13px;font-weight:560}.article-meta span+span:before{margin-right:10px;content:"/";opacity:.55}.article-header h1{margin:0;color:var(--title);font-size:58px;font-weight:680;line-height:1.08}.dek{width:min(620px,100%);margin:28px 0 0;color:var(--text);font-size:20px;font-weight:420;line-height:1.72}.article-divider{width:100%;height:1px;margin-top:42px;background:var(--soft-strong)}.article-content{color:var(--text);font-size:18px;line-height:1.92}.article-content section{scroll-margin-top:78px;margin:0 0 58px}.article-content h1,.article-content h2,.article-content h3,.article-content h4,.article-content h5,.article-content h6{margin:0 0 18px;color:var(--title);font-weight:650;line-height:1.28}.article-content h1{font-size:34px}.article-content h2{font-size:28px}.article-content h3{font-size:22px}.article-content h4,.article-content h5,.article-content h6{font-size:20px}.article-content p{margin:0 0 22px}.article-content figure{margin:34px 0}.article-content img{display:block;width:100%;max-height:72vh;margin:32px 0;border:1px solid var(--soft-strong);border-radius:14px;object-fit:contain;background:var(--panel);cursor:zoom-in}.article-content figure img{margin:0}.article-content figcaption{margin-top:10px;color:var(--muted);font-size:13px;line-height:1.6;text-align:center}.article-content pre{margin:30px 0;border:1px solid var(--soft-strong);border-radius:14px;background:var(--code-bg)!important;color:var(--code-text);box-shadow:inset 0 1px #ffffff0a;overflow:auto}.article-content code{font-family:SFMono-Regular,Consolas,Liberation Mono,monospace}.article-content :not(pre)>code{border:1px solid var(--soft-strong);border-radius:6px;padding:.14em .36em;background:var(--inline-code-bg);color:var(--title);font-size:.92em}.article-content pre code{display:block;padding:20px 22px;background:transparent;color:var(--code-text);font-size:14px;line-height:1.72}.end-note{margin:72px 0 0;color:var(--muted);font-size:13px;line-height:1.6;text-align:center}.end-note a{color:inherit;text-decoration:none}.end-note a:hover{color:var(--title);text-decoration:underline;text-underline-offset:4px}.section-rail{position:fixed;z-index:6;top:50%;right:clamp(30px,8.2vw,118px);display:grid;gap:10px;transform:translateY(-50%)}.section-rail:before{position:absolute;top:-18px;right:100%;bottom:-18px;width:26px;content:""}.rail-link{display:block;width:30px;height:4px;border-radius:999px;background:var(--soft-strong);text-decoration:none;transition:width .16s ease,background .16s ease}.rail-link:hover,.rail-link.is-active{width:34px;background:var(--title)}.section-rail.is-compact{gap:5px}.section-rail.is-compact .rail-link{width:26px;height:3px}.rail-panel{position:absolute;top:50%;right:calc(100% + 14px);display:grid;width:224px;max-height:min(520px,calc(100vh - 110px));gap:2px;border:1px solid var(--soft-strong);border-radius:18px;padding:10px;background:var(--panel);backdrop-filter:none;-webkit-backdrop-filter:none;box-shadow:0 18px 48px #00000014;overflow:auto;opacity:0;pointer-events:none;transform:translate(8px,-50%);transition:opacity .16s ease,transform .16s ease}.section-rail:hover .rail-panel,.section-rail.is-open .rail-panel,.section-rail:focus-within .rail-panel{opacity:1;pointer-events:auto;transform:translateY(-50%)}.rail-panel a{position:relative;display:block;border-radius:10px;padding:9px 10px 9px 24px;color:var(--text);font-size:13px;line-height:1.2;text-decoration:none}.rail-panel a[data-level="1"]{color:var(--title);font-weight:700}.rail-panel a[data-level="3"]{padding-left:34px;color:var(--muted);font-size:12px}.rail-panel a[data-level="4"],.rail-panel a[data-level="5"],.rail-panel a[data-level="6"]{padding-left:42px;color:var(--muted);font-size:12px}.rail-panel a:hover,.rail-panel a:focus-visible{background:var(--soft);color:var(--title)}.rail-panel a.is-current{color:var(--title)}.rail-panel a.is-current:before{position:absolute;top:50%;left:9px;transform:translateY(-50%);content:"▸"}.back-top{position:fixed;z-index:7;right:clamp(28px,6.5vw,86px);bottom:34px;display:inline-flex;width:42px;height:42px;align-items:center;justify-content:center;border:1px solid var(--soft-strong);border-radius:999px;background:var(--panel);color:var(--title);font-size:19px;line-height:1;text-decoration:none;opacity:0;pointer-events:none;transform:translateY(8px);transition:opacity .16s ease,transform .16s ease,background .16s ease,color .16s ease,border-color .16s ease}.back-top.is-visible{opacity:1;pointer-events:auto;transform:translateY(0)}.back-top:hover{border-color:var(--title);background:var(--title);color:var(--bg)}.reading-progress{position:fixed;z-index:7;right:clamp(28px,6.5vw,86px);bottom:86px;display:inline-flex;min-width:42px;height:24px;align-items:center;justify-content:center;border:1px solid var(--soft-strong);border-radius:999px;padding:0 8px;background:var(--panel);color:var(--muted);font-size:12px;font-weight:650;line-height:1;opacity:0;pointer-events:none;transform:translateY(8px);transition:opacity .16s ease,transform .16s ease}.reading-progress.is-visible{opacity:1;transform:translateY(0)}.image-lightbox{position:fixed;inset:0;z-index:40;display:grid;place-items:center;padding:28px;background:#ffffffdb;opacity:0;pointer-events:none;transition:opacity .16s ease}:root[data-mode=dark] .image-lightbox{background:#0f0f0fe6}.image-lightbox.is-open{opacity:1;pointer-events:auto}.image-lightbox img{max-width:min(1120px,96vw);max-height:92vh;border:1px solid var(--soft-strong);border-radius:14px;background:var(--panel);object-fit:contain}.not-found{position:absolute;top:220px;left:0;width:min(680px,64vw)}.not-found .code{margin:0 0 18px;color:var(--muted);font-size:13px;font-weight:650;letter-spacing:.08em;text-transform:uppercase}.not-found h1{margin:0 0 24px;color:var(--title);font-size:54px;font-weight:680;line-height:1.08}.not-found p{width:min(560px,100%);margin:0 0 42px;color:var(--text);font-size:20px;line-height:1.72}.search-overlay{position:fixed;inset:0;z-index:30;display:grid;place-items:start center;padding:92px 24px 24px;background:#ffffffb8;opacity:0;pointer-events:none;transition:opacity .16s ease}:root[data-mode=dark] .search-overlay{background:#0f0f0fb8}.search-overlay.is-open{opacity:1;pointer-events:auto}.search-dialog{width:min(680px,100%);border:1px solid var(--soft-strong);border-radius:18px;background:var(--panel);box-shadow:0 24px 70px #0000001f;overflow:hidden}.search-head{display:grid;grid-template-columns:1fr auto;gap:10px;align-items:center;border-bottom:1px solid var(--soft-strong);padding:14px}.search-input{width:100%;border:0;outline:0;background:transparent;color:var(--title);font:inherit;font-size:17px;line-height:1.4}.search-close{display:inline-flex;width:32px;height:32px;align-items:center;justify-content:center;border:1px solid transparent;border-radius:999px;background:transparent;color:var(--muted);cursor:pointer;font-size:20px;line-height:1}.search-results{max-height:min(520px,calc(100vh - 190px));overflow:auto;padding:8px}.search-empty{padding:24px 18px;color:var(--muted);font-size:14px;line-height:1.6}.search-result{display:block;border-radius:12px;padding:13px 14px;color:inherit;text-decoration:none}.search-result:hover,.search-result:focus-visible{background:var(--soft);outline:0}.search-result-title{color:var(--title);font-size:16px;font-weight:650;line-height:1.35}.search-result-meta{margin-top:4px;color:var(--muted);font-size:12px;line-height:1.4}.search-result-snippet{margin-top:8px;color:var(--text);font-size:14px;line-height:1.55}.search-mark{border-radius:4px;background:var(--soft);color:var(--title);font-weight:650}@media(max-width:860px){.shell{width:calc(100vw - 48px);margin:0 24px}.hero{width:100%}.hero h1,.intro-copy{font-size:40px}.actions{flex-wrap:wrap}.computer-graph{opacity:.42;right:-220px}.notes-intro{width:100%;padding-top:170px}.masonry{grid-template-columns:1fr}.card-body{grid-template-columns:64px minmax(0,1fr);gap:18px;padding-right:0;padding-left:0}.date-day{font-size:44px}.project-card h2{font-size:24px}.side-ornament,.note-ornament{display:none}.reading-header{grid-template-columns:auto minmax(0,1fr) auto;min-height:52px;padding:0 24px}.reading-title{max-width:calc(100vw - 180px);font-size:16px}.article-layout{width:calc(100% - 48px);margin-top:24px}.article-header h1{font-size:40px}.dek{font-size:18px}.article-content{font-size:17px}.section-rail{display:none}}
