@import"https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@400;500;600;700&family=Hanken+Grotesk:wght@400;500;600;700;800&family=IBM+Plex+Mono:wght@400;500;600&display=swap";main{--paper: oklch(.987 .004 150);--paper-2: oklch(.965 .007 155);--paper-3: oklch(.945 .01 158);--card: oklch(1 0 0);--ink: oklch(.235 .022 168);--ink-soft: oklch(.435 .018 168);--ink-faint: oklch(.585 .014 168);--line: oklch(.235 .022 168 / .12);--line-2: oklch(.235 .022 168 / .07);--brand: oklch(.52 .108 166);--brand-deep: oklch(.41 .082 168);--brand-bright: oklch(.76 .15 152);--brand-tint: oklch(.52 .108 166 / .1);--brand-tint-2: oklch(.52 .108 166 / .05);--c-practice: oklch(.56 .09 166);--c-tutorial: oklch(.56 .09 248);--c-research: oklch(.56 .09 312);--c-product: oklch(.56 .09 64);--r-sm: 8px;--r-md: 14px;--r-lg: 18px;--r-xl: 24px;--shadow-1: 0 1px 2px oklch(.235 .022 168 / .05), 0 2px 8px oklch(.235 .022 168 / .04);--shadow-2: 0 2px 6px oklch(.235 .022 168 / .06), 0 14px 40px oklch(.235 .022 168 / .1);--shadow-3: 0 4px 12px oklch(.235 .022 168 / .08), 0 30px 70px oklch(.235 .022 168 / .16);--maxw: 1200px;--font-display: "Space Grotesk", system-ui, sans-serif;--font-ui: "Hanken Grotesk", system-ui, sans-serif;--font-mono: "IBM Plex Mono", ui-monospace, monospace}main{background:var(--paper);color:var(--ink);font-family:var(--font-ui);font-size:17px;line-height:1.6;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}*,*:before,*:after{box-sizing:border-box}.wrap{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 28px}@media(max-width:680px){.wrap{padding:0 20px}}.eyebrow{font-family:var(--font-mono);font-size:12px;font-weight:500;letter-spacing:.22em;text-transform:uppercase;color:var(--brand);display:inline-flex;align-items:center;gap:9px}.eyebrow:before{content:"";width:22px;height:1px;background:var(--brand);opacity:.6}.serif{font-family:var(--font-display)}.mono{font-family:var(--font-mono)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:9px;font-family:var(--font-ui);font-weight:500;text-decoration:none;border-radius:var(--r-md);padding:11px 20px;border:1px solid;font-size:14px;line-height:1;letter-spacing:.007em;transition:.18s;white-space:nowrap;color:var(--ink);border-color:var(--line);background:var(--paper)}.btn:hover{background:var(--paper-2);border-color:var(--ink-faint)}.btn-primary{background:#1a7f64;border-color:#1a7f64;color:#fff}.btn-primary:hover{background:#165a4b;border-color:#165a4b}.tag{display:inline-flex;align-items:center;gap:6px;font-family:var(--font-mono);font-size:11px;font-weight:500;letter-spacing:.06em;text-transform:uppercase;padding:5px 11px;border-radius:999px;border:1px solid;white-space:nowrap}.cat-practice{color:var(--c-practice);border-color:color-mix(in oklch,var(--c-practice) 30%,transparent);background:color-mix(in oklch,var(--c-practice) 9%,transparent)}.cat-tutorial{color:var(--c-tutorial);border-color:color-mix(in oklch,var(--c-tutorial) 30%,transparent);background:color-mix(in oklch,var(--c-tutorial) 9%,transparent)}.cat-research{color:var(--c-research);border-color:color-mix(in oklch,var(--c-research) 30%,transparent);background:color-mix(in oklch,var(--c-research) 9%,transparent)}.cat-product{color:var(--c-product);border-color:color-mix(in oklch,var(--c-product) 30%,transparent);background:color-mix(in oklch,var(--c-product) 9%,transparent)}.iconbtn{appearance:none;border:0;background:transparent;color:var(--ink-faint);border-radius:6px;padding:7px;cursor:pointer;transition:.18s;display:inline-flex;align-items:center;justify-content:center}.iconbtn:hover{color:var(--brand);background:var(--brand-tint-2)}.scan{position:relative;--bk:oklch(1 0 0 / .9)}.scan .cnr{position:absolute;width:26px;height:26px;z-index:3;pointer-events:none;border:0;opacity:1}.scan .cnr:before,.scan .cnr:after{content:"";position:absolute;background:var(--bk);border-radius:1px;box-shadow:0 0 0 1px #00000014}.scan .cnr:before{width:100%;height:3px}.scan .cnr:after{width:3px;height:100%}.scan .tl{top:14px;left:14px}.scan .tl:before{top:0;left:0}.scan .tl:after{top:0;left:0}.scan .tr{top:14px;right:14px}.scan .tr:before{top:0;right:0}.scan .tr:after{top:0;right:0}.scan .bl{bottom:14px;left:14px}.scan .bl:before{bottom:0;left:0}.scan .bl:after{bottom:0;left:0}.scan .br{bottom:14px;right:14px}.scan .br:before{bottom:0;right:0}.scan .br:after{bottom:0;right:0}.slot{position:relative;overflow:hidden;border-radius:var(--r-md);background:radial-gradient(135% 150% at 100% 0%,color-mix(in oklch,var(--cat,var(--brand)) 9%,transparent),transparent 60%),linear-gradient(155deg,var(--paper-2),var(--paper-3));display:grid;place-items:center;isolation:isolate}.slot:before{content:"";position:absolute;inset:0;z-index:0;opacity:.6;background-image:linear-gradient(color-mix(in oklch,var(--ink) 7%,transparent) 1px,transparent 1px),linear-gradient(90deg,color-mix(in oklch,var(--ink) 7%,transparent) 1px,transparent 1px);background-size:20px 20px;mask-image:radial-gradient(125% 100% at 72% 28%,#000,transparent 74%)}.slot:after{content:"";position:absolute;inset:0;z-index:1;pointer-events:none;box-shadow:inset 0 0 0 1px #ffffff0a,inset 0 -40px 60px -40px #0d191440}.slot .slot-label{position:relative;z-index:2;font-family:var(--font-mono);font-size:12px;color:var(--ink-soft);letter-spacing:.06em;text-align:center;padding:0 16px;display:flex;flex-direction:column;align-items:center;gap:8px}.slot .slot-label .ico{width:30px;height:30px;opacity:.6}.ico{width:14px;height:14px}.cat-practice{--cat:var(--c-practice)}.cat-tutorial{--cat:var(--c-tutorial)}.cat-research{--cat:var(--c-research)}.cat-product{--cat:var(--c-product)}.progress{position:fixed;top:0;left:0;right:0;height:3px;z-index:80;background:transparent}.progress span{display:block;height:100%;width:0;background:linear-gradient(90deg,var(--brand),var(--brand-bright));box-shadow:0 0 8px var(--brand-tint);transition:width .08s linear}.crumbs{display:flex;align-items:center;gap:10px;padding:26px 0 0;font-family:var(--font-mono);font-size:12.5px;color:var(--ink-faint);flex-wrap:wrap}.crumbs a{color:var(--ink-faint);transition:.15s}.crumbs a:hover{color:var(--brand)}.crumbs .cur{color:var(--ink-soft)}.art-head{max-width:840px;margin:22px auto 0;text-align:center}.art-head h1{font-family:var(--font-display);font-weight:500;font-size:clamp(34px,5.2vw,60px);line-height:1.05;letter-spacing:-.025em;margin:18px 0 0;color:var(--ink);text-wrap:balance}.art-dek{font-size:19px;color:var(--ink-soft);line-height:1.5;max-width:60ch;margin:18px auto 0;text-wrap:pretty}.art-byline{display:flex;align-items:center;justify-content:center;gap:18px;margin:28px 0 0;flex-wrap:wrap}.author{display:flex;align-items:center;gap:10px}.avatar{display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:50%;background:var(--brand);color:#fff;font-family:var(--font-mono);font-size:11px;font-weight:600;letter-spacing:.05em}img.avatar{object-fit:cover;object-position:center;background:transparent;display:block}.author-meta{display:flex;flex-direction:column;line-height:1.25;text-align:left}.author-meta b{font-size:14.5px;color:var(--ink)}.author-meta i{font-style:normal;font-family:var(--font-mono);font-size:11.5px;color:var(--ink-faint)}.byline-sep{width:1px;height:26px;background:var(--line)}.byline-facts{display:flex;align-items:center;gap:9px;font-size:12.5px;color:var(--ink-faint)}.dot:after{content:"·";margin:0 1px}.share{display:flex;gap:7px}.art-hero{height:clamp(280px,42vw,500px);margin:36px 0 0;border-radius:var(--r-xl);overflow:hidden;position:relative}.art-hero img{width:100%;height:100%;object-fit:cover;object-position:center;display:block}.hero-cap{text-align:center;font-size:12.5px;color:var(--ink-faint);margin:14px 0 0}.art-layout{display:grid;grid-template-columns:240px minmax(0,1fr);gap:56px;align-items:start;margin:54px auto 0;max-width:1080px}.toc-wrap{position:sticky;top:96px}.toc-title{font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-faint);margin:0 0 16px}.toc ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:2px}.toc a{display:flex;align-items:center;gap:11px;font-size:13.5px;color:var(--ink-faint);padding:6px 0;line-height:1.3;transition:.18s;text-decoration:none}.toc a .tline{width:14px;height:2px;background:currentColor;border-radius:2px;opacity:.4;transition:.2s;flex:none}.toc a:hover{color:var(--ink)}.toc a.active{color:var(--brand);font-weight:500}.toc a.active .tline{width:24px;opacity:1}.toc-foot{margin-top:22px;padding-top:18px;border-top:1px solid var(--line)}.toc .toc-cta{display:flex;align-items:center;justify-content:space-between;gap:8px;white-space:nowrap;color:var(--brand);font-size:12.5px;padding:11px 14px;border:1px solid var(--line);border-radius:10px;transition:.18s;text-decoration:none}.toc .toc-cta:hover{border-color:var(--brand);background:var(--brand-tint-2)}.prose{max-width:none}.prose>*{max-width:680px}.prose .lead{font-family:var(--font-display);font-size:22px;line-height:1.5;color:var(--ink);margin:0 0 26px;font-weight:400}.prose p{font-size:17.5px;line-height:1.72;color:var(--ink-soft);margin:0 0 22px}.prose strong{color:var(--ink);font-weight:600}.prose em{color:var(--brand);font-style:italic}.prose h2{font-family:var(--font-display);font-weight:500;font-size:30px;line-height:1.15;letter-spacing:-.02em;color:var(--ink);margin:48px 0 16px;scroll-margin-top:96px;padding-top:8px}.prose h2:before{content:"";display:block;width:34px;height:3px;border-radius:3px;background:var(--brand);margin-bottom:18px}.prose h3{font-family:var(--font-ui);font-weight:600;font-size:19px;color:var(--ink);margin:30px 0 12px;letter-spacing:-.01em}.prose h4{font-family:var(--font-ui);font-weight:600;font-size:15px;color:var(--ink);margin:0 0 12px}.prose ul.ticks{list-style:none;padding:0;margin:0 0 24px;display:flex;flex-direction:column;gap:11px}.prose ul.ticks li{position:relative;padding-left:30px;font-size:16.5px;line-height:1.55;color:var(--ink-soft)}.prose ul.ticks li:before{content:"";position:absolute;left:0;top:3px;width:18px;height:18px;border-radius:50%;background:var(--brand-tint)}.prose ul.ticks li:after{content:"";position:absolute;left:6px;top:8px;width:6px;height:3px;border-left:2px solid var(--brand);border-bottom:2px solid var(--brand);transform:rotate(-45deg)}.prose ul.ticks.sm li{font-size:15px;padding-left:26px}.prose ul.ticks.cross li:before{background:color-mix(in oklch,var(--c-product) 16%,transparent)}.prose ul.ticks.cross li:after{content:"×";border:0;left:5px;top:1px;width:auto;height:auto;transform:none;color:var(--c-product);font-weight:700;font-size:13px}.prose blockquote{margin:28px 0;padding:24px 28px;border-left:3px solid var(--brand);background:var(--brand-tint-2);border-radius:0 var(--r-md) var(--r-md) 0}.prose blockquote p{font-family:var(--font-display);font-size:20px;line-height:1.5;color:var(--ink);margin:0;font-style:italic}.callout{max-width:680px;margin:30px 0;padding:26px 28px;border-radius:var(--r-md);background:var(--brand-tint-2);border:1px solid color-mix(in oklch,var(--brand) 22%,transparent);position:relative}.callout.subtle{background:var(--paper-2);border-color:var(--line)}.callout-k{font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--brand);margin:0 0 10px}.callout p:last-child{margin:0;font-size:16.5px;line-height:1.6;color:var(--ink-soft)}.split{display:grid;grid-template-columns:1fr 1fr;gap:18px;max-width:680px;margin:8px 0 24px}.split-col{background:var(--card);border:1px solid var(--line);border-radius:var(--r-md);padding:22px;box-shadow:var(--shadow-1)}.prose .split-col ul{margin:0}.phases{list-style:none;counter-reset:none;padding:0;margin:8px 0 24px;max-width:680px;display:flex;flex-direction:column;gap:0}.phases li{display:flex;gap:20px;padding:22px 0;border-top:1px solid var(--line)}.phases li:last-child{border-bottom:1px solid var(--line)}.ph-n{font-size:14px;color:var(--brand);font-weight:600;padding-top:2px;min-width:24px}.phases b{font-size:16px;color:var(--ink);display:block;margin-bottom:5px}.phases p{margin:0;font-size:15.5px}.metrics{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;max-width:680px;margin:6px 0 26px}.metric{background:var(--card);border:1px solid var(--line);border-radius:var(--r-md);padding:20px 16px;text-align:center;box-shadow:var(--shadow-1)}.metric b{font-family:var(--font-display);font-weight:500;font-size:30px;color:var(--brand);display:block;line-height:1}.metric span{font-size:12px;color:var(--ink-faint);line-height:1.35;display:block;margin-top:8px}.art-tags{display:flex;align-items:center;gap:10px;flex-wrap:wrap;max-width:680px;margin:40px 0 0;padding-top:26px;border-top:1px solid var(--line)}.art-tags .mono{font-size:12px;color:var(--ink-faint);letter-spacing:.06em}.minitag{font-size:13px;color:var(--ink-soft);border:1px solid var(--line);border-radius:999px;padding:5px 13px;transition:.18s;text-decoration:none}.minitag:hover{color:var(--brand);border-color:var(--brand)}.art-cta{position:relative;margin:64px 0 0;background:linear-gradient(155deg,var(--ink),oklch(.3 .04 170));color:#edf4ee;border-radius:var(--r-xl);padding:48px 52px;display:flex;align-items:center;justify-content:space-between;gap:36px;flex-wrap:wrap;overflow:hidden}.art-cta.scan .cnr{--bk:var(--brand-bright)}.art-cta:after{content:"";position:absolute;inset:0;opacity:.14;background-image:linear-gradient(oklch(1 0 0/.5) 1px,transparent 1px),linear-gradient(90deg,oklch(1 0 0/.5) 1px,transparent 1px);background-size:26px 26px;mask-image:radial-gradient(70% 130% at 100% 0,#000,transparent 70%)}.art-cta>*{position:relative;z-index:2}.art-cta h2{font-weight:500;font-size:clamp(24px,2.6vw,32px);line-height:1.12;margin:12px 0;color:#fff;max-width:24ch}.art-cta p{color:#dae0dad1;font-size:16px;margin:0;max-width:42ch;line-height:1.5}.art-cta-actions{display:flex;flex-direction:column;gap:12px;align-items:flex-start}.btn.lg{padding:14px 24px;font-size:16px}.cta-sub{font-size:12px;color:#dae0da99}.section-head{margin:40px 0 22px}.section-title{font-family:var(--font-display);font-weight:500;font-size:clamp(26px,3.4vw,36px);letter-spacing:-.02em;line-height:1.12;margin:6px 0 0;color:var(--ink)}.grid{display:grid;gap:28px}.related-grid{grid-template-columns:repeat(3,1fr);margin-bottom:90px}.card{background:var(--card);border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;display:flex;flex-direction:column;box-shadow:var(--shadow-1);transition:transform .28s cubic-bezier(.2,.7,.3,1),box-shadow .28s,border-color .28s;text-decoration:none;color:inherit}.card:hover{transform:translateY(-4px);box-shadow:var(--shadow-2);border-color:color-mix(in oklch,var(--ink) 18%,transparent)}.card .slot{height:190px;border-radius:0}.card-media{position:relative;height:190px;overflow:hidden;background:var(--paper-2)}.card-media img{width:100%;height:100%;object-fit:cover;object-position:center;display:block;transition:transform .4s ease}.card:hover .card-media img{transform:scale(1.05)}.card-body{padding:20px 21px 22px;display:flex;flex-direction:column;gap:12px;flex:1}.card h3{font-family:var(--font-display);font-weight:500;font-size:21px;line-height:1.22;letter-spacing:-.01em;margin:0;color:var(--ink);transition:color .2s;text-wrap:balance}.card:hover h3{color:var(--brand)}.card p{margin:0;font-size:14.5px;color:var(--ink-soft);line-height:1.55}.card-meta{margin-top:auto;padding-top:14px;border-top:1px solid var(--line-2);display:flex;align-items:center;gap:10px;font-family:var(--font-mono);font-size:12px;color:var(--ink-faint);letter-spacing:.02em}.card-meta .dot{width:3px;height:3px;border-radius:50%;background:var(--ink-faint)}.card-arrow{margin-left:auto;color:var(--brand);transition:transform .2s}.card:hover .card-arrow{transform:translate(3px)}.tag{font-family:var(--font-mono);font-size:11px;font-weight:500;letter-spacing:.165em;text-transform:uppercase;display:inline-flex;align-items:center;gap:8px;padding:0;line-height:1;background:none;border:0;color:var(--ink-faint)}.tag:before{content:"";width:7px;height:7px;border-radius:50%;background:var(--cat, var(--brand));opacity:.9}.card-body .tag{margin:0}.toast{position:fixed;bottom:28px;left:50%;transform:translate(-50%,20px);background:var(--ink);color:var(--paper);font-family:var(--font-mono);font-size:13px;padding:12px 20px;border-radius:12px;box-shadow:var(--shadow-3);opacity:0;pointer-events:none;transition:.3s;z-index:90}.toast.show{opacity:1;transform:translate(-50%)}@media(max-width:920px){.art-layout{grid-template-columns:1fr;gap:0}.toc-wrap{display:none}.prose>*,.callout,.split,.phases,.metrics{max-width:100%}.related-grid{grid-template-columns:1fr}.art-cta{padding:36px 28px}}@media(max-width:768px){.art-head h1{font-size:clamp(28px,8vw,42px)!important;line-height:1.08!important}.art-dek{font-size:16px!important}.art-hero{height:clamp(200px,45vw,320px)!important;margin:24px 0 0!important}.crumbs{font-size:11.5px!important;padding:18px 0 0!important}.art-byline{gap:14px!important;margin-top:20px!important}.prose{padding:0!important}.prose .lead{font-size:18px!important;line-height:1.5!important}.prose p{font-size:16px!important;line-height:1.7!important}.prose h2{font-size:24px!important;margin:36px 0 14px!important}.prose h3{font-size:18px!important}.callout{padding:20px 22px!important;margin:24px 0!important}.split{grid-template-columns:1fr!important}.phases li{flex-direction:column;gap:8px!important;padding:18px 0!important}.art-cta{flex-direction:column!important;align-items:stretch!important;padding:32px 20px!important;gap:20px!important}.art-cta>div:first-child{text-align:center}.art-cta h2{font-size:clamp(22px,6vw,28px)!important;max-width:none!important}.art-cta p{max-width:none!important}.art-cta-actions{width:100%!important;align-items:center!important;gap:10px!important}.btn.lg{width:auto!important;justify-content:center!important;padding:11px 22px!important;font-size:13.5px!important}.btn.lg svg{width:14px!important;height:14px!important}.cta-sub{text-align:center;font-size:11.5px!important;line-height:1.5!important}.section-title{font-size:clamp(24px,6vw,32px)!important}}@media(max-width:560px){.split,.metrics{grid-template-columns:1fr 1fr}.byline-sep{display:none}.metrics{grid-template-columns:1fr}.art-cta{flex-direction:column;text-align:center;gap:24px}.wrap{padding:0 16px!important}.art-head{margin:14px auto 0!important}.art-tags{font-size:12px!important}.minitag{font-size:11.5px!important;padding:4px 10px!important}}
