@font-face{font-family:Anuphan;font-weight:1 900;font-display:optional;src:url(/assets/fonts/anuphan.woff2) format("woff2"),url(/assets/fonts/anuphan.woff) format("woff")}@font-face{font-family:fallback-arial;size-adjust:101.55%;ascent-override:100%;descent-override:normal;line-gap-override:normal;src:local("Arial")}*,:before,:after{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }*,:before,:after{box-sizing:border-box}html{font-size:17px;line-height:1.5}body,dl,dd,p{margin:0}:root{-moz-tab-size:4;-o-tab-size:4;tab-size:4}input:disabled+label{color:#5a5053}html,body{font-family:Anuphan,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,fallback-arial,Arial,Noto Sans,sans-serif,"Apple Color Emoji","Segoe UI Emoji",Segoe UI Symbol,"Noto Color Emoji";background-color:#1d191a;color:#463539;counter-reset:footnotes}html:is(.dark *),body:is(.dark *){color:#f1e7e4}.dark{--tw-bg-opacity: 1;background-color:rgb(25 21 22 / var(--tw-bg-opacity, 1))}a{text-decoration:none;font-weight:500;color:#db1f3f;transition:color .1s}a:is(.dark *){color:#e65161}a:hover{text-decoration:underline;text-underline-position:from-font;text-decoration-thickness:2px;color:#e65161}a:hover:is(.dark *){color:#f291a0}footer a{color:#e65161}footer a:hover{color:#f291a0}h1,h2,h3,h4{letter-spacing:-.01em;font-weight:500;margin-bottom:.5rem}dt{font-weight:700}dd:not(:last-of-type){margin-bottom:1rem}article{margin-bottom:3rem;transition:opacity .1s linear;position:relative}code{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;background-color:#212121;border-radius:4px;font-size:.875rem;line-height:1.25rem;color:#f5f5f5;padding:.08em .3em;word-break:break-word}article p,.post p,.post>ul,.post pre,.post blockquote,.post .expressive-code{margin-bottom:1em}.post>h1,.post>h2{margin-top:1.3rem;margin-bottom:.6rem}.post>h3{margin-bottom:.6rem}.post li>p{margin-bottom:.6rem}.post blockquote{padding-top:.5rem;padding-bottom:.5rem;padding-left:1rem;border-left:5px solid;border-color:#e65161;background-color:#e6516124;border-radius:.125rem;font-style:italic;font-weight:450;margin-left:0;margin-right:0}@media (min-width: 640px){.post blockquote{margin-left:1.25rem;margin-right:1.25rem}}.post blockquote p:last-child{margin-bottom:0}.post blockquote [data-favicon]{margin-left:.25em}.post figure{margin-top:1.4rem;margin-bottom:1rem;text-align:center;margin-left:0;margin-right:0}@media (min-width: 640px){.post figure{margin-left:2rem;margin-right:2rem}}.post img:not([data-favicon]){max-width:100%;height:auto;border-radius:.125rem}.post .image-right{float:right;margin-left:1.5rem;margin-right:.5rem;margin-top:.8rem;max-width:-moz-min-content;max-width:min-content}@media (min-width: 640px){.post .image-left{float:left;margin-right:1.5rem;margin-left:.5rem;margin-top:.75rem;max-width:-moz-max-content;max-width:max-content}}.post figcaption{text-align:center;display:block;margin:.15rem 0;font-style:italic;color:#5a5053;font-size:.95rem}.post figcaption:is(.dark *){color:#dcdcdc}.post>iframe{margin:0 auto 1rem;display:block}article li{padding-bottom:.25em}article>ul,article>ol{margin:0 0 1em;padding:0 0 0 1.5em}li>ul,li>ol{padding:0 0 0 1.5em}.task-list-item{list-style-type:none}.project-box{padding:1em;position:relative;background:transparent;color:#fff;opacity:.9;transition:all .1s ease-out;display:flex;width:431px;border-radius:.125rem;background-color:rgb(70 53 57 / var(--tw-bg-opacity, 1));--tw-bg-opacity: .05}.project-box:is(.dark *){background-color:rgb(245 245 245 / var(--tw-bg-opacity, 1));--tw-bg-opacity: .05}.project-box.project-featured{opacity:1}.project-box:hover:hover{background-color:rgb(230 81 97 / var(--tw-bg-opacity, 1));--tw-bg-opacity: .2}.project-box:hover:is(.dark *):hover{--tw-bg-opacity: 1;background-color:rgb(230 81 97 / var(--tw-bg-opacity, 1))}.project-box:hover:hover:is(.dark *){--tw-bg-opacity: .3}.project-box:hover{opacity:1;color:#fff;text-decoration:none;transition:all .1s ease-out}a:focus>.cover-title{opacity:100}.cover-title{position:absolute;color:#fefffe;bottom:0;margin:0;width:100%;text-align:center;font-size:1.875rem;line-height:170px;background-color:rgb(230 81 97 / var(--tw-bg-opacity, 1));--tw-bg-opacity: .8;transition-property:opacity;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s;opacity:0;border-radius:.125rem}.cover-title:hover{opacity:100}.social-icon{color:inherit;margin-right:1.2em;display:flex;align-items:center}.social-icon:is(.dark *){color:inherit}.social-mastodon:hover{color:#6364ff}.social-other:hover{color:#d8d9d8}.toc{transition:opacity .1s linear;position:sticky;top:2rem}.toc ol{list-style-type:none;margin:0;padding:0}.toc .toc-depth-3{padding-left:.75rem;border-left:1px solid rgba(146,149,152,.15)}.toc a{color:#5a5053}.toc a:is(.dark *){color:#dcdcdc}[role=doc-noteref]:after{counter-increment:footnotes;content:"[" counter(footnotes) "]";font-size:.8rem;position:relative;top:-6px;left:1px;-webkit-user-select:none;-moz-user-select:none;user-select:none}.block-note{padding:1em;margin:1.5em auto;max-width:min(675px,100%);background-color:#212121;color:#f5f5f5;border-radius:.125rem}.block-note .block-title{display:block;font-weight:700;text-align:center;padding:.5rem 0;padding-top:0}.block-note p:last-of-type{margin-bottom:0}.block-note a{color:#e65161}.block-note a:hover{color:#f291a0}.visible{visibility:visible}.fixed{position:fixed}.absolute{position:absolute}.relative{position:relative}.sticky{position:sticky}.-right-px{right:-1px}.bottom-0{bottom:0}.left-0{left:0}.left-\[50rem\]{left:50rem}.right-0{right:0}.right-2{right:.5rem}.top-0{top:0}.top-1{top:.25rem}.top-4{top:1rem}.top-\[-5px\]{top:-5px}.top-\[3px\]{top:3px}.float-right{float:right}.m-0{margin:0}.m-6{margin:1.5rem}.mx-auto{margin-left:auto;margin-right:auto}.my-2{margin-top:.5rem;margin-bottom:.5rem}.my-6{margin-top:1.5rem;margin-bottom:1.5rem}.my-8{margin-top:2rem;margin-bottom:2rem}.mb-1{margin-bottom:.25rem}.mb-12{margin-bottom:3rem}.mb-2{margin-bottom:.5rem}.mb-3{margin-bottom:.75rem}.mb-4{margin-bottom:1rem}.mb-5{margin-bottom:1.25rem}.mb-6{margin-bottom:1.5rem}.ml-2{margin-left:.5rem}.ml-4{margin-left:1rem}.mr-0{margin-right:0}.mr-1{margin-right:.25rem}.mr-2{margin-right:.5rem}.mr-4{margin-right:1rem}.mt-0{margin-top:0}.mt-10{margin-top:2.5rem}.mt-2{margin-top:.5rem}.mt-4{margin-top:1rem}.block{display:block}.inline-block{display:inline-block}.inline{display:inline}.flex{display:flex}.hidden{display:none}.aspect-\[3\/4\.3\]{aspect-ratio:3/4.3}.h-0{height:0px}.h-12{height:3rem}.h-4{height:1rem}.h-5{height:1.25rem}.h-6{height:1.5rem}.h-7{height:1.75rem}.h-\[0\.875rem\]{height:.875rem}.h-\[170px\]{height:170px}.h-\[24px\]{height:24px}.h-\[48px\]{height:48px}.h-auto{height:auto}.h-full{height:100%}.min-h-min{min-height:-moz-min-content;min-height:min-content}.w-0{width:0px}.w-1\/4{width:25%}.w-11\/12{width:91.666667%}.w-2\/6{width:33.333333%}.w-20{width:5rem}.w-3\/4{width:75%}.w-4{width:1rem}.w-4\/5{width:80%}.w-4\/6{width:66.666667%}.w-5{width:1.25rem}.w-\[359px\]{width:359px}.w-\[48px\]{width:48px}.w-\[72ch\]{width:72ch}.w-\[calc\(50\%-1rem\)\]{width:calc(50% - 1rem)}.w-articleList{width:min(920px,100%)}.w-footer{width:min(980px,100%)}.w-full{width:100%}.w-index{width:min(880px,100%)}.w-layout{width:min(1280px,100%)}.max-w-\[72ch\]{max-width:72ch}.max-w-full{max-width:100%}.flex-1{flex:1 1 0%}.flex-grow{flex-grow:1}.basis-5\/12{flex-basis:41.666667%}@keyframes pulse{50%{opacity:.5}}.animate-pulse{animation:pulse 2s cubic-bezier(.4,0,.6,1) infinite}.cursor-pointer{cursor:pointer}.select-none{-webkit-user-select:none;-moz-user-select:none;user-select:none}.resize{resize:both}.list-inside{list-style-position:inside}.list-none{list-style-type:none}.appearance-none{-webkit-appearance:none;-moz-appearance:none;appearance:none}.grid-cols-content{grid-template-columns:minmax(0,4.25fr) minmax(0,1.25fr)}.flex-col{flex-direction:column}.flex-col-reverse{flex-direction:column-reverse}.flex-wrap{flex-wrap:wrap}.items-center{align-items:center}.justify-end{justify-content:flex-end}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.justify-around{justify-content:space-around}.gap-2{gap:.5rem}.gap-4{gap:1rem}.gap-5{gap:1.25rem}.gap-6{gap:1.5rem}.gap-x-2{-moz-column-gap:.5rem;column-gap:.5rem}.gap-x-3{-moz-column-gap:.75rem;column-gap:.75rem}.gap-x-4{-moz-column-gap:1rem;column-gap:1rem}.gap-x-8{-moz-column-gap:2rem;column-gap:2rem}.gap-y-3{row-gap:.75rem}.gap-y-4{row-gap:1rem}.overflow-hidden{overflow:hidden}.overflow-y-auto{overflow-y:auto}.rounded-full{border-radius:9999px}.rounded-sm{border-radius:.125rem}.rounded-bl-lg{border-bottom-left-radius:.5rem}.border{border-width:1px}.bg-black\/5{background-color:#0000000d}.bg-dark-subtle-text{--tw-bg-opacity: 1;background-color:rgb(220 220 220 / var(--tw-bg-opacity, 1))}.bg-darker-skylines{--tw-bg-opacity: 1;background-color:rgb(29 25 26 / var(--tw-bg-opacity, 1))}.bg-isabelline{--tw-bg-opacity: 1;background-color:rgb(245 245 245 / var(--tw-bg-opacity, 1))}.bg-mobile-menu{--tw-bg-opacity: 1;background-color:rgb(25 21 22 / var(--tw-bg-opacity, 1))}.bg-mobile-menu-side{--tw-bg-opacity: 1;background-color:rgb(22 19 19 / var(--tw-bg-opacity, 1))}.fill-\[\#463539\]{fill:#463539}.fill-current{fill:currentColor}.object-cover{-o-object-fit:cover;object-fit:cover}.object-top{-o-object-position:top;object-position:top}.p-0{padding:0}.p-5{padding:1.25rem}.px-3{padding-left:.75rem;padding-right:.75rem}.px-4{padding-left:1rem;padding-right:1rem}.px-5{padding-left:1.25rem;padding-right:1.25rem}.py-2{padding-top:.5rem;padding-bottom:.5rem}.py-6{padding-top:1.5rem;padding-bottom:1.5rem}.pl-\[0\.2rem\]{padding-left:.2rem}.pr-2{padding-right:.5rem}.pr-\[0\.15rem\]{padding-right:.15rem}.text-center{text-align:center}.text-right{text-align:right}.font-mono{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace}.text-2xl{font-size:1.5rem;line-height:2rem}.text-3xl{font-size:1.875rem;line-height:2.25rem}.text-4xl{font-size:2.25rem;line-height:2.5rem}.text-\[0\.95rem\]{font-size:.95rem}.text-base{font-size:1rem;line-height:1.5rem}.text-lg{font-size:1.125rem;line-height:1.75rem}.text-sm{font-size:.875rem;line-height:1.25rem}.text-xl{font-size:1.25rem;line-height:1.75rem}.text-xs{font-size:.75rem;line-height:1rem}.font-bold{font-weight:700}.font-medium{font-weight:500}.font-semibold{font-weight:600}.capitalize{text-transform:capitalize}.leading-none{line-height:1}.leading-tight{line-height:1.25}.text-beach-watermelon{color:#db1f3f}.text-black{color:#000}.text-creative-work{color:#5a5053}.text-inherit{color:inherit}.text-isabelline{color:#f5f5f5}.text-rose-ebony{color:#463539}.no-underline{text-decoration-line:none}.opacity-0{opacity:0}.opacity-35{opacity:.35}.opacity-65{opacity:.65}.blur{--tw-blur: blur(8px);filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.transition-\[width\]{transition-property:width;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-all{transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-opacity{transition-property:opacity;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.duration-100{transition-duration:.1s}.duration-300{transition-duration:.3s}.ease-in-out{transition-timing-function:cubic-bezier(.4,0,.2,1)}.ease-linear{transition-timing-function:linear}.first-letter\:uppercase:first-letter{text-transform:uppercase}.before\:text-rose-ebony:before{content:var(--tw-content);color:#463539}.before\:content-\[\'↑\'\]:before{--tw-content: "↑";content:var(--tw-content)}.checked\:before\:content-\[\'↓\'\]:checked:before{--tw-content: "↓";content:var(--tw-content)}.hover\:cursor-pointer:hover{cursor:pointer}.hover\:text-dark-pinky-unicorny:hover{color:#f291a0}.hover\:text-pinky-unicorny:hover{color:#e65161}.hover\:opacity-100:hover{opacity:1}.focus\:outline-none:focus{outline:2px solid transparent;outline-offset:2px}.dark\:bg-dark-skeleton:is(.dark *){--tw-bg-opacity: 1;background-color:rgb(51 46 47 / var(--tw-bg-opacity, 1))}.dark\:bg-darker-skylines:is(.dark *){--tw-bg-opacity: 1;background-color:rgb(29 25 26 / var(--tw-bg-opacity, 1))}.dark\:bg-mobile-menu:is(.dark *){--tw-bg-opacity: 1;background-color:rgb(25 21 22 / var(--tw-bg-opacity, 1))}.dark\:fill-\[\#F1E7E4\]:is(.dark *){fill:#f1e7e4}.dark\:text-dark-beach-watermelon:is(.dark *){color:#e65161}.dark\:text-dark-subtle-text:is(.dark *){color:#dcdcdc}.dark\:text-inherit:is(.dark *){color:inherit}.dark\:text-isabelline:is(.dark *){color:#f5f5f5}.dark\:text-white:is(.dark *){color:#fff}.dark\:before\:text-white:is(.dark *):before{content:var(--tw-content);color:#fff}@media (min-width: 640px){.sm\:m-0{margin:0}.sm\:mx-10{margin-left:2.5rem;margin-right:2.5rem}.sm\:mt-4{margin-top:1rem}.sm\:mt-6{margin-top:1.5rem}.sm\:mt-9{margin-top:2.25rem}.sm\:block{display:block}.sm\:flex{display:flex}.sm\:grid{display:grid}.sm\:hidden{display:none}.sm\:min-h-min{min-height:-moz-min-content;min-height:min-content}.sm\:w-\[20\%\]{width:20%}.sm\:w-\[37\%\]{width:37%}.sm\:w-\[63\%\]{width:63%}.sm\:w-\[80\%\]{width:80%}.sm\:w-\[calc\(20\%-1rem\)\]{width:calc(20% - 1rem)}.sm\:max-w-\[50\%\]{max-width:50%}.sm\:grid-cols-layout{grid-template-columns:minmax(0,.75fr) minmax(0,3.25fr)}.sm\:flex-row{flex-direction:row}.sm\:justify-start{justify-content:flex-start}.sm\:gap-3{gap:.75rem}.sm\:gap-x-4{-moz-column-gap:1rem;column-gap:1rem}.sm\:gap-x-6{-moz-column-gap:1.5rem;column-gap:1.5rem}.sm\:gap-y-0{row-gap:0px}.sm\:p-0{padding:0}.sm\:px-0{padding-left:0;padding-right:0}.sm\:text-\[3\.5rem\]{font-size:3.5rem}.sm\:text-base{font-size:1rem;line-height:1.5rem}.sm\:text-sm{font-size:.875rem;line-height:1.25rem}}@media (min-width: 768px){.md\:flex-row{flex-direction:row}}@media (min-width: 1024px){.lg\:gap-4{gap:1rem}}@media (min-width: 1280px){.xl\:ml-0{margin-left:0}.xl\:mr-0{margin-right:0}}@media print{.print\:hidden{display:none}}button[data-astro-cid-rcjqacvn]{border:none;margin:0;padding:0;width:auto;overflow:visible;background:transparent;color:inherit;font:inherit;line-height:normal;-webkit-font-smoothing:inherit;-moz-osx-font-smoothing:inherit;-webkit-appearance:none;position:fixed;bottom:0;right:0;margin:1.5rem;display:none;transition-property:all;transition-duration:.3s;transition-timing-function:cubic-bezier(.4,0,.2,1)}button[data-astro-cid-rcjqacvn]:hover{cursor:pointer;color:#f291a0;opacity:1}@media (min-width: 640px){button[data-astro-cid-rcjqacvn]{display:block}}@media print{button[data-astro-cid-rcjqacvn]{display:none}}
