@import"https://fonts.googleapis.com/css2?family=Source+Serif+Pro:wght@400;600&family=Noto+Serif+SC:wght@400;500&family=Noto+Sans+SC:wght@400;500&display=swap";@font-face{font-family:TsangerJinKai02;src:url(/fonts/TsangerJinKai02-W04.ttf) format("truetype");font-weight:400 500;font-style:normal;font-display:swap}:root{--bg: #f5f4ed;--bg-elev: #efede4;--bg-card: #fffef8;--bg-grain: #ebe9e0;--accent: #1B365D;--accent-fg: #f5f4ed;--accent-soft: #1B365D14;--fg: #2d2a24;--fg-dim: #5c574d;--fg-mute: #8a8477;--rule: #d9d5c8;--rule-strong: #c4bfaf;--shadow-whisper: 0 1px 2px rgba(45, 42, 36, .04);--shadow-ring: 0 0 0 1px var(--rule);--shadow-hover: 0 2px 8px rgba(45, 42, 36, .08);--serif: "TsangerJinKai02", "Source Han Serif SC", "Noto Serif CJK SC", "Songti SC", Georgia, serif;--serif-cn: "TsangerJinKai02", "Source Han Serif SC", "Noto Serif CJK SC", "Songti SC", Georgia, serif;--sans-cn: "Noto Sans SC", sans-serif;--mono: ui-monospace, "SF Mono", Consolas, monospace;--maxw: 1120px}*{box-sizing:border-box;margin:0;padding:0}html,body{background:var(--bg);color:var(--fg);font-family:var(--serif);font-size:16px;line-height:1.6;font-weight:400;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}body{min-height:100vh;overflow-x:hidden}::selection{background:var(--accent);color:var(--accent-fg)}a{color:inherit;text-decoration:none}button{font:inherit;color:inherit;background:none;border:0}.container{max-width:var(--maxw);margin:0 auto;padding:0 32px;position:relative;z-index:2}.display{font-family:var(--serif);font-weight:600;font-style:normal;letter-spacing:-.02em;line-height:1.1;overflow-wrap:anywhere}.eyebrow{font-family:var(--serif);font-size:13px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--fg-dim)}.label{font-family:var(--serif);font-size:12px;font-weight:400;letter-spacing:.04em;text-transform:uppercase;color:var(--fg-mute)}.meta{font-family:var(--serif);font-size:14px;color:var(--fg-dim)}.cn{font-family:var(--serif-cn);color:var(--fg-dim);font-style:normal}.cn-body{font-family:var(--sans-cn);letter-spacing:.3pt;color:var(--fg)}.page-enter{animation:pageIn .7s cubic-bezier(.2,.7,.2,1) both}@keyframes pageIn{0%{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}.stagger>*{opacity:0;animation:rise .8s cubic-bezier(.2,.7,.2,1) forwards}@keyframes rise{to{opacity:1;transform:none}}.page-frame{filter:blur(0px);opacity:1;transition:filter .42s cubic-bezier(.4,0,.2,1),opacity .42s cubic-bezier(.4,0,.2,1);will-change:filter,opacity}.page-frame.is-leaving{filter:blur(14px);opacity:.45;pointer-events:none}.ulink{position:relative;display:inline-block}.ulink:after{content:"";position:absolute;left:0;right:0;bottom:-2px;height:1px;background:currentColor;transform:scaleX(0);transform-origin:right;transition:transform .4s cubic-bezier(.2,.7,.2,1)}.ulink:hover:after{transform:scaleX(1);transform-origin:left}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--rule-strong);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--fg-mute)}.dock{--dock-pad: 8px;position:fixed;bottom:28px;left:50%;transform:translate(-50%);z-index:50;display:flex;align-items:center;gap:2px;padding:var(--dock-pad);border-radius:999px;background:var(--bg-card);border:1px solid var(--rule);box-shadow:var(--shadow-ring),var(--shadow-whisper)}.dock-item{position:relative;padding:13px 24px;border-radius:999px;font-family:var(--serif);font-size:14px;font-weight:400;letter-spacing:.02em;text-transform:none;color:var(--fg-dim);transition:color .2s;cursor:pointer;min-height:44px;min-width:44px}.dock-item:hover{color:var(--fg)}.dock-item.active{color:var(--accent-fg)}.dock-thumb{position:absolute;top:var(--dock-pad);height:calc(100% - 2 * var(--dock-pad));border-radius:999px;background:var(--accent);transition:left .45s cubic-bezier(.34,1.56,.64,1),width .45s cubic-bezier(.34,1.56,.64,1);touch-action:none}.dock.dragging .dock-thumb{transition:none}.dock.dragging .dock-item{transition:color .15s;cursor:grabbing}.dock-item:active{transform:scale(.96);transition:transform .12s}.hov{position:relative}.card{background:var(--bg-card);border:1px solid var(--rule);border-radius:6px;box-shadow:var(--shadow-ring);transition:border-color .25s,box-shadow .25s,transform .35s cubic-bezier(.2,.7,.2,1)}.card:hover{border-color:var(--rule-strong);box-shadow:var(--shadow-hover)}.chip{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border:none;border-bottom:2px solid transparent;border-radius:0;font-family:var(--serif);font-size:14px;font-weight:400;letter-spacing:.01em;text-transform:none;color:var(--fg-dim);background:transparent;transition:all .2s;cursor:pointer;position:relative}.chip:hover{color:var(--fg);border-bottom-color:var(--rule-strong)}.chip.on{color:var(--accent);border-bottom-color:var(--accent);font-weight:500}.chip:focus-visible{outline:1.5px solid var(--accent);outline-offset:4px}.marquee{overflow:hidden;-webkit-mask-image:linear-gradient(90deg,transparent,black 8%,black 92%,transparent);mask-image:linear-gradient(90deg,transparent,black 8%,black 92%,transparent)}.marquee-track{display:flex;gap:60px;animation:scrollx 50s linear infinite;width:max-content}@keyframes scrollx{to{transform:translate(-50%)}}.glyph{font-family:var(--mono);font-size:9px;letter-spacing:.1em;color:var(--fg-mute)}.spinring{animation:spin 30s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.35}}.ph{position:relative;overflow:hidden;background:var(--bg-elev)}.ph:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:repeating-linear-gradient(135deg,transparent 0 20px,var(--rule) 20px 21px)}.ph-warm{background:linear-gradient(135deg,#e8e2d4,#d4cfc0)}.ph-cool{background:linear-gradient(135deg,#ddd9cc,#c8c4b8)}.arr{display:inline-block;transition:transform .3s cubic-bezier(.2,.7,.2,1)}.ulink:hover .arr,a:hover .arr,button:hover .arr{transform:translate(3px,-3px)}.above-wipe{z-index:300}.prose{color:var(--fg);overflow-wrap:anywhere;word-break:break-word;min-width:0}.prose>*+*{margin-top:1.1em}.prose a{word-break:break-word}.prose h1,.prose h2,.prose h3,.prose h4,.prose h5,.prose h6{font-family:var(--serif);font-weight:500;letter-spacing:-.02em;line-height:1.2;color:var(--fg)}.prose h1{font-size:2.4em;margin-top:2em;margin-bottom:.6em}.prose h2{font-size:1.9em;margin-top:1.8em;margin-bottom:.5em}.prose h3{font-size:1.55em;margin-top:1.5em;margin-bottom:.45em}.prose h4{font-size:1.25em;margin-top:1.3em;margin-bottom:.4em}.prose h5{font-size:1.1em;margin-top:1.1em;margin-bottom:.35em}.prose h6{font-size:1em;margin-top:1em;margin-bottom:.3em;color:var(--fg-dim)}.prose h1:first-child,.prose h2:first-child,.prose h3:first-child,.prose h4:first-child,.prose h5:first-child,.prose h6:first-child{margin-top:0}.prose p{margin:0}.prose a{color:var(--fg);text-decoration:underline;text-underline-offset:3px;text-decoration-thickness:1px;text-decoration-color:var(--rule-strong)}.prose a:hover{text-decoration-color:currentColor}.prose ul,.prose ol{padding-left:1.5em}.prose li+li{margin-top:.4em}.prose blockquote{border-left:2px solid var(--rule-strong);padding-left:1em;color:var(--fg-dim);font-style:italic;margin-bottom:1.8em}.prose hr{border:0;border-top:.5px solid var(--rule-strong);margin:2em 0}.prose img{max-width:100%;border-radius:6px}.prose strong{font-weight:600;color:var(--fg)}.prose em{font-style:italic}.prose .table-scroll{width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch;border:.5px solid var(--rule-strong);border-radius:4px}.prose .table-scroll>table{border:0;min-width:560px}.prose table{width:100%;border-collapse:collapse;font-family:var(--sans);font-size:.95em;border:.5px solid var(--rule-strong)}.prose th,.prose td{border:.5px solid var(--rule-strong);padding:10px 14px;text-align:left;vertical-align:top}.prose th{background:var(--bg-elev);font-family:var(--mono);font-size:11px;font-weight:500;letter-spacing:.08em;text-transform:uppercase;color:var(--fg-dim)}.prose tbody tr:nth-child(2n) td{background:color-mix(in oklab,var(--bg-elev) 50%,transparent)}.prose code{font-family:var(--mono);font-size:.88em;background:var(--bg-elev);border:.5px solid var(--rule);padding:2px 6px;border-radius:4px}.prose pre{background:var(--bg-elev);border:.5px solid var(--rule-strong);border-radius:6px;padding:16px 18px;overflow-x:auto;font-family:var(--mono);font-size:.88em;line-height:1.55;color:var(--fg)}.prose pre code{background:transparent;border:0;padding:0;font-size:inherit;border-radius:0;white-space:pre}.prose h1,.prose h2,.prose h3,.prose h4,.prose h5,.prose h6{scroll-margin-top:80px}.thought-article>header.container{padding-top:80px}@media (max-width: 720px){.thought-article>header.container,.thought-article>.thought-body.container,.thought-article>footer.container{padding-top:80px!important;padding-left:24px!important;padding-right:24px!important}.thought-article>.thought-body.container{padding-top:32px!important}.thought-article>footer.container{padding-top:32px!important}}.thought-back-anchor{position:sticky;top:0;height:0;z-index:50;pointer-events:none}.thought-back-fab{position:absolute;top:20px;left:20px;pointer-events:auto;display:inline-flex;align-items:center;justify-content:center;width:44px;height:44px;border-radius:999px;background:color-mix(in oklab,var(--bg-elev) 70%,transparent);-webkit-backdrop-filter:blur(20px) saturate(140%);backdrop-filter:blur(20px) saturate(140%);border:.5px solid var(--rule-strong);color:var(--fg-dim);font-family:var(--mono);font-size:18px;line-height:1;text-decoration:none;box-shadow:0 8px 24px #00000040;transition:color .2s,background .2s,transform .2s,border-color .2s}.thought-back-fab:hover{color:var(--fg);background:color-mix(in oklab,var(--bg-elev) 60%,var(--fg) 6%);border-color:var(--fg-mute);transform:translate(-2px)}.thought-back-fab:focus-visible{outline:1.5px solid var(--accent);outline-offset:2px}.thought-list-section{padding-top:40px;padding-bottom:60px}.thought-list-row{display:grid;grid-template-columns:80px 140px 1fr auto;gap:28px;padding:28px 0;align-items:baseline;transition:padding .25s cubic-bezier(.2,.7,.2,1)}.thought-list-row:hover{padding-left:16px}@media (max-width: 720px){section.container.thought-list-section{padding-top:8px!important;padding-bottom:24px!important}.thought-list-row{grid-template-columns:auto 1fr auto;column-gap:14px;row-gap:8px;padding:20px 0;align-items:start}.thought-list-row:hover{padding-left:0}.thought-list-row>.meta:first-child{grid-column:1;grid-row:1}.thought-list-row>.label{grid-column:2;grid-row:1}.thought-list-row>.meta:last-child{grid-column:3;grid-row:1;align-self:center}.thought-list-row>div{grid-column:1 / -1;grid-row:2;min-width:0}.thought-list-row>div h4{font-size:22px!important;word-break:break-word}}.thought-body{padding-top:60px;padding-bottom:60px}.thought-toc{display:none;z-index:40}.thought-toc-panel{position:absolute;top:0;left:0;width:210px;max-height:calc(100vh - 200px);overflow-y:auto;padding:14px 16px;background:color-mix(in oklab,var(--bg-elev) 70%,transparent);-webkit-backdrop-filter:blur(20px) saturate(140%);backdrop-filter:blur(20px) saturate(140%);border:.5px solid var(--rule-strong);border-radius:8px;box-shadow:0 12px 40px #00000040;transition:transform .35s cubic-bezier(.2,.7,.2,1),opacity .25s}.thought-toc.is-collapsed .thought-toc-panel{transform:translate(calc(-100% - 32px));opacity:0;pointer-events:none}.thought-toc-toggle{position:absolute;top:4px;left:210px;width:30px;height:44px;display:inline-flex;align-items:center;justify-content:center;background:var(--bg-elev);border:.5px solid var(--rule-strong);border-radius:0 6px 6px 0;cursor:pointer;color:var(--fg-dim);font-family:var(--mono);font-size:16px;line-height:1;transition:left .35s cubic-bezier(.2,.7,.2,1),color .15s,background .15s}.thought-toc.is-collapsed .thought-toc-toggle{left:0;border-radius:0 6px 6px 0}.thought-toc-toggle:hover{color:var(--fg);background:color-mix(in oklab,var(--bg-elev) 60%,var(--fg) 4%)}.thought-toc-toggle:focus-visible{outline:1.5px solid var(--accent);outline-offset:2px}.thought-toc-label{font-family:var(--mono);font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--fg-mute);margin-bottom:10px}.thought-toc ul{list-style:none;padding:0;margin:0}.thought-toc li{margin:0}.thought-toc li[data-level="3"] a{padding-left:22px}.thought-toc li[data-level="4"] a{padding-left:34px}.thought-toc li[data-level="5"] a,.thought-toc li[data-level="6"] a{padding-left:46px}.thought-toc a{display:block;font-family:var(--sans);font-size:12.5px;line-height:1.4;color:var(--fg-dim);padding:5px 0 5px 12px;border-left:2px solid transparent;transition:color .15s,border-color .15s,background .15s;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.thought-toc a:hover{color:var(--fg)}.thought-toc li.is-active>a{color:var(--accent);border-left-color:var(--accent)}@media (min-width: 1100px){.thought-body{display:flex;align-items:flex-start;gap:24px}.thought-content{flex:1;min-width:0}.thought-toc{display:block;position:sticky;top:80px;align-self:flex-start;flex:0 0 240px;width:240px;height:0;transition:flex-basis .35s cubic-bezier(.2,.7,.2,1),width .35s cubic-bezier(.2,.7,.2,1)}.thought-toc.is-collapsed{flex:0 0 30px;width:30px}}@media (max-width: 960px){.container{padding:0 24px}.r-cols-3{grid-template-columns:repeat(2,1fr)!important;gap:24px!important}.r-cols-meta{grid-template-columns:1fr!important;gap:24px!important}.r-hide-md{display:none!important}.r-rule-grid{grid-template-columns:repeat(2,1fr)!important}}@media (max-width: 720px){.container{padding:0 16px}.r-cols-2,.r-cols-3,.r-cols-meta{grid-template-columns:1fr!important;gap:20px!important}.r-rule-grid{grid-template-columns:1fr!important;gap:0!important;background:transparent!important}section.container,header.container,footer.container{padding-top:40px!important;padding-bottom:40px!important}.r-hero{grid-template-columns:1fr!important;gap:24px!important}.r-hero .r-ring{order:-1}.display{font-size:clamp(40px,11vw,72px)!important;line-height:1!important}.dock{--dock-pad: 6px;bottom:16px;gap:2px;max-width:calc(100vw - 16px)}.dock-item{padding:12px 14px;font-size:12px;letter-spacing:.04em;min-height:44px}.r-stack{display:flex!important;flex-direction:column!important;align-items:flex-start!important;gap:12px!important}.r-stack>*{width:100%}.page-enter{padding-bottom:calc(env(safe-area-inset-bottom) + 140px)!important}.r-cols-3>.card,.r-cols-2>.card,.r-cols-2>a>article,.r-cols-2>.connect-link{min-height:0!important;padding:20px 0!important;background:transparent!important;border:none!important;box-shadow:none!important;border-bottom:.5px solid var(--rule)!important;border-radius:0!important}.r-cols-3>.card:last-child,.r-cols-2>.card:last-child,.r-cols-2>a:last-child>article,.r-cols-2>.connect-link:last-child{border-bottom:none!important}.r-cols-3>.card{flex-direction:row!important;align-items:flex-start!important;gap:16px!important}.r-cols-3>.card .tool-card-header,.r-cols-3>.card .web-card-header{flex-direction:column!important;align-items:center!important;flex-shrink:0!important;width:auto!important}.r-cols-3>.card .tool-cat{display:none!important}.r-cols-3>.card .tool-card-body,.r-cols-3>.card .web-card-body{flex:1!important;min-width:0!important}.r-cols-3>.card h3{font-size:18px!important;margin-bottom:4px!important}.r-cols-3>.card p{font-size:13px!important}.r-cols-3>.card .tool-card-link,.r-cols-3>.card .web-card-chips{display:none!important}.r-cols-3>.card .tool-card-header>div:first-child,.r-cols-3>.card .web-card-header>div:first-child{width:44px!important;height:44px!important;font-size:12px!important}.r-cols-2>a>article>div:first-child{margin-bottom:8px!important}.r-cols-2>a>article h4{font-size:18px!important;margin-bottom:6px!important;line-height:1.3!important}.r-cols-2>a>article p{font-size:13px!important;line-height:1.5!important}.chip,button.chip{min-height:44px!important;padding:12px 20px!important;font-size:15px!important;border-bottom-width:2.5px!important}.r-cols-2>.connect-link{gap:16px!important}.r-cols-2>.connect-link>div:first-child{width:44px!important;height:44px!important;font-size:12px!important}.r-cols-2>.connect-link h3{font-size:20px!important;margin-bottom:2px!important}.r-cols-2>.connect-link .meta{font-size:13px!important;margin-bottom:6px!important}.r-cols-2>.connect-link p{font-size:13px!important}.r-cols-2>.connect-link .arr{display:none!important}.home-header,.home-about,.home-projects,.home-thoughts,.home-connect{border-bottom:.5px solid var(--rule)!important;padding-top:32px!important;padding-bottom:32px!important}.home-footer{padding-top:32px!important;padding-bottom:32px!important}.home-projects h3{font-size:28px!important}.home-projects article>div:first-child>div:first-child{gap:12px!important}.home-projects article>div:first-child{margin-bottom:16px!important}.home-projects article p{margin-bottom:16px!important}.home-about h2,.home-projects h2,.home-thoughts h2,.home-connect h2{font-size:32px!important}.home-thoughts article{padding:20px 0!important;border-bottom:.5px solid var(--rule)!important}.home-thoughts .r-cols-2>a:last-child>article{border-bottom:none!important}}
