@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-border-style:solid;--tw-outline-style:solid;--tw-ease:initial;--tw-duration:initial;--tw-scale-x:1;--tw-scale-y:1;--tw-scale-z:1}}}@layer theme{:root,:host{--font-sans:"Inter", system-ui, -apple-system, "Segoe UI", sans-serif;--font-mono:"JetBrains Mono", "Fira Code", ui-monospace, monospace;--spacing:.25rem;--ease-out:cubic-bezier(0, 0, .2, 1);--default-transition-duration:.15s;--default-transition-timing-function:cubic-bezier(.4, 0, .2, 1);--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono);--max-width-prose:680px;--color-nothing-white:#fff;--color-nothing-red:#d01b1b;--color-nothing-red-hover:#b01515;--color-nothing-green:#16a34a;--color-surface:#fff;--color-surface-secondary:#f7f7f7;--color-surface-tertiary:#efefef;--color-border:#e5e5e5;--color-text-primary:#000;--color-text-secondary:#6b6b6b;--color-text-tertiary:#999;--color-text-link:#000;--max-width-container:720px}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab,red,red)){::placeholder{color:color-mix(in oklab,currentcolor 50%,transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){appearance:button}::file-selector-button{appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer components;@layer utilities{.fixed{position:fixed}.static{position:static}.start{inset-inline-start:var(--spacing)}.end{inset-inline-end:var(--spacing)}.container{width:100%}@media(min-width:40rem){.container{max-width:40rem}}@media(min-width:48rem){.container{max-width:48rem}}@media(min-width:64rem){.container{max-width:64rem}}@media(min-width:80rem){.container{max-width:80rem}}@media(min-width:96rem){.container{max-width:96rem}}.mt-4{margin-top:calc(var(--spacing) * 4)}.grid{display:grid}.inline{display:inline}.table{display:table}.rounded{border-radius:.25rem}.border{border-style:var(--tw-border-style);border-width:1px}.outline{outline-style:var(--tw-outline-style);outline-width:1px}.transition-none{transition-property:none}.ease-out{--tw-ease:var(--ease-out);transition-timing-function:var(--ease-out)}}@view-transition{navigation:auto}html.dark{--color-surface:#0a0a0a;--color-surface-secondary:#141414;--color-surface-tertiary:#1e1e1e;--color-border:#2a2a2a;--color-border-subtle:#1a1a1a;--color-text-primary:#fff;--color-text-secondary:#a0a0a0;--color-text-tertiary:#666;--color-text-link:#fff;--color-dot:#ffffff0f}.dot-matrix{background-image:url("data:image/svg+xml,%3Csvg width='20' height='20' xmlns='http://www.w3.org/2000/svg'%3E%3Ccircle cx='10' cy='10' r='1.5' fill='%23000' fill-opacity='0.08'/%3E%3C/svg%3E");background-repeat:repeat;background-size:20px 20px}html.dark .dot-matrix{background-image:url("data:image/svg+xml,%3Csvg width='20' height='20' xmlns='http://www.w3.org/2000/svg'%3E%3Ccircle cx='10' cy='10' r='1.5' fill='%23fff' fill-opacity='0.06'/%3E%3C/svg%3E")}.dot-matrix--dense{background-image:url("data:image/svg+xml,%3Csvg width='12' height='12' xmlns='http://www.w3.org/2000/svg'%3E%3Ccircle cx='6' cy='6' r='1' fill='%23000' fill-opacity='0.06'/%3E%3C/svg%3E");background-repeat:repeat;background-size:12px 12px}html.dark .dot-matrix--dense{background-image:url("data:image/svg+xml,%3Csvg width='12' height='12' xmlns='http://www.w3.org/2000/svg'%3E%3Ccircle cx='6' cy='6' r='1' fill='%23fff' fill-opacity='0.05'/%3E%3C/svg%3E")}html{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration));--tw-duration:.3s;transition-duration:.3s}html.transition-none{transition-property:none!important}body{min-height:100dvh;font-family:var(--font-sans);color:var(--color-text-primary);background:var(--color-surface);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;margin:0;padding:0}.nt-body{max-width:var(--max-width-container);flex-direction:column;margin:0 auto;padding:0 1rem;display:flex}@media(min-width:640px){.nt-body{padding:0 1.5rem}}@media(min-width:1024px){.nt-body{padding:0 2rem}}main{flex:1;padding:2rem 0 4rem}svg{width:18px;height:18px;transition:all .2s}a{color:var(--color-text-link);border-bottom:1px solid #0000;text-decoration:none;transition:border-color .2s,color .2s}a:active{transform:scale(.97)}time{font-family:var(--font-mono);color:var(--color-text-tertiary);font-size:.875rem}.nt-btn{color:var(--color-text-primary);cursor:pointer;background:0 0;border:none;border-radius:8px;align-items:center;gap:.25rem;padding:.5rem .75rem;font-size:.875rem;font-weight:500;line-height:1;text-decoration:none;transition:all .2s;display:inline-flex}.nt-btn:hover{background:var(--color-surface-tertiary)}.nt-btn:active{transform:scale(.96)}.nt-btn svg{flex-shrink:0;width:18px;height:18px}.nt-btn__label{display:none}@media(min-width:768px){.nt-btn__label{display:inline}}.nt-btn--outline{border:1px solid var(--color-border)}.nt-btn--outline:hover{color:var(--color-nothing-red);border-color:var(--color-nothing-red);background:0 0}.nt-btn--red{color:var(--color-nothing-white);background:var(--color-nothing-red)}.nt-btn--red:hover{background:var(--color-nothing-red-hover)}.article-content{max-width:var(--max-width-prose);color:var(--color-text-primary);letter-spacing:-.01em;font-size:1.125rem;font-weight:400;line-height:1.8}.article-content>*+*{margin-top:1.5rem}.article-content h1{letter-spacing:-.03em;margin-top:3rem;margin-bottom:1rem;font-size:2.25rem;font-weight:700;line-height:1.2}.article-content h2{letter-spacing:-.025em;border-bottom:1px solid var(--color-border);margin-top:2.5rem;margin-bottom:.75rem;padding-bottom:.5rem;font-size:1.875rem;font-weight:700;line-height:1.3}.article-content h3{letter-spacing:-.02em;margin-top:2rem;margin-bottom:.5rem;font-size:1.5rem;font-weight:600;line-height:1.4}.article-content h4,.article-content h5,.article-content h6{letter-spacing:-.015em;margin-top:1.5rem;margin-bottom:.5rem;font-size:1.25rem;font-weight:600}.article-content p{margin-bottom:1.5rem}.article-content a{color:var(--color-nothing-red);border-bottom:1px solid #0000;font-weight:500;text-decoration:none;transition:border-color .2s}.article-content a:hover{border-bottom-color:var(--color-nothing-red)}.article-content blockquote{color:var(--color-text-secondary);border-left:3px solid var(--color-nothing-red);margin:1.5rem 0;padding-left:1rem;font-style:normal}.article-content ul,.article-content ol{margin-bottom:1.5rem;padding-left:1.5rem}.article-content ul{list-style-type:disc}.article-content ol{list-style-type:decimal}.article-content li{margin-bottom:.5rem}.article-content li>ul,.article-content li>ol{margin-top:.25rem;margin-bottom:.25rem}.article-content table{border-collapse:collapse;width:100%;margin:1.5rem 0;font-size:.875rem}.article-content th,.article-content td{text-align:left;border:1px solid var(--color-border);padding:.5rem .75rem}.article-content th{background:var(--color-surface-secondary);font-weight:600}.article-content code{font-family:var(--font-mono);background:var(--color-surface-secondary);border:1px solid var(--color-border);border-radius:4px;padding:.15em .4em;font-size:.875em}.article-content pre{border-radius:8px;margin:2rem 0;overflow:hidden}.article-content pre code{background:0 0;border:none;border-radius:0;padding:0}.article-content img{border-radius:8px;margin:1.5rem 0}.article-content hr{border:none;border-top:1px solid var(--color-border);margin:2.5rem 0}.article-content strong{font-weight:700}.article-content em{font-style:italic}.article-content mark{color:var(--color-nothing-white);background:var(--color-nothing-red);border-radius:3px;padding:.1em .3em}.article-content kbd{font-family:var(--font-mono);background:var(--color-surface-tertiary);border:1px solid var(--color-border);border-radius:4px;padding:.15em .4em;font-size:.875em}.article-content abbr[title]{-webkit-text-decoration:underline dotted var(--color-text-tertiary);text-decoration:underline dotted var(--color-text-tertiary);cursor:help}.introduction a{color:var(--color-nothing-red)}.introduction a:hover{border-bottom-color:var(--color-nothing-red)}.site-header{z-index:50;background:var(--color-surface);position:sticky;top:0}.site-header__inner{max-width:var(--max-width-container);justify-content:space-between;align-items:center;margin-inline:auto;padding-block:.75rem;display:flex}.site-header__stripe{height:2px}.logo-wrapper{align-items:center;gap:.75rem;display:flex}.logo-wrapper h1{margin:0}.logo-wrapper__icon{border-radius:8px;width:32px;height:32px}.logo-wrapper__title{color:var(--color-text-primary);letter-spacing:-.025em;margin:0;font-size:1rem;font-weight:700;line-height:1.3}.logo-wrapper__description{color:var(--color-text-secondary);margin:0;font-size:.875rem;line-height:1.4}.actions-wrapper{align-items:center;display:flex}.introduction{padding:3rem 0}.introduction__inner{border:1px solid var(--color-border);background:#fff9;border-radius:12px;padding:2rem}html.dark .introduction__inner{background:#0a0a0a99}.introduction p{color:var(--color-text-primary);margin-bottom:1rem;font-size:1.125rem;line-height:1.8}.introduction p:last-child{margin-bottom:0}.blog-section h2{color:var(--color-text-tertiary);text-transform:uppercase;letter-spacing:.1em;margin-bottom:1rem;font-size:.75rem;font-weight:600}.blog-section ul{margin:0;padding:0;list-style:none}.blog-section__item{color:var(--color-text-primary);border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:center;padding:1rem 0;text-decoration:none;transition:all .2s;display:flex}.blog-section__item:hover{border-bottom-color:var(--color-nothing-red);padding-left:.75rem}.blog-section__item:last-child{border-bottom:none}.blog-section__item-title{color:var(--color-text-primary);letter-spacing:-.01em;margin:0 0 .25rem;font-size:1rem;font-weight:600}.blog-section__item-date{font-family:var(--font-mono);color:var(--color-text-tertiary);font-size:.875rem;display:block}.blog-section__item-arrow{width:18px;height:18px;color:var(--color-text-tertiary);opacity:0;flex-shrink:0;margin-left:1rem;transition:all .2s;transform:translate(-8px)}.blog-section__item:hover .blog-section__item-arrow{color:var(--color-nothing-red);opacity:1;transform:translate(0)}.post-page__title{letter-spacing:-.03em;margin-top:2rem;margin-bottom:.75rem;font-size:2.25rem;font-weight:700;line-height:1.2}@media(min-width:768px){.post-page__title{font-size:2.75rem}}.post-page__meta{flex-wrap:wrap;align-items:center;gap:.75rem;margin-bottom:1rem;display:flex}.post-page__meta-label{color:var(--color-text-tertiary);text-transform:uppercase;letter-spacing:.05em;font-size:.75rem;font-weight:500}.post-page__divider{border:none;border-top:1px solid var(--color-border);margin:1.5rem 0}.hero-image{border-radius:12px;margin-bottom:1.5rem}.site-footer{margin-top:auto}.site-footer__stripe{height:2px}.site-footer__inner{padding:1.5rem 0}.site-footer__copy{color:var(--color-text-tertiary);margin:0;font-size:.875rem}#theme-icon-sun{--tw-scale-x:100%;--tw-scale-y:100%;--tw-scale-z:100%;scale:var(--tw-scale-x) var(--tw-scale-y);rotate:0deg}#theme-icon-moon,#theme-icon-monitor{--tw-scale-x:0%;--tw-scale-y:0%;--tw-scale-z:0%;scale:var(--tw-scale-x) var(--tw-scale-y);position:absolute;rotate:90deg}[data-theme=light] #theme-icon-sun{--tw-scale-x:100%;--tw-scale-y:100%;--tw-scale-z:100%;scale:var(--tw-scale-x) var(--tw-scale-y);rotate:0deg}[data-theme=light] #theme-icon-moon,[data-theme=light] #theme-icon-monitor{--tw-scale-x:0%;--tw-scale-y:0%;--tw-scale-z:0%;scale:var(--tw-scale-x) var(--tw-scale-y);rotate:90deg}[data-theme=dark] #theme-icon-sun{--tw-scale-x:0%;--tw-scale-y:0%;--tw-scale-z:0%;scale:var(--tw-scale-x) var(--tw-scale-y);rotate:-90deg}[data-theme=dark] #theme-icon-moon{--tw-scale-x:100%;--tw-scale-y:100%;--tw-scale-z:100%;scale:var(--tw-scale-x) var(--tw-scale-y);rotate:0deg}[data-theme=dark] #theme-icon-monitor{--tw-scale-x:0%;--tw-scale-y:0%;--tw-scale-z:0%;scale:var(--tw-scale-x) var(--tw-scale-y);rotate:90deg}[data-theme=system] #theme-icon-sun{--tw-scale-x:0%;--tw-scale-y:0%;--tw-scale-z:0%;scale:var(--tw-scale-x) var(--tw-scale-y);rotate:-90deg}[data-theme=system] #theme-icon-moon{--tw-scale-x:0%;--tw-scale-y:0%;--tw-scale-z:0%;scale:var(--tw-scale-x) var(--tw-scale-y);rotate:90deg}[data-theme=system] #theme-icon-monitor{--tw-scale-x:100%;--tw-scale-y:100%;--tw-scale-z:100%;scale:var(--tw-scale-x) var(--tw-scale-y);rotate:0deg}#copy-button[data-state=success]{color:var(--color-nothing-green);border-color:var(--color-nothing-green)}#copy-button[data-state=error]{color:var(--color-nothing-red);border-color:var(--color-nothing-red)}#copy-icon--default{--tw-scale-x:100%;--tw-scale-y:100%;--tw-scale-z:100%;scale:var(--tw-scale-x) var(--tw-scale-y);rotate:0deg}#copy-icon--success,#copy-icon--error{--tw-scale-x:0%;--tw-scale-y:0%;--tw-scale-z:0%;scale:var(--tw-scale-x) var(--tw-scale-y);position:absolute;rotate:90deg}#copy-text{transition:color .2s}#copy-button[data-state=default] #copy-icon--default{--tw-scale-x:100%;--tw-scale-y:100%;--tw-scale-z:100%;scale:var(--tw-scale-x) var(--tw-scale-y);rotate:0deg}#copy-button[data-state=default] #copy-icon--success,#copy-button[data-state=default] #copy-icon--error{--tw-scale-x:0%;--tw-scale-y:0%;--tw-scale-z:0%;scale:var(--tw-scale-x) var(--tw-scale-y);rotate:90deg}#copy-button[data-state=success] #copy-icon--success{--tw-scale-x:100%;--tw-scale-y:100%;--tw-scale-z:100%;scale:var(--tw-scale-x) var(--tw-scale-y);rotate:0deg}#copy-button[data-state=success] #copy-icon--default,#copy-button[data-state=success] #copy-icon--error{--tw-scale-x:0%;--tw-scale-y:0%;--tw-scale-z:0%;scale:var(--tw-scale-x) var(--tw-scale-y);rotate:90deg}#copy-button[data-state=error] #copy-icon--error{--tw-scale-x:100%;--tw-scale-y:100%;--tw-scale-z:100%;scale:var(--tw-scale-x) var(--tw-scale-y);rotate:0deg}#copy-button[data-state=error] #copy-icon--default,#copy-button[data-state=error] #copy-icon--success{--tw-scale-x:0%;--tw-scale-y:0%;--tw-scale-z:0%;scale:var(--tw-scale-x) var(--tw-scale-y);rotate:90deg}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-outline-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-ease{syntax:"*";inherits:false}@property --tw-duration{syntax:"*";inherits:false}@property --tw-scale-x{syntax:"*";inherits:false;initial-value:1}@property --tw-scale-y{syntax:"*";inherits:false;initial-value:1}@property --tw-scale-z{syntax:"*";inherits:false;initial-value:1}@keyframes astroFadeInOut{0%{opacity:1}to{opacity:0}}@keyframes astroFadeIn{0%{opacity:0;mix-blend-mode:plus-lighter}to{opacity:1;mix-blend-mode:plus-lighter}}@keyframes astroFadeOut{0%{opacity:1;mix-blend-mode:plus-lighter}to{opacity:0;mix-blend-mode:plus-lighter}}@keyframes astroSlideFromRight{0%{transform:translate(100%)}}@keyframes astroSlideFromLeft{0%{transform:translate(-100%)}}@keyframes astroSlideToRight{to{transform:translate(100%)}}@keyframes astroSlideToLeft{to{transform:translate(-100%)}}@media(prefers-reduced-motion){::view-transition-group(*),::view-transition-old(*),::view-transition-new(*){animation:none!important}[data-astro-transition-scope]{animation:none!important}}
