@font-face{font-family:Geist;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/fef07dbb0973bf53-s.12tyk43_3sh9u.woff2?dpl=dpl_GPBng9hrvWz6FjEC8L3FdAfh1Drb)format("woff2");unicode-range:U+460-52F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F}@font-face{font-family:Geist;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/8a480f0b521d4e75-s.0jzbimsg8vl84.woff2?dpl=dpl_GPBng9hrvWz6FjEC8L3FdAfh1Drb)format("woff2");unicode-range:U+301,U+400-45F,U+490-491,U+4B0-4B1,U+2116}@font-face{font-family:Geist;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/53b9e256198e5412-s.0-wfv7uh4i7h9.woff2?dpl=dpl_GPBng9hrvWz6FjEC8L3FdAfh1Drb)format("woff2");unicode-range:U+102-103,U+110-111,U+128-129,U+168-169,U+1A0-1A1,U+1AF-1B0,U+300-301,U+303-304,U+308-309,U+323,U+329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Geist;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/7178b3e590c64307-s.0nx0ww8fni_q3.woff2?dpl=dpl_GPBng9hrvWz6FjEC8L3FdAfh1Drb)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Geist;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/caa3a2e1cccd8315-s.p.09~u27dqhyhd6.woff2?dpl=dpl_GPBng9hrvWz6FjEC8L3FdAfh1Drb)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Geist Fallback;src:local(Arial);ascent-override:95.94%;descent-override:28.16%;line-gap-override:0.0%;size-adjust:104.76%}.geist_e799d87a-module__u8MhCG__className{font-family:Geist,Geist Fallback;font-style:normal}.geist_e799d87a-module__u8MhCG__variable{--font-geist:"Geist", "Geist Fallback"}
@font-face{font-family:Geist Mono;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/5ce348bf30bf5439-s.0ee55_hj9qcer.woff2?dpl=dpl_GPBng9hrvWz6FjEC8L3FdAfh1Drb)format("woff2");unicode-range:U+460-52F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F}@font-face{font-family:Geist Mono;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/4fa387ec64143e14-s.0.qu-9752pffj.woff2?dpl=dpl_GPBng9hrvWz6FjEC8L3FdAfh1Drb)format("woff2");unicode-range:U+301,U+400-45F,U+490-491,U+4B0-4B1,U+2116}@font-face{font-family:Geist Mono;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/6306c77e7c8268e4-s.0mao5jbfbduzp.woff2?dpl=dpl_GPBng9hrvWz6FjEC8L3FdAfh1Drb)format("woff2");unicode-range:U+2000-2001,U+2004-2008,U+200A,U+23B8-23BD,U+2500-259F}@font-face{font-family:Geist Mono;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/7d817b4c03b0c5f1-s.0uzt.a6d44yda.woff2?dpl=dpl_GPBng9hrvWz6FjEC8L3FdAfh1Drb)format("woff2");unicode-range:U+102-103,U+110-111,U+128-129,U+168-169,U+1A0-1A1,U+1AF-1B0,U+300-301,U+303-304,U+308-309,U+323,U+329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Geist Mono;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/bbc41e54d2fcbd21-s.0mvwgmnhv29no.woff2?dpl=dpl_GPBng9hrvWz6FjEC8L3FdAfh1Drb)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Geist Mono;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/797e433ab948586e-s.p.09zddjkbdep5a.woff2?dpl=dpl_GPBng9hrvWz6FjEC8L3FdAfh1Drb)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Geist Mono Fallback;src:local(Arial);ascent-override:74.67%;descent-override:21.92%;line-gap-override:0.0%;size-adjust:134.59%}.geist_mono_42eec60-module__Gb1_vG__className{font-family:Geist Mono,Geist Mono Fallback;font-style:normal}.geist_mono_42eec60-module__Gb1_vG__variable{--font-geist-mono:"Geist Mono", "Geist Mono Fallback"}
@font-face{font-family:IBM Plex Sans Thai;font-style:normal;font-weight:300;font-display:swap;src:url(../media/57c9eb05141b6b7c-s.09dd5y52jc5rt.woff2?dpl=dpl_GPBng9hrvWz6FjEC8L3FdAfh1Drb)format("woff2");unicode-range:U+460-52F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F}@font-face{font-family:IBM Plex Sans Thai;font-style:normal;font-weight:300;font-display:swap;src:url(../media/c73fb3e54683eaf8-s.p.10-ku.r4hcrjo.woff2?dpl=dpl_GPBng9hrvWz6FjEC8L3FdAfh1Drb)format("woff2");unicode-range:U+2D7,U+303,U+331,U+E01-E5B,U+200C-200D,U+25CC}@font-face{font-family:IBM Plex Sans Thai;font-style:normal;font-weight:300;font-display:swap;src:url(../media/caaacb6502e94400-s.0678ct_lfye5g.woff2?dpl=dpl_GPBng9hrvWz6FjEC8L3FdAfh1Drb)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:IBM Plex Sans Thai;font-style:normal;font-weight:300;font-display:swap;src:url(../media/d9fa5058ff337146-s.p.0.uojefwi-6od.woff2?dpl=dpl_GPBng9hrvWz6FjEC8L3FdAfh1Drb)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:IBM Plex Sans Thai;font-style:normal;font-weight:400;font-display:swap;src:url(../media/08f3d05b771d66cc-s.02.3m.z9py4_p.woff2?dpl=dpl_GPBng9hrvWz6FjEC8L3FdAfh1Drb)format("woff2");unicode-range:U+460-52F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F}@font-face{font-family:IBM Plex Sans Thai;font-style:normal;font-weight:400;font-display:swap;src:url(../media/413670c8b897121b-s.p.14ap8~zrl6szq.woff2?dpl=dpl_GPBng9hrvWz6FjEC8L3FdAfh1Drb)format("woff2");unicode-range:U+2D7,U+303,U+331,U+E01-E5B,U+200C-200D,U+25CC}@font-face{font-family:IBM Plex Sans Thai;font-style:normal;font-weight:400;font-display:swap;src:url(../media/72b93e0389b54497-s.0.u5885n6nh5m.woff2?dpl=dpl_GPBng9hrvWz6FjEC8L3FdAfh1Drb)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:IBM Plex Sans Thai;font-style:normal;font-weight:400;font-display:swap;src:url(../media/ab8c2f9dfe50fb3c-s.p.02z9z4k9hf4m9.woff2?dpl=dpl_GPBng9hrvWz6FjEC8L3FdAfh1Drb)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:IBM Plex Sans Thai;font-style:normal;font-weight:500;font-display:swap;src:url(../media/57f2d0e8dd065b18-s.0weekw4rtjj~..woff2?dpl=dpl_GPBng9hrvWz6FjEC8L3FdAfh1Drb)format("woff2");unicode-range:U+460-52F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F}@font-face{font-family:IBM Plex Sans Thai;font-style:normal;font-weight:500;font-display:swap;src:url(../media/966a1ae9b0187c65-s.p.16f3t..oolz7~.woff2?dpl=dpl_GPBng9hrvWz6FjEC8L3FdAfh1Drb)format("woff2");unicode-range:U+2D7,U+303,U+331,U+E01-E5B,U+200C-200D,U+25CC}@font-face{font-family:IBM Plex Sans Thai;font-style:normal;font-weight:500;font-display:swap;src:url(../media/25d906941e607a44-s.0lxz35w72rj-1.woff2?dpl=dpl_GPBng9hrvWz6FjEC8L3FdAfh1Drb)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:IBM Plex Sans Thai;font-style:normal;font-weight:500;font-display:swap;src:url(../media/666deae7c569669f-s.p.0wbhs3.w672uy.woff2?dpl=dpl_GPBng9hrvWz6FjEC8L3FdAfh1Drb)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:IBM Plex Sans Thai;font-style:normal;font-weight:600;font-display:swap;src:url(../media/cce0da533fe89a78-s.0nlsrqwh8q3p8.woff2?dpl=dpl_GPBng9hrvWz6FjEC8L3FdAfh1Drb)format("woff2");unicode-range:U+460-52F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F}@font-face{font-family:IBM Plex Sans Thai;font-style:normal;font-weight:600;font-display:swap;src:url(../media/411573def610439a-s.p.0xiiz24wsq24s.woff2?dpl=dpl_GPBng9hrvWz6FjEC8L3FdAfh1Drb)format("woff2");unicode-range:U+2D7,U+303,U+331,U+E01-E5B,U+200C-200D,U+25CC}@font-face{font-family:IBM Plex Sans Thai;font-style:normal;font-weight:600;font-display:swap;src:url(../media/0f35197ba25d2b5b-s.0btkb4ac4ikdr.woff2?dpl=dpl_GPBng9hrvWz6FjEC8L3FdAfh1Drb)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:IBM Plex Sans Thai;font-style:normal;font-weight:600;font-display:swap;src:url(../media/e4b5e1d5de235207-s.p.0agc93klb0f7e.woff2?dpl=dpl_GPBng9hrvWz6FjEC8L3FdAfh1Drb)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:IBM Plex Sans Thai;font-style:normal;font-weight:700;font-display:swap;src:url(../media/cdf71b3840042aba-s.0u7tcimkd~9n1.woff2?dpl=dpl_GPBng9hrvWz6FjEC8L3FdAfh1Drb)format("woff2");unicode-range:U+460-52F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F}@font-face{font-family:IBM Plex Sans Thai;font-style:normal;font-weight:700;font-display:swap;src:url(../media/86fee4a10e2832ea-s.p.0yseaop5hit0-.woff2?dpl=dpl_GPBng9hrvWz6FjEC8L3FdAfh1Drb)format("woff2");unicode-range:U+2D7,U+303,U+331,U+E01-E5B,U+200C-200D,U+25CC}@font-face{font-family:IBM Plex Sans Thai;font-style:normal;font-weight:700;font-display:swap;src:url(../media/b1ef0ab36ab59f4e-s.0j0xf~qrmsfka.woff2?dpl=dpl_GPBng9hrvWz6FjEC8L3FdAfh1Drb)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:IBM Plex Sans Thai;font-style:normal;font-weight:700;font-display:swap;src:url(../media/9fdf3a539c009271-s.p.07ns-dtj7gzka.woff2?dpl=dpl_GPBng9hrvWz6FjEC8L3FdAfh1Drb)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:IBM Plex Sans Thai Fallback;src:local(Arial);ascent-override:110.31%;descent-override:52.78%;line-gap-override:0.0%;size-adjust:101.17%}.ibm_plex_sans_thai_e2031d27-module__rIEiDG__className{font-family:IBM Plex Sans Thai,IBM Plex Sans Thai Fallback;font-style:normal}.ibm_plex_sans_thai_e2031d27-module__rIEiDG__variable{--font-plex-thai:"IBM Plex Sans Thai", "IBM Plex Sans Thai Fallback"}
@font-face{font-family:Instrument Serif;font-style:italic;font-weight:400;font-display:swap;src:url(../media/fc0a7394b875fa43-s.0y1-r_vehenvp.woff2?dpl=dpl_GPBng9hrvWz6FjEC8L3FdAfh1Drb)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Instrument Serif;font-style:italic;font-weight:400;font-display:swap;src:url(../media/7ebf22b5a21034f8-s.p.10_7676vm7pyy.woff2?dpl=dpl_GPBng9hrvWz6FjEC8L3FdAfh1Drb)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Instrument Serif;font-style:normal;font-weight:400;font-display:swap;src:url(../media/ccf27e5a7366fb23-s.0hck6o0i8wq3a.woff2?dpl=dpl_GPBng9hrvWz6FjEC8L3FdAfh1Drb)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Instrument Serif;font-style:normal;font-weight:400;font-display:swap;src:url(../media/e41d5df559864f9e-s.p.0gq7fw9.sy_5..woff2?dpl=dpl_GPBng9hrvWz6FjEC8L3FdAfh1Drb)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Instrument Serif Fallback;src:local(Times New Roman);ascent-override:117.94%;descent-override:36.93%;line-gap-override:0.0%;size-adjust:83.94%}.instrument_serif_a3003299-module__pcxXmG__className{font-family:Instrument Serif,Instrument Serif Fallback;font-weight:400}.instrument_serif_a3003299-module__pcxXmG__variable{--font-instrument-serif:"Instrument Serif", "Instrument Serif Fallback"}
@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-translate-x:0;--tw-translate-y:0;--tw-translate-z:0;--tw-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-space-y-reverse:0;--tw-border-style:solid;--tw-leading:initial;--tw-font-weight:initial;--tw-tracking:initial;--tw-shadow:0 0 #0000;--tw-shadow-color:initial;--tw-shadow-alpha:100%;--tw-inset-shadow:0 0 #0000;--tw-inset-shadow-color:initial;--tw-inset-shadow-alpha:100%;--tw-ring-color:initial;--tw-ring-shadow:0 0 #0000;--tw-inset-ring-color:initial;--tw-inset-ring-shadow:0 0 #0000;--tw-ring-inset:initial;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-offset-shadow:0 0 #0000;--tw-outline-style:solid;--tw-blur:initial;--tw-brightness:initial;--tw-contrast:initial;--tw-grayscale:initial;--tw-hue-rotate:initial;--tw-invert:initial;--tw-opacity:initial;--tw-saturate:initial;--tw-sepia:initial;--tw-drop-shadow:initial;--tw-drop-shadow-color:initial;--tw-drop-shadow-alpha:100%;--tw-drop-shadow-size:initial;--tw-duration:initial}}}@layer theme{:root,:host{--font-sans:ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";--font-serif:ui-serif, Georgia, Cambria, "Times New Roman", Times, serif;--font-mono:var(--font-geist-mono), ui-monospace, "SF Mono", Menlo, monospace;--color-emerald-600:#009767;--color-black:#000;--color-white:#fff;--spacing:.25rem;--container-lg:32rem;--container-5xl:64rem;--text-xs:.75rem;--text-xs--line-height:calc(1 / .75);--text-sm:.875rem;--text-sm--line-height:calc(1.25 / .875);--text-lg:1.125rem;--text-lg--line-height:calc(1.75 / 1.125);--text-3xl:1.875rem;--text-3xl--line-height:calc(2.25 / 1.875);--text-4xl:2.25rem;--text-4xl--line-height:calc(2.5 / 2.25);--text-5xl:3rem;--text-5xl--line-height:1;--font-weight-light:300;--font-weight-medium:500;--font-weight-semibold:600;--tracking-widest:.1em;--leading-tight:1.25;--radius-xs:.125rem;--radius-md:.375rem;--radius-lg:.5rem;--radius-xl:.75rem;--animate-spin:spin 1s linear infinite;--animate-pulse:pulse 2s cubic-bezier(.4, 0, .6, 1) infinite;--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);--radius:.5rem;--color-background:#000;--color-foreground:#ededed;--color-card:#0a0a0a;--color-card-foreground:#ededed;--color-primary:#ededed;--color-primary-foreground:#000;--color-secondary:#1a1a1a;--color-secondary-foreground:#ededed;--color-muted-foreground:#999;--color-accent:#ededed;--color-accent-foreground:#000;--color-destructive:#ef4444;--color-border:#ffffff1a;--color-ring:#ffffff4d;--font-thai:var(--font-plex-thai), "IBM Plex Sans Thai", system-ui, sans-serif}@supports (color:lab(0% 0 0)){:root,:host{--color-emerald-600:lab(55.0481% -49.9246 15.93)}}}@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;-webkit-text-decoration:inherit;-webkit-text-decoration: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{.\@container\/card-header{container:card-header/inline-size}.visible{visibility:visible}.sr-only{clip-path:inset(50%);white-space:nowrap;border-width:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.absolute{position:absolute}.fixed{position:fixed}.relative{position:relative}.static{position:static}.inset-0{inset:calc(var(--spacing) * 0)}.top-4{top:calc(var(--spacing) * 4)}.top-\[50\%\]{top:50%}.right-4{right:calc(var(--spacing) * 4)}.left-\[50\%\]{left:50%}.z-50{z-index:50}.col-start-2{grid-column-start:2}.row-span-2{grid-row:span 2/span 2}.row-start-1{grid-row-start:1}.mx-auto{margin-inline:auto}.mt-8{margin-top:calc(var(--spacing) * 8)}.flex{display:flex}.grid{display:grid}.hidden{display:none}.inline{display:inline}.inline-block{display:inline-block}.inline-flex{display:inline-flex}.table{display:table}.size-2\.5{width:calc(var(--spacing) * 2.5);height:calc(var(--spacing) * 2.5)}.size-9{width:calc(var(--spacing) * 9);height:calc(var(--spacing) * 9)}.h-3{height:calc(var(--spacing) * 3)}.h-4{height:calc(var(--spacing) * 4)}.h-8{height:calc(var(--spacing) * 8)}.h-9{height:calc(var(--spacing) * 9)}.h-10{height:calc(var(--spacing) * 10)}.h-12{height:calc(var(--spacing) * 12)}.h-20{height:calc(var(--spacing) * 20)}.min-h-\[1\.25rem\]{min-height:1.25rem}.min-h-\[120px\]{min-height:120px}.min-h-screen{min-height:100vh}.w-1\/2{width:50%}.w-2\/3{width:66.6667%}.w-2\/5{width:40%}.w-3\/4{width:75%}.w-16{width:calc(var(--spacing) * 16)}.w-24{width:calc(var(--spacing) * 24)}.w-32{width:calc(var(--spacing) * 32)}.w-fit{width:fit-content}.w-full{width:100%}.max-w-5xl{max-width:var(--container-5xl)}.max-w-\[calc\(100\%-2rem\)\]{max-width:calc(100% - 2rem)}.max-w-lg{max-width:var(--container-lg)}.shrink-0{flex-shrink:0}.origin-\(--radix-tooltip-content-transform-origin\){transform-origin:var(--radix-tooltip-content-transform-origin)}.translate-x-\[-50\%\]{--tw-translate-x:-50%;translate:var(--tw-translate-x) var(--tw-translate-y)}.translate-y-\[-50\%\]{--tw-translate-y:-50%;translate:var(--tw-translate-x) var(--tw-translate-y)}.translate-y-\[calc\(-50\%_-_2px\)\]{--tw-translate-y:calc(-50% - 2px);translate:var(--tw-translate-x) var(--tw-translate-y)}.rotate-45{rotate:45deg}.transform{transform:var(--tw-rotate-x,) var(--tw-rotate-y,) var(--tw-rotate-z,) var(--tw-skew-x,) var(--tw-skew-y,)}.animate-pulse{animation:var(--animate-pulse)}.animate-spin{animation:var(--animate-spin)}.auto-rows-min{grid-auto-rows:min-content}.grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.grid-rows-\[auto_auto\]{grid-template-rows:auto auto}.flex-col{flex-direction:column}.flex-col-reverse{flex-direction:column-reverse}.items-center{align-items:center}.items-start{align-items:flex-start}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.gap-1{gap:calc(var(--spacing) * 1)}.gap-1\.5{gap:calc(var(--spacing) * 1.5)}.gap-2{gap:calc(var(--spacing) * 2)}.gap-3{gap:calc(var(--spacing) * 3)}.gap-4{gap:calc(var(--spacing) * 4)}.gap-6{gap:calc(var(--spacing) * 6)}:where(.space-y-6>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing) * 6) * var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing) * 6) * calc(1 - var(--tw-space-y-reverse)))}:where(.space-y-10>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing) * 10) * var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing) * 10) * calc(1 - var(--tw-space-y-reverse)))}.self-start{align-self:flex-start}.justify-self-end{justify-self:flex-end}.overflow-hidden{overflow:hidden}.rounded{border-radius:var(--radius)}.rounded-\[2px\]{border-radius:2px}.rounded-lg{border-radius:var(--radius-lg)}.rounded-md{border-radius:var(--radius-md)}.rounded-xl{border-radius:var(--radius-xl)}.rounded-xs{border-radius:var(--radius-xs)}.border{border-style:var(--tw-border-style);border-width:1px}.border-transparent{border-color:#0000}.border-white\/10{border-color:#ffffff1a}@supports (color:color-mix(in lab, red, red)){.border-white\/10{border-color:color-mix(in oklab, var(--color-white) 10%, transparent)}}.border-white\/20{border-color:#fff3}@supports (color:color-mix(in lab, red, red)){.border-white\/20{border-color:color-mix(in oklab, var(--color-white) 20%, transparent)}}.bg-background{background-color:var(--color-background)}.bg-black{background-color:var(--color-black)}.bg-black\/50{background-color:#00000080}@supports (color:color-mix(in lab, red, red)){.bg-black\/50{background-color:color-mix(in oklab, var(--color-black) 50%, transparent)}}.bg-border{background-color:var(--color-border)}.bg-card{background-color:var(--color-card)}.bg-destructive{background-color:var(--color-destructive)}.bg-primary{background-color:var(--color-primary)}.bg-secondary{background-color:var(--color-secondary)}.bg-transparent{background-color:#0000}.bg-white\/5{background-color:#ffffff0d}@supports (color:color-mix(in lab, red, red)){.bg-white\/5{background-color:color-mix(in oklab, var(--color-white) 5%, transparent)}}.bg-white\/10{background-color:#ffffff1a}@supports (color:color-mix(in lab, red, red)){.bg-white\/10{background-color:color-mix(in oklab, var(--color-white) 10%, transparent)}}.bg-white\/15{background-color:#ffffff26}@supports (color:color-mix(in lab, red, red)){.bg-white\/15{background-color:color-mix(in oklab, var(--color-white) 15%, transparent)}}.fill-primary{fill:var(--color-primary)}.p-6{padding:calc(var(--spacing) * 6)}.px-2{padding-inline:calc(var(--spacing) * 2)}.px-3{padding-inline:calc(var(--spacing) * 3)}.px-4{padding-inline:calc(var(--spacing) * 4)}.px-5{padding-inline:calc(var(--spacing) * 5)}.px-6{padding-inline:calc(var(--spacing) * 6)}.py-0\.5{padding-block:calc(var(--spacing) * .5)}.py-1{padding-block:calc(var(--spacing) * 1)}.py-1\.5{padding-block:calc(var(--spacing) * 1.5)}.py-2{padding-block:calc(var(--spacing) * 2)}.py-6{padding-block:calc(var(--spacing) * 6)}.py-12{padding-block:calc(var(--spacing) * 12)}.pt-2{padding-top:calc(var(--spacing) * 2)}.pt-16{padding-top:calc(var(--spacing) * 16)}.text-center{text-align:center}.text-3xl{font-size:var(--text-3xl);line-height:var(--tw-leading,var(--text-3xl--line-height))}.text-4xl{font-size:var(--text-4xl);line-height:var(--tw-leading,var(--text-4xl--line-height))}.text-lg{font-size:var(--text-lg);line-height:var(--tw-leading,var(--text-lg--line-height))}.text-sm{font-size:var(--text-sm);line-height:var(--tw-leading,var(--text-sm--line-height))}.text-xs{font-size:var(--text-xs);line-height:var(--tw-leading,var(--text-xs--line-height))}.leading-none{--tw-leading:1;line-height:1}.leading-tight{--tw-leading:var(--leading-tight);line-height:var(--leading-tight)}.font-light{--tw-font-weight:var(--font-weight-light);font-weight:var(--font-weight-light)}.font-medium{--tw-font-weight:var(--font-weight-medium);font-weight:var(--font-weight-medium)}.font-semibold{--tw-font-weight:var(--font-weight-semibold);font-weight:var(--font-weight-semibold)}.tracking-\[0\.3em\]{--tw-tracking:.3em;letter-spacing:.3em}.tracking-widest{--tw-tracking:var(--tracking-widest);letter-spacing:var(--tracking-widest)}.text-balance{text-wrap:balance}.whitespace-nowrap{white-space:nowrap}.text-card-foreground{color:var(--color-card-foreground)}.text-destructive{color:var(--color-destructive)}.text-emerald-600{color:var(--color-emerald-600)}.text-foreground{color:var(--color-foreground)}.text-muted-foreground{color:var(--color-muted-foreground)}.text-primary{color:var(--color-primary)}.text-primary-foreground{color:var(--color-primary-foreground)}.text-secondary-foreground{color:var(--color-secondary-foreground)}.text-white{color:var(--color-white)}.text-white\/40{color:#fff6}@supports (color:color-mix(in lab, red, red)){.text-white\/40{color:color-mix(in oklab, var(--color-white) 40%, transparent)}}.text-white\/60{color:#fff9}@supports (color:color-mix(in lab, red, red)){.text-white\/60{color:color-mix(in oklab, var(--color-white) 60%, transparent)}}.text-white\/70{color:#ffffffb3}@supports (color:color-mix(in lab, red, red)){.text-white\/70{color:color-mix(in oklab, var(--color-white) 70%, transparent)}}.uppercase{text-transform:uppercase}.italic{font-style:italic}.underline-offset-4{text-underline-offset:4px}.opacity-70{opacity:.7}.shadow-lg{--tw-shadow:0 10px 15px -3px var(--tw-shadow-color,#0000001a), 0 4px 6px -4px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow)}.shadow-sm{--tw-shadow:0 1px 3px 0 var(--tw-shadow-color,#0000001a), 0 1px 2px -1px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow)}.ring{--tw-ring-shadow:var(--tw-ring-inset,) 0 0 0 calc(1px + var(--tw-ring-offset-width)) var(--tw-ring-color,currentcolor);box-shadow:var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow)}.ring-offset-background{--tw-ring-offset-color:var(--color-background)}.outline{outline-style:var(--tw-outline-style);outline-width:1px}.filter{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-\[color\,box-shadow\]{transition-property:color,box-shadow;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-opacity{transition-property:opacity;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}.outline-none{--tw-outline-style:none;outline-style:none}.placeholder\:text-muted-foreground::placeholder{color:var(--color-muted-foreground)}@media (hover:hover){.hover\:border-white\/40:hover{border-color:#fff6}@supports (color:color-mix(in lab, red, red)){.hover\:border-white\/40:hover{border-color:color-mix(in oklab, var(--color-white) 40%, transparent)}}.hover\:border-white\/60:hover{border-color:#fff9}@supports (color:color-mix(in lab, red, red)){.hover\:border-white\/60:hover{border-color:color-mix(in oklab, var(--color-white) 60%, transparent)}}.hover\:bg-accent:hover{background-color:var(--color-accent)}.hover\:bg-destructive\/90:hover{background-color:#ef4444e6}@supports (color:color-mix(in lab, red, red)){.hover\:bg-destructive\/90:hover{background-color:color-mix(in oklab, var(--color-destructive) 90%, transparent)}}.hover\:bg-primary\/90:hover{background-color:#ededede6}@supports (color:color-mix(in lab, red, red)){.hover\:bg-primary\/90:hover{background-color:color-mix(in oklab, var(--color-primary) 90%, transparent)}}.hover\:bg-secondary\/80:hover{background-color:#1a1a1acc}@supports (color:color-mix(in lab, red, red)){.hover\:bg-secondary\/80:hover{background-color:color-mix(in oklab, var(--color-secondary) 80%, transparent)}}.hover\:text-accent-foreground:hover{color:var(--color-accent-foreground)}.hover\:underline:hover{text-decoration-line:underline}.hover\:opacity-100:hover{opacity:1}}.focus\:ring-2:focus{--tw-ring-shadow:var(--tw-ring-inset,) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color,currentcolor);box-shadow:var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow)}.focus\:ring-ring:focus{--tw-ring-color:var(--color-ring)}.focus\:ring-offset-2:focus{--tw-ring-offset-width:2px;--tw-ring-offset-shadow:var(--tw-ring-inset,) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color)}.focus\:outline-hidden:focus{--tw-outline-style:none;outline-style:none}@media (forced-colors:active){.focus\:outline-hidden:focus{outline-offset:2px;outline:2px solid #0000}}.focus-visible\:ring-2:focus-visible{--tw-ring-shadow:var(--tw-ring-inset,) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color,currentcolor);box-shadow:var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow)}.focus-visible\:ring-ring:focus-visible{--tw-ring-color:var(--color-ring)}.focus-visible\:ring-offset-1:focus-visible{--tw-ring-offset-width:1px;--tw-ring-offset-shadow:var(--tw-ring-inset,) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color)}.focus-visible\:ring-offset-2:focus-visible{--tw-ring-offset-width:2px;--tw-ring-offset-shadow:var(--tw-ring-inset,) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color)}.focus-visible\:outline-none:focus-visible{--tw-outline-style:none;outline-style:none}.disabled\:pointer-events-none:disabled{pointer-events:none}.disabled\:cursor-not-allowed:disabled{cursor:not-allowed}.disabled\:opacity-50:disabled{opacity:.5}.has-\[data-slot\=card-action\]\:grid-cols-\[1fr_auto\]:has(:is()){grid-template-columns:1fr auto}.has-\[\>svg\]\:px-2\.5:has(>svg){padding-inline:calc(var(--spacing) * 2.5)}.has-\[\>svg\]\:px-3:has(>svg){padding-inline:calc(var(--spacing) * 3)}.has-\[\>svg\]\:px-4:has(>svg){padding-inline:calc(var(--spacing) * 4)}.aria-\[invalid\=true\]\:border-destructive[aria-invalid=true]{border-color:var(--color-destructive)}.aria-\[invalid\=true\]\:ring-destructive\/40[aria-invalid=true]{--tw-ring-color:#ef444466}@supports (color:color-mix(in lab, red, red)){.aria-\[invalid\=true\]\:ring-destructive\/40[aria-invalid=true]{--tw-ring-color:color-mix(in oklab, var(--color-destructive) 40%, transparent)}}.data-\[orientation\=horizontal\]\:h-px[data-orientation=horizontal]{height:1px}.data-\[orientation\=horizontal\]\:w-full[data-orientation=horizontal]{width:100%}.data-\[orientation\=vertical\]\:h-full[data-orientation=vertical]{height:100%}.data-\[orientation\=vertical\]\:w-px[data-orientation=vertical]{width:1px}.data-\[state\=open\]\:bg-accent[data-state=open]{background-color:var(--color-accent)}.data-\[state\=open\]\:text-muted-foreground[data-state=open]{color:var(--color-muted-foreground)}@media (min-width:40rem){.sm\:max-w-lg{max-width:var(--container-lg)}.sm\:flex-row{flex-direction:row}.sm\:justify-end{justify-content:flex-end}.sm\:text-left{text-align:left}}@media (min-width:48rem){.md\:h-16{height:calc(var(--spacing) * 16)}.md\:text-4xl{font-size:var(--text-4xl);line-height:var(--tw-leading,var(--text-4xl--line-height))}.md\:text-5xl{font-size:var(--text-5xl);line-height:var(--tw-leading,var(--text-5xl--line-height))}}.\[\&_svg\]\:pointer-events-none svg{pointer-events:none}.\[\&_svg\]\:shrink-0 svg{flex-shrink:0}.\[\&_svg\:not\(\[class\*\=\'size-\'\]\)\]\:size-4 svg:not([class*=size-]){width:calc(var(--spacing) * 4);height:calc(var(--spacing) * 4)}.\[\.border-b\]\:pb-6.border-b{padding-bottom:calc(var(--spacing) * 6)}.\[\.border-t\]\:pt-6.border-t{padding-top:calc(var(--spacing) * 6)}.\[\&\>svg\]\:pointer-events-none>svg{pointer-events:none}.\[\&\>svg\]\:size-3>svg{width:calc(var(--spacing) * 3);height:calc(var(--spacing) * 3)}@media (hover:hover){a.\[a\&\]\:hover\:bg-accent:hover{background-color:var(--color-accent)}a.\[a\&\]\:hover\:bg-destructive\/90:hover{background-color:#ef4444e6}@supports (color:color-mix(in lab, red, red)){a.\[a\&\]\:hover\:bg-destructive\/90:hover{background-color:color-mix(in oklab, var(--color-destructive) 90%, transparent)}}a.\[a\&\]\:hover\:bg-primary\/90:hover{background-color:#ededede6}@supports (color:color-mix(in lab, red, red)){a.\[a\&\]\:hover\:bg-primary\/90:hover{background-color:color-mix(in oklab, var(--color-primary) 90%, transparent)}}a.\[a\&\]\:hover\:bg-secondary\/90:hover{background-color:#1a1a1ae6}@supports (color:color-mix(in lab, red, red)){a.\[a\&\]\:hover\:bg-secondary\/90:hover{background-color:color-mix(in oklab, var(--color-secondary) 90%, transparent)}}a.\[a\&\]\:hover\:text-accent-foreground:hover{color:var(--color-accent-foreground)}}}:root{--bg:#000;--bg-1:#0a0a0a;--bg-2:#111;--surface-hover:#ffffff09;--line:#ffffff1a;--line-strong:#ffffff2e;--fg:#ededed;--fg-1:#f5f5f5;--fg-2:#ffffffc7;--fg-3:#ffffff9e;--fg-4:#ffffff57;--accent:#fff;--accent-fg:#000;--success:#4ade80;--warn:#fbbf24;--info:#60a5fa;--c-orange:#ff7a45;--c-amber:#fbbf24;--c-rose:#fb7185;--c-pink:#ec4899;--c-magenta:#d946ef;--c-purple:#a78bfa;--c-indigo:#818cf8;--c-blue:#60a5fa;--c-cyan:#22d3ee;--c-teal:#2dd4bf;--c-green:#4ade80;--section-py:clamp(72px, 9vw, 132px);--container-max:1240px;--container-px:clamp(20px, 3.5vw, 40px);--cell-p:32px;--font-sans:var(--font-geist), "Geist", "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", system-ui, sans-serif;--font-mono:var(--font-geist-mono), "Geist Mono", ui-monospace, "SF Mono", "Menlo", monospace;--font-thai:var(--font-plex-thai), "IBM Plex Sans Thai", var(--font-geist), system-ui, sans-serif;--font-serif:var(--font-instrument-serif), "Instrument Serif", "Times New Roman", serif}:root[data-theme=light]{--bg:#fafafa;--bg-1:#fff;--bg-2:#f3f3f3;--surface-hover:#00000008;--line:#0000001a;--line-strong:#0000002e;--fg:#0a0a0a;--fg-1:#000;--fg-2:#000000c7;--fg-3:#0000009e;--fg-4:#00000057;--accent:#0a0a0a;--accent-fg:#fff}:root[data-density=compact]{--section-py:clamp(48px, 6vw, 80px);--cell-p:22px}:root[data-density=spacious]{--section-py:clamp(110px, 13vw, 200px);--cell-p:48px}*{box-sizing:border-box;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;margin:0;padding:0}html{scroll-behavior:smooth}body{background:var(--bg);color:var(--fg);font-family:var(--font-sans);font-feature-settings:"ss01", "ss02", "cv11";font-size:16px;line-height:1.55;transition:background-color .25s,color .25s;overflow-x:hidden}:root[data-lang=th] body{font-family:var(--font-thai);letter-spacing:0;line-height:1.7}:root[data-lang=th] .h-section,:root[data-lang=th] .cta-title,:root[data-lang=th] .hero-title{font-family:var(--font-thai);letter-spacing:-.005em;word-break:break-word;overflow-wrap:anywhere;text-wrap:balance;font-weight:500;line-height:1.25}:root[data-lang=th] .h-section em,:root[data-lang=th] .cta-title em,:root[data-lang=th] .hero-title em{font-family:var(--font-thai);color:var(--fg-3);letter-spacing:-.005em;font-style:normal;font-weight:300}:root[data-lang=th] .hero-title{max-width:none;font-size:clamp(30px,4.8vw,58px);line-height:1.25}:root[data-lang=th] .h-section{font-size:clamp(26px,3.6vw,40px);line-height:1.3}:root[data-lang=th] .cta-title{font-size:clamp(28px,4vw,48px);line-height:1.3}:root[data-lang=th] .lede{max-width:52ch;font-size:17px;line-height:1.8}:root[data-lang=th] .job-desc,:root[data-lang=th] .proj-desc,:root[data-lang=th] .hero-sub-en{line-height:1.8}:root[data-lang=th] .nav-link{letter-spacing:0}:root[data-lang=th] .terminal,:root[data-lang=th] code{font-family:var(--font-mono)!important}:root[data-lang=th] .label-mono,:root[data-lang=th] .nav-link-num,:root[data-lang=th] .stat-value,:root[data-lang=th] .stat-unit,:root[data-lang=th] .stat-label,:root[data-lang=th] .job-period,:root[data-lang=th] .post-date,:root[data-lang=th] .proj-tag,:root[data-lang=th] .proj-status,:root[data-lang=th] .proj-glyph,:root[data-lang=th] .footer-bottom,:root[data-lang=th] .footer-col-title,:root[data-lang=th] .footer-brand-line,:root[data-lang=th] .skill-mark,:root[data-lang=th] .brand-cell-mark,:root[data-lang=th] .statement-side-eyebrow,:root[data-lang=th] .statement-side-meta-label,:root[data-lang=th] .nav-cta,:root[data-lang=th] .hero-eyebrow,:root[data-lang=th] .cta-eyebrow{letter-spacing:.04em;font-family:var(--font-thai)!important}:root[data-lang=th] .label-mono,:root[data-lang=th] .statement-side-eyebrow,:root[data-lang=th] .footer-col-title,:root[data-lang=th] .hero-eyebrow,:root[data-lang=th] .cta-eyebrow,:root[data-lang=th] .stat-label,:root[data-lang=th] .statement-side-meta-label{text-transform:none;letter-spacing:.02em;font-size:13px;font-weight:400}a{color:inherit;text-decoration:none}button{color:inherit;cursor:pointer;background:0 0;border:none;font-family:inherit}::selection{background:var(--fg);color:var(--bg)}:focus-visible{outline:2px solid var(--accent,#fff);outline-offset:2px;border-radius:2px}a:focus-visible,button:focus-visible,.btn:focus-visible,[role=button]:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible{outline:2px solid var(--accent,#fff);outline-offset:3px;box-shadow:0 0 0 4px #000000d9}.frame{max-width:var(--container-max);border-inline:1px solid var(--line);margin-inline:auto}.row{border-top:1px solid var(--line);position:relative}.row:first-child{border-top:none}.cols{grid-template-columns:repeat(var(--cols,12), 1fr);display:grid}.cell{padding:var(--cell-p);min-width:0}.cols.cols-grid>.cell{border-right:1px solid var(--line)}.cell-pad-0{padding:0}.c-1{grid-column:span 1}.c-2{grid-column:span 2}.c-3{grid-column:span 3}.c-4{grid-column:span 4}.c-5{grid-column:span 5}.c-6{grid-column:span 6}.c-7{grid-column:span 7}.c-8{grid-column:span 8}.c-9{grid-column:span 9}.c-10{grid-column:span 10}.c-12{grid-column:span 12}@media (max-width:900px){.cols{grid-template-columns:1fr!important}.cols.cols-grid>.cell{border-right:none;border-bottom:1px solid var(--line)}.cols.cols-grid>.cell:last-child{border-bottom:none}[class*=c-]{grid-column:span 1!important}}.label-mono{font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.1em;color:var(--fg-3);font-size:11px}.label-mono.dot:before{content:"";background:var(--success);width:6px;height:6px;box-shadow:0 0 8px var(--success);vertical-align:middle;border-radius:50%;margin-right:8px;display:inline-block}.row-head .label-mono{margin-bottom:16px}.h-section{letter-spacing:-.03em;color:var(--fg-1);font-size:clamp(32px,4.5vw,52px);font-weight:500;line-height:1.04}.h-section em{font-family:var(--font-serif);color:var(--fg-2);font-style:italic;font-weight:400}.h-section-th{font-family:var(--font-thai);color:var(--fg-3);max-width:540px;margin-top:10px;font-size:clamp(18px,2.2vw,24px);font-weight:400;line-height:1.35}.lede{color:var(--fg-2);max-width:56ch;font-size:18px;line-height:1.6}.lede-th{font-family:var(--font-thai);color:var(--fg-3);max-width:50ch;margin-top:14px;font-size:16px;font-weight:300;line-height:1.7}.mono{font-family:var(--font-mono)}.th-text{font-family:var(--font-thai)}.bi{grid-template-columns:1fr 1fr;gap:0;display:grid}.bi>*{padding-inline:0}.bi>.bi-th{font-family:var(--font-thai);color:var(--fg-3);border-left:1px solid var(--line);margin-left:28px;padding-left:28px;font-weight:300}@media (max-width:760px){.bi{grid-template-columns:1fr}.bi>.bi-th{border-left:none;border-top:1px solid var(--line);margin-top:16px;margin-left:0;padding-top:16px;padding-left:0}}.nav{z-index:100;background:var(--bg);position:sticky;top:0}@supports (color:color-mix(in lab, red, red)){.nav{background:color-mix(in oklab, var(--bg) 86%, transparent)}}.nav{-webkit-backdrop-filter:saturate(160%)blur(12px);border-bottom:1px solid var(--line)}.nav-inner{max-width:var(--container-max);padding:14px var(--container-px);border-inline:1px solid var(--line);align-items:center;gap:8px;margin-inline:auto;display:flex}.nav-logo{font-family:var(--font-mono);letter-spacing:-.01em;border-right:1px solid var(--line);align-items:center;gap:10px;height:28px;margin-right:8px;padding-right:18px;font-size:13.5px;font-weight:500;display:flex}.nav-logo-mark{background:var(--fg);width:26px;height:26px;font-size:12px;font-weight:700;font-family:var(--font-mono);color:var(--bg);border-radius:50%;place-items:center;display:grid;overflow:hidden}.nav-logo-mark img{object-fit:cover;object-position:50% 30%;width:100%;height:100%}.nav-links{align-items:center;gap:2px;display:flex}.nav-link{color:var(--fg-3);border-radius:6px;align-items:center;gap:6px;padding:7px 12px;font-size:13px;font-weight:450;transition:all .15s;display:inline-flex}.nav-link:hover{color:var(--fg);background:var(--surface-hover)}.nav-link-num{font-family:var(--font-mono);color:var(--fg-4);font-size:10.5px}.nav-spacer{flex:1}.nav-tail{border-left:1px solid var(--line);align-items:center;gap:6px;height:28px;padding-left:12px;display:flex}.theme-toggle,.lang-toggle{font-family:var(--font-mono);color:var(--fg-3);border-radius:6px;align-items:center;gap:6px;padding:7px 10px;font-size:12px;transition:all .15s;display:inline-flex}.theme-toggle:hover,.lang-toggle:hover{color:var(--fg);background:var(--surface-hover)}.lang-seg{border:1px solid var(--line);background:var(--bg-1);border-radius:999px;align-items:center;height:28px;padding:2px;display:inline-flex}.lang-seg-btn{font-family:var(--font-mono);letter-spacing:.06em;height:22px;color:var(--fg-3);border-radius:999px;padding:0 10px;font-size:11px;transition:all .15s}.lang-seg-btn:hover{color:var(--fg-2)}.lang-seg-btn.active{background:var(--accent);color:var(--accent-fg)}.nav-cta{background:var(--accent);color:var(--accent-fg);border-radius:999px;align-items:center;gap:7px;padding:8px 14px;font-size:13px;font-weight:500;transition:opacity .15s;display:inline-flex}.nav-cta:hover{opacity:.88}@media (max-width:760px){.nav-links{display:none}}.btn{letter-spacing:-.005em;white-space:nowrap;border:1px solid #0000;border-radius:999px;justify-content:center;align-items:center;gap:9px;height:42px;padding:0 22px;font-size:14px;font-weight:500;transition:all .15s;display:inline-flex}.btn-primary:hover{opacity:.9}.btn-ghost{color:var(--fg);border-color:var(--line-strong);background:0 0}.btn-arrow{transition:transform .15s;display:inline-flex}.hero{position:relative}.hero-v1{grid-template-columns:6fr 5fr;min-height:clamp(540px,64vh,720px);display:grid}.hero-v1>.hero-text{border-right:1px solid var(--line);isolation:isolate;flex-direction:column;justify-content:center;padding:clamp(64px,9vw,120px) clamp(32px,5vw,72px);display:flex;position:relative}.hero-eyebrow{font-family:var(--font-mono);letter-spacing:.08em;text-transform:uppercase;color:var(--fg-3);align-items:center;gap:8px;margin-bottom:28px;font-size:11px;display:inline-flex}.hero-eyebrow:before{content:"";background:var(--success);width:6px;height:6px;box-shadow:0 0 10px var(--success);border-radius:50%}.hero-title{letter-spacing:-.04em;color:var(--fg-1);max-width:14ch;font-size:clamp(40px,6.4vw,84px);font-weight:500;line-height:.98}.hero-title em{font-family:var(--font-serif);color:var(--fg-2);letter-spacing:-.02em;font-style:italic;font-weight:400}.hero-title-th{font-family:var(--font-thai);color:var(--fg-3);max-width:22ch;margin-top:18px;font-size:clamp(22px,2.8vw,30px);font-weight:400;line-height:1.3}.hero-sub{grid-template-columns:1fr;gap:0;max-width:540px;margin-top:36px;display:grid}.hero-sub-en{color:var(--fg-2);font-size:16px;line-height:1.6}.hero-sub-th{font-family:var(--font-thai);color:var(--fg-3);border-top:1px dashed var(--line);margin-top:12px;padding-top:12px;font-size:15px;font-weight:300;line-height:1.7}.hero-cta-row{flex-wrap:wrap;gap:10px;margin-top:36px;display:flex}.hero-art{background:radial-gradient(ellipse at 60% 40%, #ffffff0d, transparent 60%), radial-gradient(ellipse at 30% 80%, #78b4ff0a, transparent 60%), var(--bg);place-items:center;display:grid;position:relative;overflow:hidden}.hero-art-grid{background-image:linear-gradient(var(--line) 1px, transparent 1px), linear-gradient(90deg, var(--line) 1px, transparent 1px);opacity:.5;background-size:48px 48px;position:absolute;inset:0;-webkit-mask-image:radial-gradient(#000 30%,#0000 70%);mask-image:radial-gradient(#000 30%,#0000 70%)}.hero-art-orb{aspect-ratio:1;filter:blur(60px);opacity:.7;mix-blend-mode:screen;background:radial-gradient(circle at 30% 30%,#a87aff73,#0000 55%),radial-gradient(circle at 70% 70%,#6450c84d,#0000 55%),radial-gradient(circle,#ffffff1a,#0000 60%);border-radius:50%;width:70%;animation:16s ease-in-out infinite orbDrift;position:absolute}@keyframes orbDrift{0%,to{transform:translate(0)scale(1)}33%{transform:translate(5%,-4%)scale(1.07)}66%{transform:translate(-5%,4%)scale(.95)}}.hero-art-portrait{aspect-ratio:1;border:1px solid var(--line-strong);isolation:isolate;background:radial-gradient(at 50% 30%,#f5efe2 0%,#e8dfcc 60%,#d8ccb3 100%);place-items:center;width:78%;max-width:460px;display:grid;position:relative;overflow:hidden;box-shadow:0 0 0 1px #0006,0 30px 60px #a87aff2e,0 60px 120px #00000080}.hero-art-portrait:before{content:"";pointer-events:none;z-index:0;background-image:radial-gradient(circle at 20% 20%,#a87aff14,#0000 40%),radial-gradient(circle at 80% 80%,#ffc8780d,#0000 40%);position:absolute;inset:0}.hero-art-portrait:after{content:"BL4CKMEOW · 2026";font-family:var(--font-mono);letter-spacing:.12em;color:#0006;z-index:2;pointer-events:none;justify-content:space-between;align-items:center;font-size:10.5px;display:flex;position:absolute;bottom:16px;left:18px;right:18px}.hero-art-portrait img{z-index:1;object-fit:contain;mix-blend-mode:multiply;filter:drop-shadow(0 12px 28px #3c1e6459);width:92%;height:92%;position:relative}:root[data-theme=light] .hero-art-portrait{background:radial-gradient(at 50% 30%,#fff 0%,#f1ebd9 60%,#e2d5b9 100%);box-shadow:0 0 0 1px #0000001a,0 30px 60px #a87aff33,0 60px 120px #0000001a}@media (max-width:900px){.hero-v1{grid-template-columns:1fr}.hero-v1>.hero-text{border-right:none;border-bottom:1px solid var(--line)}.hero-art{min-height:420px}}.hero-v2{grid-template-columns:6fr 6fr;min-height:clamp(540px,64vh,720px);display:grid}.hero-v2>.hero-text{border-right:1px solid var(--line);flex-direction:column;justify-content:center;padding:clamp(64px,9vw,120px) clamp(32px,5vw,72px);display:flex}.hero-v2>.hero-term{justify-content:center;align-items:center;padding:clamp(48px,7vw,88px) clamp(32px,5vw,64px);display:flex}@media (max-width:900px){.hero-v2{grid-template-columns:1fr}.hero-v2>.hero-text{border-right:none;border-bottom:1px solid var(--line)}}.hero-v3{padding:clamp(64px,9vw,120px) clamp(32px,5vw,72px) clamp(48px,6vw,72px)}.hero-v3 .hero-title{max-width:18ch}.hero-v3-strip{border-top:1px solid var(--line);grid-template-columns:repeat(4,1fr);margin:clamp(32px,4vw,56px) calc(-1*clamp(32px,5vw,72px)) 0;display:grid}.hero-v3-strip>.cell{border-right:1px solid var(--line);padding:28px}.hero-v3-strip>.cell:last-child{border-right:none}@media (max-width:900px){.hero-v3-strip{grid-template-columns:1fr 1fr}}@media (max-width:600px){.hero-v3-strip{grid-template-columns:1fr}}.statement{letter-spacing:-.02em;color:var(--fg-3);padding:clamp(56px,6vw,96px) clamp(28px,4vw,56px);font-size:clamp(24px,2.8vw,34px);font-weight:400;line-height:1.4}.statement strong{color:var(--fg);font-weight:500}.statement .brand{color:var(--fg);align-items:baseline;gap:4px;font-weight:600;display:inline-flex}.statement-side{flex-direction:column;gap:28px;min-height:100%;padding:clamp(56px,6vw,96px) clamp(28px,4vw,56px);display:flex}.statement-side-eyebrow{font-family:var(--font-mono);letter-spacing:.1em;text-transform:uppercase;color:var(--fg-3);align-items:center;gap:8px;width:fit-content;font-size:11px;display:inline-flex}.statement-side-eyebrow:before{content:"";background:var(--success);width:6px;height:6px;box-shadow:0 0 8px var(--success);border-radius:50%}.statement-side-body{color:var(--fg-2);max-width:38ch;font-size:16px;line-height:1.65}.statement-side-avail{flex-direction:column;gap:10px;margin-top:4px;display:flex}.statement-side-avail-label{font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.1em;color:var(--fg-4);font-size:10.5px}.statement-side-avail-list{flex-direction:column;gap:6px;padding:0;list-style:none;display:flex}.statement-side-avail-list li{color:var(--fg-2);align-items:baseline;gap:10px;font-size:14.5px;line-height:1.5;display:flex}.statement-side-avail-list li:before{content:"—";color:var(--fg-4);font-family:var(--font-mono);flex-shrink:0}.statement-side-cta{background:var(--bg-1);border:1px solid var(--line);width:fit-content;color:var(--fg);border-radius:999px;justify-content:space-between;align-items:center;gap:16px;margin-top:4px;padding:10px 8px 10px 20px;font-size:13.5px;font-weight:500;transition:all .18s;display:inline-flex}.statement-side-cta:hover{border-color:var(--line-strong);background:var(--surface-hover)}.statement-side-cta-icon{background:var(--accent);width:28px;height:28px;color:var(--accent-fg);border-radius:50%;place-items:center;margin-left:8px;display:grid}.statement-side-meta{border-top:1px solid var(--line);grid-template-columns:repeat(4,1fr);display:grid}.statement-side-meta>*{border-right:1px solid var(--line);padding:22px clamp(28px,4vw,56px)}.statement-side-meta>:last-child{border-right:none}.statement-side-meta-label{font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.08em;color:var(--fg-4);margin-bottom:6px;font-size:10.5px}.statement-side-meta-value{color:var(--fg-1);font-size:14px;font-weight:500}@media (max-width:700px){.statement-side-meta{grid-template-columns:1fr 1fr}.statement-side-meta>:nth-child(2n){border-right:none}.statement-side-meta>:nth-child(-n+2){border-bottom:1px solid var(--line)}}.tabs{border:1px solid var(--line);background:var(--bg-1);border-radius:999px;align-items:center;gap:2px;padding:4px;display:inline-flex}.tab{color:var(--fg-3);cursor:pointer;border-radius:999px;padding:7px 16px;font-size:13px;font-weight:500;transition:all .15s}.tab:hover{color:var(--fg-2)}.tab.active{color:var(--accent-fg);background:var(--accent)}.brand-inline{font-family:var(--font-sans);letter-spacing:-.015em;color:var(--fg-1);font-weight:700}.brand-inline.gistda{letter-spacing:.06em;font-weight:700}.brand-inline.drite{font-weight:700;font-family:var(--font-mono);letter-spacing:-.02em}.proj{padding:var(--cell-p);flex-direction:column;gap:14px;min-height:260px;transition:background .18s;display:flex;position:relative}.proj:hover{background:var(--surface-hover)}.proj-glyph{border:1px solid var(--line);width:44px;height:44px;font-family:var(--font-mono);color:var(--fg);place-items:center;font-size:11px;font-weight:600;display:grid}.proj-meta{justify-content:space-between;align-items:center;gap:12px;display:flex}.proj-tag{font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.08em;color:var(--fg-3);font-size:11px}.proj-status{font-family:var(--font-mono);color:var(--fg-3);align-items:center;gap:6px;font-size:11px;display:inline-flex}.proj-status:before{content:"";background:var(--success);width:6px;height:6px;box-shadow:0 0 8px var(--success);border-radius:50%}.proj-status.wip:before{background:var(--warn);box-shadow:0 0 8px var(--warn)}.proj-status.archived:before{background:var(--fg-4);box-shadow:none}.proj-title{letter-spacing:-.02em;color:var(--fg-1);margin-top:4px;font-size:22px;font-weight:500;line-height:1.2}.proj-title-th{font-family:var(--font-thai);color:var(--fg-3);margin-top:6px;font-size:15px;font-weight:400;line-height:1.45}.proj-desc{color:var(--fg-3);font-size:14px;line-height:1.55}.proj-tech{flex-wrap:wrap;gap:6px;margin-top:auto;padding-top:12px;display:flex}.tag{font-family:var(--font-mono);border:1px solid var(--line);color:var(--fg-2);border-radius:3px;padding:3px 9px;font-size:11px}.proj-link-arrow{top:var(--cell-p);right:var(--cell-p);color:var(--fg-3);transition:transform .15s,color .15s;position:absolute}.proj:hover .proj-link-arrow{color:var(--fg);transform:translate(2px,-2px)}.job-row{border-top:1px solid var(--line);grid-template-columns:180px 1fr 1fr;display:grid}.job-row.job-row-2{grid-template-columns:200px 1fr}.job-row:first-child{border-top:none}.job-row>.cell{padding:32px var(--cell-p)}.job-row>.cell-period,.job-row>.cell-en{border-right:1px solid var(--line)}.job-row.job-row-2>.cell:last-child{border-right:none}.job-period{font-family:var(--font-mono);color:var(--fg-3);flex-direction:column;gap:8px;font-size:12px;display:flex}.job-current{color:var(--success);align-items:center;gap:6px;font-weight:500;display:inline-flex}.job-current:before{content:"";background:var(--success);width:6px;height:6px;box-shadow:0 0 8px var(--success);border-radius:50%}.job-role{letter-spacing:-.02em;color:var(--fg-1);font-size:20px;font-weight:500;line-height:1.25}.job-company{font-family:var(--font-mono);color:var(--fg-3);margin-top:6px;font-size:12.5px}.job-desc{color:var(--fg-2);margin-top:14px;font-size:14.5px;line-height:1.6}.job-tags{flex-wrap:wrap;gap:6px;margin-top:16px;display:flex}.job-desc-th{font-family:var(--font-thai);color:var(--fg-3);font-size:14.5px;font-weight:300;line-height:1.75}@media (max-width:900px){.job-row{grid-template-columns:1fr}.job-row>.cell-period,.job-row>.cell-en{border-right:none;border-bottom:1px solid var(--line)}}.skills-grid{grid-template-columns:repeat(3,1fr);display:grid}.skill-cell{padding:var(--cell-p);border-right:1px solid var(--line);border-bottom:1px solid var(--line);flex-direction:column;gap:16px;display:flex}.skill-cell:nth-child(3n){border-right:none}.skill-cell:nth-last-child(-n+3){border-bottom:none}@media (max-width:900px){.skills-grid{grid-template-columns:1fr 1fr}.skill-cell:nth-child(3n){border-right:1px solid var(--line)}.skill-cell:nth-child(2n){border-right:none}}@media (max-width:600px){.skills-grid{grid-template-columns:1fr}.skill-cell{border-right:none!important}}.skill-head{align-items:center;gap:10px;display:flex}.skill-mark{border:1px solid var(--line);width:26px;height:26px;font-family:var(--font-mono);color:var(--fg-2);place-items:center;font-size:10.5px;font-weight:600;display:grid}.skill-title{color:var(--fg-1);font-size:14px;font-weight:500}.skill-title-th{font-family:var(--font-thai);color:var(--fg-3);margin-left:auto;font-size:13px;font-weight:400}.skill-list{flex-wrap:wrap;gap:6px;display:flex}.posts{flex-direction:column;display:flex}.post{padding:22px var(--cell-p);border-top:1px solid var(--line);cursor:pointer;grid-template-columns:140px 1fr 1fr 80px;align-items:center;gap:0;transition:background .15s;display:grid}.post.post-3col{grid-template-columns:160px 1fr 60px}.post:hover{background:var(--surface-hover)}.post-date{font-family:var(--font-mono);color:var(--fg-3);font-size:12px}.post-title{letter-spacing:-.015em;color:var(--fg-1);font-size:17px;font-weight:500;line-height:1.35}.post-title-th{font-family:var(--font-thai);color:var(--fg-3);border-left:1px solid var(--line);padding-left:28px;font-size:14.5px;font-weight:400;line-height:1.45}.post-arrow{text-align:right;font-family:var(--font-mono);color:var(--fg-3);font-size:14px;transition:transform .15s,color .15s}.post:hover .post-arrow{color:var(--fg);transform:translate(4px)}@media (max-width:900px){.post{grid-template-columns:1fr;gap:6px}.post-title-th{border-left:none;padding-left:0}.post-arrow{text-align:left}}.stats{grid-template-columns:repeat(4,1fr);max-width:1100px;margin:0 auto;display:grid}.stat{border-right:1px solid var(--line);text-align:center;padding:32px clamp(20px,3vw,40px)}.stat:last-child{border-right:none}.stat-value{letter-spacing:-.02em;color:var(--fg-1);font-size:clamp(32px,3.5vw,48px);font-weight:500;line-height:1}.stat-unit{font-family:var(--font-mono);color:var(--fg-3);margin-left:4px;font-size:14px}.stat-label-th{font-family:var(--font-thai);color:var(--fg-4);text-transform:none;letter-spacing:0;margin-top:4px;font-size:13px;font-weight:300}@media (max-width:800px){.stats{grid-template-columns:1fr 1fr;max-width:100%}.stat:nth-child(2n){border-right:none}.stat:nth-child(-n+2){border-bottom:1px solid var(--line)}}.cta{padding:clamp(80px, 12vw, 160px) var(--cell-p);text-align:center;isolation:isolate;flex-direction:column;align-items:center;gap:22px;display:flex;position:relative;overflow:hidden}.cta:before{content:"";background-image:linear-gradient(var(--line) 1px, transparent 1px), linear-gradient(90deg, var(--line) 1px, transparent 1px);opacity:.35;pointer-events:none;z-index:-1;background-size:56px 56px;position:absolute;inset:0;-webkit-mask-image:radial-gradient(#0000 20%,#000 80%);mask-image:radial-gradient(#0000 20%,#000 80%)}.cta-eyebrow{color:var(--fg-3);font-family:var(--font-mono);letter-spacing:.12em;text-transform:uppercase;font-size:11px}.cta-title{letter-spacing:-.035em;max-width:24ch;color:var(--fg-1);font-size:clamp(36px,5vw,60px);font-weight:500;line-height:1.05}.cta-title em{font-family:var(--font-serif);color:var(--fg-2);font-style:italic;font-weight:400}.cta-title-th{font-family:var(--font-thai);color:var(--fg-3);max-width:28ch;margin-top:-6px;font-size:clamp(18px,2vw,22px);font-weight:400;line-height:1.4}.cta-row{flex-wrap:wrap;justify-content:center;gap:10px;margin-top:12px;display:flex}.socials{gap:4px;margin-top:24px;display:flex}.social{border:1px solid var(--line);width:38px;height:38px;color:var(--fg-2);place-items:center;transition:all .15s;display:grid}.social:hover{background:var(--surface-hover);border-color:var(--line-strong);color:var(--fg)}.footer{border-top:1px solid var(--line)}.footer-inner{max-width:var(--container-max);border-inline:1px solid var(--line);margin-inline:auto}.footer-grid{grid-template-columns:1.4fr 1fr 1fr 1fr 1fr;display:grid}.footer-col{padding:40px var(--cell-p);border-right:1px solid var(--line);min-height:240px}.footer-col:last-child{border-right:none}@media (max-width:900px){.footer-grid{grid-template-columns:1fr 1fr}.footer-col{border-bottom:1px solid var(--line);min-height:auto}.footer-col:nth-child(2n){border-right:none}.footer-col:nth-last-child(-n+2){border-bottom:none}}.footer-brand .nav-logo{border:none;height:auto;margin:0;padding:0}.footer-brand-line{font-family:var(--font-mono);color:var(--fg-3);max-width:28ch;margin-top:14px;font-size:12px;line-height:1.7}.footer-brand-line.th{font-family:var(--font-thai);color:var(--fg-4);margin-top:6px;font-weight:300}.footer-col-title{font-family:var(--font-mono);letter-spacing:.12em;text-transform:uppercase;color:var(--fg-3);margin-bottom:18px;font-size:11px}.footer-col-link{color:var(--fg-2);padding:4px 0;font-size:13.5px;transition:color .15s;display:block}.footer-col-link:hover{color:var(--fg)}.footer-bottom{padding:18px var(--cell-p);border-top:1px solid var(--line);font-family:var(--font-mono);color:var(--fg-3);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;font-size:11.5px;display:flex}.footer-bottom-status:before{content:"";background:var(--success);width:6px;height:6px;box-shadow:0 0 8px var(--success);vertical-align:middle;border-radius:50%;margin-right:8px;display:inline-block}.terminal{background:var(--bg-1);border:1px solid var(--line);width:100%;max-width:540px;font-family:var(--font-mono);font-size:12.5px;position:relative}.terminal-head{border-bottom:1px solid var(--line);background:var(--bg-2);align-items:center;gap:10px;padding:11px 14px;display:flex}.terminal-dot{background:var(--bg-2);border-radius:50%;width:10px;height:10px}.terminal-dot.r{background:#ff5f57}.terminal-dot.y{background:#febc2e}.terminal-dot.g{background:#28c840}.terminal-title{text-align:center;color:var(--fg-3);flex:1;font-size:11px}.terminal-body{min-height:260px;padding:18px 20px;line-height:1.7}.terminal-line{white-space:pre-wrap;display:block}.t-prompt{color:var(--success)}.t-cmd{color:var(--fg)}.t-flag{color:var(--info)}.t-str{color:var(--warn)}.t-comment{color:var(--fg-4)}.t-key{color:#c084fc}.t-num{color:#fb923c}.t-fn{color:#60a5fa}.t-ok{color:var(--success)}.t-err{color:#f87171}.t-dim{color:var(--fg-3)}.cursor{background:var(--fg);vertical-align:text-bottom;width:7px;height:1em;margin-left:2px;animation:1s steps(2,end) infinite blink;display:inline-block}@keyframes blink{50%{opacity:0}}.spotlight{pointer-events:none;z-index:0;background:radial-gradient(560px circle at var(--mx,50%) var(--my,50%), #ffffff0a, transparent 40%);position:fixed;inset:0}:root[data-theme=light] .spotlight{background:radial-gradient(560px circle at var(--mx,50%) var(--my,50%), #00000008, transparent 40%)}.fade-up{opacity:0;transition:opacity .7s cubic-bezier(.16,1,.3,1),transform .7s cubic-bezier(.16,1,.3,1);transform:translateY(16px)}.fade-up.in{opacity:1;transform:translateY(0)}.now-clock-row{font-family:var(--font-mono);color:var(--fg-3);align-items:center;gap:8px;margin-top:22px;font-size:12px;display:inline-flex}.now-clock-row:before{content:"";background:var(--success);width:6px;height:6px;box-shadow:0 0 8px var(--success);border-radius:50%}.brand-row{flex-wrap:wrap;align-items:center;gap:clamp(16px,2.5vw,32px);display:flex}.brand-row-label{font-family:var(--font-mono);letter-spacing:.1em;text-transform:uppercase;color:var(--fg-4);white-space:nowrap;font-size:11px}.brand-row-divider{background:var(--line);flex:1;min-width:40px;height:1px}.brand-row-items{flex-wrap:wrap;align-items:center;gap:clamp(10px,1.6vw,20px);display:inline-flex}.brand-row-name{font-family:var(--font-sans);letter-spacing:-.01em;color:var(--fg-2);font-size:clamp(14px,1.4vw,17px);font-weight:500;transition:color .15s}.brand-row-name:hover{color:var(--fg)}.brand-row-dot{color:var(--fg-4);font-family:var(--font-mono);font-size:12px}:root[data-lang=th] .brand-row-label{text-transform:none;letter-spacing:.02em;font-size:13px;font-weight:400;font-family:var(--font-thai)!important}@media (max-width:700px){.brand-row-divider{display:none}}.prism{pointer-events:none;z-index:0;position:absolute;inset:0;overflow:hidden}.prism:before{content:"";aspect-ratio:1;filter:blur(38px)saturate(1.15);background:conic-gradient(from 200deg at 50% 100%,#0000 0deg,#60a5fa8c 22deg,#2dd4bf8c 50deg,#4ade808c 75deg,#fbbf248c 95deg,#ff7a4599 115deg,#f871718c 140deg,#0000 160deg);width:130%;position:absolute;bottom:-10%;left:50%;transform:translate(-50%);-webkit-mask-image:radial-gradient(at 50% 100%,#000 25%,#0000 75%);mask-image:radial-gradient(at 50% 100%,#000 25%,#0000 75%)}.prism:after{content:"";opacity:.85;mix-blend-mode:multiply;background-image:repeating-linear-gradient(#0000 0 2px,#0000008c 2px 3px);position:absolute;inset:0;-webkit-mask-image:radial-gradient(at 50% 95%,#000 5%,#0000 65%);mask-image:radial-gradient(at 50% 95%,#000 5%,#0000 65%)}:root[data-theme=light] .prism:before{opacity:.55;filter:blur(50px)saturate(.95)}:root[data-theme=light] .prism:after{opacity:.35}.prism.prism-soft:before{opacity:.55;filter:blur(54px)saturate(.95)}.prism.prism-soft:after{opacity:.55}.painterly-stripes{filter:blur(.6px)saturate(1.2)brightness(.92);pointer-events:none;background:linear-gradient(94deg,#1a0f12 0% 4%,#ff7a45 7% 11%,#1a0f12 13%,#ec4899 17% 22%,#1a0f12 24%,#60a5fa 28% 33%,#1a0f12 36%,#fbbf24 40% 45%,#1a0f12 47%,#d946ef 51% 56%,#1a0f12 58%,#4ade80 62% 67%,#1a0f12 70%,#fb7185 74% 79%,#1a0f12 82%,#22d3ee 86% 91%,#1a0f12 94% 100%);position:absolute;inset:0}.painterly-stripes:after{content:"";mix-blend-mode:multiply;background-image:repeating-linear-gradient(96deg,#0000 0 4px,#0000002e 4px 6px);position:absolute;inset:0}.rainbow-bar{background:linear-gradient(104deg,#ff7a45 0 7%,#f87171 7% 13%,#0a0a0a 13% 15%,#ec4899 15% 23%,#2563eb 23% 32%,#0a0a0a 32% 34%,#4ade80 34% 42%,#e8dfcc 42% 50%,#fbbf24 50% 58%,#ff8a3c 58% 66%,#ef4444 66% 75%,#0a0a0a 75% 77%,#ff7a45 77% 85%,#f9a8d4 85% 100%);height:18px;position:relative;box-shadow:inset 0 1px #ffffff1f,inset 0 -1px #00000073}.rainbow-bar:before{content:"";mix-blend-mode:multiply;opacity:.85;pointer-events:none;background-image:radial-gradient(#0000008c .6px,#0000 .6px),radial-gradient(#ffffff47 .5px,#0000 .5px),repeating-linear-gradient(104deg,#0000 0 6px,#0000002e 6px 7px);background-position:0 0,1px 2px,0 0;background-size:3px 3px,4px 4px,auto;position:absolute;inset:0}.rainbow-bar:after{content:"";mix-blend-mode:screen;opacity:.5;pointer-events:none;background-image:radial-gradient(#ffffff59 .6px,#0000 .7px);background-position:2px 1px;background-size:5px 5px;position:absolute;inset:0}.rainbow-bar.tall{height:26px}.rainbow-bar.subtle{opacity:.92}.btn-warm{background:var(--c-amber);color:#1a1208;border-color:var(--c-amber);transition:box-shadow .2s,transform .15s,background .15s;box-shadow:0 0 #fbbf2400}.btn-warm:hover{background:#ffd24a;box-shadow:0 0 0 6px #fbbf2429,0 12px 30px #fbbf2438}.hero-title em,.h-section em,.cta-title em{color:var(--c-orange)}:root[data-theme=light] .hero-title em,:root[data-theme=light] .h-section em,:root[data-theme=light] .cta-title em{color:#d65a25}.label-mono.dot.c-blue:before{background:var(--c-blue);box-shadow:0 0 8px var(--c-blue)}.label-mono.dot.c-orange:before{background:var(--c-orange);box-shadow:0 0 8px var(--c-orange)}.label-mono.dot.c-pink:before{background:var(--c-pink);box-shadow:0 0 8px var(--c-pink)}.label-mono.dot.c-purple:before{background:var(--c-purple);box-shadow:0 0 8px var(--c-purple)}.label-mono.dot.c-amber:before{background:var(--c-amber);box-shadow:0 0 8px var(--c-amber)}.label-mono.dot.c-cyan:before{background:var(--c-cyan);box-shadow:0 0 8px var(--c-cyan)}.stats .stat .stat-value{color:var(--fg-1)}.stats .stat .stat-unit{color:var(--fg-3)}.proj-glyph[data-cat=space]{color:var(--c-purple);border-color:#a78bfa73}.proj-glyph[data-cat=infra]{color:var(--c-blue);border-color:#60a5fa73}.proj-glyph[data-cat=web]{color:var(--c-orange);border-color:#ff7a4573}.proj-glyph[data-cat=tool]{color:var(--c-green);border-color:#4ade8073}.proj-glyph[data-cat=data]{color:var(--c-cyan);border-color:#22d3ee73}.proj-glyph[data-cat=lab]{color:var(--c-pink);border-color:#ec489973}.proj:hover .proj-glyph[data-cat]{background:currentColor}@supports (color:color-mix(in lab, red, red)){.proj:hover .proj-glyph[data-cat]{background:color-mix(in oklab, currentColor 12%, transparent)}}.hero-term{isolation:isolate;position:relative}.hero-term .prism{z-index:-1}.terminal{z-index:1;position:relative;box-shadow:0 0 0 1px #00000080,0 30px 80px #0000008c}.cta{isolation:isolate}.cta .prism{z-index:-1;opacity:.85}.cta:before{opacity:.18}.proj,.post{--hov-stroke:var(--c-amber);--hov-glow:var(--c-orange);position:relative}.hov-frame{pointer-events:none;z-index:1;position:absolute;inset:0}.btn{isolation:isolate;transition:transform .22s cubic-bezier(.34,1.56,.64,1),box-shadow .25s,border-color .2s,color .25s,background .25s;position:relative;overflow:hidden}.btn-primary{background:var(--accent);color:var(--accent-fg)}.btn-primary:before{content:"";background:linear-gradient(180deg, var(--c-amber), var(--c-orange));z-index:-1;pointer-events:none;transition:transform .42s cubic-bezier(.65,0,.35,1);position:absolute;inset:0;transform:translateY(101%)}.btn-primary:hover{color:#1a0d05;box-shadow:0 10px 28px -10px #fbbf2473}.btn-primary:hover:before{transform:translateY(0)}.btn-primary:active{transform:scale(.97)}@keyframes btnArrowNudge{0%,60%,to{transform:translate(0)}75%{transform:translate(3px)}90%{transform:translate(1px)}}.btn-arrow{will-change:transform;transition:transform .28s cubic-bezier(.34,1.56,.64,1);animation:2.4s ease-in-out infinite btnArrowNudge}.btn:hover .btn-arrow{animation:none;transform:translate(5px)}.btn-ghost:hover{background:var(--surface-hover);border-color:var(--fg-2)}.btn-ghost:active{transform:scale(.97)}.btn-warm{position:relative}.btn-warm:before{content:"";pointer-events:none;z-index:-1;background:linear-gradient(100deg,#0000 38%,#ffffff52 50%,#0000 62%);transition:transform .7s cubic-bezier(.22,1,.36,1);position:absolute;inset:0;transform:translate(-130%)skew(-12deg)}.btn-warm:hover:before{transform:translate(130%)skew(-12deg)}.btn-warm:active{transform:scale(.97)}.nav-cta{isolation:isolate;position:relative;overflow:hidden}.nav-cta:before{content:"";pointer-events:none;z-index:-1;background:linear-gradient(100deg,#0000 38%,#ffffff73 50%,#0000 62%);transition:transform .6s cubic-bezier(.22,1,.36,1);position:absolute;inset:0;transform:translate(-130%)skew(-12deg)}.nav-cta:hover:before{transform:translate(130%)skew(-12deg)}.nav-cta:active{transform:scale(.96)}.statement-side-cta .statement-side-cta-icon{transition:transform .35s cubic-bezier(.34,1.56,.64,1)}.statement-side-cta:hover .statement-side-cta-icon{transform:translate(3px)rotate(-8deg)}.social{transition:color .2s,background .2s,border-color .2s,transform .25s cubic-bezier(.34,1.56,.64,1)}.social:hover{transform:translateY(-2px)}:root[data-hoverfx=off] .hov-frame,:root[data-hoverfx=off] .btn-primary:before,:root[data-hoverfx=off] .btn-warm:before,:root[data-hoverfx=off] .nav-cta:before{display:none!important}@media (prefers-reduced-motion:reduce){*,:before,:after{scroll-behavior:auto!important;transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}.btn-primary:before,.btn-warm:before,.nav-cta:before{transition:none}.hero-eyebrow .dot,.status-dot{animation:none!important}}:root[data-color=off] .proj,:root[data-color=off] .post{--hov-stroke:var(--fg);--hov-glow:var(--fg-3)}:root[data-color=off] .btn-primary:before{background:linear-gradient(#2a2a2a,#111)}:root[data-color=off] .btn-primary:hover{color:var(--accent-fg)}:root[data-color=off] .prism,:root[data-color=off] .painterly-stripes,:root[data-color=off] .rainbow-bar{display:none!important}:root[data-color=off] .hero-title em,:root[data-color=off] .h-section em,:root[data-color=off] .cta-title em{color:var(--fg-2)}:root[data-color=off] .stats .stat .stat-value{color:var(--fg-1)!important}:root[data-color=off] .btn-warm{background:var(--accent);color:var(--accent-fg);border-color:var(--accent);box-shadow:none}@keyframes statusPulse{0%,to{box-shadow:0 0 0 0 #4ade808c, 0 0 10px var(--success);transform:scale(1)}50%{box-shadow:0 0 0 7px #4ade8000, 0 0 14px var(--success);transform:scale(1.12)}}.label-mono.dot,.hero-eyebrow,.statement-side-eyebrow,.footer-bottom-status,.now-clock-row,.job-current,.proj-status{align-items:center;gap:8px;line-height:1;display:inline-flex}.label-mono.dot:before,.hero-eyebrow:before,.statement-side-eyebrow:before,.footer-bottom-status:before{content:"";background:var(--success);vertical-align:middle;border-radius:50%;flex-shrink:0;width:7px;height:7px;margin-right:0}.hero-eyebrow:before{background:var(--success);width:8px;height:8px;box-shadow:0 0 10px var(--success);animation:2.4s cubic-bezier(.4,0,.6,1) infinite statusPulse}.brand-row-dot{vertical-align:middle;align-items:center;line-height:1;display:inline-flex}@keyframes hovHueShift{0%{filter:hue-rotate()}to{filter:hue-rotate(360deg)}}.stats{text-align:center;grid-template-columns:repeat(4,1fr)}.stat{text-align:center;flex-direction:column;justify-content:center;align-items:center;display:flex}.stat-value{letter-spacing:-.02em;color:var(--fg-1);font-size:clamp(32px,3.5vw,48px);font-weight:550}.stat-unit{color:var(--fg-3);margin-left:6px;font-size:.42em;font-weight:400}.stat-label{font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.08em;color:var(--fg-3);margin-top:10px;font-size:11.5px}.statement-side-meta{text-align:center;grid-template-columns:repeat(4,1fr);max-width:100%;margin-left:auto;margin-right:auto}.statement-side-meta>div{flex-direction:column;justify-content:center;align-items:center;gap:6px;display:flex}@media (max-width:700px){.statement-side-meta{grid-template-columns:repeat(2,1fr)}}.cols.cols-grid>.cell{border-left:none}.cols.cols-grid>.cell:last-child{border-right:none}.frame>.row:first-child{border-top:none}.proj-link-arrow{justify-content:center;align-items:center;width:28px;height:28px;display:inline-flex}.proj-link-arrow svg{width:18px;height:18px}.post-arrow{justify-content:center;align-items:center;width:36px;height:36px;font-size:20px;line-height:1;display:inline-flex}.post-arrow svg{width:18px;height:18px}.proj .hov-frame,.post .hov-frame{width:calc(100% + 2px)!important;height:calc(100% + 2px)!important;inset:-1px!important}@property --tw-translate-x{syntax:"*";inherits:false;initial-value:0}@property --tw-translate-y{syntax:"*";inherits:false;initial-value:0}@property --tw-translate-z{syntax:"*";inherits:false;initial-value:0}@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-space-y-reverse{syntax:"*";inherits:false;initial-value:0}@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-tracking{syntax:"*";inherits:false}@property --tw-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-shadow-color{syntax:"*";inherits:false}@property --tw-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-inset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-shadow-color{syntax:"*";inherits:false}@property --tw-inset-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-ring-color{syntax:"*";inherits:false}@property --tw-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-ring-color{syntax:"*";inherits:false}@property --tw-inset-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-ring-inset{syntax:"*";inherits:false}@property --tw-ring-offset-width{syntax:"<length>";inherits:false;initial-value:0}@property --tw-ring-offset-color{syntax:"*";inherits:false;initial-value:#fff}@property --tw-ring-offset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-outline-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-blur{syntax:"*";inherits:false}@property --tw-brightness{syntax:"*";inherits:false}@property --tw-contrast{syntax:"*";inherits:false}@property --tw-grayscale{syntax:"*";inherits:false}@property --tw-hue-rotate{syntax:"*";inherits:false}@property --tw-invert{syntax:"*";inherits:false}@property --tw-opacity{syntax:"*";inherits:false}@property --tw-saturate{syntax:"*";inherits:false}@property --tw-sepia{syntax:"*";inherits:false}@property --tw-drop-shadow{syntax:"*";inherits:false}@property --tw-drop-shadow-color{syntax:"*";inherits:false}@property --tw-drop-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-drop-shadow-size{syntax:"*";inherits:false}@property --tw-duration{syntax:"*";inherits:false}@keyframes spin{to{transform:rotate(360deg)}}@keyframes pulse{50%{opacity:.5}}
