﻿:root{color-scheme:light;--bg: #f7f4ec;--bg-alt: #efeadf;--card: #fffdf7;--surface: #f1ede2;--surface-2: #e7e1d2;--glass-bg: rgba(252, 250, 243, 0.78);--ink: #1d1a14;--ink-2: #4c4639;--ink-3: #837b69;--ghost: rgba(29, 26, 20, 0.07);--on-accent: #fffdf7;--accent: #c03a1d;--accent-deep: #9a2c13;--accent-bright: #e25433;--accent-soft: rgba(192, 58, 29, 0.085);--accent-softer: rgba(192, 58, 29, 0.05);--accent-line: rgba(192, 58, 29, 0.32);--blue: #28457e;--blue-bright: #3a5da6;--blue-soft: rgba(40, 69, 126, 0.09);--gold: #a3761b;--gold-soft: rgba(163, 118, 27, 0.12);--ok: #2e6b46;--ok-soft: rgba(46, 107, 70, 0.10);--line: rgba(29, 26, 20, 0.12);--line-soft: rgba(29, 26, 20, 0.07);--line-strong: rgba(29, 26, 20, 0.24);--dot: rgba(29, 26, 20, 0.065);--glow-1: rgba(192, 58, 29, 0.06);--glow-2: rgba(40, 69, 126, 0.055);--shadow-sm: 0 1px 2px rgba(36, 30, 18, 0.05), 0 3px 10px rgba(36, 30, 18, 0.05);--shadow-md: 0 8px 26px rgba(36, 30, 18, 0.10);--shadow-lg: 0 22px 56px rgba(36, 30, 18, 0.16);--ring: 0 0 0 3px rgba(192, 58, 29, 0.22);--font-display: "Fraunces", "Source Serif 4", Georgia, serif;--font-serif: "Source Serif 4", Georgia, serif;--font-sans: "Inter", "Noto Sans SC", system-ui, -apple-system, "Helvetica Neue", sans-serif;--font-mono: "JetBrains Mono", "SFMono-Regular", ui-monospace, Consolas, monospace;--space-1: 0.25rem;--space-2: 0.5rem;--space-3: 0.75rem;--space-4: 1rem;--space-5: 1.25rem;--space-6: 1.5rem;--space-7: 2rem;--space-8: 2.5rem;--space-9: 3.5rem;--space-10: 5rem;--radius-sm: 0.4rem;--radius-md: 0.75rem;--radius-lg: 1.15rem;--radius-xl: 1.75rem;--radius-pill: 999px;--ease-spring: cubic-bezier(0.34, 1.45, 0.45, 1);--ease-smooth: cubic-bezier(0.4, 0, 0.2, 1);--ease-out: cubic-bezier(0.16, 1, 0.3, 1);--t-fast: 160ms var(--ease-smooth);--t-med: 260ms var(--ease-smooth);--t-spring: transform 420ms var(--ease-spring), box-shadow 300ms var(--ease-smooth), border-color 220ms var(--ease-smooth), background-color 220ms var(--ease-smooth), color 220ms var(--ease-smooth);--glass: blur(16px) saturate(160%);--shell-max: 71rem;--header-h: 4rem;--pulse-from: 0 0 0 0 rgba(192, 58, 29, 0.45);--pulse-mid: 0 0 0 0.55rem rgba(192, 58, 29, 0);--pulse-to: 0 0 0 0 rgba(192, 58, 29, 0)}[data-theme=dark]{color-scheme:dark;--bg: #14120e;--bg-alt: #1a1813;--card: #1d1a15;--surface: #252119;--surface-2: #2f2a20;--glass-bg: rgba(24, 22, 17, 0.78);--ink: #f1ebdd;--ink-2: #c9c1ad;--ink-3: #918a77;--ghost: rgba(241, 235, 221, 0.06);--on-accent: #16130d;--accent: #ff6a45;--accent-deep: #ff8a6b;--accent-bright: #ff7e5c;--accent-soft: rgba(255, 106, 69, 0.12);--accent-softer: rgba(255, 106, 69, 0.07);--accent-line: rgba(255, 106, 69, 0.38);--blue: #93aede;--blue-bright: #aabfe8;--blue-soft: rgba(147, 174, 222, 0.13);--gold: #d9ab51;--gold-soft: rgba(217, 171, 81, 0.14);--ok: #7cc49a;--ok-soft: rgba(124, 196, 154, 0.13);--line: rgba(241, 235, 221, 0.13);--line-soft: rgba(241, 235, 221, 0.07);--line-strong: rgba(241, 235, 221, 0.26);--dot: rgba(241, 235, 221, 0.05);--glow-1: rgba(255, 106, 69, 0.07);--glow-2: rgba(147, 174, 222, 0.05);--shadow-sm: 0 1px 2px rgba(0, 0, 0, 0.3), 0 3px 10px rgba(0, 0, 0, 0.25);--shadow-md: 0 8px 26px rgba(0, 0, 0, 0.38);--shadow-lg: 0 22px 56px rgba(0, 0, 0, 0.5);--ring: 0 0 0 3px rgba(255, 106, 69, 0.28);--pulse-from: 0 0 0 0 rgba(255, 106, 69, 0.45);--pulse-mid: 0 0 0 0.55rem rgba(255, 106, 69, 0);--pulse-to: 0 0 0 0 rgba(255, 106, 69, 0)}*,*::before,*::after{box-sizing:border-box}*{margin:0}html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}body{position:relative;min-height:100vh;background-color:var(--bg);background-image:radial-gradient(rgba(29, 26, 20, 0.065) 1px, transparent 1.5px);background-size:26px 26px;color:var(--ink);font-family:var(--font-sans);font-size:1rem;line-height:1.65;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow-x:hidden}[data-theme=dark] body{background-image:radial-gradient(rgba(241, 235, 221, 0.05) 1px, transparent 1.5px)}.canvas-glow{position:fixed;inset:0;z-index:-1;pointer-events:none;background:radial-gradient(46rem 30rem at 84% -8%, rgba(192, 58, 29, 0.06), transparent 65%),radial-gradient(40rem 28rem at -10% 26%, rgba(40, 69, 126, 0.055), transparent 65%)}[data-theme=dark] .canvas-glow{background:radial-gradient(46rem 30rem at 84% -8%, rgba(255, 106, 69, 0.07), transparent 65%),radial-gradient(40rem 28rem at -10% 26%, rgba(147, 174, 222, 0.05), transparent 65%)}.canvas-grain{position:fixed;inset:0;z-index:2000;pointer-events:none;opacity:.55;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.82' numOctaves='2' stitchTiles='stitch'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3CfeComponentTransfer%3E%3CfeFuncA type='linear' slope='0.05'/%3E%3C/feComponentTransfer%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}::selection{background:var(--accent);color:var(--on-accent)}:focus{outline:none}:focus-visible{outline:none;box-shadow:var(--ring);border-radius:var(--radius-sm)}img,svg,video{display:block;max-width:100%}h1,h2,h3,h4,h5,h6{font-family:var(--font-display);font-weight:700;line-height:1.12;letter-spacing:-0.015em;color:var(--ink);overflow-wrap:break-word}p{overflow-wrap:break-word}a{color:var(--accent-deep);text-decoration:none;transition:color var(--t-fast)}a:hover{color:var(--accent)}strong,b{font-weight:650;color:var(--ink)}code,kbd,samp{font-family:var(--font-mono);font-size:.86em}small{font-size:.85em}hr{border:0;border-top:1px solid var(--line)}code{padding:.14em .45em;border:1px solid var(--line);border-radius:var(--radius-sm);background:var(--surface);color:var(--ink-2)}.mono{font-family:var(--font-mono);font-feature-settings:"zero" 1}.kicker{display:inline-flex;align-items:center;gap:var(--space-2);font-family:var(--font-mono);font-size:.72rem;font-weight:600;letter-spacing:.22em;text-transform:uppercase;color:var(--accent)}.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}*{scrollbar-width:thin;scrollbar-color:var(--line-strong) rgba(0,0,0,0)}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-thumb{background:var(--line-strong);border-radius:var(--radius-pill);border:2px solid var(--bg)}::-webkit-scrollbar-track{background:rgba(0,0,0,0)}.shell{width:100%;max-width:var(--shell-max);margin:0 auto;padding:0 clamp(1.1rem,4vw,2.5rem)}.page-main{counter-reset:section;padding-bottom:var(--space-10)}.section{position:relative;margin-top:clamp(4rem,9vw,6.5rem);counter-increment:section;scroll-margin-top:calc(var(--header-h) + 2rem)}.section-head{display:flex;align-items:baseline;gap:var(--space-4);margin-bottom:clamp(1.6rem,4vw,2.6rem)}.section-index{font-family:var(--font-mono);font-size:.8rem;font-weight:600;letter-spacing:.08em;color:var(--accent);transform:translateY(-0.35rem)}.section-index::before{content:"(" counter(section, decimal-leading-zero) ")"}.section-title{font-size:clamp(1.7rem,3.6vw,2.4rem);font-weight:700;letter-spacing:-0.02em}.title-dot{color:var(--accent)}.section-rule{flex:1 1 auto;height:1px;background:var(--line);transform:translateY(-0.45rem)}.section-action{flex:0 0 auto;display:inline-flex;align-items:center;gap:var(--space-2);font-family:var(--font-mono);font-size:.78rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-2);transform:translateY(-0.35rem);transition:var(--t-fast)}.section-action i{font-size:.7rem;transition:transform var(--t-med)}.section-action:hover{color:var(--accent)}.section-action:hover i{transform:translateX(0.25rem)}.page-header{position:relative;padding:clamp(2.6rem,7vw,5rem) 0 clamp(1.8rem,4vw,2.8rem);border-bottom:1px solid var(--line)}.page-header-kicker{margin-bottom:var(--space-4)}.page-header-title{font-size:clamp(2.6rem,7vw,4.6rem);font-weight:800;letter-spacing:-0.03em;line-height:1}.page-header-subtitle{max-width:38rem;margin-top:var(--space-4);color:var(--ink-2);font-family:var(--font-serif);font-size:1.08rem;line-height:1.7}.page-header-meta{display:flex;flex-wrap:wrap;gap:var(--space-2);margin-top:var(--space-6)}.page-header-stat{display:inline-flex;align-items:center;gap:var(--space-2);padding:.3rem .85rem;border:1px solid var(--line);border-radius:var(--radius-pill);background:var(--card);color:var(--ink-2);font-family:var(--font-mono);font-size:.76rem;font-weight:500}.page-header-stat i{color:var(--accent);font-size:.72rem}.panel{border:1px solid var(--line);border-radius:var(--radius-lg);background:var(--card);box-shadow:var(--shadow-sm)}.site-dialog{margin:auto;padding:var(--space-7);max-width:20rem;border:1px solid var(--line);border-radius:var(--radius-lg);background:var(--card);color:var(--ink);box-shadow:var(--shadow-lg);text-align:center}.site-dialog::backdrop{background:rgba(12,10,6,.55);backdrop-filter:blur(4px)}.site-dialog img{margin:0 auto var(--space-3);border-radius:var(--radius-md)}.site-dialog h6{margin-bottom:var(--space-4);font-size:1rem}.dialog-close{position:absolute;top:.6rem;right:.8rem;border:0;background:rgba(0,0,0,0);color:var(--ink-3);font-size:1.3rem;line-height:1;cursor:pointer}.dialog-close:hover{color:var(--accent)}.cursor-pointer{cursor:pointer}.site-header{position:sticky;top:0;z-index:100;padding-top:var(--space-4);pointer-events:none}.topbar{pointer-events:auto;position:relative;display:flex;align-items:center;gap:var(--space-4);min-height:var(--header-h);padding:0 var(--space-4) 0 var(--space-5);border:1px solid var(--line);border-radius:var(--radius-lg);background:var(--glass-bg);backdrop-filter:var(--glass);-webkit-backdrop-filter:var(--glass);box-shadow:var(--shadow-sm);transition:box-shadow var(--t-med),border-color var(--t-med),background-color var(--t-med)}.topbar.nav-scrolled{border-color:var(--line-strong);box-shadow:var(--shadow-md)}.brand{display:inline-flex;align-items:center;gap:var(--space-3);color:var(--ink)}.brand:hover{color:var(--ink)}.brand-seal{display:grid;place-items:center;width:2.1rem;height:2.1rem;border-radius:var(--radius-sm);background:var(--accent);color:var(--on-accent);font-family:var(--font-mono);font-size:.78rem;font-weight:700;letter-spacing:.04em;box-shadow:var(--shadow-sm);transition:var(--t-spring)}.brand:hover .brand-seal{transform:rotate(-6deg) scale(1.04)}.brand-name{font-family:var(--font-display);font-size:1.08rem;font-weight:700;letter-spacing:-0.01em}.nav-links{display:flex;align-items:center;gap:var(--space-1);margin-left:auto}.nav-link{position:relative;display:inline-flex;align-items:center;padding:.45rem .85rem;border-radius:var(--radius-sm);color:var(--ink-2);font-family:var(--font-mono);font-size:.78rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;transition:var(--t-fast)}.nav-link:hover{color:var(--ink);background:var(--surface)}.nav-link.active{color:var(--accent)}.nav-link.active::after{content:"";position:absolute;left:50%;bottom:.1rem;width:.85rem;height:2px;border-radius:var(--radius-pill);background:var(--accent);transform:translateX(-50%)}.nav-actions{display:flex;align-items:center;gap:var(--space-2);margin-left:var(--space-2)}.theme-toggle,.nav-burger{display:inline-flex;align-items:center;justify-content:center;width:2.3rem;height:2.3rem;padding:0;border:1px solid var(--line);border-radius:var(--radius-pill);background:var(--card);color:var(--ink-2);font-size:.85rem;cursor:pointer;transition:var(--t-spring)}.theme-toggle:hover,.nav-burger:hover{border-color:var(--accent-line);color:var(--accent);transform:translateY(-1px) rotate(8deg);box-shadow:var(--shadow-sm)}.nav-burger{display:none}@media(max-width: 719.98px){.nav-links{position:absolute;top:calc(100% + .6rem);right:0;left:auto;flex-direction:column;align-items:stretch;gap:var(--space-1);min-width:13rem;margin:0;padding:var(--space-3);border:1px solid var(--line);border-radius:var(--radius-md);background:var(--card);box-shadow:var(--shadow-lg);opacity:0;transform:translateY(-0.5rem);visibility:hidden;transition:opacity var(--t-med),transform var(--t-med),visibility var(--t-med)}.topbar.nav-open .nav-links{opacity:1;transform:translateY(0);visibility:visible}.nav-link{justify-content:flex-start;padding:.65rem .85rem}.nav-link.active::after{display:none}.nav-link.active{background:var(--accent-soft)}.nav-burger{display:inline-flex}}.site-footer{margin-top:clamp(4rem,10vw,7rem);border-top:1px solid var(--line);background:var(--bg-alt)}.footer-base{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:var(--space-2) var(--space-5);padding:var(--space-6) 0;color:var(--ink-3);font-size:.8rem}.footer-note{flex:1 1 24rem;min-width:0;overflow-wrap:anywhere}.footer-meta{display:inline-flex;align-items:center;gap:var(--space-3);font-family:var(--font-mono);font-size:.72rem;letter-spacing:.04em;white-space:nowrap}.footer-meta .sep{color:var(--accent)}.prompt-body{display:grid;place-items:center;min-height:100vh}.prompt-container{width:100%;max-width:36rem;padding:var(--space-7);text-align:center}.prompt-code{font-size:clamp(5rem,18vw,9rem);font-weight:800;letter-spacing:-0.04em;line-height:1}.prompt-text{margin:var(--space-4) 0 var(--space-7);color:var(--ink-2);font-family:var(--font-serif);font-size:1.05rem}.social-btn,.btn-pub-link,.pub-view-all,.btn-ink{display:inline-flex;align-items:center;justify-content:center;gap:.5em;border:1px solid var(--line);border-radius:var(--radius-pill);background:var(--card);color:var(--ink-2);font-family:var(--font-sans);font-weight:600;line-height:1;cursor:pointer;white-space:nowrap;transition:var(--t-spring)}.social-btn{padding:.62rem 1.1rem;font-size:.84rem}.social-btn i{font-size:.9em;color:var(--accent);transition:transform var(--t-med)}.social-btn:hover{border-color:var(--accent-line);color:var(--ink);transform:translateY(-2px);box-shadow:var(--shadow-md)}.social-btn:hover i{transform:scale(1.15) rotate(-6deg)}.social-btn-primary{border-color:var(--ink);background:var(--ink);color:var(--bg)}.social-btn-primary i{color:var(--accent-bright)}.social-btn-primary:hover{border-color:var(--accent);background:var(--accent);color:var(--on-accent);box-shadow:var(--shadow-lg)}.btn-ink{padding:.85rem 1.6rem;border-color:var(--ink);background:var(--ink);color:var(--bg);font-size:.9rem}.btn-ink:hover{border-color:var(--accent);background:var(--accent);color:var(--on-accent);transform:translateY(-2px);box-shadow:var(--shadow-lg)}.btn-ghost{background:rgba(0,0,0,0)}.btn-pub-link{padding:.4rem .85rem;font-family:var(--font-mono);font-size:.72rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase}.btn-pub-link::after{content:"↗";font-size:.85em;color:var(--accent);transition:transform var(--t-med)}.btn-pub-link:hover{border-color:var(--accent-line);background:var(--accent-soft);color:var(--accent-deep)}.btn-pub-link:hover::after{transform:translate(2px, -2px)}.pub-view-all{padding:.55rem 1.1rem;font-family:var(--font-mono);font-size:.76rem;letter-spacing:.08em;text-transform:uppercase}.pub-view-all:hover{border-color:var(--accent-line);color:var(--accent-deep);transform:translateY(-2px);box-shadow:var(--shadow-sm)}.post-feed{margin-top:clamp(2rem,5vw,3.2rem)}.post-list{margin:0;padding:0;list-style:none}.post-item{display:grid;grid-template-columns:8.5rem minmax(0, 1fr);gap:var(--space-5);padding:var(--space-6) var(--space-3);border-bottom:1px solid var(--line-soft);border-radius:var(--radius-sm);transition:background-color var(--t-fast)}.post-item:hover{background:var(--accent-softer)}.post-item-date{padding-top:.35rem;color:var(--ink-3);font-size:.78rem;font-weight:500;letter-spacing:.05em;white-space:nowrap}.post-pin{margin-right:.45rem;color:var(--accent);font-size:.72rem;transform:rotate(24deg);display:inline-block}.post-item-title{margin:0;font-size:clamp(1.18rem,2.4vw,1.45rem);font-weight:700;letter-spacing:-0.01em;line-height:1.3}.post-item-title a{color:var(--ink)}.post-item-title a:hover{color:var(--accent)}.post-item-desc{margin-top:var(--space-2);color:var(--ink-2);font-size:.95rem;line-height:1.6}.post-item-meta{display:flex;flex-wrap:wrap;align-items:center;gap:var(--space-2);margin-top:var(--space-3)}.post-item-read{margin-left:auto;color:var(--ink-3);font-family:var(--font-mono);font-size:.72rem;letter-spacing:.05em;white-space:nowrap}.post-chip{display:inline-flex;align-items:center;gap:.25em;padding:.22rem .7rem;border:1px solid var(--line);border-radius:var(--radius-pill);background:var(--card);color:var(--ink-2);font-family:var(--font-mono);font-size:.72rem;font-weight:500;letter-spacing:.03em;white-space:nowrap;transition:var(--t-fast)}.post-chip:hover{border-color:var(--accent-line);background:var(--accent-soft);color:var(--accent-deep)}.post-chip-hash{color:var(--accent);font-weight:600}.post-chip-cat{border-color:var(--accent-line);background:var(--accent-soft);color:var(--accent-deep);font-weight:600}.post-chip-cat:hover{background:var(--accent);color:var(--on-accent)}.pager{display:flex;align-items:center;justify-content:space-between;gap:var(--space-4);margin-top:clamp(2.2rem,5vw,3.2rem)}.pager-pages{display:flex;align-items:center;gap:var(--space-2)}.pager-num{display:grid;place-items:center;min-width:2.3rem;height:2.3rem;padding:0 .5rem;border:1px solid var(--line);border-radius:var(--radius-pill);background:var(--card);color:var(--ink-2);font-family:var(--font-mono);font-size:.8rem;font-weight:600;transition:var(--t-spring)}.pager-num:hover{border-color:var(--accent-line);color:var(--accent);transform:translateY(-1px);box-shadow:var(--shadow-sm)}.pager-num.active{border-color:var(--ink);background:var(--ink);color:var(--bg)}.pager-arrow{display:inline-flex;align-items:center;gap:var(--space-2);padding:.45rem .9rem;border:1px solid var(--line);border-radius:var(--radius-pill);background:var(--card);color:var(--ink-2);font-family:var(--font-mono);font-size:.74rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;transition:var(--t-spring)}.pager-arrow:hover{border-color:var(--accent-line);color:var(--accent-deep);transform:translateY(-1px);box-shadow:var(--shadow-sm)}.pager-arrow.disabled{opacity:.35;pointer-events:none}.pager-arrow i{font-size:.7rem}.post-header .page-header-title{font-size:clamp(1.9rem,5vw,3rem);line-height:1.15}.post-header .page-header-kicker a{color:inherit}.post-header .page-header-kicker a:hover{color:var(--accent-deep)}.post-tags{display:flex;flex-wrap:wrap;gap:var(--space-2);margin-top:var(--space-5)}.prose{margin-top:clamp(1.8rem,4vw,2.6rem);color:var(--ink-2);font-size:1.02rem;line-height:1.85;overflow-wrap:break-word}.page-prose{font-size:1.04rem}.prose>*+*{margin-top:var(--space-5)}.prose h1,.prose h2,.prose h3,.prose h4{position:relative;margin-top:var(--space-8);color:var(--ink);scroll-margin-top:calc(var(--header-h) + 2rem)}.prose h1{font-size:1.65rem}.prose h2{font-size:1.45rem}.prose h3{font-size:1.2rem}.prose h4{font-size:1.05rem}.heading-anchor{margin-left:.4em;color:var(--accent);font-family:var(--font-mono);font-size:.8em;opacity:0;transition:opacity var(--t-fast)}.prose h1:hover .heading-anchor,.prose h2:hover .heading-anchor,.prose h3:hover .heading-anchor,.prose h4:hover .heading-anchor,.heading-anchor:focus-visible{opacity:1}.post-body{display:grid;grid-template-columns:minmax(0, 1fr);gap:var(--space-7);align-items:start}.post-toc{display:none}@media(min-width: 1024px){.post-body:not(.no-toc){grid-template-columns:minmax(0, 1fr) 13.5rem}.post-toc{display:block;position:sticky;top:calc(var(--header-h) + 2.5rem);margin-top:clamp(1.8rem,4vw,2.6rem)}}.toc-label{margin-bottom:var(--space-3);color:var(--ink-3);font-family:var(--font-mono);font-size:.7rem;font-weight:600;letter-spacing:.18em;text-transform:uppercase}.toc-list{margin:0;padding:0;list-style:none;border-left:1px solid var(--line);max-height:calc(100vh - var(--header-h) - 9rem);overflow-y:auto}.toc-item{margin:0}.toc-l2 .toc-link{padding-left:1.7rem}.toc-l3 .toc-link{padding-left:2.5rem}.toc-l4 .toc-link{padding-left:3.3rem}.toc-link{display:block;margin-left:-1px;padding:.3rem .5rem .3rem .9rem;border-left:2px solid rgba(0,0,0,0);color:var(--ink-3);font-size:.8rem;line-height:1.45;overflow-wrap:break-word;transition:var(--t-fast)}.toc-link:hover{color:var(--ink)}.toc-link.active{border-left-color:var(--accent);color:var(--accent);font-weight:600}.prose a{color:var(--accent-deep);text-decoration:underline;text-decoration-color:var(--accent-line);text-underline-offset:.2em;transition:var(--t-fast)}.prose a:hover{color:var(--accent);text-decoration-color:var(--accent)}.prose ul,.prose ol{padding-left:1.4rem}.prose li+li{margin-top:var(--space-2)}.prose li::marker{color:var(--accent);font-family:var(--font-mono);font-size:.92em}.prose blockquote{padding:var(--space-4) var(--space-5);border-left:3px solid var(--accent-line);border-radius:0 var(--radius-md) var(--radius-md) 0;background:var(--accent-softer);color:var(--ink-2)}.prose blockquote>*+*{margin-top:var(--space-3)}.prose img{margin:var(--space-6) auto;border:1px solid var(--line);border-radius:var(--radius-md);box-shadow:var(--shadow-sm)}.prose hr{margin:var(--space-7) 0}.prose table{width:100%;border-collapse:collapse;font-size:.92rem}.prose th,.prose td{padding:.55rem .8rem;border:1px solid var(--line);text-align:left}.prose th{background:var(--surface);color:var(--ink);font-weight:650}.prose pre{position:relative;margin:var(--space-5) 0 0;padding:var(--space-5);overflow-x:auto;border:1px solid var(--line);border-radius:var(--radius-md);background:var(--bg-alt);box-shadow:var(--shadow-sm);line-height:1.7}[data-theme=dark] .prose pre{background:#181610}.prose pre code{display:block;padding:0;border:0;border-radius:0;background:rgba(0,0,0,0);color:var(--ink-2);font-size:.86rem}.code-copy{position:absolute;top:.6rem;right:.6rem;display:grid;place-items:center;width:2rem;height:2rem;border:1px solid var(--line);border-radius:var(--radius-sm);background:var(--card);color:var(--ink-3);font-size:.78rem;cursor:pointer;opacity:0;transition:var(--t-fast)}.prose pre:hover .code-copy,.code-copy:focus-visible{opacity:1}.code-copy:hover{border-color:var(--accent-line);color:var(--accent)}.code-copy.copied{border-color:var(--ok);color:var(--ok);opacity:1}.token.comment,.token.prolog,.token.doctype,.token.cdata{color:var(--ink-3);font-style:italic}.token.punctuation{color:var(--ink-2)}.token.property,.token.tag,.token.constant,.token.symbol,.token.deleted{color:var(--accent-deep)}.token.boolean,.token.number{color:var(--gold)}.token.selector,.token.attr-name,.token.string,.token.char,.token.builtin,.token.inserted{color:var(--ok)}.token.operator,.token.entity,.token.url{color:var(--blue)}.token.atrule,.token.attr-value,.token.keyword{color:var(--blue-bright)}.token.function,.token.class-name{color:var(--accent)}.token.regex,.token.important,.token.variable{color:var(--gold)}.post-footer{margin-top:clamp(2.5rem,6vw,4rem)}.post-nav{display:grid;grid-template-columns:repeat(2, minmax(0, 1fr));gap:var(--space-4)}.post-nav-card{display:flex;flex-direction:column;gap:var(--space-2);padding:var(--space-5);transition:var(--t-spring)}.post-nav-card.empty{border:0;background:rgba(0,0,0,0);box-shadow:none}a.post-nav-card:hover{border-color:var(--accent-line);transform:translateY(-2px);box-shadow:var(--shadow-md)}.post-nav-label{color:var(--ink-3);font-family:var(--font-mono);font-size:.7rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase}.post-nav-label i{color:var(--accent)}.post-nav-title{color:var(--ink);font-weight:650;font-size:.95rem;line-height:1.45}a.post-nav-card:hover .post-nav-title{color:var(--accent-deep)}.post-nav-next{align-items:flex-end;text-align:right}.post-comments{margin-top:clamp(3rem,7vw,4.5rem)}#giscus-container{min-height:14rem;margin-top:var(--space-6)}.term-cloud{display:flex;flex-wrap:wrap;gap:var(--space-2) var(--space-3)}.term-chip{display:inline-flex;align-items:center;gap:.45em;padding:.42rem .95rem;border:1px solid var(--line);border-radius:var(--radius-pill);background:var(--card);color:var(--ink-2);font-size:.88rem;font-weight:550;transition:var(--t-spring)}.term-chip:hover{border-color:var(--accent-line);color:var(--accent-deep);transform:translateY(-2px);box-shadow:var(--shadow-sm)}.term-count{padding:.05rem .5rem;border-radius:var(--radius-pill);background:var(--surface-2);color:var(--ink-3);font-family:var(--font-mono);font-size:.7rem;font-weight:600}.term-chip:hover .term-count{background:var(--accent-soft);color:var(--accent-deep)}.archive-list{position:relative;margin:0;padding:0;list-style:none}.archive-list::before{content:"";position:absolute;top:.6rem;bottom:.6rem;left:5.81rem;width:1px;background:var(--line)}.archive-item{position:relative;display:grid;grid-template-columns:5.5rem 1.6rem minmax(0, 1fr);align-items:baseline;padding:.7rem 0}.archive-date{padding-right:1.1rem;color:var(--ink-3);font-size:.74rem;font-weight:500;letter-spacing:.05em;text-align:right;white-space:nowrap}.archive-node{position:relative;align-self:center;width:.62rem;height:.62rem;border:2px solid var(--accent);border-radius:var(--radius-pill);background:var(--bg);transition:var(--t-med)}.archive-item:hover .archive-node{background:var(--accent);box-shadow:var(--pulse-from)}.archive-text{display:flex;flex-wrap:wrap;align-items:baseline;gap:var(--space-2) var(--space-3);padding-left:var(--space-4);font-size:.97rem;line-height:1.6}.archive-link{color:var(--ink-2);font-weight:550;transition:color var(--t-fast)}.archive-item:hover .archive-link{color:var(--ink)}.archive-link:hover{color:var(--accent) !important}.archive-cat{color:var(--ink-3);font-family:var(--font-mono);font-size:.7rem;letter-spacing:.04em}.archive-cat:hover{color:var(--accent)}.archive-cat::before{content:"/";margin-right:.5em;color:var(--accent)}.archive-year-marker{display:grid;grid-template-columns:5.5rem 1.6rem minmax(0, 1fr);padding:1.1rem 0 .2rem;scroll-margin-top:calc(var(--header-h) + 2rem)}.archive-year-marker:first-child{padding-top:0}.archive-year-label{grid-column:3;padding-left:var(--space-4);color:var(--ink);font-family:var(--font-display);font-size:1.2rem;font-weight:700}.archive-year-label::after{content:"";display:inline-block;width:.4rem;height:.4rem;margin-left:.55rem;border-radius:1px;background:var(--accent);transform:rotate(45deg) translateY(-1px)}.tools-grid{display:grid;grid-template-columns:repeat(auto-fill, minmax(19rem, 1fr));gap:var(--space-5);margin:0;padding:0;list-style:none}.tool-card{position:relative;display:flex;flex-direction:column;gap:var(--space-3);padding:var(--space-6);overflow:hidden;transition:var(--t-spring)}.tool-card::before{content:"";position:absolute;inset:0 0 auto 0;height:3px;background:linear-gradient(90deg, var(--accent), var(--accent-bright) 55%, transparent);opacity:0;transition:opacity var(--t-med)}.tool-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);border-color:var(--accent-line)}.tool-card:hover::before{opacity:1}.tool-card.is-archived{opacity:.72}.tool-card-head{display:flex;align-items:center;gap:var(--space-3)}.tool-icon{display:inline-flex;align-items:center;justify-content:center;flex:0 0 auto;width:2.6rem;height:2.6rem;border:1px solid var(--line);border-radius:var(--radius-md);background:var(--accent-softer);color:var(--accent);font-size:1.1rem;transition:transform var(--t-med)}.tool-card:hover .tool-icon{transform:scale(1.08) rotate(-4deg)}.tool-name{margin:0;font-family:var(--font-display);font-size:1.18rem;line-height:1.3}.tool-name-link{color:var(--ink);text-decoration:none}.tool-name-link:hover{color:var(--accent-deep)}.tool-name-link::after{content:"";position:absolute;inset:0}.tool-badge{margin-left:auto;padding:.18rem .6rem;border-radius:var(--radius-pill);font-family:var(--font-mono);font-size:.66rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase}.tool-badge-beta{background:var(--gold-soft);color:var(--gold)}.tool-badge-archived{background:var(--ghost);color:var(--ink-3)}.tool-tagline{margin:0;color:var(--ink);font-weight:600;font-size:.98rem;line-height:1.55}.tool-desc{margin:0;color:var(--ink-2);font-size:.9rem;line-height:1.7}.tool-tech{display:flex;flex-wrap:wrap;gap:var(--space-2);margin:0;padding:0;list-style:none}.tool-tech-chip{padding:.2rem .62rem;border:1px solid var(--line-soft);border-radius:var(--radius-pill);background:var(--surface);color:var(--ink-3);font-size:.7rem;font-weight:600}.tool-actions{position:relative;z-index:1;display:flex;flex-wrap:wrap;gap:var(--space-3);margin-top:auto;padding-top:var(--space-2)}.tool-actions .social-btn{padding:.55rem 1.05rem;font-size:.8rem}.search-dialog{width:min(42rem,100vw - 2.5rem);margin:9vh auto auto;padding:var(--space-6);border:1px solid var(--line);border-radius:var(--radius-lg);background:var(--card);color:var(--ink);box-shadow:var(--shadow-lg)}.search-dialog::backdrop{background:rgba(12,10,6,.45);backdrop-filter:blur(4px)}.search-dialog .dialog-close{position:absolute;top:.6rem;right:.8rem;border:0;background:rgba(0,0,0,0);color:var(--ink-3);font-size:1.3rem;line-height:1;cursor:pointer}.search-dialog .dialog-close:hover{color:var(--accent)}.search-dialog .pagefind-box{min-height:7rem}.pagefind-box{--pagefind-ui-scale: 0.95;--pagefind-ui-primary: var(--accent);--pagefind-ui-text: var(--ink-2);--pagefind-ui-background: var(--card);--pagefind-ui-border: var(--line);--pagefind-ui-tag: var(--surface);--pagefind-ui-border-width: 1px;--pagefind-ui-border-radius: var(--radius-md);--pagefind-ui-image-border-radius: var(--radius-md);--pagefind-ui-image-box-ratio: 3 / 2;--pagefind-ui-font: var(--font-sans)}.pagefind-box .pagefind-ui__search-input{border-radius:var(--radius-pill);background:var(--card);color:var(--ink);font-weight:500;transition:border-color var(--t-fast),box-shadow var(--t-fast)}.pagefind-box .pagefind-ui__search-input:focus{border-color:var(--accent-line);box-shadow:var(--ring);outline:none}.pagefind-box .pagefind-ui__search-clear{color:var(--ink-3);background:rgba(0,0,0,0)}.pagefind-box .pagefind-ui__result{border-top:1px solid var(--line-soft)}.pagefind-box .pagefind-ui__result-link{color:var(--ink);font-family:var(--font-display);font-weight:700}.pagefind-box .pagefind-ui__result-link:hover{color:var(--accent);text-decoration:none}.pagefind-box .pagefind-ui__result-excerpt{color:var(--ink-2)}.pagefind-box .pagefind-ui__result-excerpt mark{padding:.05em .25em;border-radius:var(--radius-sm);background:var(--accent-soft);color:var(--accent-deep);font-weight:600}.pagefind-box .pagefind-ui__button{border:1px solid var(--line);border-radius:var(--radius-pill);background:var(--card);color:var(--ink-2);font-weight:600;transition:var(--t-fast)}.pagefind-box .pagefind-ui__button:hover{border-color:var(--accent-line);color:var(--accent-deep)}.pagefind-box .pagefind-ui__message{color:var(--ink-3);font-family:var(--font-mono);font-size:.8rem}.search-unavailable{padding:var(--space-5);border:1px dashed var(--line-strong);border-radius:var(--radius-md);color:var(--ink-3);font-size:.92rem}@keyframes status-pulse{0%{box-shadow:var(--pulse-from)}70%{box-shadow:var(--pulse-mid)}100%{box-shadow:var(--pulse-to)}}.reveal-item{opacity:0;transform:translateY(1.6rem);transition:opacity 700ms var(--ease-out),transform 700ms var(--ease-out);will-change:opacity,transform}.reveal-item.revealed{opacity:1;transform:none}@keyframes rise-in{from{opacity:0;transform:translateY(1.2rem)}to{opacity:1;transform:none}}.hero .hero-text>*{animation:rise-in 800ms var(--ease-out) backwards}.hero .hero-text>*:nth-child(1){animation-delay:60ms}.hero .hero-text>*:nth-child(2){animation-delay:140ms}.hero .hero-text>*:nth-child(3){animation-delay:220ms}.hero .hero-text>*:nth-child(4){animation-delay:300ms}.hero .hero-text>*:nth-child(5){animation-delay:380ms}.hero .hero-text>*:nth-child(6){animation-delay:460ms}.hero .hero-side{animation:rise-in 900ms var(--ease-out) 250ms backwards}@media(prefers-reduced-motion: reduce){html{scroll-behavior:auto}*,*::before,*::after{animation-duration:.01ms !important;animation-iteration-count:1 !important;transition-duration:.01ms !important}.reveal-item{opacity:1;transform:none}}@media(max-width: 719.98px){.section-head{flex-wrap:wrap;row-gap:var(--space-1)}.section-rule{display:none}.post-nav{grid-template-columns:minmax(0, 1fr)}.post-nav-card.empty{display:none}.post-nav-next{align-items:flex-start;text-align:left}}@media(max-width: 559.98px){body{font-size:.97rem}.post-item{grid-template-columns:minmax(0, 1fr);gap:var(--space-2);padding-left:0;padding-right:0}.post-item-date{padding-top:0}.post-item-read{margin-left:0}.archive-item,.archive-year-marker{grid-template-columns:1rem minmax(0, 1fr)}.archive-list::before{left:.31rem}.archive-date{display:block;grid-column:2;grid-row:2;padding:.15rem 0 0 var(--space-4);text-align:left}.archive-node{grid-column:1;grid-row:1;align-self:baseline;transform:translateY(0.2rem)}.archive-text{grid-column:2;grid-row:1}.archive-year-label{grid-column:2}.pager{flex-wrap:wrap;justify-content:center}.pager-pages{order:-1;width:100%;justify-content:center}.footer-base{flex-direction:column;align-items:flex-start}}