:root{--accent: #5C6B73;--accent-soft: rgba(92, 107, 115, .08);--bg-primary: #FAEBD7;--bg-secondary: #F5EBD3;--card-bg: #FFF8F0;--text-primary: #1F2326;--text-secondary: #4A5560;--text-muted: #7A8590;--border-color: #DDE2E6;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 14px;--shadow-sm: 0 1px 2px rgba(31, 35, 38, .04);--shadow-md: 0 4px 12px rgba(31, 35, 38, .08);--shadow-lg: 0 12px 32px rgba(31, 35, 38, .12);--font-sans: "ZCOOL XiaoWei", "Noto Serif SC", system-ui, -apple-system, sans-serif;--font-serif: "Noto Serif SC", "ZCOOL XiaoWei", Georgia, serif;--font-mono: "JetBrains Mono", ui-monospace, "SF Mono", Menlo, monospace;--ease: cubic-bezier(.4, 0, .2, 1);--dur: .32s;--dur-slow: .48s;--layout-max: 1400px;--reading-size: 16px}[data-theme=dark]{--accent: #A8B4BC;--accent-soft: rgba(168, 180, 188, .1);--bg-primary: #131518;--bg-secondary: #181B1F;--card-bg: #1E2225;--text-primary: #EEF1F3;--text-secondary: #B6BEC5;--text-muted: #7A8590;--border-color: #2A2F34;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .3);--shadow-md: 0 4px 12px rgba(0, 0, 0, .4);--shadow-lg: 0 12px 32px rgba(0, 0, 0, .5)}*,*:before,*:after{box-sizing:border-box}html{font-size:16px;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;scroll-behavior:smooth}body{margin:0;font-family:var(--font-sans);font-size:var(--reading-size);line-height:1.8;color:var(--text-primary);background:var(--bg-primary);transition:background var(--dur) var(--ease),color var(--dur) var(--ease);min-height:100vh}img{max-width:100%;display:block}a{color:inherit;text-decoration:none;transition:color var(--dur) var(--ease)}a:hover{color:var(--accent)}button{font:inherit;cursor:pointer;border:0;background:none;color:inherit}:focus-visible{outline:2px solid var(--accent);outline-offset:3px;border-radius:3px}::selection{background:var(--accent);color:var(--card-bg)}main{padding-top:72px;min-height:100vh}.container{max-width:720px;margin:0 auto;padding:0 24px}.container--wide{max-width:980px}.container--three{max-width:var(--layout-max);margin:0 auto;padding:0 24px;display:grid;grid-template-columns:240px 1fr 240px;gap:2rem;align-items:start}.hero{padding:96px 0 64px}.hero .eyebrow{font-size:11px;letter-spacing:.4em;text-transform:uppercase;color:var(--text-muted);margin-bottom:28px}.hero h1{font-family:var(--font-sans);font-size:clamp(32px,5vw,52px);font-weight:400;line-height:1.4;letter-spacing:.02em;margin:0 0 22px;color:var(--text-primary);min-height:1.5em}.caret{display:inline-block;width:2px;height:.95em;vertical-align:-.12em;margin-left:4px;background:var(--accent);animation:blink 1s steps(1) infinite}@keyframes blink{50%{opacity:0}}.hero .sub{font-size:15px;line-height:1.95;color:var(--text-secondary);max-width:36em;margin:0 0 28px}.mood{display:inline-flex;align-items:center;gap:14px;padding:8px 16px;font-size:12px;color:var(--text-muted);background:var(--card-bg);border:1px solid var(--border-color);border-radius:999px;font-family:var(--font-mono);flex-wrap:wrap}.mood .sep{color:var(--border-color)}.mood strong{color:var(--text-secondary);font-weight:500}.sect-title{display:flex;align-items:baseline;justify-content:space-between;margin:64px 0 24px;padding-bottom:14px;border-bottom:1px solid var(--border-color)}.sect-title h2{font-size:16px;font-weight:500;letter-spacing:.18em;color:var(--text-primary);margin:0;white-space:nowrap;flex:0 0 auto}.sect-title .more{font-size:12px;font-family:var(--font-mono);color:var(--text-muted);letter-spacing:.06em}.sect-title .more:hover{color:var(--accent)}.post-list{display:flex;flex-direction:column;gap:28px;padding:0 0 64px}.post-card{display:block;background:transparent;border-bottom:1px solid var(--border-color);padding:8px 0 28px;cursor:pointer;transition:padding-left var(--dur) var(--ease);color:inherit}.post-card:hover{padding-left:8px}.post-card .meta{display:flex;align-items:center;gap:14px;margin-bottom:10px;font-size:11px;font-family:var(--font-mono);color:var(--text-muted);letter-spacing:.06em}.post-card h3{font-size:22px;font-weight:500;line-height:1.55;color:var(--text-primary);margin:0 0 10px;text-wrap:pretty;transition:color var(--dur) var(--ease)}.post-card:hover h3{color:var(--accent)}.post-card .excerpt{font-size:14.5px;line-height:1.85;color:var(--text-secondary);margin:0 0 14px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.post-card .footer{display:flex;justify-content:space-between;align-items:center;font-size:12px;color:var(--text-muted);font-family:var(--font-mono)}.post-card .footer .read-more{display:inline-flex;align-items:center;gap:6px;color:var(--accent);transition:gap var(--dur) var(--ease)}.post-card:hover .read-more{gap:10px}.post-card.with-cover{display:grid;grid-template-columns:1fr 200px;gap:28px;align-items:start}.post-card.with-cover .cover{aspect-ratio:16 / 11;border-radius:var(--radius-md);background-size:cover;background-position:center;background-color:var(--bg-secondary);overflow:hidden}@media(max-width:640px){.post-card.with-cover{grid-template-columns:1fr}.post-card.with-cover .cover{order:-1;aspect-ratio:16 / 9}}.chip{display:inline-flex;align-items:center;padding:3px 10px;font-size:11.5px;letter-spacing:.08em;color:var(--accent);background:var(--accent-soft);border-radius:999px;border:1px solid transparent;transition:all var(--dur) var(--ease)}.chip:hover,.chip.active{border-color:var(--accent)}.chip.active{background:var(--accent);color:var(--card-bg)}.filter-bar{display:flex;flex-direction:column;gap:16px;padding:24px 0 8px}.search-box{position:relative;width:100%}.search-box input{width:100%;height:44px;padding:0 16px 0 44px;background:var(--card-bg);border:1px solid var(--border-color);border-radius:var(--radius-md);font:inherit;color:var(--text-primary);outline:none;transition:border-color var(--dur) var(--ease)}.search-box input:focus{border-color:var(--accent)}.search-box .icon{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:var(--text-muted);pointer-events:none}.tag-chips{display:flex;flex-wrap:wrap;gap:8px}.tag-chips .chip{cursor:pointer}.year-group{padding:32px 0;border-bottom:1px solid var(--border-color)}.year-group:last-child{border-bottom:0}.year-group h3{font-family:var(--font-mono);font-size:36px;font-weight:400;letter-spacing:.04em;color:var(--text-muted);margin:0 0 18px}.year-group ul{list-style:none;margin:0;padding:0}.year-group li{display:grid;grid-template-columns:80px 1fr auto;gap:24px;align-items:baseline;padding:14px 0;border-bottom:1px dashed var(--border-color);cursor:pointer;transition:padding-left var(--dur) var(--ease)}.year-group li:hover{padding-left:8px}.year-group li:last-child{border-bottom:0}.year-group .date{font-family:var(--font-mono);font-size:12px;color:var(--text-muted)}.year-group .title{font-size:16px;color:var(--text-primary);transition:color var(--dur) var(--ease)}.year-group li:hover .title{color:var(--accent)}.year-group .cat{font-size:11px;color:var(--text-muted);letter-spacing:.1em}.article{padding:32px 0 80px}.article-cover{aspect-ratio:21 / 9;border-radius:var(--radius-lg);background-size:cover;background-position:center;margin:0 0 36px;box-shadow:var(--shadow-md)}.article-meta{display:flex;align-items:center;gap:14px;font-size:12px;font-family:var(--font-mono);color:var(--text-muted);margin-bottom:18px;flex-wrap:wrap}.article h1{font-size:clamp(28px,4vw,36px);font-weight:500;line-height:1.45;letter-spacing:.01em;margin:0 0 36px;text-wrap:balance}.article-body{font-family:var(--font-serif);font-size:var(--reading-size);line-height:1.95;color:var(--text-primary)}.article-body>*{margin:0 0 1.4em}.article-body h2{font-family:var(--font-sans);font-size:22px;font-weight:500;margin:2.2em 0 .8em;letter-spacing:.02em;position:relative;padding-left:14px;scroll-margin-top:100px}.article-body h2:before{content:"";position:absolute;left:0;top:.5em;bottom:.5em;width:3px;background:var(--accent);border-radius:2px}.article-body h3{font-family:var(--font-sans);font-size:18px;font-weight:500;margin:1.8em 0 .6em;letter-spacing:.02em;scroll-margin-top:100px}.article-body p{text-wrap:pretty}.article-body blockquote{margin:1.6em 0;padding:4px 0 4px 22px;border-left:2px solid var(--border-color);color:var(--text-secondary);font-style:italic}.article-body code{font-family:var(--font-mono);font-size:.88em;padding:2px 6px;border-radius:4px;background:var(--accent-soft);color:var(--accent)}.article-body pre{background:var(--card-bg);border:1px solid var(--border-color);padding:18px 20px;border-radius:var(--radius-md);overflow-x:auto;font-size:13px;line-height:1.7}.article-body pre code{background:none;color:var(--text-primary);padding:0}.article-body img{border-radius:var(--radius-md);margin:1.6em auto}.article-body hr{border:0;border-top:1px solid var(--border-color);margin:2em 0}.article-body ul,.article-body ol{padding-left:1.4em}.article-body li{margin:.4em 0}.article-nav{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin:56px 0 0}.article-nav a{padding:22px 24px;background:var(--card-bg);border:1px solid var(--border-color);border-radius:var(--radius-md);display:block;transition:transform var(--dur) var(--ease),box-shadow var(--dur) var(--ease)}.article-nav a:hover{transform:translateY(-3px);box-shadow:var(--shadow-md)}.article-nav .lab{font-size:11px;font-family:var(--font-mono);letter-spacing:.16em;color:var(--text-muted);margin-bottom:6px}.article-nav .ttl{font-size:14px;color:var(--text-primary);line-height:1.6}.article-nav a:hover .ttl{color:var(--accent)}.article-nav a.next{text-align:right}@media(max-width:640px){.article-nav{grid-template-columns:1fr}.article-nav a.next{text-align:left}}.toc-card{position:sticky;top:96px;padding:22px 20px;background:var(--card-bg);border:1px solid var(--border-color);border-radius:var(--radius-md);box-shadow:var(--shadow-sm)}.toc-card h4{margin:0 0 14px;font-size:11px;letter-spacing:.24em;text-transform:uppercase;color:var(--text-muted);font-weight:500}.toc-list{list-style:none;margin:0;padding:0;counter-reset:toc}.toc-list li{counter-increment:toc;position:relative;padding:8px 0 8px 28px;border-left:1px solid var(--border-color);margin-left:6px;transition:border-color var(--dur) var(--ease)}.toc-list li:before{content:counter(toc,decimal-leading-zero);position:absolute;left:10px;top:8px;font-family:var(--font-mono);font-size:10px;color:var(--text-muted)}.toc-list a{display:block;font-size:13px;line-height:1.6;color:var(--text-secondary);transition:color var(--dur) var(--ease),padding var(--dur) var(--ease)}.toc-list li.active{border-left-color:var(--accent)}.toc-list li.active a{color:var(--accent);padding-left:4px}.toc-list li.active:before{color:var(--accent)}.toc-list a:hover{color:var(--accent)}.author-rail{position:sticky;top:96px;padding:24px 22px;background:var(--card-bg);border:1px solid var(--border-color);border-radius:var(--radius-md);text-align:center}.author-rail .avatar{width:72px;height:72px;border-radius:50%;margin:0 auto 12px;background-size:cover;background-position:center;border:2px solid var(--card-bg);box-shadow:0 0 0 1px var(--border-color)}.author-rail .name{font-size:16px;margin:0 0 4px;font-weight:500}.author-rail .role{font-size:11px;color:var(--text-muted);letter-spacing:.18em;text-transform:uppercase}.author-rail p{font-size:13px;line-height:1.85;color:var(--text-secondary);margin:14px 0 0}.author-rail .links{display:flex;justify-content:center;gap:10px;margin-top:14px}.author-rail .links a{width:30px;height:30px;display:grid;place-items:center;border-radius:50%;color:var(--text-muted);border:1px solid var(--border-color);transition:all var(--dur) var(--ease)}.author-rail .links a:hover{color:var(--accent);border-color:var(--accent)}.comments{margin-top:72px;padding-top:32px;border-top:1px solid var(--border-color)}.comments h3{font-size:15px;font-weight:500;letter-spacing:.18em;margin:0 0 24px;color:var(--text-primary)}.comment-form{display:flex;flex-direction:column;gap:12px;margin-bottom:32px}.comment-form textarea{width:100%;min-height:100px;padding:14px 16px;background:var(--card-bg);border:1px solid var(--border-color);border-radius:var(--radius-md);font:inherit;color:var(--text-primary);resize:vertical;outline:none;transition:border-color var(--dur) var(--ease)}.comment-form textarea:focus{border-color:var(--accent)}.comment-form .row{display:flex;gap:10px;align-items:center}.comment-form input[type=text]{flex:1;height:38px;padding:0 14px;background:var(--card-bg);border:1px solid var(--border-color);border-radius:var(--radius-sm);font:inherit;color:var(--text-primary);outline:none}.comment-form input[type=text]:focus{border-color:var(--accent)}.comment-form button{height:38px;padding:0 22px;background:var(--accent);color:var(--card-bg);border-radius:var(--radius-sm);font-weight:500;letter-spacing:.08em;transition:opacity var(--dur) var(--ease)}.comment-form button:hover{opacity:.85}.comment-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:22px}.comment{display:grid;grid-template-columns:36px 1fr;gap:14px;padding:16px 0;border-bottom:1px dashed var(--border-color)}.comment:last-child{border-bottom:0}.comment .av{width:36px;height:36px;border-radius:50%;background:var(--accent-soft);display:grid;place-items:center;font-family:var(--font-mono);font-size:12px;color:var(--accent);background-size:cover}.comment .who{font-size:13.5px;font-weight:500;color:var(--text-primary)}.comment .when{font-family:var(--font-mono);font-size:11px;color:var(--text-muted);margin-left:8px}.comment .body{font-size:14px;line-height:1.85;color:var(--text-secondary);margin:6px 0 0}#tcomment{margin-top:16px}#tcomment .tk-input,#tcomment .tk-comment{font-family:var(--font-sans)!important}#tcomment .tk-submit-action-icon{color:var(--accent)!important}.reading-progress{position:fixed;top:0;left:0;height:2px;background:var(--accent);z-index:200;transition:width .1s linear;pointer-events:none;width:0}.about{padding:32px 0 80px}.about .lead{font-size:19px;line-height:1.9;color:var(--text-secondary);font-family:var(--font-serif);max-width:32em;margin:0 0 56px;text-wrap:pretty}.about .prose{font-size:15px;line-height:1.95;color:var(--text-secondary);max-width:36em}.about .prose p{margin:0 0 1em}.timeline{list-style:none;padding:0;margin:0}.timeline li{position:relative;display:grid;grid-template-columns:100px 1fr;gap:24px;padding:18px 0 18px 24px;border-left:1px solid var(--border-color)}.timeline li:before{content:"";position:absolute;left:-5px;top:26px;width:9px;height:9px;border-radius:50%;background:var(--card-bg);border:2px solid var(--accent)}.timeline .y{font-family:var(--font-mono);font-size:13px;color:var(--accent)}.timeline .e{font-size:14.5px;line-height:1.85;color:var(--text-primary)}.timeline .e small{display:block;color:var(--text-muted);font-size:12px;margin-top:4px;font-family:var(--font-mono)}.page-enter{animation:enter var(--dur-slow) var(--ease) both}@keyframes enter{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}@media(max-width:1100px){.container--three{grid-template-columns:1fr 240px}.container--three>.col-left{display:none}}@media(max-width:768px){main{padding-top:60px}.container--three{grid-template-columns:1fr;padding:0 18px}.container--three>.col-right{display:none}.hero{padding:64px 0 40px}.container{padding:0 18px}.year-group li{grid-template-columns:70px 1fr}.year-group li .cat{display:none}.timeline li{grid-template-columns:80px 1fr;gap:16px}}.expressive-code .frame figcaption.header{position:relative!important;display:flex!important;align-items:center!important;justify-content:flex-end!important;height:36px!important;min-height:36px!important;padding:0 16px!important;background-color:#24292e!important;border-bottom:none!important;box-sizing:border-box!important}.expressive-code .frame figcaption .title{display:none!important}.expressive-code .frame .dots,.expressive-code .frame figcaption .dots{display:none!important}.expressive-code .mac-dots{position:absolute!important;left:16px!important;top:50%!important;transform:translateY(-50%)!important;display:flex!important;gap:8px!important}.expressive-code .mac-dots span{width:14px!important;height:14px!important;border-radius:50%!important;display:block!important;flex-shrink:0!important}.expressive-code .mac-dots .dot-red{background-color:#ff5f56!important}.expressive-code .mac-dots .dot-yellow{background-color:#ffbd2e!important}.expressive-code .mac-dots .dot-green{background-color:#27c93f!important}.expressive-code .copy{position:absolute!important;right:12px!important;top:50%!important;transform:translateY(-50%)!important;margin:0!important;opacity:.7;transition:opacity .2s}.expressive-code .copy:hover{opacity:1}.expressive-code .frame pre{margin-top:0!important;border-top-left-radius:0!important;border-top-right-radius:0!important;background-color:beige!important}.expressive-code .frame pre code{color:#333!important}.expressive-code .frame{border:none!important;box-shadow:0 4px 20px #00000026!important}.site-header[data-astro-cid-3ef6ksr2]{position:fixed;top:0;left:0;right:0;z-index:100;display:flex;align-items:center;justify-content:space-between;padding:16px 32px;background:transparent;transition:transform var(--dur-slow) var(--ease)}.site-header[data-astro-cid-3ef6ksr2].is-hidden{transform:translateY(-110%)}.brand[data-astro-cid-3ef6ksr2]{display:flex;align-items:baseline;gap:10px;font-weight:600;letter-spacing:.02em}.brand[data-astro-cid-3ef6ksr2] .dot[data-astro-cid-3ef6ksr2]{width:7px;height:7px;border-radius:50%;background:var(--accent);align-self:center;transition:transform var(--dur) var(--ease)}.brand[data-astro-cid-3ef6ksr2]:hover .dot[data-astro-cid-3ef6ksr2]{transform:scale(1.4)}.brand[data-astro-cid-3ef6ksr2] .name[data-astro-cid-3ef6ksr2]{font-size:18px;color:var(--text-primary);white-space:nowrap}.brand[data-astro-cid-3ef6ksr2] .tag[data-astro-cid-3ef6ksr2]{font-size:12px;color:var(--text-muted);letter-spacing:.16em;white-space:nowrap}@media(max-width:1100px){.brand[data-astro-cid-3ef6ksr2] .tag[data-astro-cid-3ef6ksr2]{display:none}}.nav[data-astro-cid-3ef6ksr2]{display:flex;gap:28px;font-size:14px;color:var(--text-secondary)}.nav[data-astro-cid-3ef6ksr2] a[data-astro-cid-3ef6ksr2]{position:relative;padding:4px 2px}.nav[data-astro-cid-3ef6ksr2] a[data-astro-cid-3ef6ksr2]:after{content:"";position:absolute;left:0;right:0;bottom:-4px;height:1px;background:var(--accent);transform:scaleX(0);transform-origin:left;transition:transform var(--dur) var(--ease)}.nav[data-astro-cid-3ef6ksr2] a[data-astro-cid-3ef6ksr2]:hover:after,.nav[data-astro-cid-3ef6ksr2] a[data-astro-cid-3ef6ksr2].active:after{transform:scaleX(1)}.nav[data-astro-cid-3ef6ksr2] a[data-astro-cid-3ef6ksr2].active{color:var(--text-primary)}.tools[data-astro-cid-3ef6ksr2]{display:flex;align-items:center;gap:10px;color:var(--text-secondary)}.iconbtn[data-astro-cid-3ef6ksr2]{width:34px;height:34px;display:grid;place-items:center;border-radius:50%;color:var(--text-secondary);transition:background var(--dur) var(--ease),color var(--dur) var(--ease)}.iconbtn[data-astro-cid-3ef6ksr2]:hover{background:var(--accent-soft);color:var(--accent)}.icon-sun[data-astro-cid-3ef6ksr2]{display:none}.icon-moon[data-astro-cid-3ef6ksr2],[data-astro-cid-3ef6ksr2][data-theme=dark] .icon-sun[data-astro-cid-3ef6ksr2]{display:block}[data-astro-cid-3ef6ksr2][data-theme=dark] .icon-moon[data-astro-cid-3ef6ksr2]{display:none}@media(max-width:768px){.site-header[data-astro-cid-3ef6ksr2]{padding:14px 18px}.nav[data-astro-cid-3ef6ksr2]{gap:16px;font-size:13px}}@media(max-width:480px){.nav[data-astro-cid-3ef6ksr2]{display:none}}.site-footer[data-astro-cid-sz7xmlte]{padding:56px 32px 32px;border-top:1px solid var(--border-color);font-size:12px;color:var(--text-muted);display:flex;justify-content:space-between;align-items:center;font-family:var(--font-mono);letter-spacing:.04em;margin-top:80px;flex-wrap:wrap;gap:16px}.site-footer[data-astro-cid-sz7xmlte] .line[data-astro-cid-sz7xmlte]{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.site-footer[data-astro-cid-sz7xmlte] .heart[data-astro-cid-sz7xmlte]{color:var(--accent)}.site-footer[data-astro-cid-sz7xmlte] a[data-astro-cid-sz7xmlte]{color:inherit}.site-footer[data-astro-cid-sz7xmlte] a[data-astro-cid-sz7xmlte]:hover{color:var(--accent)}@media(max-width:600px){.site-footer[data-astro-cid-sz7xmlte]{padding:40px 18px 24px;flex-direction:column;text-align:center}.site-footer[data-astro-cid-sz7xmlte] .line[data-astro-cid-sz7xmlte]{justify-content:center}}
