:root{--post-prose:720px}.blog-page main,.post-page main{display:block}.blog-page .so-section,.post-page .so-section{padding:56px 0}@media (max-width:768px){.blog-page .so-section,.post-page .so-section{padding:36px 0}}.blog-img{aspect-ratio:16/9;background:var(--so-bg-1);border-bottom:1px solid var(--so-line);width:100%;position:relative;overflow:hidden}.blog-img>img{object-fit:cover;width:100%;height:100%;display:block}.blog-img-large{aspect-ratio:21/9;border:1px solid var(--so-line);border-radius:0}.blog-img-pattern{background-image:repeating-linear-gradient(-45deg,#ffffff0a 0 8px,#ffffff1a 8px 9px);position:absolute;inset:0;-webkit-mask-image:radial-gradient(at 30% 40%,#000 30%,#0000 90%);mask-image:radial-gradient(at 30% 40%,#000 30%,#0000 90%)}.blog-img-meta{letter-spacing:.22em;gap:10px;font-family:Geist Mono,monospace;font-size:10px;display:flex;position:absolute;bottom:12px;left:14px}.blog-img-cat{color:var(--so-ink-0)}.blog-img-id{color:var(--so-ink-3)}.blog-img-tone-orange{background:linear-gradient(135deg,#1f1208 0%,#2a1812 40%,#3a1f0e 100%)}.blog-img-tone-orange .blog-img-pattern{background-image:repeating-linear-gradient(-45deg,#fb923c1a 0 8px,#fb923c38 8px 9px)}.blog-img-tone-orange .blog-img-cat{color:var(--so-orange)}.blog-img-tone-slate{background:linear-gradient(135deg,#0e131c 0%,#161c28 40%,#1a2536 100%)}.blog-img-tone-slate .blog-img-pattern{background-image:repeating-linear-gradient(-45deg,#7dd3fc1a 0 8px,#7dd3fc38 8px 9px)}.blog-img-tone-slate .blog-img-cat{color:#7dd3fc}.blog-img-tone-deep{background:linear-gradient(135deg,#1c0a0a 0%,#2a0f10 40%,#3a1418 100%)}.blog-img-tone-deep .blog-img-pattern{background-image:repeating-linear-gradient(-45deg,#d977571f 0 8px,#d977573d 8px 9px)}.blog-img-tone-deep .blog-img-cat{color:#fdba74}.blog-img-tone-dim{background:linear-gradient(135deg,#131316 0%,#1a1a1f 40%,#25252c 100%)}.blog-img-tone-dim .blog-img-pattern{background-image:repeating-linear-gradient(-45deg,#ffffff0f 0 8px,#ffffff21 8px 9px)}.blog-header{border-bottom:1px solid var(--so-line);padding-top:56px!important;padding-bottom:40px!important}@media (max-width:768px){.blog-header{padding-top:28px!important}}.blog-header-kicker{letter-spacing:.22em;color:var(--so-ink-4);border-bottom:1px solid var(--so-line);align-items:center;gap:12px;margin-bottom:36px;padding-bottom:18px;font-family:Geist Mono,monospace;font-size:11px;display:flex}.blog-header-tag{color:var(--so-orange)}.blog-header-spacer{border-bottom:1px dashed var(--so-line-2);flex:1;height:1px;margin:0 8px}.blog-header-meta{color:var(--so-ink-5);white-space:nowrap}@media (max-width:700px){.blog-header-spacer,.blog-header-meta{display:none}}.blog-header-title{letter-spacing:-.035em;text-wrap:balance;max-width:22ch;margin:0;font-family:Geist,sans-serif;font-size:clamp(36px,5.4vw,72px);font-weight:800;line-height:.98}.blog-header-sub{color:var(--so-ink-2);text-wrap:pretty;max-width:60ch;margin:20px 0 0;font-size:clamp(15px,1.4vw,18px);line-height:1.55}.blog-grid-sec{padding-top:40px!important}.blog-grid-head{letter-spacing:.18em;color:var(--so-ink-4);border-bottom:1px solid var(--so-line);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;margin-bottom:28px;padding-bottom:16px;font-family:Geist Mono,monospace;font-size:11px;display:flex}.blog-grid-head-tag{color:var(--so-ink-2)}.blog-grid{grid-template-columns:repeat(3,1fr);gap:28px 24px;display:grid}@media (max-width:1024px){.blog-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:640px){.blog-grid{grid-template-columns:1fr;gap:20px}}.blog-card{border:1px solid var(--so-line);background:var(--so-bg-1);color:inherit;flex-direction:column;min-height:100%;text-decoration:none;transition:border-color .16s,background .16s,transform .16s;display:flex}.blog-card:hover{border-color:var(--so-line-2);background:var(--so-bg-2)}.blog-card:hover .blog-card-title{color:var(--so-orange)}.blog-card:focus-visible{outline:1px solid var(--so-orange);outline-offset:2px}.blog-card-body{flex-direction:column;flex:1;gap:12px;padding:20px 22px 22px;display:flex}.blog-card-meta{letter-spacing:.22em;color:var(--so-ink-4);align-items:center;gap:8px;font-family:Geist Mono,monospace;font-size:10px;display:flex}.blog-card-cat{color:var(--so-orange)}.blog-card-dot{color:var(--so-ink-5)}.blog-card-date{color:var(--so-ink-3)}.blog-card-title{letter-spacing:-.018em;color:var(--so-ink-0);text-wrap:balance;-webkit-line-clamp:3;-webkit-box-orient:vertical;margin:0;font-family:Geist,sans-serif;font-size:20px;font-weight:700;line-height:1.22;transition:color .16s;display:-webkit-box;overflow:hidden}.blog-card-dek{color:var(--so-ink-2);text-wrap:pretty;-webkit-line-clamp:3;-webkit-box-orient:vertical;margin:0;font-size:14px;line-height:1.55;display:-webkit-box;overflow:hidden}.blog-card-foot{border-top:1px solid var(--so-line);align-items:center;gap:10px;margin-top:auto;padding-top:14px;display:flex}.blog-card-avatar{width:28px;height:28px;color:var(--so-orange);border:1px solid var(--so-orange);letter-spacing:.06em;background:#fb923c1a;flex-shrink:0;justify-content:center;align-items:center;font-family:Geist Mono,monospace;font-size:10px;font-weight:600;display:inline-flex}.blog-card-author{flex-direction:column;flex:1;gap:1px;min-width:0;display:flex}.blog-card-author-name{color:var(--so-ink-1);text-overflow:ellipsis;white-space:nowrap;font-size:12px;font-weight:500;overflow:hidden}.blog-card-author-role{letter-spacing:.16em;color:var(--so-ink-4);text-transform:uppercase;text-overflow:ellipsis;white-space:nowrap;font-family:Geist Mono,monospace;font-size:9px;overflow:hidden}.blog-card-read{letter-spacing:.18em;color:var(--so-ink-4);flex-shrink:0;font-family:Geist Mono,monospace;font-size:10px}.blog-empty{border:1px dashed var(--so-line-2);background:var(--so-bg-1);text-align:center;color:var(--so-ink-3);letter-spacing:.18em;padding:40px 32px;font-family:Geist Mono,monospace;font-size:12px}.post-back-bar{border-bottom:1px solid var(--so-line);z-index:40;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#09090bd9;padding:14px 0;position:sticky;top:56px}.post-back{letter-spacing:.18em;color:var(--so-ink-2);text-transform:uppercase;border:1px solid #0000;align-items:center;gap:10px;margin-left:-12px;padding:6px 12px;font-family:Geist Mono,monospace;font-size:11px;text-decoration:none;transition:all .14s;display:inline-flex}.post-back:hover{color:var(--so-orange);border-color:var(--so-line-2);background:var(--so-bg)}.post-back-arrow{font-family:Geist Mono,monospace;font-size:14px;transition:transform .16s}.post-back:hover .post-back-arrow{transform:translate(-3px)}.post-header{border-bottom:1px solid var(--so-line);padding:56px 0 32px}@media (max-width:768px){.post-header{padding:32px 0 24px}}.post-header-inner{max-width:880px;margin:0 auto}@media (min-width:1200px){.post-header-inner{padding-left:0;padding-right:0}}.post-kicker{letter-spacing:.22em;color:var(--so-ink-4);align-items:center;gap:10px;margin-bottom:24px;font-family:Geist Mono,monospace;font-size:11px;display:flex}.post-kicker-cat{color:var(--so-orange);font-weight:600}.post-kicker-dot{color:var(--so-ink-5)}.post-kicker-date{color:var(--so-ink-2)}.post-kicker-read{color:var(--so-ink-3)}.post-title{letter-spacing:-.035em;color:var(--so-ink-0);text-wrap:balance;margin:0;font-family:Geist,sans-serif;font-size:clamp(32px,5vw,60px);font-weight:800;line-height:1.02}.post-dek{color:var(--so-ink-2);text-wrap:pretty;max-width:60ch;margin:22px 0 0;font-size:clamp(17px,1.6vw,21px);line-height:1.5}.post-byline{border-top:1px solid var(--so-line);align-items:center;gap:14px;margin-top:32px;padding-top:22px;display:flex}.post-byline-avatar{width:36px;height:36px;color:var(--so-orange);border:1px solid var(--so-orange);letter-spacing:.06em;background:#fb923c1a;flex-shrink:0;justify-content:center;align-items:center;font-family:Geist Mono,monospace;font-size:11px;font-weight:600;display:inline-flex}.post-byline-text{flex-direction:column;gap:2px;min-width:0;display:flex}.post-byline-name{color:var(--so-ink-0);font-size:14px;font-weight:500}.post-byline-role{letter-spacing:.18em;color:var(--so-ink-4);text-transform:uppercase;font-family:Geist Mono,monospace;font-size:10px}.post-byline-spacer{flex:1}.post-byline-share{gap:6px;display:inline-flex}.post-byline-share a{letter-spacing:.18em;color:var(--so-ink-3);border:1px solid var(--so-line-2);padding:6px 10px;font-family:Geist Mono,monospace;font-size:10px;text-decoration:none;transition:all .12s}.post-byline-share a:hover{color:var(--so-orange);border-color:var(--so-orange);background:#fb923c0d}.post-hero-wrap{max-width:1120px;margin:36px auto 0}@media (max-width:768px){.post-hero-wrap{margin-top:24px}}.post-hero-img{object-fit:cover;border:1px solid var(--so-line);width:100%;max-height:540px;display:block}.post-article{padding:48px 0 64px}@media (max-width:768px){.post-article{padding:32px 0 40px}}.post-article-inner{max-width:880px;margin:0 auto}.post-prose{max-width:var(--post-prose);color:var(--so-ink-1);margin:0 auto;font-size:17px;line-height:1.7}.post-p{text-wrap:pretty;margin:0 0 22px}.post-prose>.post-p:first-child:first-letter{font-weight:600}.post-prose a{color:var(--so-orange);text-underline-offset:3px;-webkit-text-decoration:underline #fb923c66;text-decoration:underline #fb923c66;text-decoration-thickness:1px;transition:text-decoration-color .12s}.post-prose a:hover{-webkit-text-decoration-color:var(--so-orange);text-decoration-color:var(--so-orange)}.post-prose strong{color:var(--so-ink-0);font-weight:600}.post-prose em{color:var(--so-ink-0);font-style:italic}.post-inline-code{background:var(--so-bg-1);border:1px solid var(--so-line);color:var(--so-ink-0);white-space:nowrap;padding:1px 6px;font-family:Geist Mono,monospace;font-size:.9em}.post-h2{letter-spacing:-.022em;color:var(--so-ink-0);text-wrap:balance;margin:48px 0 18px;font-family:Geist,sans-serif;font-size:clamp(24px,2.4vw,30px);font-weight:700;line-height:1.2}.post-h3{letter-spacing:-.015em;color:var(--so-ink-0);margin:36px 0 14px;font-family:Geist,sans-serif;font-size:19px;font-weight:600;line-height:1.3}.post-list{flex-direction:column;gap:10px;margin:0 0 24px;padding-left:24px;display:flex}.post-list li{padding-left:6px}.post-list li::marker{color:var(--so-orange);font-family:Geist Mono,monospace}.post-list-ol li::marker{font-weight:600}.post-rule{border:none;border-top:1px solid var(--so-line);height:0;margin:40px 0;position:relative}.post-rule:after{content:"◆";background:var(--so-bg);color:var(--so-orange);padding:0 12px;font-size:10px;position:absolute;top:-10px;left:50%;transform:translate(-50%)}.post-figure{flex-direction:column;gap:12px;margin:36px -40px;display:flex}@media (max-width:880px){.post-figure{margin:28px 0}}.post-img{border:1px solid var(--so-line);width:100%;display:block}.post-caption{letter-spacing:.06em;color:var(--so-ink-3);text-align:center;max-width:56ch;margin:0 auto;font-family:Geist Mono,monospace;font-size:11px;line-height:1.55}.post-video{border:1px solid var(--so-line);aspect-ratio:16/9;background:#000;width:100%;display:block}.post-quote{border-left:3px solid var(--so-orange);background:var(--so-bg-1);margin:36px -20px;padding:24px 28px;position:relative}.post-quote p{letter-spacing:-.015em;color:var(--so-ink-0);text-wrap:balance;margin:0;font-family:Geist,sans-serif;font-size:clamp(19px,2vw,24px);font-weight:500;line-height:1.4}.post-quote-cite{letter-spacing:.14em;color:var(--so-ink-3);margin-top:14px;font-family:Geist Mono,monospace;font-size:11px;font-style:normal;display:block}.post-quote-mark{color:var(--so-orange);opacity:.25;font-family:Geist,serif;font-size:64px;font-weight:700;line-height:1;position:absolute;top:12px;right:22px}@media (max-width:880px){.post-quote{margin:28px 0}}.post-code{background:var(--so-bg-1);border:1px solid var(--so-line);color:var(--so-ink-1);margin:28px -20px;font-family:Geist Mono,JetBrains Mono,monospace;font-size:13.5px;line-height:1.65;overflow-x:auto}@media (max-width:880px){.post-code{margin:24px 0}}.post-code-bar{border-bottom:1px solid var(--so-line);background:var(--so-bg-2);letter-spacing:.22em;color:var(--so-ink-4);justify-content:space-between;align-items:center;padding:8px 14px;font-family:Geist Mono,monospace;font-size:10px;display:flex}.post-code-dots{gap:5px;display:inline-flex}.post-code-dots i{background:var(--so-line-2);border-radius:50%;width:8px;height:8px;display:inline-block}.post-code-lang{color:var(--so-orange)}.post-code code{white-space:pre;padding:16px 20px;display:block}.post-callout{border:1px solid var(--so-line);background:var(--so-bg-1);grid-template-columns:auto 1fr;align-items:start;gap:18px;margin:28px 0;padding:18px 22px;display:grid}.post-callout-tag{letter-spacing:.22em;color:var(--so-orange);border:1px solid var(--so-orange);background:#fb923c1a;flex-shrink:0;align-self:start;padding:4px 8px;font-family:Geist Mono,monospace;font-size:10px}.post-callout p{color:var(--so-ink-1);margin:0;font-size:15px;line-height:1.6}.post-callout-warn .post-callout-tag{color:#f87171;background:#f871711f;border-color:#f87171}.post-keep{border-top:1px solid var(--so-line);background:var(--so-bg-1);padding:64px 0 80px;position:relative}.post-keep:before{content:"";pointer-events:none;background:radial-gradient(at 50% 0,#fb923c14 0%,#0000 60%);height:200px;position:absolute;top:0;left:0;right:0}@media (max-width:768px){.post-keep{padding:40px 0 56px}}.post-keep-head{flex-wrap:wrap;justify-content:space-between;align-items:flex-end;gap:24px;margin-bottom:32px;display:flex;position:relative}.post-keep-kicker{letter-spacing:.22em;color:var(--so-orange);font-family:Geist Mono,monospace;font-size:11px}.post-keep-title{letter-spacing:-.025em;color:var(--so-ink-0);margin:8px 0 0;font-family:Geist,sans-serif;font-size:clamp(28px,3.4vw,40px);font-weight:800;line-height:1.05}.post-keep-all{letter-spacing:.18em;color:var(--so-ink-2);border:1px solid var(--so-line-2);padding:8px 14px;font-family:Geist Mono,monospace;font-size:11px;text-decoration:none;transition:all .12s}.post-keep-all:hover{color:var(--so-orange);border-color:var(--so-orange);background:#fb923c0d}.post-keep-grid{grid-template-columns:repeat(3,1fr);gap:20px;display:grid;position:relative}@media (max-width:900px){.post-keep-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:600px){.post-keep-grid{grid-template-columns:1fr}}.post-related-card{border:1px solid var(--so-line);background:var(--so-bg);color:inherit;flex-direction:column;text-decoration:none;transition:all .16s;display:flex}.post-related-card:hover{border-color:var(--so-orange);transform:translateY(-2px)}.post-related-card:hover .post-related-title,.post-related-card:hover .post-related-link{color:var(--so-orange)}.post-related-body{flex-direction:column;flex:1;gap:10px;padding:18px 20px 20px;display:flex}.post-related-meta{letter-spacing:.18em;color:var(--so-ink-4);gap:8px;font-family:Geist Mono,monospace;font-size:10px;display:flex}.post-related-meta>span:first-child{color:var(--so-orange)}.post-related-title{letter-spacing:-.015em;color:var(--so-ink-0);text-wrap:balance;-webkit-line-clamp:3;-webkit-box-orient:vertical;margin:0;font-family:Geist,sans-serif;font-size:16px;font-weight:700;line-height:1.3;transition:color .16s;display:-webkit-box;overflow:hidden}.post-related-link{letter-spacing:.18em;color:var(--so-ink-3);margin-top:auto;font-family:Geist Mono,monospace;font-size:11px;transition:color .16s}.post-404{text-align:center;padding:96px 0 120px}.post-404 .so-wrap{max-width:640px}.post-404-tag{letter-spacing:.22em;color:var(--so-orange);margin-bottom:18px;font-family:Geist Mono,monospace;font-size:11px}.post-404 h1{letter-spacing:-.025em;text-wrap:balance;margin:0 0 14px;font-size:clamp(28px,3.4vw,40px);font-weight:700}.post-404 h1 code{background:var(--so-bg-1);border:1px solid var(--so-line);color:var(--so-orange);padding:2px 8px;font-family:Geist Mono,monospace;font-size:.85em}.post-404 p{color:var(--so-ink-2);margin:0 0 28px;line-height:1.6}@media (max-width:640px){.post-byline{flex-wrap:wrap}.post-byline-share{width:100%}.post-back-bar{padding:10px 0}.post-figure,.post-quote,.post-code{margin-left:0;margin-right:0}}
