@font-face{font-family:RobotoMono;src:url(/fonts/code/RobotoMono-Bold.ttf) format("truetype");font-weight:700}@font-face{font-family:RobotoMono;src:url(/fonts/code/RobotoMono-BoldItalic.ttf) format("truetype");font-weight:700;font-style:italic}@font-face{font-family:RobotoMono;src:url(/fonts/code/RobotoMono-ExtraLight.ttf) format("truetype");font-weight:200}@font-face{font-family:RobotoMono;src:url(/fonts/code/RobotoMono-ExtraLightItalic.ttf) format("truetype");font-weight:200;font-style:italic}@font-face{font-family:RobotoMono;src:url(/fonts/code/RobotoMono-Italic.ttf) format("truetype");font-style:italic}@font-face{font-family:RobotoMono;src:url(/fonts/code/RobotoMono-Light.ttf) format("truetype");font-weight:300}@font-face{font-family:RobotoMono;src:url(/fonts/code/RobotoMono-LightItalic.ttf) format("truetype");font-weight:300;font-style:italic}@font-face{font-family:RobotoMono;src:url(/fonts/code/RobotoMono-Medium.ttf) format("truetype");font-weight:500}@font-face{font-family:RobotoMono;src:url(/fonts/code/RobotoMono-MediumItalic.ttf) format("truetype");font-weight:500;font-style:italic}@font-face{font-family:RobotoMono;src:url(/fonts/code/RobotoMono-Regular.ttf) format("truetype");font-weight:400}@font-face{font-family:Pretendard;src:local("Pretendard Black"),url(/fonts/pretendard/Pretendard-Black.woff2) format("woff2"),url(/fonts/pretendard/Pretendard-Black.woff) format("woff");font-weight:900}@font-face{font-family:Pretendard;font-weight:800;font-display:swap;src:local("Pretendard ExtraBold"),url(/fonts/pretendard/Pretendard-ExtraBold.woff2) format("woff2"),url(/fonts/pretendard/Pretendard-ExtraBold.woff) format("woff")}@font-face{font-family:Pretendard;font-weight:700;font-display:swap;src:local("Pretendard Bold"),url(/fonts/pretendard/Pretendard-Bold.woff2) format("woff2"),url(/fonts/pretendard/Pretendard-Bold.woff) format("woff")}@font-face{font-family:Pretendard;font-weight:600;font-display:swap;src:local("Pretendard SemiBold"),url(/fonts/pretendard/Pretendard-SemiBold.woff2) format("woff2"),url(/fonts/pretendard/Pretendard-SemiBold.woff) format("woff")}@font-face{font-family:Pretendard;font-weight:500;font-display:swap;src:local("Pretendard Medium"),url(/fonts/pretendard/Pretendard-Medium.woff2) format("woff2"),url(/fonts/pretendard/Pretendard-Medium.woff) format("woff")}@font-face{font-family:Pretendard;font-weight:400;font-display:swap;src:local("Pretendard Regular"),url(/fonts/pretendard/Pretendard-Regular.woff2) format("woff2"),url(/fonts/pretendard/Pretendard-Regular.woff) format("woff")}@font-face{font-family:Pretendard;font-weight:300;font-display:swap;src:local("Pretendard Light"),url(/fonts/pretendard/Pretendard-Light.woff2) format("woff2"),url(/fonts/pretendard/Pretendard-Light.woff) format("woff")}@font-face{font-family:Pretendard;font-weight:200;font-display:swap;src:local("Pretendard ExtraLight"),url(/fonts/pretendard/Pretendard-ExtraLight.woff2) format("woff2"),url(/fonts/pretendard/Pretendard-ExtraLight.woff) format("woff")}@font-face{font-family:Pretendard;font-weight:100;font-display:swap;src:local("Pretendard Thin"),url(/fonts/pretendard/Pretendard-Thin.woff2) format("woff2"),url(/fonts/pretendard/Pretendard-Thin.woff) format("woff")}.robotoMono,.robotoMono *{font-family:RobotoMono,sans-serif}.pretendard *{font-family:Pretendard,sans-serif}body *{font-family:Pretendard,monospace}

