:root{--navy: #000;--navy-2: #0a0a0a;--navy-3: #111;--navy-4: #1a1a1a;--blue: #ededed;--blue-hover: #fff;--blue-dim: #a1a1a1;--blue-glow: rgba(var(--accent-rgb), .04);--blue-line: rgba(var(--accent-rgb), .08);--white: #ededed;--white-dim: rgba(237, 237, 237, .65);--white-faint: rgba(237, 237, 237, .4);--white-ghost: rgba(237, 237, 237, .06);--green: #0ce490;--amber: #f5a623;--red: #ee0000;--text-dark: #ededed;--text-mid: #a1a1a1;--text-light: #666;--border-light: #1f1f1f;--bg-light: #0a0a0a;--accent-rgb: 255, 255, 255;--invert-fg: #000;--accent-blue: #0070f3;--accent-blue-rgb: 0, 112, 243;--green-rgb: 12, 228, 144;--nav-bg: rgba(0, 0, 0, .72)}[data-theme=light]{--navy: #fff;--navy-2: #fafafa;--navy-3: #f4f4f4;--navy-4: #eaeaea;--blue: #000;--blue-hover: #333;--blue-dim: #666;--blue-glow: rgba(0, 0, 0, .04);--blue-line: rgba(0, 0, 0, .08);--white: #000;--white-dim: rgba(0, 0, 0, .65);--white-faint: rgba(0, 0, 0, .4);--white-ghost: rgba(0, 0, 0, .04);--green: #0a8050;--amber: #c47e0c;--red: #cc0000;--text-dark: #000;--text-mid: #444;--text-light: #666;--border-light: #eaeaea;--bg-light: #fafafa;--accent-rgb: 0, 0, 0;--invert-fg: #fff;--accent-blue: #0070f3;--accent-blue-rgb: 0, 112, 243;--green-rgb: 10, 128, 80;--nav-bg: rgba(255, 255, 255, .78)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{font-family:Geist,sans-serif;background:var(--navy);color:var(--white);-webkit-font-smoothing:antialiased;overflow-x:hidden;line-height:1.6}a{color:inherit}nav.tj-nav{position:fixed;top:0;left:0;right:0;z-index:100;display:flex;align-items:center;justify-content:space-between;padding:0 40px;height:60px;background:var(--nav-bg);backdrop-filter:blur(16px);border-bottom:1px solid var(--blue-line)}.nav-logo{display:flex;align-items:center;text-decoration:none;color:var(--white)}.brand-logo{height:42px;width:auto;display:block;transition:opacity .15s}.nav-logo:hover .brand-logo{opacity:.85}.nav-links{display:flex;align-items:center;gap:28px;list-style:none}.nav-links a{font-size:14px;color:var(--white-dim);text-decoration:none;font-weight:400;transition:color .15s}.nav-links a:hover,.nav-links a[aria-current=page]{color:var(--white)}.nav-actions{display:flex;align-items:center;gap:12px}.theme-picker{position:relative}.theme-toggle{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;background:transparent;border:1px solid rgba(var(--accent-rgb),.12);border-radius:6px;color:var(--white-dim);cursor:pointer;padding:0;transition:color .15s,border-color .15s,background .15s}.theme-toggle:hover{color:var(--white);border-color:rgba(var(--accent-rgb),.25);background:rgba(var(--accent-rgb),.04)}.theme-toggle .theme-icon{display:none}:root[data-theme-pref=system] .theme-toggle .theme-icon-system,:root:not([data-theme-pref]) .theme-toggle .theme-icon-system{display:block}:root[data-theme-pref=light] .theme-toggle .theme-icon-sun{display:block}:root[data-theme-pref=dark] .theme-toggle .theme-icon-moon{display:block}.theme-menu{position:absolute;top:calc(100% + 6px);right:0;min-width:132px;background:var(--navy-2);border:1px solid rgba(var(--accent-rgb),.12);border-radius:8px;padding:4px;box-shadow:0 8px 24px #00000040;display:none;z-index:200}.theme-picker.open .theme-menu{display:block}.theme-menu-item{display:flex;align-items:center;gap:8px;width:100%;padding:7px 10px;background:transparent;border:none;border-radius:5px;color:var(--white-dim);font-family:Geist,sans-serif;font-size:13px;text-align:left;cursor:pointer;transition:color .12s,background .12s}.theme-menu-item:hover,.theme-menu-item[aria-current=true]{color:var(--white);background:rgba(var(--accent-rgb),.06)}.theme-menu-item svg{flex-shrink:0}.nav-github{display:inline-flex;align-items:center;color:var(--white-dim);transition:color .2s}.nav-github:hover{color:var(--white)}@media(max-width:640px){nav.tj-nav{padding:0 20px}.nav-links{display:none}}main.tj-main{min-height:calc(100vh - 260px);padding:120px 40px 80px;max-width:820px;margin:0 auto}@media(max-width:640px){main.tj-main{padding:96px 20px 56px}}footer.tj-footer{display:flex;align-items:center;justify-content:space-between;padding:40px;border-top:1px solid var(--blue-line);background:var(--navy)}footer.tj-footer .footer-left{display:flex;align-items:center;gap:20px}footer.tj-footer .footer-logo{height:32px;color:var(--white)}footer.tj-footer .footer-meta{display:flex;align-items:center;gap:14px;color:var(--white-dim);font-size:13px}footer.tj-footer .footer-meta a{color:var(--white-dim);text-decoration:none;transition:color .15s}footer.tj-footer .footer-meta a:hover{color:var(--white)}footer.tj-footer .license-badge{font-family:Geist Mono,monospace;font-size:11px;padding:2px 6px;border:1px solid rgba(var(--accent-rgb),.2);border-radius:4px;color:var(--white-dim)}footer.tj-footer .footer-right{font-size:12px;font-family:Geist Mono,monospace;color:rgba(var(--accent-rgb),.45)}@media(max-width:640px){footer.tj-footer{flex-direction:column;gap:20px;padding:32px 20px;align-items:flex-start}}.blog-hero{margin-bottom:48px}.blog-hero h1{font-size:40px;font-weight:600;letter-spacing:-.02em;margin-bottom:12px}.blog-hero p{color:var(--white-dim);font-size:17px}.post-list{list-style:none;display:flex;flex-direction:column;gap:8px}.post-card{display:block;padding:24px 0;border-bottom:1px solid var(--blue-line);text-decoration:none;color:inherit;transition:opacity .15s}.post-card:hover{opacity:.8}.post-card .post-meta{display:flex;gap:12px;align-items:center;font-family:Geist Mono,monospace;font-size:12px;color:var(--white-faint);margin-bottom:8px}.post-card .post-pillar{text-transform:uppercase;letter-spacing:.05em;color:var(--accent-blue)}.post-card h2{font-size:22px;font-weight:600;letter-spacing:-.01em;margin-bottom:6px}.post-card p{color:var(--white-dim);font-size:15px}.chip-row{display:flex;flex-wrap:wrap;gap:8px;margin:16px 0}.chip{display:inline-block;font-family:Geist Mono,monospace;font-size:12px;padding:4px 10px;border:1px solid var(--blue-line);border-radius:999px;color:var(--white-dim);text-decoration:none;transition:color .15s,border-color .15s}.chip:hover{color:var(--white);border-color:rgba(var(--accent-rgb),.3)}.prose{font-size:17px;line-height:1.75;color:var(--white)}.prose h1,.prose h2,.prose h3,.prose h4{font-weight:600;letter-spacing:-.01em;line-height:1.3;margin:1.6em 0 .6em}.prose h1{font-size:36px}.prose h2{font-size:28px}.prose h3{font-size:22px}.prose h4{font-size:18px}.prose p{margin:0 0 1.1em}.prose a{color:var(--accent-blue);text-decoration:underline;text-decoration-color:rgba(var(--accent-blue-rgb),.4);text-underline-offset:3px}.prose a:hover{text-decoration-color:var(--accent-blue)}.prose ul,.prose ol{margin:0 0 1.1em 1.4em}.prose li{margin-bottom:.4em}.prose blockquote{border-left:3px solid var(--accent-blue);padding:.2em 0 .2em 1em;margin:1.2em 0;color:var(--white-dim);font-style:italic}.prose code{font-family:Geist Mono,monospace;font-size:.92em;background:var(--white-ghost);padding:2px 6px;border-radius:4px}.prose pre{background:var(--navy-2)!important;border:1px solid var(--blue-line);border-radius:8px;padding:16px;overflow-x:auto;font-size:14px;line-height:1.6;margin:1.2em 0}.prose pre code{background:transparent;padding:0;font-size:inherit}.prose img{max-width:100%;border-radius:8px;margin:1.2em 0}.prose hr{border:0;border-top:1px solid var(--blue-line);margin:2em 0}.prose table{width:100%;border-collapse:collapse;margin:1.2em 0;font-size:15px}.prose th,.prose td{border:1px solid var(--blue-line);padding:10px 14px;text-align:left}.prose th{background:var(--white-ghost);font-weight:600}.article-header{margin-bottom:32px}.article-header h1{font-size:40px;font-weight:600;letter-spacing:-.02em;margin-bottom:12px;line-height:1.2}.article-byline{display:flex;flex-wrap:wrap;gap:14px;align-items:center;font-family:Geist Mono,monospace;font-size:13px;color:var(--white-faint)}.article-byline a{color:var(--white-dim);text-decoration:none}.article-byline a:hover{color:var(--white)}.article-cover{display:block;width:100%;height:auto;border-radius:8px;border:1px solid var(--blue-line);margin-bottom:32px}.tj-tldr{margin:24px 0;padding:16px 20px;border-left:3px solid var(--accent-blue);background:var(--white-ghost);border-radius:0 8px 8px 0}.tj-tldr-label{display:block;font-family:Geist Mono,monospace;font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--accent-blue);margin-bottom:6px}.tj-callout{margin:20px 0;padding:14px 18px;border:1px solid var(--blue-line);border-radius:8px;background:var(--white-ghost)}.tj-callout--info{border-left:3px solid var(--accent-blue)}.tj-callout--warn{border-left:3px solid var(--amber)}.tj-callout--tip{border-left:3px solid var(--green)}.tj-defbox{margin:24px 0;padding:18px 22px;border:1px solid var(--blue-line);border-radius:8px}.tj-defbox h2{font-size:20px;margin:0 0 8px;font-family:Geist Mono,monospace}.tj-faq dt{font-weight:600;margin-top:18px}.tj-faq dd{margin:6px 0 0;color:var(--white-dim)}.copy-for-ai{display:inline-flex;align-items:center;gap:6px;font-family:Geist Mono,monospace;font-size:12px;padding:6px 12px;margin-bottom:24px;border:1px solid var(--blue-line);border-radius:6px;background:transparent;color:var(--white-dim);cursor:pointer;transition:color .15s,border-color .15s,background .15s}.copy-for-ai:hover{color:var(--white);border-color:rgba(var(--accent-rgb),.3);background:var(--white-ghost)}.copy-for-ai[data-copied=true]{color:var(--green);border-color:rgba(var(--green-rgb),.4)}.author-card{margin-top:48px;padding:20px;border:1px solid var(--blue-line);border-radius:8px;background:var(--white-ghost)}.author-card-head{display:flex;flex-wrap:wrap;gap:8px 12px;align-items:baseline;margin-bottom:6px}.author-card-name{color:var(--white);text-decoration:none;font-weight:600;font-size:15px}.author-card-name:hover{color:var(--accent-blue)}.author-card-role{font-family:Geist Mono,monospace;font-size:12px;color:var(--white-faint)}.author-card-bio{color:var(--white-dim);font-size:14px;line-height:1.55}.related-posts{margin-top:56px;padding-top:32px;border-top:1px solid var(--blue-line)}.related-posts h3{font-size:14px;font-family:Geist Mono,monospace;text-transform:uppercase;letter-spacing:.08em;color:var(--white-faint);margin-bottom:16px}.related-posts ul{list-style:none;display:flex;flex-direction:column;gap:10px}.related-posts a{color:var(--white);text-decoration:none;font-size:16px}.related-posts a:hover{color:var(--accent-blue)}
