.blog-root,.blog-root *,.blog-root :before,.blog-root :after{box-sizing:border-box;margin:0;padding:0}.blog-root{color:#fafafa;-webkit-font-smoothing:antialiased;overscroll-behavior-x:none;background:#000;width:100%;max-width:100vw;min-height:100vh;font-family:Inter,system-ui,-apple-system,sans-serif;line-height:1.5;overflow-x:hidden}.blog-root .article-body a,.blog-root .article-body code{word-break:break-word;overflow-wrap:break-word}.blog-root ::selection{color:#000;background:#fff}.blog-root a{color:inherit;text-decoration:none}.blog-root .site-header{z-index:50;-webkit-backdrop-filter:saturate(180%)blur(14px);background:#000000b8;border-bottom:1px solid #ffffff0f;position:sticky;top:0}.blog-root .nav{justify-content:space-between;align-items:center;padding:14px 32px;display:flex}.blog-root .nav-left{align-items:center;gap:40px;display:flex}.blog-root .nav-logo{color:#fafafa;letter-spacing:.075em;text-transform:uppercase;font-size:17px;font-weight:700;transition:opacity .2s}.blog-root .nav-logo:hover{opacity:.85}.blog-root .nav-links{align-items:center;gap:30px;display:flex}.blog-root .nav-links a{color:#c4c4c6;font-size:14px;transition:color .18s;position:relative}.blog-root .nav-links a:hover{color:#fafafa}.blog-root .nav-links a.active{color:#a3a3a3}.blog-root .nav-search{color:#c4c4c6;cursor:pointer;width:16px;height:16px;transition:color .18s}.blog-root .nav-search:hover{color:#fafafa}.blog-root .nav-right{align-items:center;gap:8px;display:flex}.blog-root .btn-pill{letter-spacing:.005em;cursor:pointer;border-radius:9999px;justify-content:center;align-items:center;gap:6px;height:38px;padding:0 20px;font-size:13.5px;font-weight:500;transition:background .2s,color .2s,transform .15s,box-shadow .2s;display:inline-flex}.blog-root .btn-pill svg{flex-shrink:0}.blog-root .btn-pill-dark{color:#fafafa;background:#1c1c1f;box-shadow:inset 0 1px #ffffff0a}.blog-root .btn-pill-dark:hover{background:#26262a}.blog-root .btn-pill-light{color:#0a0a0a;background:#fafafa;box-shadow:0 1px 2px #0003}.blog-root .btn-pill-light:hover{background:#fff;transform:translateY(-1px);box-shadow:0 4px 12px #ffffff14}.blog-root .btn-pill-light:active{transform:translateY(0)}.blog-root .page{max-width:1456px;margin:0 auto;padding:0 32px}.blog-root .page-header{padding:100px 0 0}.blog-root .page-header h1{letter-spacing:-.03em;color:#fafafa;font-size:56px;font-weight:500;line-height:1.05}.blog-root .filter-row{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:24px;margin-top:56px;padding-bottom:48px;display:flex}.blog-root .filter-tabs{flex-wrap:wrap;align-items:center;gap:22px;font-size:14px;display:flex}.blog-root .filter-tabs a{color:#8a8a8c;transition:color .15s}.blog-root .filter-tabs a:hover{color:#c4c4c6}.blog-root .filter-tabs a.active{color:#fafafa}.blog-root .filter-controls{color:#c4c4c6;align-items:center;gap:22px;font-size:14px;display:flex}.blog-root .filter-control-btn{cursor:pointer;align-items:center;gap:6px;padding:6px 0;display:inline-flex}.blog-root .filter-control-btn:hover{color:#fafafa}.blog-root .view-toggle{border-left:1px solid #2a2a2e;align-items:center;gap:4px;padding-left:18px;display:flex}.blog-root .view-toggle a{color:#525256;padding:6px;display:inline-flex}.blog-root .view-toggle a.active{color:#fafafa}.blog-root .view-toggle a:hover{color:#c4c4c6}.blog-root .grid{grid-template-columns:repeat(3,1fr);gap:144px 56px;display:grid}.blog-root .card{display:block}.blog-root .card .img{aspect-ratio:1;border-radius:8px;width:100%;transition:opacity .25s;overflow:hidden}.blog-root .card:hover .img{opacity:.92}.blog-root .card h2{color:#fafafa;letter-spacing:-.003em;margin-top:16px;font-size:17px;font-weight:400;line-height:1.4}.blog-root .card .meta{color:#8a8a8c;margin-top:10px;font-size:14px}.blog-root .card .meta .cat{color:#c4c4c6;margin-right:14px}.blog-root .blog-empty{text-align:center;color:#8a8a8c;padding:96px 0;font-size:15px}.blog-root .load-more-wrap{justify-content:center;padding:96px 0;display:flex}.blog-root .load-more{color:#fafafa;cursor:pointer;letter-spacing:.005em;background:#1f1f22;border:none;border-radius:9999px;justify-content:center;align-items:center;height:44px;padding:0 28px;font-family:inherit;font-size:14px;font-weight:500;transition:background .2s,transform .2s;display:inline-flex}.blog-root .load-more:hover{background:#2a2a2e;transform:translateY(-1px)}.blog-root .load-more:active{transform:translateY(0)}.blog-root .article-header{text-align:center;max-width:1024px;margin:0 auto;padding:80px 24px 56px}.blog-root .meta-eyebrow{color:#8a8a8c;text-transform:uppercase;letter-spacing:.24em;border:1px solid #ffffff1f;border-radius:999px;margin-bottom:36px;padding:6px 14px;font-size:12px;display:inline-block}.blog-root .article-header h1{letter-spacing:-.025em;color:#fafafa;max-width:960px;margin:0 auto;font-size:64px;font-weight:500;line-height:1.08}.blog-root .article-header .dek{color:#8a8a8c;max-width:540px;margin:28px auto 12px;font-size:18px;font-weight:400;line-height:1.55}.blog-root .article-header .date-bottom{color:#8a8a8c;margin-top:40px;font-size:13px}.blog-root .toolbar-wrap{max-width:1100px;margin:0 auto;padding:0 24px}.blog-root .toolbar{color:#c4c4c6;border-top:1px solid #1f1f22;justify-content:space-between;align-items:center;padding:18px 0;font-size:14px;display:flex}.blog-root .toolbar-actions{align-items:center;gap:18px;display:flex}.blog-root .toolbar-action{color:#c4c4c6;cursor:pointer;font:inherit;background:0 0;border:none;align-items:center;gap:8px;padding:0;transition:color .18s;display:inline-flex}.blog-root .toolbar-action:hover{color:#fafafa}.blog-root .toolbar-action svg{flex-shrink:0}.blog-root .toolbar-divider{background:#2a2a2e;width:1px;height:14px}.blog-root .toolbar-meta{color:#8a8a8c}.blog-root .article-body{max-width:792px;margin:56px auto 0;padding:0 24px}.blog-root .article-body p{color:#e2e2e4;letter-spacing:-.005em;margin-bottom:28px;font-size:21px;line-height:1.65}.blog-root .article-body strong{color:#fafafa;font-weight:600}.blog-root .article-body a{color:#fafafa;text-underline-offset:4px;-webkit-text-decoration:underline #525256;text-decoration:underline #525256;transition:text-decoration-color .2s}.blog-root .article-body a:hover{text-decoration-color:#fafafa}.blog-root .article-body h2{letter-spacing:-.02em;color:#fafafa;margin-top:72px;margin-bottom:24px;font-size:36px;font-weight:400;line-height:1.2}.blog-root .article-body h3{color:#fafafa;margin-top:48px;margin-bottom:12px;font-size:22px;font-weight:500;line-height:1.3}.blog-root .article-body ul,.blog-root .article-body ol{color:#e2e2e4;letter-spacing:-.005em;margin-bottom:28px;padding-left:0;font-size:21px;line-height:1.75;list-style:none}.blog-root .article-body ul li,.blog-root .article-body ol li{margin-bottom:10px;padding-left:20px;position:relative}.blog-root .article-body ul li:before{content:"";background:#525256;border-radius:50%;width:6px;height:6px;position:absolute;top:14px;left:0}.blog-root .article-body ol{counter-reset:ol-counter}.blog-root .article-body ol li{counter-increment:ol-counter}.blog-root .article-body ol li:before{content:counter(ol-counter) ".";color:#8a8a8c;font-feature-settings:"tnum";position:absolute;top:0;left:0}.blog-root .article-body img,.blog-root .article-body figure img{border-radius:0;width:100%;height:auto;margin:32px 0 8px;display:block}.blog-root .article-body figure{margin:32px 0}.blog-root .article-body img.full-bleed,.blog-root .article-body figure.full-bleed,.blog-root .article-body pre.full-bleed,.blog-root .article-body .embed.full-bleed{width:100vw;max-width:100vw;margin:56px 0;position:relative;left:50%;transform:translate(-50%)}.blog-root .article-body figure.full-bleed img{margin:0}.blog-root .article-body img.breakout,.blog-root .article-body figure.breakout,.blog-root .article-body pre.breakout,.blog-root .article-body .embed.breakout{width:max(100%,min(60vw,1280px));max-width:100vw;position:relative;left:50%;transform:translate(-50%)}.blog-root .article-body figure.breakout img{margin:0}.blog-root .article-body figcaption{color:#525256;text-align:center;letter-spacing:.02em;margin-top:14px;font-family:JetBrains Mono,SF Mono,Menlo,Consolas,monospace;font-size:12px;line-height:1.55}.blog-root .article-body figcaption .fig-label{color:#8a8a8c;margin-right:8px}.blog-root .article-body .image-grid-feature{grid-template-rows:1fr 1fr;grid-template-columns:2fr 1fr;gap:12px;width:max(100%,min(60vw,1280px));max-width:100vw;margin:32px 0;display:grid;position:relative;left:50%;transform:translate(-50%)}.blog-root .article-body .image-grid-feature>:first-child{grid-row:span 2}.blog-root .article-body .image-grid-feature img{object-fit:cover;border-radius:4px;width:100%;height:100%;margin:0;display:block}.blog-root .article-body table{border-collapse:collapse;color:#e2e2e4;width:100%;margin:32px 0;font-size:16px}.blog-root .article-body table th{text-align:left;color:#8a8a8c;letter-spacing:.16em;text-transform:uppercase;border-bottom:1px solid #ffffff1f;padding:14px 18px 14px 0;font-size:12px;font-weight:500}.blog-root .article-body table td{font-variant-numeric:tabular-nums;border:none;padding:18px 18px 18px 0}.blog-root .article-body table tbody tr:first-child td{padding-top:22px}.blog-root .article-body .callout{background:#ffffff09;border-radius:8px;align-items:flex-start;gap:14px;margin:32px 0;padding:24px 28px;display:flex}.blog-root .article-body .callout-icon{color:#fafafa;flex-shrink:0;width:22px;height:22px;margin-top:2px}.blog-root .article-body .callout-body .callout-label{letter-spacing:.22em;text-transform:uppercase;color:#fafafa;margin-bottom:4px;font-size:11px;font-weight:600;display:block}.blog-root .article-body .callout-body p{color:#e2e2e4;margin-bottom:8px;font-size:16px;line-height:1.6}.blog-root .article-body .callout-body p:last-child{margin-bottom:0}.blog-root .article-body .stat-hero{text-align:center;margin:48px 0;padding:24px 0}.blog-root .article-body .stat-hero .stat-num{letter-spacing:-.04em;color:#fafafa;font-feature-settings:"tnum";font-size:96px;font-weight:500;line-height:1}.blog-root .article-body .stat-hero .stat-label{color:#8a8a8c;letter-spacing:.2em;text-transform:uppercase;margin-top:16px;font-size:13px}.blog-root .article-body .code-block{width:max(100%,min(60vw,1280px));max-width:100vw;margin:32px 0;position:relative;left:50%;transform:translate(-50%)}.blog-root .article-body .code-block .code-filename{color:#8a8a8c;letter-spacing:.04em;border-bottom:1px solid #ffffff14;padding:0 4px 12px;font-family:JetBrains Mono,SF Mono,Menlo,Consolas,monospace;font-size:12px}.blog-root .article-body .code-block pre{border-top:none;width:100%;margin:0;padding:20px 4px 24px;left:auto;transform:none}.blog-root .article-body .embed{width:max(100%,min(60vw,1280px));max-width:100vw;margin:32px 0;position:relative;left:50%;transform:translate(-50%)}.blog-root .article-body .embed>iframe,.blog-root .article-body .embed>video{aspect-ratio:16/9;border:none;width:100%;display:block}.blog-root .article-body code{background:#ffffff0f;border-radius:4px;padding:2px 6px;font-family:SF Mono,Menlo,Consolas,monospace;font-size:.92em}.blog-root .article-body pre{background:0 0;border:1px solid #ffffff14;border-left:none;border-right:none;border-radius:0;margin:32px 0;padding:24px 4px;font-size:14.5px;line-height:1.7}.blog-root .article-body pre code{font-size:inherit;white-space:pre-wrap;word-wrap:break-word;overflow-wrap:anywhere;background:0 0;padding:0}.blog-root .article-body blockquote{color:#fafafa;text-align:center;border:none;margin:40px 0;padding:32px 0;font-family:"Source Serif 4",Georgia,serif;font-size:28px;font-style:italic;font-weight:400;line-height:1.4;position:relative}.blog-root .article-body blockquote:before{content:"“";color:#525256;margin-bottom:16px;font-family:"Source Serif 4",Georgia,serif;font-size:56px;font-style:normal;line-height:.8;display:block}.blog-root .article-body blockquote cite{color:#8a8a8c;margin-top:18px;font-family:Inter,system-ui,-apple-system,sans-serif;font-size:13px;font-style:normal;display:block}.blog-root .article-end{max-width:1100px;margin:80px auto 0;padding:0 24px}.blog-root .end-box{background:#18181b;border-radius:16px;padding:44px 48px}.blog-root .end-tags{flex-wrap:wrap;gap:8px;display:flex}.blog-root .end-tag{color:#fafafa;background:#27272a;border-radius:9999px;align-items:center;height:36px;padding:0 18px;font-size:14px;font-weight:500;transition:background .18s;display:inline-flex}.blog-root .end-tag:hover{background:#2f2f33}.blog-root .end-author{margin-top:36px}.blog-root .end-author-label{color:#8a8a8c;margin-bottom:8px;font-size:14px}.blog-root .end-author-name{color:#fafafa;letter-spacing:.075em;text-transform:uppercase;font-size:14px;font-weight:700}.blog-root .article-titlebar{opacity:0;pointer-events:none;border-top:1px solid #ffffff0f;justify-content:space-between;align-items:center;max-height:0;padding:0 32px;transition:max-height .25s,opacity .25s,padding .25s;display:flex;overflow:hidden}.blog-root .article-titlebar.visible{opacity:1;pointer-events:auto;max-height:48px;padding:12px 32px}.blog-root .article-titlebar-left{align-items:center;gap:14px;min-width:0;display:flex}.blog-root .article-titlebar-back{color:#c4c4c6;transition:color .18s;display:inline-flex}.blog-root .article-titlebar-back:hover{color:#fafafa}.blog-root .article-titlebar-title{color:#fafafa;white-space:nowrap;text-overflow:ellipsis;font-size:14px;font-weight:500;overflow:hidden}.blog-root .article-titlebar-up{color:#c4c4c6;cursor:pointer;background:0 0;border:none;padding:0;transition:color .18s}.blog-root .article-titlebar-up:hover{color:#fafafa}.blog-root .keep-reading{max-width:1100px;margin:96px auto 0;padding:0 24px}.blog-root .keep-reading-head{justify-content:space-between;align-items:baseline;margin-bottom:36px;display:flex}.blog-root .keep-reading-head h2{color:#fafafa;font-size:28px;font-weight:600}.blog-root .keep-reading-head a{color:#fafafa;font-size:15px}.blog-root .keep-reading-head a:hover{color:#a3a3a3}.blog-root .related-grid{grid-template-columns:repeat(3,1fr);gap:24px;display:grid}.blog-root .related-card{display:block}.blog-root .related-card .img{aspect-ratio:1;border-radius:8px;width:100%;overflow:hidden}.blog-root .related-card h3{color:#fafafa;margin-top:16px;font-size:18px;font-weight:500;line-height:1.35}.blog-root .related-card .meta{color:#8a8a8c;margin-top:8px;font-size:14px}.blog-root .related-card .meta .cat{color:#c4c4c6}.blog-root .related-card:hover .img{opacity:.9}.blog-root .page-end{padding-bottom:128px}.blog-root footer{border-top:1px solid #ffffff0f;margin-top:24px;padding:0}.blog-root .footer-container{max-width:1456px;margin:0 auto;padding:0 32px}.blog-root .footer-grid{grid-template-columns:1fr 1fr 1fr 1fr;gap:48px;padding:48px 0 32px;display:grid}.blog-root .footer-brand-name{color:#e7e6e4;letter-spacing:.075em;text-transform:uppercase;font-size:14px;font-weight:700}.blog-root .footer-newsletter{margin-top:18px}.blog-root .footer-newsletter-heading{color:#e7e6e4;margin-bottom:4px;font-size:13px;font-weight:500}.blog-root .footer-newsletter-caption{color:#78716c;margin-bottom:12px;font-size:12px;line-height:1.5}.blog-root .footer-newsletter-form{background:#ffffff0a;border:1px solid #ffffff14;border-radius:8px;align-items:stretch;max-width:280px;transition:border-color .2s,background .2s;display:flex;overflow:hidden}.blog-root .footer-newsletter-form:hover{background:#ffffff0f}.blog-root .footer-newsletter-form:focus-within{background:#ffffff0f;border-color:#ffffff2e}.blog-root .footer-newsletter-input{color:#e7e6e4;background:0 0;border:none;outline:none;flex:1;min-width:0;height:36px;padding:0 12px;font-family:inherit;font-size:13px}.blog-root .footer-newsletter-input::placeholder{color:#525256}.blog-root .footer-newsletter-submit{color:#78716c;cursor:pointer;background:0 0;border:none;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;transition:color .2s;display:inline-flex}.blog-root .footer-newsletter-submit:hover{color:#e7e6e4}.blog-root .footer-newsletter.subscribed .footer-newsletter-form{display:none}.blog-root .footer-newsletter-success{color:#4ade80;align-items:center;gap:6px;font-size:13px;display:none}.blog-root .footer-newsletter.subscribed .footer-newsletter-success{display:inline-flex}.blog-root .footer-heading{text-transform:uppercase;letter-spacing:.08em;color:#78716c;margin-bottom:16px;font-size:11px;font-weight:600}.blog-root .footer-col{flex-direction:column;gap:10px;display:flex}.blog-root .footer-col a{color:#a8a29e;font-size:13px;transition:color .2s}.blog-root .footer-col a:hover{color:#e7e6e4}.blog-root .footer-bottom{border-top:1px solid #ffffff0f;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;padding:20px 0;display:flex}.blog-root .footer-bottom span{color:#78716c;font-size:12px}.blog-root .footer-socials{align-items:center;gap:14px;display:flex}.blog-root .footer-social{color:#78716c;align-items:center;transition:color .2s;display:inline-flex}.blog-root .footer-social:hover{color:#e7e6e4}@media (max-width:1024px){.blog-root .grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:768px){.blog-root .nav-links{display:none}.blog-root .page{padding:0 20px}.blog-root .page-header h1{font-size:56px}.blog-root .filter-row{flex-direction:column;align-items:flex-start}.blog-root .grid{grid-template-columns:1fr;gap:40px}.blog-root .article-header{padding:56px 20px 40px}.blog-root .article-header h1{font-size:44px;line-height:1.1}.blog-root .article-header .dek,.blog-root .article-body p,.blog-root .article-body ul,.blog-root .article-body ol{font-size:18px}.blog-root .article-body h2{font-size:28px;line-height:1.2}.blog-root .article-body h3{font-size:20px;line-height:1.3}.blog-root .related-grid{grid-template-columns:1fr;gap:32px}.blog-root .footer-grid{grid-template-columns:1fr 1fr;gap:32px}.blog-root .footer-bottom{text-align:center;flex-direction:column}}
