@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap";@font-face{font-family:Mona Sans;src:url(/fonts/Mona-Sans.var.woff2) format("woff2");font-weight:200 900;font-style:normal;font-display:swap}:root{--color-white: #ffffff;--color-gray-50: #f9fafb;--color-gray-200: #e5e7eb;--color-gray-300: #d1d5db;--color-gray-400: #9ca3af;--color-gray-500: #6b7280;--color-gray-600: #4b5563;--color-gray-800: #1f2937;--color-gray-900: #111827;--color-sky-300: #7dd3fc;--color-sky-400: #38bdf8;--color-sky-500: #0ea5e9;--color-sky-600: #0284c7;--typography-body: var(--color-gray-600);--typography-headings: var(--color-gray-900);--typography-quotes: var(--color-gray-500);--typography-quotes-border: var(--color-gray-200);--typography-links: var(--color-sky-500);--typography-link-hover: var(--color-sky-600);--typography-link-underline: rgba(14, 165, 233, .4);--typography-link-hover-underline: rgba(2, 132, 199, .4);--typography-pre: var(--color-gray-300);--typography-pre-shadow: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -1px rgba(0, 0, 0, .06);--typography-bold: var(--color-gray-900);--typography-kbd: var(--color-gray-600);--typography-kbd-border: var(--color-gray-200);--typography-kbd-bg: var(--color-gray-50);--typography-code: var(--color-gray-900);--typography-hr: rgba(17, 24, 39, .05);--typography-th-borders: rgba(17, 24, 39, .2);--typography-td-borders: rgba(17, 24, 39, .05);--nav-bg: rgba(255, 255, 255, .9);--nav-border: rgba(24, 24, 27, .05);--nav-text: #27272a;--nav-active: #14b8a6;--bg-hover: #f4f4f5;--font-inter: "Inter", ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, "Noto Sans", sans-serif;--font-mona-sans: "Mona Sans", ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, "Noto Sans", sans-serif;--font-sans: var(--font-inter);--font-display: var(--font-mona-sans);--font-mono: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace}body{font-family:var(--font-sans);background-color:var(--color-white);color:var(--typography-body)}@media (prefers-color-scheme: dark){:root{--typography-body: var(--color-gray-300);--typography-headings: var(--color-white);--typography-quotes: var(--color-gray-400);--typography-quotes-border: var(--color-gray-800);--typography-links: var(--color-sky-400);--typography-link-hover: var(--color-white);--typography-link-underline: rgba(56, 189, 248, .4);--typography-link-hover-underline: rgba(255, 255, 255, .4);--typography-pre: var(--color-gray-400);--typography-pre-shadow: inset 0 0 0 1px rgba(255, 255, 255, .1);--typography-bold: var(--color-white);--typography-kbd: var(--color-white);--typography-kbd-border: var(--color-gray-800);--typography-kbd-bg: var(--color-gray-900);--typography-code: var(--color-white);--typography-hr: rgba(255, 255, 255, .1);--typography-th-borders: rgba(255, 255, 255, .1);--typography-td-borders: rgba(255, 255, 255, .05)}}body{background-color:var(--color-white);color:var(--typography-body)}@media (prefers-color-scheme: dark){body{background-color:var(--color-gray-900)}}.typography{color:var(--typography-body);font-size:.875rem;line-height:1.5rem}.typography h2{font-family:var(--font-display);color:var(--typography-headings);font-weight:600;font-size:1.25rem;line-height:2rem}.typography h3{color:var(--typography-headings);font-family:var(--font-display);font-weight:600;font-size:1rem;line-height:1.5rem;display:flex;align-items:center;-moz-column-gap:.75rem;column-gap:.75rem}.typography h3>svg{flex:none;width:1rem;height:1rem}.typography h4{color:var(--typography-headings);font-family:var(--font-display);font-weight:600;font-size:.875rem;line-height:1.5rem}.typography blockquote{border-left:3px solid var(--typography-quotes-border);padding-left:1.5rem;color:var(--typography-quotes)}.typography a:not(h2 a){font-weight:600;color:var(--typography-links);text-decoration:underline;text-decoration-color:var(--typography-link-underline);text-underline-offset:2px;transition-property:color,text-decoration-color;transition-duration:.15s;transition-timing-function:cubic-bezier(.4,0,.2,1)}.typography a:not(h2 a):hover{color:var(--typography-link-hover);text-decoration-color:var(--typography-link-hover-underline)}.typography strong{font-weight:600}.typography strong:not(a strong){color:var(--typography-bold)}.typography kbd{display:inline-block;border-radius:.25rem;background-color:var(--typography-kbd-bg);padding:0 .375rem;font-family:var(--font-mono);font-size:.75rem;font-weight:400;line-height:1.25rem;color:var(--typography-kbd);box-shadow:inset 0 0 0 1px var(--typography-kbd-border)}.typography code{font-family:var(--font-mono)}.typography code:not(a code,pre code){color:var(--typography-code)}.typography code:not(pre code){font-size:calc(12 / 14 * 1em);line-height:1;font-weight:700}.typography code:not(pre code):before{content:"`"}.typography code:not(pre code):after{content:"`"}.typography pre{display:flex;background-color:var(--color-gray-900);border-radius:.5rem;overflow-x:auto;box-shadow:var(--typography-pre-shadow)}.typography pre code{flex:none;padding:1.5rem;font-size:.8125rem;line-height:1.5rem;color:var(--typography-pre)}.typography hr{border-color:var(--typography-hr);border-top-width:1px}.typography ul,.typography ol{padding-left:1.375rem}.typography ul{list-style-type:disc}.typography ol{list-style-type:decimal}.typography li{padding-left:.625rem}.typography li::marker{color:var(--color-gray-400)}.typography ol>li::marker{font-size:.75rem;font-weight:600}.typography table{width:100%;text-align:left}.typography thead{border-bottom:1px solid var(--typography-th-borders)}.typography thead th{font-weight:600;padding-top:0;padding-bottom:calc(.5rem - 1px);color:var(--typography-headings)}.typography tbody tr{border-bottom:1px solid var(--typography-td-borders)}.typography tbody td{padding-top:calc(.5rem - 1px);padding-bottom:.5rem}.typography :is(th,td):first-child{padding-left:0;padding-right:.5rem}.typography :is(th,td):last-child{padding-left:.5rem;padding-right:0}.typography :is(th,td):not(:first-child,:last-child){padding-left:.5rem;padding-right:.5rem}.typography>*{margin-top:1.5rem}.typography :is(h2,h3,h4,blockquote,pre,table){margin-top:2rem}.typography hr{margin-top:calc(4rem - 1px)}.typography li{margin-top:1rem}.typography li>:is(p,ol,ul){margin-top:1rem}.typography :is(h2,h3,h4)+*{margin-top:1rem}.typography :is(blockquote,pre,table)+*{margin-top:2rem}.typography hr+*{margin-top:4rem}.typography>:first-child,.typography li>:first-child{margin-top:0}.page-header{max-width:42rem}.page-title{font-family:var(--font-display);font-size:1.875rem;font-weight:700;letter-spacing:-.025em;color:var(--typography-headings)}@media (min-width: 640px){.page-title{font-size:2.25rem}}.page-description{margin-top:1.5rem;font-size:1.125rem;line-height:1.75rem;color:var(--typography-body)}.nav-container{position:sticky;top:0;z-index:50;display:flex;flex-direction:column;pointer-events:none}.nav-wrapper{top:0;z-index:10;height:4rem;padding-top:1.5rem}.nav-inner{max-width:80rem;margin-left:auto;margin-right:auto;padding-left:1rem;padding-right:1rem}@media (min-width: 640px){.nav-inner{padding-left:1.5rem;padding-right:1.5rem}}@media (min-width: 1024px){.nav-inner{padding-left:2rem;padding-right:2rem}}.nav-flex{position:relative;display:flex;gap:1rem}.nav-center{display:flex;flex:1;justify-content:center}.nav-menu{pointer-events:auto}.nav-list{display:flex;border-radius:9999px;background-color:var(--nav-bg);padding-left:.75rem;padding-right:.75rem;font-size:.875rem;font-weight:500;color:var(--nav-text);box-shadow:0 10px 15px -3px #0000001a;border:1px solid var(--nav-border);backdrop-filter:blur(4px)}@media (prefers-color-scheme: dark){.nav-list{background-color:#27272ae6;border:1px solid rgba(255,255,255,.1);color:var(--color-gray-300)}}.nav-item{list-style:none}.nav-link{position:relative;display:block;padding:.5rem .75rem;transition:color .15s;color:var(--nav-text);text-decoration:none}@media (prefers-color-scheme: dark){.nav-link{color:var(--color-gray-300)}}.nav-link:hover,.nav-link-active{color:var(--nav-active)}.nav-indicator{position:absolute;left:.25rem;right:.25rem;bottom:-1px;height:1px;background:linear-gradient(to right,#14b8a600,#14b8a666,#14b8a600)}.article-list{margin-top:4rem}@media (min-width: 640px){.article-list{margin-top:5rem}}.article-item{display:grid;grid-template-columns:1fr;gap:1rem 2rem;align-items:baseline}@media (min-width: 640px){.article-item{grid-template-columns:12rem 1fr}}.article-date{flex:none;font-size:.875rem;color:var(--typography-quotes);font-family:var(--font-mono);letter-spacing:.025em}@media (min-width: 640px){.article-date{text-align:right}}.article-content{min-width:0}.article-link{display:block;position:relative;padding:1rem;margin:-1rem;border-radius:1rem;transition:background-color .15s;text-decoration:none}.article-link:hover{background-color:var(--bg-hover)}@media (prefers-color-scheme: dark){.article-link:hover{background-color:#ffffff0d}}.article-title{font-size:1.0625rem;font-weight:600;letter-spacing:-.025em;color:var(--typography-headings);transition:color .15s}.article-link:hover .article-title{color:var(--nav-active)}.article-summary{margin-top:.5rem;font-size:1rem;line-height:1.5rem;color:var(--typography-body)}.category-section{margin-bottom:4rem}.category-header{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:2rem}.category-title{font-size:1.25rem;font-weight:700;letter-spacing:-.025em;color:var(--typography-headings)}.category-count{font-size:.9375rem;color:var(--typography-quotes);font-family:var(--font-mono)}.category-list{list-style:none;padding:0;margin:0}.category-list-item{margin-top:1rem;padding-top:1rem;border-top:1px solid var(--typography-td-borders)}.category-list-item:first-child{margin-top:0;padding-top:0;border-top:none}.category-post-link{display:block;font-size:1.0625rem;font-weight:500;color:var(--typography-headings);text-decoration:none;transition:color .15s}.category-post-link:hover{color:var(--nav-active)}.footer{margin-top:8rem}.footer-inner{max-width:80rem;margin-left:auto;margin-right:auto;padding-left:1rem;padding-right:1rem}@media (min-width: 640px){.footer-inner{padding-left:1.5rem;padding-right:1.5rem}}@media (min-width: 1024px){.footer-inner{padding-left:2rem;padding-right:2rem}}.footer-content{border-top:1px solid var(--typography-td-borders);padding-top:2.5rem;padding-bottom:4rem}.footer-wrapper{max-width:42rem;margin-left:auto;margin-right:auto}.footer-flex{display:flex;flex-direction:column;align-items:center;justify-content:space-between;gap:1.5rem}@media (min-width: 768px){.footer-flex{flex-direction:row}}.footer-links{display:flex;flex-wrap:wrap;justify-content:center;gap:1.5rem 1rem;font-size:.875rem;font-weight:500;color:var(--nav-text)}@media (prefers-color-scheme: dark){.footer-links{color:var(--color-gray-300)}}.footer-link{color:inherit;text-decoration:none;transition:color .15s}.footer-link:hover{color:var(--nav-active)}.footer-copyright{font-size:.875rem;color:var(--typography-quotes)}.container{max-width:80rem;margin-left:auto;margin-right:auto;padding-left:1rem;padding-right:1rem;margin-top:4rem}@media (min-width: 640px){.container{padding-left:1.5rem;padding-right:1.5rem;margin-top:8rem}}@media (min-width: 1024px){.container{padding-left:2rem;padding-right:2rem}}.container-narrow{max-width:42rem;margin-left:auto;margin-right:auto}.space-y-8>*+*{margin-top:2rem}.flex-1{flex:1}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}
