:root{--bg:#FAFAFA;--bg-alt:#F4F4F5;--surface:#FFFFFF;--fg:#111111;--fg-2:#52525B;--fg-3:#A1A1AA;--accent:#7C3AED;--accent-hover:#6D28D9;--accent-dim:#EDE9FE;--border:#E4E4E7;--code-bg:#282A36;--code-fg:#F8F8F2;--inline-bg:#F1F5F9;--inline-fg:#6D28D9;--font-serif:'Newsreader', Georgia, 'Times New Roman', serif;--font-sans:'Inter', system-ui, -apple-system, sans-serif;--font-mono:'JetBrains Mono', 'Fira Code', 'Cascadia Code', 'Consolas', monospace;--header-h:60px;--prose-w:660px;--wide-w:980px;--r-sm:4px;--r-md:8px;--r-lg:12px;--shadow-sm:0 1px 3px rgba(0,0,0,.06), 0 1px 2px rgba(0,0,0,.04);--shadow-md:0 4px 16px rgba(0,0,0,.08);--t:180ms ease;--t-fast:120ms ease}[data-theme=dark]{--bg:#0A0A0A;--bg-alt:#111111;--surface:#111111;--fg:#EDEDED;--fg-2:#A1A1AA;--fg-3:#52525B;--accent:#A78BFA;--accent-hover:#C4B5FD;--accent-dim:#2D1B69;--border:#27272A;--inline-bg:#1E1B2E;--inline-fg:#C4B5FD;--shadow-sm:0 1px 3px rgba(0,0,0,.4);--shadow-md:0 4px 16px rgba(0,0,0,.5)}*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;scroll-behavior:smooth;-webkit-text-size-adjust:100%}body{font-family:var(--font-sans);font-size:1rem;line-height:1.75;color:var(--fg);background:var(--bg);transition:background var(--t),color var(--t);min-height:100dvh;display:flex;flex-direction:column}img{max-width:100%;height:auto;display:block}a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline;text-underline-offset:3px}.container{max-width:var(--wide-w);margin:0 auto;padding:0 1.5rem;width:100%}.container--prose{max-width:calc(var(--prose-w) + 3rem)}main{flex:1}.site-header{position:sticky;top:0;z-index:100;height:var(--header-h);background:0 0;border-bottom:1px solid transparent;transition:background var(--t),border-color var(--t)}.site-header.is-scrolled{background:color-mix(in srgb,var(--bg) 60%,transparent);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border-bottom-color:var(--border)}.site-header__inner{max-width:var(--wide-w);margin:0 auto;padding:0 1.5rem;height:100%;display:flex;align-items:center;justify-content:space-between;gap:1.5rem}.site-logo{font-family:var(--font-serif);font-size:1.25rem;font-weight:600;color:var(--fg);text-decoration:none;flex-shrink:0;letter-spacing:-.01em}.site-logo:hover{color:var(--accent);text-decoration:none}.site-nav{display:flex;align-items:center;gap:1.75rem;margin-left:auto}.site-nav a{font-size:.875rem;font-weight:500;color:var(--fg-2);text-decoration:none;transition:color var(--t-fast)}.site-nav a:hover,.site-nav a[aria-current=page]{color:var(--accent);text-decoration:none}.header-actions{display:flex;align-items:center;gap:.5rem;flex-shrink:0}.icon-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border:1px solid var(--border);border-radius:var(--r-md);background:0 0;color:var(--fg-2);cursor:pointer;transition:background var(--t-fast),color var(--t-fast),border-color var(--t-fast)}.icon-btn:hover{background:var(--bg-alt);color:var(--fg)}.icon-btn svg{width:16px;height:16px;flex-shrink:0}.icon-sun{display:none}.icon-moon{display:block}[data-theme=dark] .icon-sun{display:block}[data-theme=dark] .icon-moon{display:none}.nav-toggle{display:none}.site-footer{margin-top:5rem;padding:2rem 1.5rem;border-top:1px solid var(--border);text-align:center;font-size:.875rem;color:var(--fg-3)}.home-hero{padding:3.5rem 0 2.5rem;border-bottom:1px solid var(--border);margin-bottom:2.5rem}.home-hero__name{font-family:var(--font-serif);font-size:clamp(1.75rem,4vw,2.25rem);font-weight:600;color:var(--fg);margin-bottom:.5rem;letter-spacing:-.02em}.home-hero__sub{color:var(--fg-2);font-size:1rem}.section-label{font-size:.6875rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--fg-3);margin-bottom:1.5rem}.list-toolbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.5rem}.view-toggle{display:flex;border:1px solid var(--border);border-radius:var(--r-md);overflow:hidden}.view-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;background:0 0;border:none;color:var(--fg-3);cursor:pointer;transition:background var(--t-fast),color var(--t-fast)}.view-btn:hover{background:var(--bg-alt);color:var(--fg)}.view-btn.is-active{background:var(--accent);color:#fff}.view-btn svg{width:15px;height:15px;flex-shrink:0}.post-list{list-style:none;display:grid;grid-template-columns:repeat(2,1fr);gap:1.75rem}.post-card{display:flex;flex-direction:column;color:inherit;text-decoration:none;border:1px solid var(--border);border-radius:var(--r-lg);overflow:hidden;transition:border-color var(--t-fast),box-shadow var(--t-fast)}.post-card:hover{text-decoration:none;border-color:transparent;box-shadow:var(--shadow-md)}.post-card--img{}.post-card__body{display:flex;flex-direction:column;gap:.375rem;padding:1.125rem 1.375rem 1.375rem;flex:1}.post-card__cat{font-size:.6875rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--accent)}.post-card__title{font-family:var(--font-serif);font-size:1.125rem;font-weight:600;color:var(--fg);line-height:1.4;transition:color var(--t-fast)}.post-card:hover .post-card__title{color:var(--accent)}.post-card__desc{font-size:.9rem;color:var(--fg-2);line-height:1.6;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.post-card__meta{display:flex;gap:.625rem;font-size:.8125rem;color:var(--fg-3);margin-top:.375rem}.post-card__thumb{aspect-ratio:16/9;width:100%;overflow:hidden;flex-shrink:0}.post-card__thumb img{width:100%;height:100%;object-fit:cover;transition:transform 350ms ease}.post-card:hover .post-card__thumb img{transform:scale(1.04)}.post-list--list{display:flex;flex-direction:column;gap:1.25rem}.post-list--list .post-card{flex-direction:row;align-items:center;min-height:140px}.post-list--list .post-card__thumb{width:220px;flex-shrink:0;aspect-ratio:3/2;align-self:stretch;border-radius:0}.post-list--list .post-card__body{padding:1.25rem 1.5rem;justify-content:center}.post-list--list .post-card__desc{-webkit-line-clamp:2}.post-layout{padding:2.5rem 0 5rem;display:grid;grid-template-columns:1fr;align-items:start}@media(min-width:1080px){.post-layout{grid-template-columns:minmax(0,var(--prose-w))1fr;gap:4rem}}.post-article{min-width:0;max-width:var(--prose-w)}@media(min-width:1080px){.post-article{max-width:none}}.post-header{margin-bottom:2.5rem}.post-back{display:inline-flex;align-items:center;gap:.375rem;font-size:.875rem;color:var(--fg-3);margin-bottom:1.75rem;transition:color var(--t-fast)}.post-back:hover{color:var(--accent);text-decoration:none}.post-back svg{width:14px;height:14px}.post-header__cat{font-size:.6875rem;font-weight:600;text-transform:uppercase;letter-spacing:.1em;color:var(--accent);margin-bottom:.75rem}.post-header__title{font-family:var(--font-serif);font-size:clamp(1.75rem,4vw,2.625rem);font-weight:600;line-height:1.2;color:var(--fg);margin-bottom:1rem;letter-spacing:-.02em}.post-header__meta{display:flex;flex-wrap:wrap;gap:.75rem;font-size:.875rem;color:var(--fg-3)}.post-cover{margin-bottom:2.5rem;border-radius:var(--r-lg);overflow:hidden;aspect-ratio:16/9}.post-cover img{width:100%;height:100%;object-fit:cover}.prose{font-size:1.0625rem;line-height:1.8;color:var(--fg);overflow-wrap:break-word}.prose>*+*{margin-top:1.5em}.prose h1,.prose h2,.prose h3,.prose h4,.prose h5,.prose h6{font-family:var(--font-serif);font-weight:600;color:var(--fg);line-height:1.3;margin-top:2.25em;margin-bottom:.6em;letter-spacing:-.01em}.prose h2{font-size:1.5rem;padding-bottom:.4em;border-bottom:1px solid var(--border)}.prose h3{font-size:1.25rem}.prose h4{font-size:1.125rem}.prose p{margin-bottom:0}.prose a{color:var(--accent);text-decoration:underline;text-underline-offset:3px;text-decoration-thickness:1px}.prose a:hover{text-decoration-thickness:2px}.prose ul,.prose ol{padding-left:1.5em}.prose li{margin-bottom:.25em}.prose blockquote{border-left:3px solid var(--accent);padding:.75rem 1rem .75rem 1.5rem;background:var(--bg-alt);border-radius:0 var(--r-md)var(--r-md)0;font-style:italic;color:var(--fg-2)}.prose blockquote p{margin:0}.prose hr{border:none;border-top:1px solid var(--border);margin:2.5em 0}.prose img{margin:0 auto;border-radius:var(--r-md)}.prose table{width:100%;border-collapse:collapse;font-size:.9375rem;overflow-x:auto;display:block}.prose th{text-align:left;font-weight:600;padding:.625rem 1rem;background:var(--bg-alt);border-bottom:2px solid var(--border);font-size:.875rem;white-space:nowrap}.prose td{padding:.625rem 1rem;border-bottom:1px solid var(--border);vertical-align:top}.prose tr:last-child td{border-bottom:none}.prose :not(pre)>code{font-family:var(--font-mono);font-size:.85em;background:var(--inline-bg);color:var(--inline-fg);padding:.15em .4em;border-radius:var(--r-sm);border:1px solid var(--border);font-weight:500}.prose .highlight,.prose pre{margin-left:-1.5rem;margin-right:-1.5rem;border-radius:0}@media(min-width:640px){.prose .highlight,.prose pre{margin-left:-2.5rem;margin-right:-2.5rem;border-radius:var(--r-md)}}@media(min-width:1024px){.prose .highlight,.prose pre{margin-left:-4rem;margin-right:-4rem}}.highlight{position:relative;background:var(--code-bg);border-radius:var(--r-md);overflow:hidden}.highlight-bar{display:flex;align-items:center;justify-content:space-between;padding:.4rem 1rem;background:#1e1f2b;border-bottom:1px solid #383a4a}.highlight-lang{font-family:var(--font-mono);font-size:.6875rem;color:#6c7086;text-transform:lowercase;letter-spacing:.04em}.highlight pre{margin:0;padding:1.125rem 1.5rem;overflow-x:auto;font-family:var(--font-mono);font-size:.875rem;line-height:1.7;color:var(--code-fg);background:0 0;border-radius:0;-webkit-overflow-scrolling:touch}.highlight pre::-webkit-scrollbar{height:5px}.highlight pre::-webkit-scrollbar-track{background:#1e1f2b}.highlight pre::-webkit-scrollbar-thumb{background:#383a4a;border-radius:3px}.copy-btn{display:flex;align-items:center;gap:.25rem;padding:.2rem .625rem;font-family:var(--font-sans);font-size:.6875rem;font-weight:500;color:#6c7086;background:0 0;border:1px solid #383a4a;border-radius:var(--r-sm);cursor:pointer;transition:color var(--t-fast),border-color var(--t-fast),background var(--t-fast);white-space:nowrap;flex-shrink:0}.copy-btn:hover{color:#cdd6f4;border-color:#4f5168;background:#1e1f2b}.copy-btn.copied{color:#a6e3a1;border-color:#a6e3a1}.youtube-embed{position:relative;padding-bottom:56.25%;height:0;overflow:hidden;border-radius:var(--r-md);background:#000}.youtube-embed iframe{position:absolute;inset:0;width:100%;height:100%;border:none}.tags{display:flex;flex-wrap:wrap;gap:.5rem}.tag{font-size:.75rem;font-weight:500;padding:.2rem .75rem;background:var(--accent-dim);color:var(--accent);border-radius:100px;text-decoration:none;transition:background var(--t-fast),color var(--t-fast);border:1px solid transparent}.tag:hover{background:var(--accent);color:#fff;text-decoration:none}.toc-aside{display:none}@media(min-width:1080px){.toc-aside{display:block;position:sticky;top:calc(var(--header-h) + 1.5rem);max-height:calc(100vh - var(--header-h) - 3rem);overflow-y:auto}}.toc-label{font-size:.6875rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--fg-3);margin-bottom:.75rem}.toc-aside nav ul,.toc-inline nav ul{list-style:none}.toc-aside nav ul ul,.toc-inline nav ul ul{padding-left:.875rem}.toc-aside nav a,.toc-inline nav a{display:block;padding:.2rem 0 .2rem .625rem;font-size:.8125rem;color:var(--fg-2);text-decoration:none;line-height:1.5;border-left:2px solid transparent;transition:color var(--t-fast),border-color var(--t-fast)}.toc-aside nav a:hover,.toc-aside nav a.toc-active,.toc-inline nav a:hover{color:var(--accent);border-left-color:var(--accent);text-decoration:none}.toc-mobile{margin-bottom:2rem;border:1px solid var(--border);border-radius:var(--r-md);overflow:hidden}@media(min-width:1080px){.toc-mobile{display:none}}.toc-mobile summary{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;font-size:.875rem;font-weight:500;cursor:pointer;background:var(--bg-alt);list-style:none;color:var(--fg-2);transition:color var(--t-fast)}.toc-mobile summary::-webkit-details-marker{display:none}.toc-mobile[open] summary{border-bottom:1px solid var(--border);color:var(--fg)}.toc-mobile summary svg{width:14px;height:14px;flex-shrink:0;transition:transform var(--t-fast)}.toc-mobile[open] summary svg{transform:rotate(180deg)}.toc-mobile .toc-inline{padding:.75rem 1rem}.post-footer{margin-top:3rem;padding-top:2rem;border-top:1px solid var(--border);display:flex;flex-direction:column;gap:1rem}.list-wrap{padding:3rem 0 5rem}.list-header{margin-bottom:2.5rem;padding-bottom:1.5rem;border-bottom:1px solid var(--border)}.list-header__title{font-family:var(--font-serif);font-size:1.875rem;font-weight:600;color:var(--fg);letter-spacing:-.02em}.archives-wrap{padding:3rem 0 5rem}.archives-title{font-family:var(--font-serif);font-size:1.875rem;font-weight:600;margin-bottom:1.5rem;letter-spacing:-.02em}.archives-search-field{margin-bottom:.75rem}.archives-status{font-size:.8125rem;color:var(--accent);margin-bottom:2rem;min-height:1.25rem}.archives-group{margin-bottom:2.5rem}.archives-year{font-family:var(--font-serif);font-size:1.375rem;font-weight:600;color:var(--fg);margin-bottom:1rem;padding-bottom:.625rem;border-bottom:1px solid var(--border)}.archives-list{list-style:none}.archives-item{display:grid;grid-template-columns:72px 1fr auto;gap:.75rem 1rem;padding:.5rem 0;border-bottom:1px solid var(--bg-alt);align-items:baseline}.archives-cat{font-size:.6875rem;font-weight:500;color:var(--fg-3);text-align:right;white-space:nowrap}.archives-empty{color:var(--fg-2);font-size:.9375rem;padding:2rem 0}.archives-date{font-size:.8125rem;color:var(--fg-3);font-variant-numeric:tabular-nums;flex-shrink:0}.archives-link{font-size:.9375rem;color:var(--fg);text-decoration:none;transition:color var(--t-fast);line-height:1.5}.archives-link:hover{color:var(--accent);text-decoration:none}.search-wrap{padding:3rem 0 5rem}.search-title{font-family:var(--font-serif);font-size:1.875rem;font-weight:600;margin-bottom:1.5rem;letter-spacing:-.02em}.search-field{position:relative;margin-bottom:2.5rem}.search-input{width:100%;padding:.75rem 1rem;padding-right:2.75rem;font-family:var(--font-sans);font-size:1rem;background:var(--surface);color:var(--fg);border:1px solid var(--border);border-radius:var(--r-md);outline:none;transition:border-color var(--t-fast),box-shadow var(--t-fast);-webkit-appearance:none}.search-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-dim)}.search-input::placeholder{color:var(--fg-3)}.search-icon{position:absolute;right:.875rem;top:50%;transform:translateY(-50%);color:var(--fg-3);pointer-events:none}.search-empty{text-align:center;color:var(--fg-2);padding:3rem 0;font-size:.9375rem}.page-wrap{max-width:var(--prose-w);padding:3rem 0 5rem}.page-title{font-family:var(--font-serif);font-size:1.875rem;font-weight:600;margin-bottom:2rem;padding-bottom:1.25rem;border-bottom:1px solid var(--border);letter-spacing:-.02em}.pagination{display:flex;justify-content:center;align-items:center;gap:.375rem;margin-top:3rem;padding-top:2.5rem;border-top:1px solid var(--border);flex-wrap:wrap}.pagination a,.pagination span{display:flex;align-items:center;justify-content:center;min-width:38px;height:38px;padding:0 .5rem;font-size:.875rem;border:1px solid var(--border);border-radius:var(--r-md);color:var(--fg-2);text-decoration:none;transition:background var(--t-fast),color var(--t-fast)}.pagination a:hover{background:var(--bg-alt);color:var(--fg);text-decoration:none}.pagination .pg-active{background:var(--accent);border-color:var(--accent);color:#fff}.error-wrap{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;text-align:center;padding:2rem}.error-code{font-family:var(--font-serif);font-size:5rem;font-weight:700;color:var(--accent);line-height:1;margin-bottom:1rem}.error-msg{font-size:1.125rem;color:var(--fg-2);margin-bottom:1.5rem}.scroll-top{position:fixed;bottom:1.75rem;right:1.75rem;width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);color:var(--fg-2);cursor:pointer;opacity:0;transform:translateY(10px);pointer-events:none;transition:opacity var(--t),transform var(--t),background var(--t-fast),color var(--t-fast),border-color var(--t-fast);box-shadow:var(--shadow-sm);z-index:50}.scroll-top.is-visible{opacity:1;transform:translateY(0);pointer-events:auto}.scroll-top:hover{background:var(--accent);color:#fff;border-color:var(--accent)}.scroll-top svg{width:18px;height:18px}@media(max-width:640px){.site-nav{display:none}.site-nav.is-open{display:flex;flex-direction:column;position:absolute;top:var(--header-h);left:0;right:0;background:var(--surface);border-bottom:1px solid var(--border);padding:1rem 1.5rem;gap:1rem;box-shadow:var(--shadow-md)}.nav-toggle{display:flex}.post-list{grid-template-columns:1fr}.post-list--list .post-card{flex-direction:row;min-height:unset;align-items:center}.post-list--list .post-card__thumb{width:100px;flex-shrink:0;aspect-ratio:3/2;align-self:stretch}.post-list--list .post-card__body{padding:.75rem 1rem}.post-list--list .post-card__desc{display:none}}@media(prefers-reduced-motion:reduce){*,*::before,*::after{animation-duration:.01ms!important;transition-duration:.01ms!important}html{scroll-behavior:auto}}.tags-cloud{display:flex;flex-wrap:wrap;gap:.75rem;padding-top:.5rem}.tag-item{display:inline-flex;align-items:center;gap:.625rem;padding:.5rem 1rem;background:var(--bg-alt);border:1px solid var(--border);border-radius:var(--r-md);text-decoration:none;color:var(--fg);font-size:.875rem;transition:background var(--t-fast),border-color var(--t-fast),color var(--t-fast)}.tag-item:hover{background:var(--accent-dim);border-color:var(--accent);color:var(--accent);text-decoration:none}.tag-item__name{font-weight:500}.tag-item__count{font-size:.75rem;color:var(--fg-3);background:var(--surface);border:1px solid var(--border);padding:.05rem .45rem;border-radius:100px;min-width:1.5rem;text-align:center;transition:color var(--t-fast)}.tag-item:hover .tag-item__count{color:var(--accent);border-color:var(--accent)}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}