:root{--bg:#fbfaf7;--surface:#fffefb;--surface-warm:#f5f1e8;--ink:#191714;--ink-soft:#4f4941;--muted:#81786b;--line:#e6ded0;--line-strong:#d1c5b3;--accent:#b75f32;--accent-deep:#7d3c22;--accent-soft:#f3dfd1;--green:#35685c;--code-bg:#24211d;--code-ink:#f5efe5;--shadow:0 24px 70px rgba(74,52,28,0.09);--container:1160px}*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;background:linear-gradient(90deg,rgba(183,95,50,.035) 1px,transparent 1px),linear-gradient(rgba(183,95,50,.03) 1px,transparent 1px),var(--bg);background-size:44px 44px;color:var(--ink);font-family:ui-serif,Songti SC,"Noto Serif CJK SC",Georgia,serif;line-height:1.75;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;overflow-x:hidden}a{color:inherit;text-decoration:none}img{display:block;max-width:100%}button,input{font:inherit}.container{width:min(var(--container),calc(100% - 40px));margin-inline:auto}.site-header{position:-webkit-sticky;position:sticky;top:0;z-index:50;border-bottom:1px solid rgba(230,222,208,.88);background:rgba(251,250,247,.86);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px)}.site-header-inner{display:flex;align-items:center;justify-content:space-between;min-height:64px;gap:24px}.brand{display:inline-flex;align-items:center;gap:10px;font-weight:800;letter-spacing:0}.brand-mark{display:grid;width:30px;height:30px;place-items:center;border:1px solid var(--ink);border-radius:50%;background:var(--ink);color:var(--surface);font-size:13px;line-height:1}.main-nav{display:flex;align-items:center;gap:22px;color:var(--muted);font-family:ui-sans-serif,system-ui,sans-serif;font-size:14px}.main-nav a:hover{color:var(--accent-deep)}.site-footer{margin-top:88px;border-top:1px solid var(--line);color:var(--muted);font-family:ui-sans-serif,system-ui,sans-serif;font-size:14px}.site-footer-inner{display:flex;justify-content:space-between;gap:16px;padding-block:28px}.hero{padding:78px 0 52px}.hero-grid{display:grid;grid-template-columns:minmax(0,1.18fr) minmax(280px,.82fr);grid-gap:clamp(40px,8vw,96px);gap:clamp(40px,8vw,96px);align-items:flex-end}.eyebrow{margin:0 0 18px;color:var(--accent-deep);font-family:ui-sans-serif,system-ui,sans-serif;font-size:13px;font-weight:700;letter-spacing:.12em;text-transform:uppercase}.hero h1,.page-title{margin:0;max-width:760px;font-size:clamp(44px,8vw,92px);font-weight:900;letter-spacing:0;line-height:1.02}.hero-lead,.page-lead{margin:24px 0 0;max-width:680px;color:var(--ink-soft);font-size:clamp(18px,2.2vw,23px);line-height:1.75}.hero-aside{border-left:1px solid var(--line-strong);padding-left:28px}.hero-aside p{margin:0;color:var(--ink-soft)}.section{padding:56px 0}.section-head{display:flex;align-items:flex-end;justify-content:space-between;gap:24px;margin-bottom:24px}.section-head h2{margin:0;font-size:clamp(28px,4vw,44px);line-height:1.12}.view-link{color:var(--accent-deep);font-family:ui-sans-serif,system-ui,sans-serif;font-size:14px;font-weight:700}.article-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));grid-gap:18px;gap:18px}.article-card,.note-panel,.project-card{border:1px solid var(--line);background:rgba(255,254,251,.78);box-shadow:var(--shadow)}.article-card{display:flex;min-height:260px;flex-direction:column;padding:24px;transition:transform .18s ease,border-color .18s ease}.article-card:hover{border-color:var(--accent);transform:translateY(-3px)}.article-card-featured{grid-column:span 2}.meta-row{display:flex;flex-wrap:wrap;gap:10px;color:var(--muted);font-family:ui-sans-serif,system-ui,sans-serif;font-size:13px}.article-card h3{margin:18px 0 12px;font-size:clamp(22px,3vw,34px);line-height:1.22}.article-card p{margin:0;color:var(--ink-soft)}.tag-list{display:flex;flex-wrap:wrap;gap:8px;margin-top:auto;padding-top:22px}.tag{border:1px solid var(--line-strong);border-radius:999px;color:var(--muted);font-family:ui-sans-serif,system-ui,sans-serif;font-size:12px;padding:3px 9px}.project-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));grid-gap:18px;gap:18px}.project-card{overflow:hidden}.project-card-image{aspect-ratio:16/9;background:var(--surface-warm);border-bottom:1px solid var(--line)}.project-card-image img{width:100%;height:100%;object-fit:cover}.project-card-body{padding:22px}.project-card h3{margin:0 0 8px;font-size:22px;line-height:1.24}.project-card p{margin:0;color:var(--ink-soft)}.page-shell{padding:54px 0}.content-list{display:grid;grid-gap:16px;gap:16px;margin-top:32px}.list-item{display:grid;grid-template-columns:minmax(0,1fr) auto;grid-gap:24px;gap:24px;border-top:1px solid var(--line);padding:24px 0}.list-item h2{margin:0 0 8px;font-size:clamp(24px,3vw,34px);line-height:1.2}.list-item p{margin:0;color:var(--ink-soft)}.article-layout{display:grid;grid-template-columns:250px minmax(0,760px) 230px;grid-gap:34px;gap:34px;width:min(1400px,calc(100% - 36px));margin:0 auto;padding-top:34px}.article-sidebar,.article-toc{position:-webkit-sticky;position:sticky;top:88px;height:calc(100vh - 112px);overflow:auto;padding-bottom:24px;font-family:ui-sans-serif,system-ui,sans-serif;scrollbar-width:thin}.side-label{margin:0 0 12px;color:var(--muted);font-size:12px;font-weight:800;letter-spacing:.1em;text-transform:uppercase}.side-card{border-left:1px solid var(--line-strong);padding-left:16px}.side-list{display:grid;grid-gap:8px;gap:8px;margin:0;padding:0;list-style:none}.side-list a{display:block;border-radius:8px;color:var(--muted);font-size:14px;line-height:1.45;padding:8px 10px}.side-list a.active,.side-list a:hover{background:var(--accent-soft);color:var(--accent-deep)}.article-main{min-width:0}.article-header{border-bottom:1px solid var(--line);margin-bottom:34px;padding-bottom:28px}.article-header h1{margin:0;font-size:clamp(36px,6vw,62px);line-height:1.08;letter-spacing:0;overflow-wrap:anywhere}.article-description{margin:18px 0 0;color:var(--ink-soft);font-size:19px}.mobile-article-tools{display:none;margin:22px 0}.mobile-article-tools details{border:1px solid var(--line);background:var(--surface);margin-bottom:10px}.mobile-article-tools summary{cursor:pointer;font-family:ui-sans-serif,system-ui,sans-serif;font-weight:700;padding:12px 14px}.mobile-article-tools .side-card{border-left:0;border-top:1px solid var(--line);padding:12px}.prose{color:var(--ink);font-size:18px;overflow-wrap:anywhere}.prose h2,.prose h3{scroll-margin-top:92px}.prose h2{border-top:1px solid var(--line);margin:52px 0 18px;padding-top:28px;font-size:32px;line-height:1.22}.prose h3{margin:34px 0 12px;font-size:24px;line-height:1.28}.prose blockquote,.prose ol,.prose p,.prose pre,.prose table,.prose ul{margin:0 0 22px}.prose a{color:var(--accent-deep);text-decoration:underline;text-decoration-thickness:1px;text-underline-offset:3px}.prose strong{font-weight:800}.prose ol,.prose ul{padding-left:1.35em}.prose li+li{margin-top:7px}.prose blockquote{border-left:3px solid var(--accent);background:rgba(243,223,209,.42);color:var(--ink-soft);padding:16px 20px}.prose code{border-radius:5px;background:var(--surface-warm);color:var(--accent-deep);font-family:SFMono-Regular,Consolas,monospace;font-size:.88em;padding:.14em .34em}.prose pre{position:relative;overflow:auto;border-radius:12px;background:var(--code-bg);color:var(--code-ink);padding:20px}.prose pre code{background:transparent;color:inherit;padding:0}.copy-code-button{position:absolute;top:10px;right:10px;border:1px solid rgba(255,255,255,.2);border-radius:999px;background:rgba(255,255,255,.08);color:var(--code-ink);cursor:pointer;font-family:ui-sans-serif,system-ui,sans-serif;font-size:12px;padding:4px 9px}.prose table{display:block;max-width:100%;overflow-x:auto;width:100%;border-collapse:collapse;font-size:15px}.prose td,.prose th{border:1px solid var(--line);padding:10px 12px;text-align:left;vertical-align:top}.prose th{background:var(--surface-warm)}.toc-list{display:grid;grid-gap:4px;gap:4px;margin:0;padding:0;list-style:none}.toc-list a{display:block;border-left:2px solid transparent;color:var(--muted);font-size:13px;line-height:1.4;padding:6px 0 6px 10px}.toc-list a[data-level="3"]{padding-left:22px}.toc-list a.active,.toc-list a:hover{border-left-color:var(--accent);color:var(--accent-deep)}.article-bottom-nav{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));grid-gap:14px;gap:14px;border-top:1px solid var(--line);margin-top:48px;padding-top:24px}.article-bottom-nav a{border:1px solid var(--line);background:var(--surface);padding:16px}.article-bottom-nav span{display:block;color:var(--muted);font-family:ui-sans-serif,system-ui,sans-serif;font-size:12px;margin-bottom:4px}.about-grid{display:grid;grid-template-columns:minmax(0,1fr) 320px;grid-gap:48px;gap:48px;align-items:start}@media (max-width:1100px){.article-layout{grid-template-columns:minmax(0,1fr);width:auto;max-width:820px;margin-inline:17px}.article-sidebar,.article-toc{display:none}.mobile-article-tools{display:block}}@media (max-width:860px){.about-grid,.article-grid,.hero-grid,.project-grid{grid-template-columns:1fr}.article-card-featured{grid-column:auto}.hero-aside{border-left:0;border-top:1px solid var(--line-strong);padding:22px 0 0}.list-item,.section-head,.site-footer-inner,.site-header-inner{align-items:start;flex-direction:column}.main-nav{gap:14px}}@media (max-width:560px){.container{width:min(100% - 28px,var(--container))}.site-header-inner{min-height:auto;padding-block:14px}.main-nav{width:100%;justify-content:space-between;font-size:13px}.hero{padding-top:48px}.article-layout{width:auto;margin-inline:14px}.article-header h1{font-size:clamp(32px,9.5vw,38px);line-height:1.14;word-break:break-all}.article-main{overflow-x:hidden}.article-description,.prose{font-size:17px;word-break:break-word}.article-bottom-nav{grid-template-columns:1fr}}