.brand[data-astro-cid-tvrurpns]{display:inline-flex;align-items:center;gap:10px;color:var(--color-ink);text-decoration:none}.brand[data-astro-cid-tvrurpns] img[data-astro-cid-tvrurpns]{width:88px;height:88px;object-fit:contain;transition:filter var(--duration-normal) var(--ease-soft)}:root[data-theme=dark] .brand[data-astro-cid-tvrurpns] img[data-astro-cid-tvrurpns]{filter:invert(1)}.brand-large[data-astro-cid-tvrurpns]{flex-direction:column;gap:var(--space-4);align-items:center}.brand-large[data-astro-cid-tvrurpns] img[data-astro-cid-tvrurpns]{width:clamp(260px,24vw,360px);height:auto}.site-header[data-astro-cid-3ef6ksr2]{position:sticky;z-index:10;top:0;background:color-mix(in srgb,var(--color-paper) 94%,transparent);border-bottom:1px solid transparent;backdrop-filter:blur(10px)}.header-inner[data-astro-cid-3ef6ksr2]{display:flex;width:calc(100% - clamp(32px,4.5vw,72px));min-height:72px;align-items:center;justify-content:space-between;gap:var(--space-4);margin-inline:auto}.site-nav[data-astro-cid-3ef6ksr2]{display:flex;align-items:center;gap:var(--space-3)}.site-nav[data-astro-cid-3ef6ksr2] a[data-astro-cid-3ef6ksr2]{border-radius:var(--radius-pill);padding:9px 13px;color:var(--color-ink);font-family:var(--font-display);font-size:25px;font-weight:700;line-height:1;text-decoration:none;transition:background-color var(--duration-fast) var(--ease-soft)}.site-nav[data-astro-cid-3ef6ksr2] a[data-astro-cid-3ef6ksr2]:hover,.site-nav[data-astro-cid-3ef6ksr2] a[data-astro-cid-3ef6ksr2][aria-current=page]{background:var(--color-mist)}.menu-button[data-astro-cid-3ef6ksr2]{display:none;width:44px;height:44px;align-items:center;justify-content:center;gap:5px;border:0;border-radius:var(--radius-pill);background:var(--color-mist);color:var(--color-ink);cursor:pointer}.theme-toggle[data-astro-cid-3ef6ksr2]{display:inline-flex;width:44px;height:44px;align-items:center;justify-content:center;border:0;border-radius:50%;padding:0;background:transparent;color:var(--color-ink);cursor:pointer;transition:transform var(--duration-fast) var(--ease-soft)}.theme-toggle[data-astro-cid-3ef6ksr2]:hover{transform:scale(1.06)}.theme-toggle[data-astro-cid-3ef6ksr2]:active{transform:scale(.94)}.icon-wrap[data-astro-cid-3ef6ksr2]{position:relative;width:22px;height:22px;display:block}.icon[data-astro-cid-3ef6ksr2]{position:absolute;inset:0;width:100%;height:100%;transition:opacity .25s ease,transform .35s ease}.sun-icon[data-astro-cid-3ef6ksr2]{opacity:1;transform:scale(1)}.sun-icon[data-astro-cid-3ef6ksr2] line[data-astro-cid-3ef6ksr2]{stroke:currentColor;stroke-width:8;stroke-linecap:round}.moon-icon[data-astro-cid-3ef6ksr2]{opacity:0;transform:scale(.6)}:root[data-theme=dark] .sun-icon[data-astro-cid-3ef6ksr2]{opacity:0;transform:scale(.6)}:root[data-theme=dark] .moon-icon[data-astro-cid-3ef6ksr2]{opacity:1;transform:scale(1)}.menu-button[data-astro-cid-3ef6ksr2] span[data-astro-cid-3ef6ksr2]{display:block;width:18px;height:2px;border-radius:2px;background:currentColor}@media(max-width:720px){.header-inner[data-astro-cid-3ef6ksr2]{min-height:68px}.menu-button[data-astro-cid-3ef6ksr2]{display:inline-grid}.site-nav[data-astro-cid-3ef6ksr2]{position:absolute;top:calc(100% + 8px);right:var(--space-page-x);display:none;width:min(220px,calc(100vw - var(--space-page-x) * 2));border:1px solid var(--color-line);border-radius:var(--radius-card);padding:var(--space-2);background:var(--color-paper)}.site-nav[data-astro-cid-3ef6ksr2][data-open]{display:grid}.site-nav[data-astro-cid-3ef6ksr2] a[data-astro-cid-3ef6ksr2]{min-height:44px;align-content:center;font-size:22px}.theme-toggle[data-astro-cid-3ef6ksr2]{width:100%;min-height:44px;border-radius:var(--radius-pill)}}:root{--color-ink: #0b0b0b;--color-paper: #ffffff;--color-soft-paper: #fafaf8;--color-mist: #f1f1ef;--color-line: #e2e2de;--color-muted: #666a70;--color-faint: #a5a5a0;--color-leaf: #4f8f63;--color-sun: #d6a23a;--color-mark: #f4d35e;--font-display: "Gaegu", "Patrick Hand", "ZCOOL KuaiLe", "Comic Neue", "Comic Sans MS", "LXGW WenKai", "霞鹜文楷", "Kaiti SC", "STKaiti", "KaiTi", cursive;--font-sans: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-cn: "LXGW WenKai", "霞鹜文楷", "Kaiti SC", "STKaiti", "KaiTi", serif;--container-sm: 720px;--container-md: 960px;--container-lg: 1120px;--space-page-x: 24px;--radius-card: 8px;--radius-pill: 999px;--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 24px;--space-6: 32px;--space-7: 48px;--space-8: 64px;--space-9: 96px;--space-10: 128px;--ease-soft: cubic-bezier(.22, 1, .36, 1);--duration-fast: .14s;--duration-normal: .22s;--duration-slow: .42s}:root[data-theme=dark]{--color-ink: #f4f1e8;--color-paper: #111210;--color-soft-paper: #191a17;--color-mist: #20211e;--color-line: #343630;--color-muted: #b6b4aa;--color-faint: #777971;--color-mark: #d6a23a}@media(min-width:768px){:root{--space-page-x: 48px}}@media(min-width:1280px){:root{--space-page-x: 64px}}h1,h2,h3,h4,p{overflow-wrap:break-word}h1,h2,h3,h4,.display{margin:0;font-family:var(--font-cn);font-weight:500;letter-spacing:0}.display{font-family:var(--font-display)}h1{font-size:42px;line-height:1.12}h2{font-size:32px;line-height:1.16}h3{font-size:23px;line-height:1.24}h4{font-size:18px;line-height:1.35}p{margin:0;line-height:1.75}.lead{max-width:690px;color:var(--color-muted);font-size:18px;line-height:1.72}.meta{color:var(--color-muted);font-size:14px;line-height:1.5}.article-body{color:var(--color-ink);font-size:17px;line-height:1.82}.article-body>*+*{margin-top:var(--space-5)}.article-body h2{margin-top:var(--space-8);font-size:28px}.article-body h3{margin-top:var(--space-7)}.article-body ul,.article-body ol{padding-left:1.25rem}.article-body li+li{margin-top:var(--space-2)}.article-body blockquote{margin-inline:0;border-left:3px solid var(--color-ink);padding:var(--space-3) var(--space-5);background:var(--color-soft-paper)}.article-body code{border-radius:5px;padding:.12em .32em;background:var(--color-mist);font-size:.92em}.article-body pre{overflow-x:auto;border:1px solid var(--color-line);border-radius:var(--radius-card);padding:var(--space-5);background:var(--color-mist)}.article-body pre code{padding:0;background:transparent}.article-body strong{font-weight:700}.article-body em{font-style:italic}.article-body del{text-decoration:line-through;opacity:.7}.article-body a{color:var(--color-ink);text-decoration:underline;text-decoration-thickness:1px;text-underline-offset:.18em}.article-body a:hover{color:var(--color-muted)}.article-body hr{margin:var(--space-8) 0;border:0;border-top:1px solid var(--color-line)}.article-body table{width:100%;border-collapse:collapse;font-size:.95em;margin-block:var(--space-6)}.article-body thead{border-bottom:2px solid var(--color-ink)}.article-body th,.article-body td{padding:10px 14px;text-align:left;border-bottom:1px solid var(--color-line)}.article-body th{font-weight:700;color:var(--color-ink)}.article-body td{color:var(--color-muted)}.article-body input[type=checkbox]{width:auto;margin-right:6px;accent-color:var(--color-ink)}.article-body pre[class]:before{content:attr(class);display:block;margin-bottom:8px;color:var(--color-muted);font-size:.78em;letter-spacing:.04em}@media(min-width:760px){h1{font-size:58px}h2{font-size:38px}h3{font-size:26px}}*{box-sizing:border-box}html{color:var(--color-ink);background:var(--color-paper);font-family:var(--font-sans);line-height:1.5;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased}body{min-width:320px;margin:0;color:var(--color-ink);background:var(--color-paper)}html,body{transition:background-color var(--duration-normal) var(--ease-soft),color var(--duration-normal) var(--ease-soft)}a{color:inherit;text-decoration-thickness:1px;text-underline-offset:.18em}button,input,textarea,select{font:inherit}img,svg{display:block;max-width:100%}:focus-visible{outline:2px solid var(--color-ink);outline-offset:4px}::selection{color:var(--color-ink);background:var(--color-mark)}.container{width:min(100% - var(--space-page-x) * 2,var(--container-lg));margin-inline:auto}.listing-container{width:min(calc(100% - var(--space-page-x) * 2),1320px);margin-inline:auto}.container-sm{width:min(100% - var(--space-page-x) * 2,var(--container-sm));margin-inline:auto}.section{padding-block:var(--space-9)}.section+.section{padding-top:var(--space-6)}.muted{color:var(--color-muted)}.eyebrow{margin:0 0 var(--space-3);color:var(--color-muted);font-family:var(--font-display);font-size:14px;line-height:1.4}.content-section main{font-family:var(--font-display)}.content-section main :where(h1,h2,h3,h4){font-family:inherit;font-weight:400}.button-row{display:flex;flex-wrap:wrap;gap:var(--space-3);align-items:center}.button{display:inline-flex;min-height:44px;align-items:center;justify-content:center;border:1px solid transparent;border-radius:var(--radius-pill);padding:10px 18px;background:var(--color-mist);color:var(--color-ink);font-size:15px;line-height:1.2;text-decoration:none;transition:transform var(--duration-fast) var(--ease-soft),background-color var(--duration-fast) var(--ease-soft),border-color var(--duration-fast) var(--ease-soft)}.button:hover{transform:translateY(-1px);background:color-mix(in srgb,var(--color-mist) 86%,var(--color-ink))}.button:active{transform:translateY(0)}.button-primary{background:var(--color-ink);color:var(--color-paper)}.button-primary:hover{background:color-mix(in srgb,var(--color-ink) 88%,var(--color-paper))}.button-text{min-height:auto;border:0;border-radius:0;padding:0;background:transparent;text-decoration:underline}.button-text:hover{background:transparent}.tag-list{display:flex;flex-wrap:wrap;gap:var(--space-2);padding:0;margin:0;list-style:none}.tag{display:inline-flex;align-items:center;min-height:28px;border:1px solid var(--color-line);border-radius:var(--radius-pill);padding:5px 10px;background:var(--color-paper);color:var(--color-muted);font-size:13px;line-height:1.2;white-space:nowrap}.card-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(min(100%,520px),1fr));gap:var(--space-5)}.card{border:1px solid var(--color-line);border-radius:var(--radius-card);background:var(--color-paper)}.idea-page,.listing-page,.article-page,.work-page{animation:page-enter .42s var(--ease-soft) both}.article-body,.work-body{animation:content-enter .52s var(--ease-soft) 90ms both}.article-index>*,.work-grid>*{animation:list-reveal .42s var(--ease-soft) both}.article-index>:nth-child(1),.work-grid>:nth-child(1){animation-delay:50ms}.article-index>:nth-child(2),.work-grid>:nth-child(2){animation-delay:90ms}.article-index>:nth-child(3),.work-grid>:nth-child(3){animation-delay:.13s}.article-index>:nth-child(4),.work-grid>:nth-child(4){animation-delay:.17s}.article-index>:nth-child(5),.work-grid>:nth-child(5){animation-delay:.21s}.article-index>:nth-child(6),.work-grid>:nth-child(6){animation-delay:.25s}.article-index>:nth-child(7),.work-grid>:nth-child(7){animation-delay:.29s}.article-index>:nth-child(8),.work-grid>:nth-child(8){animation-delay:.33s}.article-index>:nth-child(n+9),.work-grid>:nth-child(n+9){animation-delay:.36s}@keyframes page-enter{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes list-reveal{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes content-enter{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.surface{background:var(--color-soft-paper)}.skip-link{position:absolute;z-index:20;top:var(--space-3);left:var(--space-3);transform:translateY(-160%);border-radius:var(--radius-pill);padding:10px 14px;background:var(--color-ink);color:var(--color-paper);text-decoration:none;transition:transform var(--duration-fast) var(--ease-soft)}.skip-link:focus{transform:translateY(0)}@media(min-width:1040px){.card-grid.three{grid-template-columns:repeat(auto-fit,minmax(min(100%,340px),1fr))}}@media(max-width:720px){.section{padding-block:var(--space-8)}.button-row{align-items:stretch}.button-row .button{flex:1 1 auto}}@media(prefers-reduced-motion:reduce){html{scroll-behavior:auto!important}.idea-page,.listing-page,.article-page,.work-page,.article-body,.work-body,.article-index>*,.work-grid>*{animation:none!important}}
