:root{--radius-sm: 6px;--radius-md: 10px;--content-max: 42rem;--space-xs: .25rem;--space-sm: .5rem;--space-md: 1rem;--space-lg: 1.5rem;--space-xl: 2.5rem;--font-sans: "DM Sans", "Source Han Sans SC", "Noto Sans SC", system-ui, sans-serif;--font-mono: "JetBrains Mono", ui-monospace, monospace;--font-display: var(--font-sans)}[data-theme=warm]{color-scheme:light;--bg: #efe8dc;--bg-elevated: #f5f0e8;--surface: #faf7f1;--ink: #1c1814;--ink-muted: #5a534a;--ink-faint: #8a8278;--accent: #1a4a5c;--accent-soft: #dde8ec;--border: #dcd3c4;--on-accent: #fffaf5;--shadow: 0 1px 1px rgba(60, 48, 30, .06), 0 10px 28px rgba(60, 48, 30, .07);--shadow-card-hover: 0 6px 16px rgba(60, 48, 30, .08), 0 20px 44px rgba(60, 48, 30, .09);--pre-bg: #2a2520;--pre-fg: #f2ebe4;--font-display: "Newsreader", "Source Han Serif SC", "Noto Serif SC", Georgia, "Times New Roman", serif;--content-max: 44rem;--particle-dot-bg: rgba(139, 115, 85, .18);--particle-blob-bg: rgba(26, 74, 92, .07);--dot-opacity: .14;--blob-min-opacity: .03;--blob-max-opacity: .07;--particle-star-bg: rgba(90, 70, 50, .7);--star-min-opacity: .08;--star-max-opacity: .45}[data-theme=dark]{color-scheme:dark;--bg: #12151a;--bg-elevated: #181c24;--surface: #1c222d;--ink: #e8eaef;--ink-muted: #a8b0bd;--ink-faint: #7a8494;--accent: #7eb8ff;--accent-soft: rgba(126, 184, 255, .12);--border: #2a3342;--on-accent: #0f1419;--shadow: 0 1px 0 rgba(255, 255, 255, .04), 0 12px 40px rgba(0, 0, 0, .45);--shadow-card-hover: 0 8px 28px rgba(0, 0, 0, .5);--pre-bg: #0d1117;--pre-fg: #d8e0ea;--particle-dot-bg: rgba(126, 184, 255, .28);--particle-blob-bg: rgba(126, 184, 255, .1);--dot-opacity: .3;--blob-min-opacity: .05;--blob-max-opacity: .12;--particle-star-bg: rgba(180, 210, 255, .8);--star-min-opacity: .08;--star-max-opacity: .5}[data-theme=cool]{color-scheme:light;--bg: #eef2f6;--bg-elevated: #f7f9fc;--surface: #ffffff;--ink: #152028;--ink-muted: #4a5a68;--ink-faint: #7a8b99;--accent: #0d6b7c;--accent-soft: #d9eef1;--border: #d4dde6;--on-accent: #ffffff;--shadow: 0 1px 2px rgba(21, 32, 40, .05), 0 8px 22px rgba(21, 32, 40, .06);--shadow-card-hover: 0 4px 14px rgba(21, 32, 40, .08), 0 18px 44px rgba(21, 32, 40, .07);--pre-bg: #152028;--pre-fg: #e8f2f5;--particle-dot-bg: rgba(13, 107, 124, .15);--particle-blob-bg: rgba(13, 107, 124, .06);--dot-opacity: .14;--blob-min-opacity: .03;--blob-max-opacity: .06;--particle-star-bg: rgba(13, 107, 124, .45);--star-min-opacity: .06;--star-max-opacity: .28}*,*:before,*:after{box-sizing:border-box}body{margin:0;min-height:100vh;font-family:var(--font-sans);font-size:1rem;line-height:1.65;color:var(--ink);background-color:var(--bg);background-image:none;-webkit-font-smoothing:antialiased}.bg-particles{position:fixed;top:0;right:0;bottom:0;left:0;z-index:0;pointer-events:none;overflow:hidden}.bg-particles__dot{position:absolute;border-radius:50%;background:var(--particle-dot-bg);opacity:0;animation:floatDot var(--float-duration, 18s) var(--float-delay, 0s) infinite ease-in-out}@keyframes floatDot{0%{opacity:0;transform:translate(0) scale(.6)}15%{opacity:var(--dot-opacity, .12)}85%{opacity:var(--dot-opacity, .12)}to{opacity:0;transform:translate(var(--float-x, 40px),var(--float-y, -120px)) scale(1)}}.bg-particles__blob{position:absolute;border-radius:50%;background:var(--particle-blob-bg);filter:blur(80px);opacity:0;animation:driftBlob var(--blob-duration, 22s) var(--blob-delay, 0s) infinite ease-in-out}@keyframes driftBlob{0%,to{opacity:var(--blob-min-opacity, .04);transform:translate(0) scale(1)}50%{opacity:var(--blob-max-opacity, .08);transform:translate(var(--blob-x, 30px),var(--blob-y, -40px)) scale(1.15)}}.bg-particles__star{position:absolute;border-radius:50%;background:var(--particle-star-bg);animation:twinkle var(--twinkle-duration, 3s) var(--twinkle-delay, 0s) infinite ease-in-out}@keyframes twinkle{0%,to{opacity:var(--star-min-opacity, .08);transform:scale(.8)}50%{opacity:var(--star-max-opacity, .35);transform:scale(1.3)}}.layout{position:relative;z-index:1}[data-theme=warm] body{font-size:1.0625rem}#root{min-height:100vh}a{color:var(--accent);text-decoration-thickness:1px;text-underline-offset:3px}a:hover{text-decoration:none}img{max-width:100%;height:auto}code,pre{font-family:var(--font-mono);font-size:.9em}pre{padding:var(--space-md);border-radius:var(--radius-md);background:var(--pre-bg);color:var(--pre-fg);overflow-x:auto}pre code{font-size:inherit}.theme-toggle{display:flex;flex-wrap:wrap;gap:2px;padding:3px;border-radius:999px;border:1px solid var(--border);background:var(--bg-elevated)}.theme-toggle button{border:none;background:transparent;color:var(--ink-muted);font:inherit;font-size:.78rem;font-weight:600;padding:.35rem .65rem;border-radius:999px;cursor:pointer;transition:background .15s ease,color .15s ease}.theme-toggle button:hover{color:var(--accent)}.theme-toggle button.is-active{background:var(--accent);color:var(--on-accent)}.layout{min-height:100vh;display:flex;flex-direction:column}.layout__header{position:sticky;top:0;z-index:10;border-bottom:1px solid var(--border);background:color-mix(in srgb,var(--bg) 92%,transparent);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.layout__header-inner{max-width:88rem;margin:0 auto;padding:var(--space-md) var(--space-lg);display:flex;align-items:center;justify-content:space-between;gap:var(--space-md) var(--space-lg);flex-wrap:wrap}.layout__end{display:flex;align-items:center;flex-wrap:wrap;gap:var(--space-md) var(--space-lg)}.layout__brand{font-weight:700;font-size:1.05rem;letter-spacing:-.02em;color:var(--ink);text-decoration:none}.layout__brand span{color:var(--accent)}.layout__nav{display:flex;gap:var(--space-lg);align-items:center}.layout__nav a{color:var(--ink-muted);font-size:.95rem;text-decoration:none}.layout__nav a:hover{color:var(--accent)}.layout__main{flex:1;width:100%;max-width:88rem;margin:0 auto;padding:var(--space-xl) var(--space-lg)}.layout__footer{border-top:1px solid var(--border);padding:var(--space-lg);text-align:center;font-size:.875rem;color:var(--ink-faint)}.back-to-top{position:fixed;bottom:1.5rem;right:1.5rem;z-index:50;display:flex;flex-direction:column;align-items:center;gap:.1rem;padding:.55rem .65rem .45rem;border:1.5px solid var(--accent);border-radius:var(--radius-md);background:var(--surface);color:var(--accent);font-size:.7rem;font-weight:600;cursor:pointer;box-shadow:0 2px 12px #0000001a;transition:transform .18s ease,box-shadow .18s ease,opacity .25s ease;animation:fadeUpIn .3s ease;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.back-to-top:hover{transform:translateY(-2px);box-shadow:0 4px 18px #00000029}.back-to-top:active{transform:translateY(0)}@keyframes fadeUpIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.resume{max-width:48rem}.resume__hero{text-align:center;margin-bottom:var(--space-xl);padding-bottom:var(--space-xl);border-bottom:1px solid var(--border)}.resume__name{margin:0 0 var(--space-xs);font-family:var(--font-display);font-size:clamp(2.2rem,5vw,3.2rem);font-weight:700;letter-spacing:-.03em;line-height:1.15}.resume__role{margin:0 0 var(--space-md);font-size:clamp(1rem,2.2vw,1.2rem);font-weight:500;color:var(--ink-muted)}.resume__contact{list-style:none;margin:0;padding:0;display:flex;flex-wrap:wrap;justify-content:center;gap:var(--space-sm);font-size:.92rem;color:var(--ink-muted)}.resume__contact li{display:inline-flex;align-items:center;gap:.35em}.resume__contact li+li:before{content:"·";margin-right:var(--space-sm);color:var(--ink-faint)}.resume__contact-label{color:var(--ink-faint);font-size:.82rem}.resume__section{margin-bottom:var(--space-xl)}.resume__h2{display:inline-block;margin:0 0 var(--space-md);padding:.3em .85em;font-size:.82rem;font-weight:700;letter-spacing:.05em;color:#fff;background:var(--ink);border-radius:var(--radius-sm);line-height:1.4}.resume__timeline{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:var(--space-md)}.resume__card{padding:var(--space-lg);border-radius:var(--radius-md);border:1px solid var(--border);background:var(--surface);box-shadow:var(--shadow)}.resume__card-head{display:flex;flex-wrap:wrap;align-items:baseline;justify-content:space-between;gap:var(--space-sm);margin-bottom:var(--space-sm)}.resume__card-head time{font-size:.85rem;color:var(--ink-faint);white-space:nowrap;flex-shrink:0}.resume__muted{color:var(--ink-muted);font-weight:400}.resume__stack{margin:0 0 var(--space-xs);font-size:.85rem;color:var(--ink-faint)}.resume__card-body{margin:0;color:var(--ink-muted);font-size:.95rem;line-height:1.65}.resume__bullets{margin:var(--space-sm) 0 0;padding-left:1.15rem;color:var(--ink-muted);font-size:.93rem;line-height:1.7}.resume__bullets li{margin-bottom:.4em}.resume__bullets li:last-child{margin-bottom:0}.resume__skills{list-style:disc;margin:0;padding-left:1.4rem}.resume__skills li{font-size:.93rem;line-height:1.7;margin-bottom:.5em;color:var(--ink-muted)}.resume__skills li:last-child{margin-bottom:0}.resume__skills strong{color:var(--ink);font-weight:600}.home__shell{display:grid;gap:var(--space-xl)}.home__outline{border:1px solid var(--border);border-radius:var(--radius-md);background:color-mix(in srgb,var(--surface) 88%,var(--bg));box-shadow:var(--shadow);overflow:hidden}.home__outline-head{padding:var(--space-md) var(--space-md) var(--space-sm);border-bottom:1px solid var(--border)}.home__outline-kicker{margin:0 0 .15rem;color:var(--accent);font-size:.72rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase}.home__outline h2{margin:0;font-family:var(--font-display);font-size:1.05rem;line-height:1.25}.home__outline-groups{max-height:24rem;overflow-y:auto;overscroll-behavior:contain}.home__outline-group{border-bottom:1px solid var(--border)}.home__outline-group:last-child{border-bottom:0}.home__outline-group summary{display:flex;align-items:center;justify-content:space-between;gap:var(--space-sm);padding:.78rem var(--space-md);border-left:3px solid transparent;background:color-mix(in srgb,var(--bg-elevated) 58%,transparent);color:var(--ink);cursor:pointer;list-style:none;font-weight:700;line-height:1.25}.home__outline-group summary::-webkit-details-marker{display:none}.home__outline-group summary:before{content:"›";flex:0 0 auto;color:var(--ink-faint);font-size:1.05rem;line-height:1;transform:rotate(0);transition:transform .15s ease}.home__outline-group[open] summary:before{transform:rotate(90deg)}.home__outline-group[open] summary{border-left-color:var(--accent)}.home__outline-group summary span:first-child{flex:1}.home__outline-group summary span:last-child{min-width:1.65rem;padding:.05rem .45rem;border-radius:999px;background:var(--accent-soft);color:var(--accent);font-size:.78rem;text-align:center}.home__outline-group ul{list-style:none;margin:0;padding:var(--space-xs) var(--space-sm) var(--space-sm)}.home__outline-group li{margin:0}.home__outline-group a{position:relative;display:grid;gap:.12rem;min-height:3rem;padding:.48rem .7rem .48rem 1.4rem;border-radius:var(--radius-sm);color:var(--ink-muted);text-decoration:none;line-height:1.35;transition:background .15s ease,color .15s ease,transform .15s ease}.home__outline-group a:before{content:"";position:absolute;top:.85rem;left:.55rem;width:.42rem;height:.42rem;border-radius:50%;border:1px solid var(--accent);background:var(--surface)}.home__outline-title{display:-webkit-box;overflow:hidden;color:var(--ink);font-size:.9rem;font-weight:600;-webkit-box-orient:vertical;-webkit-line-clamp:2}.home__outline-date{color:var(--ink-faint);font-size:.76rem;line-height:1.2}.home__outline-group a:hover{color:var(--accent);background:color-mix(in srgb,var(--accent-soft) 58%,transparent);transform:translate(2px)}.home__outline-group a:hover .home__outline-title{color:var(--accent)}.home__outline-group a:hover:before{background:var(--accent)}.home__content{min-width:0}.home__hero{max-width:var(--content-max);margin-bottom:var(--space-xl)}.home__eyebrow{margin:0 0 var(--space-sm);font-size:.82rem;text-transform:uppercase;letter-spacing:.14em;color:var(--accent);font-weight:600}.home__title{margin:0 0 var(--space-md);font-family:var(--font-display);font-size:clamp(2.15rem,5.5vw,3.35rem);font-weight:700;letter-spacing:-.035em;line-height:1.12}.home__lead{margin:0;color:var(--ink-muted);font-size:clamp(1.05rem,2.2vw,1.2rem);max-width:36em}.home__lead code{font-size:.9em;padding:.15em .4em;border-radius:var(--radius-sm);background:var(--accent-soft);color:var(--accent)}.home__toolbar{display:flex;flex-direction:column;gap:var(--space-md);margin-bottom:var(--space-xl)}.home__search{display:flex;align-items:center;max-width:30rem;border:1px solid var(--border);border-radius:var(--radius-md);background:var(--surface);box-shadow:var(--shadow)}.home__search-scope{padding:.55rem 1.2rem .55rem .7rem;border:none;border-right:1px solid var(--border);background:transparent;font:inherit;font-size:.85rem;color:var(--ink);cursor:pointer;flex-shrink:0;-webkit-appearance:auto;-moz-appearance:auto;appearance:auto;margin-right:.3rem}.home__search-scope:focus{outline:none}.home__search input{flex:1;min-width:0;padding:.55rem .8rem;border:none;background:transparent;font:inherit;color:var(--ink)}.home__search input::placeholder{color:var(--ink-faint)}.home__search input:focus{outline:none}.home__chips{display:flex;flex-wrap:wrap;gap:var(--space-sm)}.home__chips button{border:1px solid var(--border);background:var(--surface);color:var(--ink-muted);padding:.4rem .85rem;border-radius:999px;font:inherit;font-size:.875rem;cursor:pointer;transition:background .15s ease,color .15s ease,border-color .15s ease}.home__chips button:hover{border-color:var(--accent);color:var(--accent)}.home__chips button.is-active{background:var(--accent);border-color:var(--accent);color:var(--on-accent)}.home__chip-star{display:inline-flex;align-items:center;gap:.25rem;border:1px solid var(--border);background:var(--surface);color:var(--ink-muted);padding:.4rem .75rem;border-radius:999px;font:inherit;font-size:.875rem;cursor:pointer;transition:all .15s ease;margin-left:.25rem}.home__chip-star:hover{border-color:var(--accent);color:var(--accent)}.home__chip-star.is-active{border-color:var(--accent);color:var(--accent);background:transparent}.home__list{list-style:none;margin:0;padding:0;display:grid;gap:var(--space-md)}@media(min-width:640px){.home__list{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(min-width:980px){.home__shell{grid-template-columns:minmax(16rem,18rem) minmax(0,1fr);align-items:start}.home__outline{position:sticky;top:5.75rem}.home__outline-groups{max-height:calc(100vh - 12rem)}}@media(min-width:1240px){.home__list{grid-template-columns:repeat(3,minmax(0,1fr))}}@media(max-width:639px){.home__outline-head{padding:var(--space-sm) var(--space-md)}.home__outline-groups{max-height:18rem}.home__outline-group a{min-height:auto}.home__pagination{align-items:flex-start;flex-direction:column}.home__pagination-actions{justify-content:flex-start}}.card{position:relative;height:100%;border-radius:var(--radius-md);border:1px solid var(--border);background:var(--surface);box-shadow:var(--shadow);transition:transform .18s ease,box-shadow .18s ease}.card:hover{transform:translateY(-2px);box-shadow:var(--shadow-card-hover)}.card__star{position:absolute;top:.55rem;right:.55rem;z-index:2;display:flex;align-items:center;justify-content:center;width:2rem;height:2rem;border:none;border-radius:var(--radius-sm);background:transparent;color:var(--ink-faint);cursor:pointer;transition:color .15s ease,background .15s ease,transform .15s ease}.card__star:hover{color:var(--accent);background:var(--accent-soft);transform:scale(1.15)}.card__star.is-active{color:var(--accent)}.card__star.is-active:hover{color:var(--ink-muted)}.card__link{display:flex;flex-direction:column;height:100%;padding:var(--space-lg);color:inherit;text-decoration:none}.card__cat{display:inline-block;font-size:.75rem;font-weight:600;color:var(--accent);letter-spacing:.04em;text-transform:uppercase}.card__title{margin:var(--space-sm) 0;font-family:var(--font-display);font-size:clamp(1.2rem,2.4vw,1.35rem);font-weight:600;letter-spacing:-.02em;line-height:1.25}.card__desc{margin:0 0 var(--space-md);color:var(--ink-muted);font-size:.95rem;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.card__date{margin-top:auto;padding-top:var(--space-sm);font-size:.85rem;color:var(--ink-faint)}.home__empty{color:var(--ink-muted);margin-top:var(--space-xl)}.home__pagination{display:flex;align-items:center;justify-content:space-between;gap:var(--space-md);margin-top:var(--space-xl);padding-top:var(--space-lg);border-top:1px solid var(--border)}.home__pagination p{margin:0;color:var(--ink-muted);font-size:.9rem}.home__pagination-actions{display:flex;flex-wrap:wrap;justify-content:flex-end;gap:var(--space-sm)}.home__pagination button{min-width:2.25rem;min-height:2.25rem;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface);color:var(--ink-muted);font:inherit;font-size:.88rem;cursor:pointer;transition:background .15s ease,border-color .15s ease,color .15s ease}.home__pagination button:hover:not(:disabled){border-color:var(--accent);color:var(--accent)}.home__pagination button.is-active{border-color:var(--accent);background:var(--accent);color:var(--on-accent)}.home__pagination button:disabled{cursor:not-allowed;opacity:.45}.home__pagination-ellipsis{display:inline-flex;align-items:center;justify-content:center;min-width:1.5rem;min-height:2.25rem;color:var(--ink-faint)}.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.post-layout{display:grid;gap:var(--space-xl);align-items:start}.post-page{max-width:var(--content-max);min-width:0}@media(min-width:1200px){.post-layout{grid-template-columns:minmax(0,1fr) 15rem}}.post-page__back{display:inline-block;margin-bottom:var(--space-lg);font-size:.9rem;color:var(--ink-muted);text-decoration:none}.post-page__back:hover{color:var(--accent)}.post-page__header{margin-bottom:var(--space-xl);padding-bottom:var(--space-lg);border-bottom:1px solid var(--border)}.post-page__cat{margin:0 0 var(--space-sm);font-size:.8rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--accent)}.post-page__title{margin:0 0 var(--space-sm);font-family:var(--font-display);font-size:clamp(1.85rem,4.8vw,2.65rem);font-weight:700;letter-spacing:-.03em;line-height:1.2}.post-page__star{display:inline-flex;align-items:center;gap:.35rem;margin-bottom:var(--space-md);padding:.35rem .75rem;border:1.5px solid var(--border);border-radius:999px;background:var(--surface);color:var(--ink-muted);font:inherit;font-size:.85rem;cursor:pointer;transition:background .15s ease,color .15s ease,border-color .15s ease,transform .15s ease}.post-page__star:hover{border-color:var(--accent);color:var(--accent);transform:translateY(-1px)}.post-page__star.is-active{background:var(--accent-soft);border-color:var(--accent);color:var(--accent)}.post-page__date{font-size:.9rem;color:var(--ink-faint)}.post-page__tags{display:flex;flex-wrap:wrap;gap:var(--space-sm);margin:var(--space-md) 0 0;padding:0;list-style:none}.post-page__tags li{font-size:.8rem;padding:.2rem .55rem;border-radius:var(--radius-sm);background:var(--accent-soft);color:var(--accent)}.prose{font-size:clamp(1.04rem,2.1vw,1.14rem);color:var(--ink);line-height:1.72}.prose h2,.prose h3{margin-top:1.75em;margin-bottom:.5em;font-family:var(--font-display);font-weight:600;letter-spacing:-.02em;line-height:1.3}.prose p{margin:0 0 1em}.prose ul,.prose ol{margin:0 0 1em;padding-left:1.35em}.prose li{margin-bottom:.35em}.prose a{font-weight:500}.prose blockquote{margin:1.25em 0;padding-left:1em;border-left:3px solid var(--accent);color:var(--ink-muted)}.prose table{width:100%;border-collapse:collapse;font-size:.95em;margin:1em 0}.prose th,.prose td{border:1px solid var(--border);padding:.5em .65em}.prose th{background:var(--accent-soft);text-align:left}.prose hr{border:none;border-top:1px solid var(--border);margin:2em 0}.post-toc{display:none}@media(min-width:1200px){.post-toc{display:block;position:sticky;top:5.75rem;max-height:calc(100vh - 8rem);overflow-y:auto;padding-left:var(--space-md);border-left:1px solid var(--border);font-size:.88rem}}.post-toc__title{margin:0 0 .65rem;font-size:.72rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-faint)}.post-toc__link{display:block;color:var(--ink-muted);text-decoration:none;line-height:1.45;border-left:2px solid transparent;padding:.3rem 0 .3rem .6rem;margin-left:-1px;transition:color .15s ease,border-color .15s ease}.post-toc__link:hover{color:var(--accent)}.post-toc__link.is-active{color:var(--accent);border-left-color:var(--accent);font-weight:600}.post-toc__link--sub{padding-left:1.3rem;font-size:.83rem}
