.astro-route-announcer{position:absolute;left:0;top:0;clip:rect(0 0 0 0);clip-path:inset(50%);overflow:hidden;white-space:nowrap;width:1px;height:1px}:root{--bg: #f7f8fb;--bg-soft: #eef1f6;--surface: #ffffff;--surface-2: #fbfcfd;--border: #e6e9ef;--border-soft: #eef0f4;--topbar-bg: rgba(255, 255, 255, .72);--overlay: rgba(15, 20, 28, .45);--ink: #0c1424;--ink-2: #38425a;--ink-3: #6a7488;--ink-4: #98a2b5;--brand-1: #1aa3f0;--brand-2: #2a6fea;--brand-3: #3fd896;--brand-grad: linear-gradient(135deg, #1aa3f0 0%, #2a6fea 45%, #3fd896 100%);--brand-grad-soft: linear-gradient(135deg, rgba(26, 163, 240, .1) 0%, rgba(63, 216, 150, .1) 100%);--success: #2c9a6b;--warning: #ea7d2a;--error: #c43838;--info: #1aa3f0;--violet: #a86ee8;--shadow-sm: 0 1px 2px rgba(20, 40, 90, .04), 0 1px 0 rgba(20, 40, 90, .03);--shadow-md: 0 4px 16px -2px rgba(20, 40, 90, .06), 0 1px 3px rgba(20, 40, 90, .04);--shadow-lg: 0 24px 60px -16px rgba(20, 40, 90, .18), 0 6px 16px -4px rgba(20, 40, 90, .08);--shadow-brand: 0 6px 18px rgba(42, 111, 234, .22);--radius-sm: 10px;--radius-md: 14px;--radius-lg: 20px;--radius-full: 9999px;--code-bg: #0f1626;--code-fg: #d8e0f0;--code-inline-bg: #eef1f6;--code-inline-fg: #2a6fea;--tok-key: #5b8df5;--tok-str: #45c08a;--tok-num: #e8a14c;--tok-com: #6a7488;--tok-fn: #38b6f6;--tok-punc: #98a2b5;--tok-tag: #e8709c;--astro-code-foreground: var(--code-fg);--astro-code-background: var(--code-bg);--astro-code-token-keyword: var(--tok-key);--astro-code-token-string: var(--tok-str);--astro-code-token-string-expression: var(--tok-str);--astro-code-token-constant: var(--tok-num);--astro-code-token-comment: var(--tok-com);--astro-code-token-function: var(--tok-fn);--astro-code-token-parameter: #b9c2d4;--astro-code-token-punctuation: var(--tok-punc);--astro-code-token-link: var(--tok-key);--font-sans: "Inter", "Noto Sans SC", "MiSans", "PingFang SC", "HarmonyOS Sans SC", system-ui, -apple-system, "Microsoft YaHei", sans-serif;--font-serif: var(--font-sans);--font-mono: "JetBrains Mono", "SF Mono", "Fira Code", monospace;--topbar-h: 60px;--measure: 720px;--transition-fast: .15s ease;--transition-base: .25s ease}[data-theme=dark]{--bg: #0a101e;--bg-soft: #0e1626;--surface: #121b2e;--surface-2: #182338;--border: #253149;--border-soft: #1d2840;--topbar-bg: rgba(13, 19, 33, .72);--overlay: rgba(2, 6, 16, .65);--ink: #e9edf5;--ink-2: #b9c2d4;--ink-3: #8a96ac;--ink-4: #5d6b84;--brand-1: #38b6f6;--brand-2: #5b8df5;--brand-3: #45dda0;--brand-grad-soft: linear-gradient(135deg, rgba(56, 182, 246, .14) 0%, rgba(69, 221, 160, .12) 100%);--success: #44d695;--warning: #f5984c;--error: #f07070;--info: #38b6f6;--violet: #bd8df0;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .35);--shadow-md: 0 4px 16px -2px rgba(0, 0, 0, .4), 0 1px 3px rgba(0, 0, 0, .3);--shadow-lg: 0 24px 60px -16px rgba(0, 0, 0, .55), 0 6px 16px -4px rgba(0, 0, 0, .35);--shadow-brand: 0 6px 18px rgba(42, 111, 234, .4);--code-bg: #0c1322;--code-inline-bg: #182338;--code-inline-fg: #5b8df5}*{box-sizing:border-box}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;color-scheme:light;scroll-behavior:smooth;scroll-padding-top:calc(var(--topbar-h) + 24px)}html[data-theme=dark]{color-scheme:dark}body{margin:0;font-family:var(--font-sans);background:var(--bg);color:var(--ink);line-height:1.6;min-height:100vh;font-feature-settings:"cv11","ss01";position:relative}body:before{content:"";position:fixed;inset:0;background:radial-gradient(55% 45% at 85% -5%,rgba(63,216,150,.1),transparent 60%),radial-gradient(50% 55% at 8% 12%,rgba(26,163,240,.12),transparent 60%);pointer-events:none;z-index:0}[data-theme=dark] body:before{background:radial-gradient(55% 45% at 85% -5%,rgba(63,216,150,.06),transparent 60%),radial-gradient(50% 55% at 8% 12%,rgba(26,163,240,.08),transparent 60%)}a{color:inherit;text-decoration:none}img{max-width:100%;display:block}::selection{background:#2a6fea2e}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border);border-radius:5px;border:2px solid var(--bg)}::-webkit-scrollbar-thumb:hover{background:var(--ink-4)}.wrap{width:100%;max-width:1140px;margin:0 auto;padding:0 28px;position:relative;z-index:1}.progress{position:fixed;top:0;left:0;height:3px;width:0;background:var(--brand-grad);z-index:60;transition:width 80ms linear;box-shadow:0 0 12px #2a6fea66}.topbar{position:sticky;top:0;z-index:50;height:var(--topbar-h);background:var(--topbar-bg);backdrop-filter:saturate(180%) blur(16px);-webkit-backdrop-filter:saturate(180%) blur(16px);border-bottom:1px solid var(--border-soft)}.topbar .wrap{display:flex;align-items:center;gap:28px;height:100%}.brand{display:flex;align-items:center;gap:11px;font-weight:800;letter-spacing:-.02em;white-space:nowrap}.brand .mark{width:30px;height:30px}.brand .name{font-size:16px}.brand .name .dot{background:var(--brand-grad);-webkit-background-clip:text;background-clip:text;color:transparent}.nav{display:flex;align-items:center;gap:4px;margin-left:8px}.nav a{font-size:13.5px;font-weight:600;color:var(--ink-3);padding:7px 13px;border-radius:var(--radius-sm);transition:color var(--transition-fast),background var(--transition-fast)}.nav a:hover,.nav a.active{color:var(--ink);background:var(--bg-soft)}.topbar .spacer{flex:1}.tb-actions{display:flex;align-items:center;gap:6px}.icon-btn{display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--surface);color:var(--ink-3);cursor:pointer;transition:all var(--transition-fast)}.icon-btn:hover{color:var(--ink);border-color:var(--ink-4);background:var(--surface-2)}.icon-btn svg{width:18px;height:18px}.icon-btn .moon,[data-theme=dark] .icon-btn .sun{display:none}[data-theme=dark] .icon-btn .moon{display:block}.nav-toggle,.nav-toggle .close,[data-menu-open] .nav-toggle .menu{display:none}[data-menu-open] .nav-toggle .close{display:block}.mobile-nav{display:none;border-bottom:1px solid var(--border-soft);background:var(--topbar-bg);backdrop-filter:saturate(180%) blur(16px);-webkit-backdrop-filter:saturate(180%) blur(16px);position:sticky;top:var(--topbar-h);z-index:49}.mobile-nav .wrap{display:flex;flex-direction:column;padding-top:8px;padding-bottom:12px;gap:2px}.mobile-nav a{font-size:15px;font-weight:600;color:var(--ink-2);padding:11px 12px;border-radius:var(--radius-sm)}.mobile-nav a:hover,.mobile-nav a.active{background:var(--bg-soft);color:var(--ink)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;font-family:var(--font-sans);font-weight:700;font-size:13.5px;height:40px;padding:0 18px;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--surface);color:var(--ink-2);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap}.btn:hover{border-color:var(--ink-4);background:var(--surface-2)}.btn-primary{background:var(--brand-grad);color:#fff;border:none;box-shadow:var(--shadow-brand)}.btn-primary:hover{transform:translateY(-1px)}.btn svg{width:16px;height:16px}.tag{display:inline-flex;align-items:center;gap:5px;font-size:12px;font-weight:600;color:var(--ink-3);background:var(--bg-soft);padding:4px 11px;border-radius:var(--radius-full);transition:all var(--transition-fast);border:1px solid transparent;white-space:nowrap}a.tag:hover{color:var(--brand-2);border-color:#2a6fea40;background:var(--surface)}.tag .hash{color:var(--ink-4);font-weight:700}.tag-brand{background:var(--brand-grad);color:#fff}.tag-brand .hash{color:#ffffffb3}.footer{border-top:1px solid var(--border-soft);margin-top:80px;padding:40px 0 56px;color:var(--ink-3);font-size:13px}.footer .wrap{display:flex;align-items:center;justify-content:space-between;gap:20px;flex-wrap:wrap}.footer .f-brand{display:flex;align-items:center;gap:10px;font-weight:700;color:var(--ink-2)}.footer .f-brand .mark{width:24px;height:24px;border-radius:7px}.footer .f-links{display:flex;gap:20px}.footer .f-links a{transition:color var(--transition-fast)}.footer .f-links a:hover{color:var(--brand-2)}.eyebrow{display:inline-flex;align-items:center;gap:8px;font-size:11.5px;font-weight:800;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-4);white-space:nowrap}.eyebrow .bar{width:22px;height:2px;border-radius:2px;background:var(--brand-grad)}.grad{background:var(--brand-grad);-webkit-background-clip:text;background-clip:text;color:transparent}@media(prefers-reduced-motion:reduce){html{scroll-behavior:auto}}.search-trigger{display:inline-flex;align-items:center;gap:8px;height:38px;padding:0 9px 0 11px;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--surface);color:var(--ink-3);cursor:pointer;font-family:inherit;transition:all var(--transition-fast)}.search-trigger:hover{color:var(--ink);border-color:var(--ink-4);background:var(--surface-2)}.search-trigger svg{width:17px;height:17px}.search-trigger .st-label{font-size:13px;font-weight:600}.search-trigger .st-kbd{font:600 11px/1 var(--font-mono);color:var(--ink-4);background:var(--bg-soft);border:1px solid var(--border);border-radius:6px;padding:3px 6px}@media(max-width:720px){.search-trigger{width:38px;padding:0;justify-content:center}.search-trigger .st-label,.search-trigger .st-kbd{display:none}}.search-modal{display:none;position:fixed;inset:0;z-index:80}html[data-search-open]{overflow:hidden}html[data-search-open] .search-modal{display:block}.sm-backdrop{position:absolute;inset:0;background:var(--overlay);backdrop-filter:blur(3px);-webkit-backdrop-filter:blur(3px);animation:sm-fade var(--transition-fast) ease}.sm-dialog{position:relative;z-index:1;width:min(640px,calc(100vw - 32px));margin:9vh auto 0;max-height:78vh;display:flex;flex-direction:column;overflow:hidden;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);animation:sm-pop var(--transition-base) cubic-bezier(.2,.8,.2,1)}@keyframes sm-fade{0%{opacity:0}}@keyframes sm-pop{0%{opacity:0;transform:translateY(-8px) scale(.98)}}.sm-head{display:flex;align-items:center;gap:11px;padding:14px 16px;border-bottom:1px solid var(--border-soft)}.sm-head .sm-search-icon{width:19px;height:19px;color:var(--ink-3);flex:none}.sm-input{flex:1;min-width:0;border:0;outline:0;background:transparent;font-family:inherit;font-size:16px;color:var(--ink)}.sm-input::placeholder{color:var(--ink-4)}.sm-input::-webkit-search-cancel-button{-webkit-appearance:none}.sm-close{display:inline-flex;align-items:center;border:0;background:transparent;padding:0;cursor:pointer}.sm-close kbd,.sm-foot kbd{font:600 11px/1 var(--font-mono);color:var(--ink-4);background:var(--bg-soft);border:1px solid var(--border);border-radius:6px;padding:4px 7px}.sm-close:hover kbd{color:var(--ink-2);border-color:var(--ink-4)}.sm-results{flex:1;overflow-y:auto;padding:8px}.sm-empty{padding:34px 16px;text-align:center;color:var(--ink-4);font-size:14px}.sr-item{display:block;padding:11px 13px;border-radius:var(--radius-md);border:1px solid transparent;cursor:pointer}.sr-item.active{background:var(--bg-soft);border-color:var(--border-soft)}.sr-title{font-size:14.5px;font-weight:700;color:var(--ink);margin-bottom:3px}.sr-snippet{font-size:12.5px;color:var(--ink-3);line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.sr-meta{display:flex;align-items:center;gap:8px;margin-top:7px;flex-wrap:wrap}.sr-date{font:600 11px/1 var(--font-mono);color:var(--ink-4)}.sr-tag{font-size:11px;font-weight:600;color:var(--ink-3);background:var(--bg-soft);border-radius:var(--radius-full);padding:3px 9px}.sr-item mark{background:#2a6fea29;color:var(--brand-2);border-radius:3px;padding:0 1px}[data-theme=dark] .sr-item mark{background:#5b8df538;color:var(--brand-1)}.sm-foot{display:flex;align-items:center;gap:16px;padding:10px 16px;border-top:1px solid var(--border-soft);color:var(--ink-4);font-size:12px}.sm-foot kbd{padding:2px 6px}.sm-foot .sm-count{margin-left:auto}@media(max-width:720px){.sm-dialog{width:100vw;max-height:100vh;height:100%;margin:0;border:0;border-radius:0}.sm-foot span:not(.sm-count){display:none}}.hero{padding:64px 0 30px}.hero h1{font-family:var(--font-sans);font-weight:800;letter-spacing:-.03em;font-size:clamp(34px,5vw,52px);line-height:1.08;margin:18px 0 0}.hero p{margin:20px 0 0;max-width:600px;font-size:17px;line-height:1.7;color:var(--ink-3)}.hero .meta{margin-top:26px;display:flex;align-items:center;gap:14px;flex-wrap:wrap}.hero .meta .pill{display:inline-flex;align-items:center;gap:7px;font-size:13px;font-weight:600;color:var(--ink-3);white-space:nowrap}.hero .meta .pill svg{width:15px;height:15px;color:var(--brand-2)}.hero .meta .sep{width:4px;height:4px;border-radius:50%;background:var(--ink-4)}.filterbar{display:flex;align-items:center;gap:9px;flex-wrap:wrap;padding:8px 0 6px}.filterbar .chip{font-size:13px;font-weight:600;color:var(--ink-3);padding:7px 14px;border-radius:var(--radius-full);cursor:pointer;border:1px solid var(--border);background:var(--surface);transition:all var(--transition-fast)}.filterbar .chip:hover{color:var(--ink);border-color:var(--ink-4)}.filterbar .chip.active{color:#fff;background:var(--brand-grad);border-color:transparent;box-shadow:var(--shadow-brand)}.post-list{margin-top:14px}.post{display:grid;grid-template-columns:92px 1fr;gap:28px;padding:30px 0;border-top:1px solid var(--border-soft);transition:opacity var(--transition-base)}.post:first-child{border-top:none}.post .when{padding-top:4px}.post .when .day{font-size:22px;font-weight:800;letter-spacing:-.02em;line-height:1}.post .when .ym{margin-top:6px;font-size:12px;font-weight:600;color:var(--ink-4);font-family:var(--font-mono)}.post .body h2{margin:0;font-size:23px;font-weight:800;letter-spacing:-.02em;line-height:1.25;transition:color var(--transition-fast)}.post:hover .body h2{color:var(--brand-2)}.post .body .excerpt{margin:10px 0 0;color:var(--ink-3);font-size:15px;line-height:1.65;max-width:62ch}.post .body .tags{margin-top:14px;display:flex;gap:8px;align-items:center;flex-wrap:wrap}.post .body .read{margin-left:auto;font-size:12px;font-weight:600;color:var(--ink-4);font-family:var(--font-mono);white-space:nowrap}.post .body .row{display:flex;align-items:center;gap:10px}.post-featured{grid-template-columns:1fr;gap:0;padding:0;border:none;margin-bottom:8px}.post-featured .card{display:block;position:relative;overflow:hidden;border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--surface);box-shadow:var(--shadow-md);padding:34px 36px;transition:all var(--transition-base)}.post-featured .card:before{content:"";position:absolute;inset:0 0 auto;height:4px;background:var(--brand-grad)}.post-featured .card:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}.post-featured .badge-feat{display:inline-flex;align-items:center;gap:6px;font-size:11px;font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:#fff;background:var(--brand-grad);padding:4px 11px;border-radius:var(--radius-full);white-space:nowrap}.post-featured h2{margin:16px 0 0;font-size:clamp(26px,3.4vw,34px);font-weight:800;letter-spacing:-.025em;line-height:1.15;transition:color var(--transition-fast)}.post-featured .card:hover h2{color:var(--brand-2)}.post-featured .excerpt{margin:14px 0 0;font-size:16px;color:var(--ink-3);line-height:1.7;max-width:70ch}.post-featured .foot{margin-top:22px;display:flex;align-items:center;gap:12px;flex-wrap:wrap}.post-featured .read{margin-left:auto;font-size:12px;font-weight:600;color:var(--ink-4);font-family:var(--font-mono);white-space:nowrap}.article-grid{display:grid;grid-template-columns:1fr minmax(0,var(--measure)) 1fr;gap:0;align-items:start;padding-top:40px}.article-main{grid-column:2;min-width:0}.toc-col{grid-column:3;position:sticky;top:calc(var(--topbar-h) + 28px);padding-left:40px;align-self:start}.article-head{margin-bottom:38px}.article-head .crumbs{display:flex;align-items:center;gap:9px;font-size:12.5px;color:var(--ink-4);font-weight:600;margin-bottom:22px;flex-wrap:wrap}.article-head .crumbs a:hover{color:var(--brand-2)}.article-head .crumbs svg{width:13px;height:13px}.article-head .tags{display:flex;gap:8px;margin-bottom:18px;flex-wrap:wrap}.article-head h1{font-family:var(--font-sans);font-weight:800;letter-spacing:-.03em;font-size:clamp(30px,4.2vw,44px);line-height:1.13;margin:0}.article-head .sub{margin:18px 0 0;font-size:18px;color:var(--ink-3);line-height:1.6;font-family:var(--font-serif);font-style:italic}.article-meta{margin-top:26px;padding-top:22px;border-top:1px solid var(--border-soft);display:flex;align-items:center;gap:14px;flex-wrap:wrap}.article-meta .avatar{width:38px;height:38px;border-radius:50%;background:var(--brand-grad);display:grid;place-items:center;color:#fff;font-weight:800;font-size:15px;flex-shrink:0}.article-meta .who{font-size:13.5px}.article-meta .who .name{font-weight:700}.article-meta .who .det{color:var(--ink-4);font-size:12.5px}.article-meta .det-row{display:flex;align-items:center;gap:10px;color:var(--ink-4);font-size:12.5px;font-weight:600;font-family:var(--font-mono);white-space:nowrap}.article-meta .det-row .sep{width:3px;height:3px;border-radius:50%;background:var(--ink-4)}.cover{border-radius:var(--radius-md);overflow:hidden;border:1px solid var(--border);margin-bottom:38px;aspect-ratio:16/8;position:relative;background:var(--brand-grad-soft)}.cover img{width:100%;height:100%;object-fit:cover}.cover .ph{position:absolute;inset:0;display:grid;place-items:center;color:var(--ink-4);font-size:13px;font-weight:600;gap:8px}.cover .ornament{position:absolute;inset:0;background:radial-gradient(40% 60% at 18% 30%,rgba(26,163,240,.22),transparent 60%),radial-gradient(45% 55% at 82% 75%,rgba(63,216,150,.2),transparent 60%),radial-gradient(30% 40% at 60% 20%,rgba(42,111,234,.18),transparent 60%)}.prose{font-family:var(--font-serif);font-size:18.5px;line-height:1.85;color:var(--ink-2)}.prose>*+*{margin-top:1.35em}.prose p{margin:0}.prose h2{font-family:var(--font-sans);font-weight:800;letter-spacing:-.02em;font-size:26px;line-height:1.25;color:var(--ink);margin:2em 0 0;scroll-margin-top:calc(var(--topbar-h) + 24px);padding-top:4px}.prose h3{font-family:var(--font-sans);font-weight:700;font-size:20px;color:var(--ink);margin:1.7em 0 0;scroll-margin-top:calc(var(--topbar-h) + 24px)}.prose a{color:var(--brand-2);font-weight:600;border-bottom:1px solid rgba(42,111,234,.3);transition:border-color var(--transition-fast)}.prose a:hover{border-color:var(--brand-2)}.prose strong{color:var(--ink);font-weight:700}.prose ul,.prose ol{margin:1.1em 0;padding-left:1.4em}.prose li{margin:.5em 0}.prose li::marker{color:var(--brand-2)}.prose blockquote{margin:1.6em 0;padding:4px 0 4px 22px;border-left:3px solid;border-image:var(--brand-grad) 1;color:var(--ink-3);font-style:italic;font-size:18px}.prose blockquote p{margin:0}.prose hr{border:none;border-top:1px solid var(--border);margin:2.4em 0}.prose .lead{font-size:21px;line-height:1.7;color:var(--ink-2)}.prose img{border-radius:var(--radius-md);border:1px solid var(--border)}.prose figure{margin:1.8em 0}.prose figure .frame{border-radius:var(--radius-md);border:1px solid var(--border);overflow:hidden;aspect-ratio:16/9;background:var(--brand-grad-soft);position:relative}.prose figure .frame .ph{position:absolute;inset:0;display:grid;place-items:center;color:var(--ink-4);font-size:13px;font-weight:600}.prose figcaption{margin-top:10px;font-family:var(--font-sans);font-size:13px;color:var(--ink-4);text-align:center}.prose :not(pre)>code{font-family:var(--font-mono);font-size:.83em;background:var(--code-inline-bg);color:var(--code-inline-fg);padding:2px 6px;border-radius:6px;font-feature-settings:"tnum"}.codeblock{font-family:var(--font-mono);background:var(--code-bg);color:var(--code-fg);border-radius:var(--radius-md);overflow:hidden;margin:1.7em 0;box-shadow:var(--shadow-md);border:1px solid rgba(255,255,255,.06)}.codeblock .cb-head{display:flex;align-items:center;gap:8px;padding:11px 16px;background:#ffffff08;border-bottom:1px solid rgba(255,255,255,.06)}.codeblock .cb-dots{display:flex;gap:6px}.codeblock .cb-dots i{width:11px;height:11px;border-radius:50%;display:block}.codeblock .cb-dots i:nth-child(1){background:#ff5f57}.codeblock .cb-dots i:nth-child(2){background:#febc2e}.codeblock .cb-dots i:nth-child(3){background:#28c840}.codeblock .cb-lang{margin-left:6px;font-size:12px;color:#8a96ac;font-weight:600;text-transform:lowercase}.codeblock .cb-copy{margin-left:auto;font-size:12px;color:#8a96ac;background:none;border:none;cursor:pointer;display:inline-flex;gap:5px;align-items:center;transition:color var(--transition-fast)}.codeblock .cb-copy:hover{color:#d8e0f0}.codeblock .cb-copy svg{width:13px;height:13px}.codeblock pre{margin:0;padding:18px 20px;overflow-x:auto;font-size:13.5px;line-height:1.75;background:var(--code-bg)!important}.codeblock pre code{background:none;color:inherit;padding:0;font-size:inherit;font-family:var(--font-mono)}.tok-key{color:var(--tok-key)}.tok-str{color:var(--tok-str)}.tok-num{color:var(--tok-num)}.tok-com,.tok-comment{color:var(--tok-com);font-style:italic}.tok-fn{color:var(--tok-fn)}.tok-punc{color:var(--tok-punc)}.tok-tag{color:var(--tok-tag)}.callout{display:flex;gap:14px;padding:18px 20px;border-radius:var(--radius-md);background:var(--brand-grad-soft);border:1px solid rgba(42,111,234,.18);font-family:var(--font-sans);font-size:15px;line-height:1.6;color:var(--ink-2);margin:1.7em 0}.callout .ic{flex-shrink:0;width:22px;height:22px;color:var(--brand-2)}.callout strong{color:var(--ink)}.prose .embed-video{display:block;width:100%;max-height:72vh;margin:1.7em 0;border-radius:var(--radius-md);border:1px solid var(--border);background:#000}.prose .embed-audio{display:block;width:100%;margin:1.7em 0}.prose .embed-frame{position:relative;margin:1.7em 0;aspect-ratio:16 / 9;border-radius:var(--radius-md);overflow:hidden;border:1px solid var(--border);background:var(--bg-soft)}.prose .embed-frame iframe{position:absolute;inset:0;width:100%;height:100%;border:0}.prose .embed-music{display:block;width:100%;max-width:480px;height:86px;margin:1.7em 0;border-radius:var(--radius-md);border:1px solid var(--border)}.prose .embed-fallback{margin:1.7em 0}.toc{font-size:13px}.toc .toc-title{font-size:11px;font-weight:800;letter-spacing:.13em;text-transform:uppercase;color:var(--ink-4);margin-bottom:14px}.toc ul{list-style:none;margin:0;padding:0;border-left:2px solid var(--border)}.toc li a{display:block;padding:6px 0 6px 16px;margin-left:-2px;color:var(--ink-3);font-weight:600;border-left:2px solid transparent;transition:all var(--transition-fast);line-height:1.4}.toc li a:hover{color:var(--ink)}.toc li.sub a{padding-left:28px;font-weight:500;font-size:12.5px}.toc li a.active{color:var(--brand-2);border-left-color:var(--brand-2)}.toc .share{margin-top:26px;padding-top:22px;border-top:1px solid var(--border-soft);display:flex;gap:8px}.toc .share button{width:34px;height:34px}.author-card{margin-top:56px;padding:28px;border-radius:var(--radius-lg);border:1px solid var(--border);background:var(--surface);box-shadow:var(--shadow-sm);display:flex;gap:20px;align-items:flex-start}.author-card .av{width:60px;height:60px;border-radius:50%;background:var(--brand-grad);flex-shrink:0;display:grid;place-items:center;color:#fff;font-weight:800;font-size:22px;box-shadow:var(--shadow-brand)}.author-card .name{font-size:17px;font-weight:800}.author-card .role{font-size:13px;color:var(--brand-2);font-weight:600;margin-top:2px}.author-card .bio{margin-top:10px;font-size:14.5px;color:var(--ink-3);line-height:1.6}.author-card .links{margin-top:14px;display:flex;gap:10px;flex-wrap:wrap}.pn{margin-top:40px;display:grid;grid-template-columns:1fr 1fr;gap:16px}.pn a{padding:20px 22px;border-radius:var(--radius-md);border:1px solid var(--border);background:var(--surface);transition:all var(--transition-base)}.pn a:hover{border-color:var(--ink-4);box-shadow:var(--shadow-md);transform:translateY(-2px)}.pn .dir{font-size:12px;font-weight:700;color:var(--ink-4);display:flex;align-items:center;gap:6px}.pn .dir svg{width:14px;height:14px}.pn .pn-title{margin-top:8px;font-size:15.5px;font-weight:700;letter-spacing:-.01em;line-height:1.35}.pn a:hover .pn-title{color:var(--brand-2)}.pn .next{text-align:right}.pn .next .dir{justify-content:flex-end}.page-head{padding:56px 0 12px}.page-head h1{font-size:clamp(30px,4vw,42px);font-weight:800;letter-spacing:-.03em;margin:14px 0 0;line-height:1.1}.page-head p{margin:14px 0 0;color:var(--ink-3);font-size:16px;max-width:560px}.tag-cloud{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:14px;margin-top:34px}.tag-card{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:18px 20px;border-radius:var(--radius-md);border:1px solid var(--border);background:var(--surface);box-shadow:var(--shadow-sm);transition:all var(--transition-base);cursor:pointer}.tag-card:hover{border-color:transparent;box-shadow:var(--shadow-md);transform:translateY(-2px)}.tag-card .tc-l{display:flex;align-items:center;gap:12px;min-width:0}.tag-card .tc-hash{width:38px;height:38px;border-radius:11px;display:grid;place-items:center;background:var(--brand-grad-soft);color:var(--brand-2);font-weight:800;flex-shrink:0}.tag-card:hover .tc-hash{background:var(--brand-grad);color:#fff}.tag-card .tc-name{font-weight:700;font-size:15px}.tag-card .tc-desc{font-size:12.5px;color:var(--ink-4);margin-top:1px}.tag-card .tc-count{font-size:13px;font-weight:700;color:var(--ink-4);font-family:var(--font-mono);flex-shrink:0}.archive{margin-top:30px}.archive .yr{display:grid;grid-template-columns:120px 1fr;gap:28px;padding:28px 0;border-top:1px solid var(--border-soft)}.archive .yr:first-child{border-top:none}.archive .yr .y{font-size:30px;font-weight:800;letter-spacing:-.02em;color:var(--ink);position:sticky;top:calc(var(--topbar-h) + 28px);align-self:start;font-family:var(--font-mono)}.archive .yr .y .cnt{display:block;font-family:var(--font-sans);font-size:12px;font-weight:600;color:var(--ink-4);margin-top:4px}.archive .items{display:flex;flex-direction:column}.archive .item{display:flex;align-items:baseline;gap:16px;padding:12px 0;border-bottom:1px solid var(--border-soft);transition:all var(--transition-fast)}.archive .item:last-child{border-bottom:none}.archive .item .date{font-size:12.5px;font-family:var(--font-mono);color:var(--ink-4);width:52px;flex-shrink:0}.archive .item .t{font-size:16px;font-weight:600;transition:color var(--transition-fast)}.archive .item:hover .t{color:var(--brand-2)}.archive .item:hover{padding-left:6px}.archive .item .tg{margin-left:auto;flex-shrink:0}.about-hero{display:grid;grid-template-columns:140px 1fr;gap:34px;align-items:center;padding:50px 0 10px}.about-hero .big-av{width:140px;height:140px;border-radius:28px;background:var(--brand-grad);display:grid;place-items:center;color:#fff;font-weight:800;font-size:56px;box-shadow:var(--shadow-lg)}.about-hero h1{font-size:clamp(30px,4vw,42px);font-weight:800;letter-spacing:-.03em;margin:0}.about-hero .tagline{margin-top:10px;font-size:17px;color:var(--brand-2);font-weight:600}.about-hero .links{margin-top:18px;display:flex;gap:10px;flex-wrap:wrap}.about-body{margin-top:40px;display:grid;grid-template-columns:minmax(0,var(--measure)) 1fr;gap:50px;align-items:start}.about-prose{font-family:var(--font-serif);font-size:18px;line-height:1.85;color:var(--ink-2)}.about-prose>*+*{margin-top:1.3em}.about-prose h2{font-family:var(--font-sans);font-size:22px;font-weight:800;color:var(--ink);margin:1.8em 0 0}.about-side{position:sticky;top:calc(var(--topbar-h) + 28px)}.about-side .panel{padding:22px;border-radius:var(--radius-md);border:1px solid var(--border);background:var(--surface);box-shadow:var(--shadow-sm)}.about-side .panel+.panel{margin-top:16px}.about-side .panel h3{margin:0 0 14px;font-size:11px;font-weight:800;letter-spacing:.13em;text-transform:uppercase;color:var(--ink-4)}.about-side .stack{display:flex;flex-wrap:wrap;gap:8px}.about-side .kv{display:flex;justify-content:space-between;gap:10px;font-size:13.5px;padding:7px 0;border-top:1px solid var(--border-soft)}.about-side .kv:first-of-type{border-top:none}.about-side .kv .k{color:var(--ink-4)}.about-side .kv .v{font-weight:600}.timeline-section{--tl-axis: 114px;margin-top:64px;padding-top:40px;border-top:1px solid var(--border-soft)}.tl-head{margin-bottom:32px}.tl-head h2{margin:12px 0 0;font-size:26px;font-weight:800;letter-spacing:-.02em;color:var(--ink)}.tl-track{position:relative}.tl-track:before{content:"";position:absolute;left:var(--tl-axis);top:12px;bottom:30px;width:2px;transform:translate(-1px);border-radius:2px;background:linear-gradient(180deg,var(--brand-1),var(--brand-2) 50%,var(--brand-3));opacity:.26}.tl-node{position:relative;display:grid;grid-template-columns:96px 36px 1fr;column-gap:0;align-items:start;padding-bottom:38px}.tl-node:last-child{padding-bottom:6px}.timeline-section.tl-ready .tl-node{opacity:0;transform:translateY(20px);transition:opacity .7s ease,transform .7s cubic-bezier(.16,1,.3,1)}.timeline-section.tl-ready .tl-node.in{opacity:1;transform:none}.tl-year{grid-column:1;justify-self:end;align-self:start;display:inline-flex;font-family:var(--font-mono);font-weight:800;font-size:36px;line-height:1;letter-spacing:-.02em}.tl-year,.tl-year .digit{background:var(--brand-grad);-webkit-background-clip:text;background-clip:text;color:transparent}.tl-year .reel{display:inline-block;height:1em;overflow:hidden;vertical-align:top}.tl-year .reel-inner{display:block;transition:transform 1s cubic-bezier(.16,1,.3,1);will-change:transform}.tl-year .digit{display:block;height:1em;line-height:1;text-align:center}.tl-dot{grid-column:2;justify-self:center;align-self:start;margin-top:11px;position:relative;z-index:1;width:14px;height:14px;border-radius:50%;background:var(--brand-grad);box-shadow:0 0 0 4px var(--surface),0 0 0 5px var(--border);transform:scale(0);transition:transform .5s cubic-bezier(.34,1.56,.64,1) .1s}.timeline-section.tl-ready .tl-node.in .tl-dot{transform:scale(1)}.tl-node.in .tl-dot:after{content:"";position:absolute;inset:-4px;border-radius:50%;border:2px solid var(--brand-2);opacity:0;animation:tl-ping .9s ease-out .25s 1}@keyframes tl-ping{0%{opacity:.5;transform:scale(.6)}to{opacity:0;transform:scale(1.85)}}.tl-content{grid-column:3;padding-left:18px;padding-top:1px}.tl-content .tl-month{display:inline-block;font-family:var(--font-mono);font-size:12px;font-weight:700;letter-spacing:.04em;color:var(--brand-2);background:var(--brand-grad-soft);border:1px solid var(--border);padding:3px 10px;border-radius:var(--radius-full)}.tl-content h3{margin:11px 0 0;font-size:18px;font-weight:800;letter-spacing:-.01em;color:var(--ink)}.tl-content p{margin:5px 0 0;font-size:14.5px;line-height:1.7;color:var(--ink-3);max-width:52ch}.notfound{padding:90px 0 60px;text-align:center}.notfound .code{font-family:var(--font-mono);font-size:clamp(64px,12vw,120px);font-weight:800;line-height:1;letter-spacing:-.04em}.notfound p{margin:18px 0 26px;color:var(--ink-3);font-size:16px}@media(max-width:1080px){.article-grid{grid-template-columns:1fr}.article-main{grid-column:1;max-width:var(--measure);margin:0 auto;width:100%}.toc-col{display:none}.about-body{grid-template-columns:1fr}.about-side{position:static}}@media(max-width:720px){.nav{display:none}.nav-toggle{display:inline-flex}[data-menu-open] .mobile-nav{display:block}.wrap{padding:0 18px}.post{grid-template-columns:1fr;gap:10px}.post .when{display:flex;align-items:baseline;gap:8px;padding-top:0}.post .when .ym{margin-top:0}.pn{grid-template-columns:1fr}.about-hero{grid-template-columns:1fr;text-align:center;justify-items:center}.archive .yr{grid-template-columns:1fr;gap:12px}.archive .yr .y{position:static}.timeline-section{--tl-axis: 78px}.tl-node{grid-template-columns:60px 36px 1fr;padding-bottom:30px}.tl-year{font-size:26px}.tl-dot{margin-top:7px}.tl-content{padding-left:14px}.tl-content h3{font-size:16.5px}}