/*! tailwindcss v4.1.7 | MIT License | https://tailwindcss.com */@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,::backdrop,:after,:before{--tw-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-border-style:solid;--tw-leading:initial;--tw-font-weight:initial;--tw-duration:initial;--tw-ease:initial;--tw-scale-x:1;--tw-scale-y:1;--tw-scale-z:1}}}@layer theme{:host,:root{--font-sans:ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji";--font-mono:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace;--color-violet-800:oklch(43.2% .232 292.759);--color-gray-200:oklch(92.8% .006 264.531);--color-gray-400:oklch(70.7% .022 261.325);--color-gray-800:oklch(27.8% .033 256.848);--color-black:#000;--color-white:#fff;--font-weight-bold:700;--radius-xl:.75rem;--ease-in-out:cubic-bezier(.4,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);--spacing-0:0px;--spacing-1:1px;--spacing-4:4px;--spacing-8:8px;--spacing-10:10px;--spacing-16:16px;--spacing-25:25px;--spacing-32:32px;--spacing-40:40px;--spacing-88:88px;--nav-height:64px;--layout-padding:32px;--sidebar-width:272px;--sidebar-bg-color:#f9fbfa;--sidebar-border-default:#e1e2e4;--sidebar-border-active:#7d7d7d}}@layer base{*,::backdrop,:after,:before{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}:host,html{-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,pre,samp{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}menu,ol,ul{list-style:none}audio,canvas,embed,iframe,img,object,svg,video{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,optgroup,select,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,::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-day-field,::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-hour-field,::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-millisecond-field,::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}:-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,::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer components;@layer utilities{.pointer-events-none{pointer-events:none}.absolute{position:absolute}.fixed{position:fixed}.relative{position:relative}.sticky{position:sticky}.inset-0{inset:var(--spacing-0)}.top-0{top:var(--spacing-0)}.top-40{top:var(--spacing-40)}.top-\[100px\]{top:100px}.top-\[var\(--nav-height\)\]{top:var(--nav-height)}.right-25{right:var(--spacing-25)}.left-0{left:var(--spacing-0)}.z-10{z-index:10}.z-50{z-index:50}.container{width:100%}@media (min-width:1027px){.container{max-width:1027px}}@media (min-width:1309px){.container{max-width:1309px}}@media (min-width:40rem){.container{max-width:40rem}}@media (min-width:80rem){.container{max-width:80rem}}@media (min-width:96rem){.container{max-width:96rem}}.m-88{margin:var(--spacing-88)}.my-\[8px\]{margin-block:8px}.mt-\[2px\]{margin-top:2px}.mt-\[4px\]{margin-top:4px}.mr-4{margin-right:var(--spacing-4)}.mb-10{margin-bottom:var(--spacing-10)}.mb-\[20px\]{margin-bottom:20px}.line-clamp-4{-webkit-line-clamp:4;-webkit-box-orient:vertical;display:-webkit-box;overflow:hidden}.block{display:block}.contents{display:contents}.flex{display:flex}.hidden{display:none}.inline{display:inline}.h-25{height:var(--spacing-25)}.h-\[40px\]{height:40px}.h-\[120px\]{height:120px}.h-fit{height:fit-content}.h-full{height:100%}.max-h-0{max-height:var(--spacing-0)}.max-h-\[50dvh\]{max-height:50dvh}.w-1{width:var(--spacing-1)}.w-25{width:var(--spacing-25)}.w-\[40px\]{width:40px}.w-\[200px\]{width:200px}.w-\[250px\]{width:250px}.w-full{width:100%}.flex-1{flex:1}.shrink-0{flex-shrink:0}.scale-\[1\.02\]{scale:1.02}.rotate-90{rotate:90deg}.transform{transform:var(--tw-rotate-x,)var(--tw-rotate-y,)var(--tw-rotate-z,)var(--tw-skew-x,)var(--tw-skew-y,)}.cursor-pointer{cursor:pointer}.resize{resize:both}.list-none{list-style-type:none}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-4{gap:var(--spacing-4)}.gap-8{gap:var(--spacing-8)}.gap-32{gap:var(--spacing-32)}.gap-\[4px\]{gap:4px}.gap-\[8px\]{gap:8px}.overflow-auto{overflow:auto}.rounded-\[4px\]{border-radius:4px}.rounded-\[12px\]{border-radius:12px}.rounded-b-xl{border-bottom-right-radius:var(--radius-xl);border-bottom-left-radius:var(--radius-xl)}.border{border-style:var(--tw-border-style);border-width:1px}.border-b{border-bottom-style:var(--tw-border-style);border-bottom-width:1px}.border-\[\#d0d5dd\]{border-color:#d0d5dd}.bg-\[rgba\(0\,0\,0\,0\.7\)\]{background-color:#000000b3}.bg-black{background-color:var(--color-black)}.bg-violet-800{background-color:var(--color-violet-800)}.object-cover{object-fit:cover}.p-4{padding:var(--spacing-4)}.p-\[16px\]{padding:16px}.px-4{padding-inline:var(--spacing-4)}.px-40{padding-inline:var(--spacing-40)}.py-8{padding-block:var(--spacing-8)}.py-10{padding-block:var(--spacing-10)}.py-16{padding-block:var(--spacing-16)}.pb-10{padding-bottom:var(--spacing-10)}.pb-\[12px\]{padding-bottom:12px}.pl-16{padding-left:var(--spacing-16)}.pl-\[var\(--layout-padding\)\]{padding-left:var(--layout-padding)}.text-center{text-align:center}.text-\[1\.4rem\]{font-size:1.4rem}.text-\[13px\]{font-size:13px}.text-\[14px\]{font-size:14px}.text-\[18px\]{font-size:18px}.text-\[22px\]{font-size:22px}.text-\[24px\]{font-size:24px}.leading-\[1\.4\]{--tw-leading:1.4;line-height:1.4}.leading-\[40px\]{--tw-leading:40px;line-height:40px}.font-bold{--tw-font-weight:var(--font-weight-bold);font-weight:var(--font-weight-bold)}.text-\[\#6b7280\]{color:#6b7280}.text-\[\#2964aa\]{color:#2964aa}.text-gray-800{color:var(--color-gray-800)}.text-white{color:var(--color-white)}.italic{font-style:italic}.underline{text-decoration-line:underline}.opacity-0{opacity:0}.opacity-90{opacity:.9}.opacity-100{opacity:1}.transition{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to,opacity,box-shadow,transform,translate,scale,rotate,filter,-webkit-backdrop-filter,backdrop-filter,display,visibility,content-visibility,overlay,pointer-events;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-all{transition-property:all;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-colors{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))}.transition-transform{transition-property:transform,translate,scale,rotate;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.duration-200{--tw-duration:.2s;transition-duration:.2s}.duration-300{--tw-duration:.3s;transition-duration:.3s}.ease-in-out{--tw-ease:var(--ease-in-out);transition-timing-function:var(--ease-in-out)}@media (hover:hover){.group-hover\:scale-105:is(:where(.group):hover *){--tw-scale-x:105%;--tw-scale-y:105%;--tw-scale-z:105%;scale:var(--tw-scale-x)var(--tw-scale-y)}.group-hover\:text-\[\#3ea2ff\]:is(:where(.group):hover *){color:#3ea2ff}.hover\:text-\[\#749ac8\]:hover{color:#749ac8}.hover\:text-gray-400:hover{color:var(--color-gray-400)}}@media (min-width:1027px){.md\:hidden{display:none}.md\:h-0{height:var(--spacing-0)}.md\:w-0{width:var(--spacing-0)}.md\:w-\[var\(--sidebar-width\)\]{width:var(--sidebar-width)}}@media (min-width:1309px){.lg\:block{display:block}}@media (min-width:40rem){.sm\:h-\[150px\]{height:150px}.sm\:flex-row{flex-direction:row}}@media (prefers-color-scheme:dark){.dark\:text-gray-200{color:var(--color-gray-200)}}}#post figure[data-rehype-pretty-code-figure]{background-color:#030713;border-radius:8px;max-width:calc(100dvw - 80px);margin-bottom:12px;padding:4px 12px 8px;position:relative}#post div[data-rehype-pretty-code-title],#post figcaption{color:oklch(70.7% .022 261.325);margin-top:4px;margin-bottom:8px;font-size:12px}#post figcaption[data-rehype-pretty-code-caption]{position:absolute;top:3px;right:13px}#post pre{color:#e1e4e8;background-color:#232731;border:1px solid #353333;border-radius:8px;padding:20px 14px}#post code *{font-family:monospace;font-size:14px;font-weight:500;line-height:1.3}#post [data-highlighted-line-id=minus]{background-color:#f003;text-decoration:line-through}#post [data-highlighted-line-id=plus]{background-color:#0f03}#post pre{overflow:auto}#post pre [data-line]{margin-bottom:1.5px;padding:.03rem}#post pre code[data-line-numbers]{counter-reset:line}#post pre code[data-line-numbers]>[data-line]:before{counter-increment:line;content:counter(line);text-align:right;color:gray;width:.75rem;margin-right:1rem;display:inline-block}#post{color:#3a4954;line-height:1.6}#post h1{color:#374151;margin-top:1rem;margin-bottom:1rem;font-size:2.625rem;font-weight:900}#post h2{margin-top:3rem;font-size:2.1875rem}#post h2,#post h3{color:#374151;margin-bottom:1rem;font-weight:600}#post h3{margin-top:2rem;font-size:1.5rem}#post>p{margin-bottom:12px}#post p code{color:#0d0d0d;background-color:#f5f5f5;border-radius:4px;padding:.2em .4em;font-size:.95em}#post ul{padding-left:12px}#post ul li{padding-left:6px}#post ul li::marker{content:"• ";font-size:1.2em;font-weight:700}#post strong{color:#0d0d0d;font-weight:600}#container{grid-template:"header header""sidenav contents"1fr/auto 1fr;display:grid}#header{height:var(--nav-height);padding:0 var(--layout-padding);z-index:1;background-color:#fff;border-bottom:1px solid #d3d3d3;grid-area:header;justify-content:space-between;align-items:center;display:flex;position:sticky;top:0}.sidenav-left{height:calc(100dvh - var(--nav-height));background-color:var(--sidebar-bg-color);position:sticky}.sidenav-left,.sidenav-top{top:var(--nav-height);color:oklch(44.6% .03 256.802);grid-area:sidenav;overflow-y:auto}.sidenav-top{z-index:20;background-color:#fff;position:fixed}#contents{grid-area:contents}@property --tw-rotate-x{syntax:"*";inherits:false}@property --tw-rotate-y{syntax:"*";inherits:false}@property --tw-rotate-z{syntax:"*";inherits:false}@property --tw-skew-x{syntax:"*";inherits:false}@property --tw-skew-y{syntax:"*";inherits:false}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-leading{syntax:"*";inherits:false}@property --tw-font-weight{syntax:"*";inherits:false}@property --tw-duration{syntax:"*";inherits:false}@property --tw-ease{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}