@font-face{font-family:Syne;font-style:normal;font-weight:400;font-display:swap;src:url(../media/ab624315db63c58d-s.028be875.woff2)format("woff2");unicode-range:U+370-377,U+37A-37F,U+384-38A,U+38C,U+38E-3A1,U+3A3-3FF}@font-face{font-family:Syne;font-style:normal;font-weight:400;font-display:swap;src:url(../media/e94b8ab81811a983-s.399ca42d.woff2)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:Syne;font-style:normal;font-weight:400;font-display:swap;src:url(../media/0c795a286deabae8-s.p.b6c48e4e.woff2)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:Syne;font-style:normal;font-weight:700;font-display:swap;src:url(../media/ab624315db63c58d-s.028be875.woff2)format("woff2");unicode-range:U+370-377,U+37A-37F,U+384-38A,U+38C,U+38E-3A1,U+3A3-3FF}@font-face{font-family:Syne;font-style:normal;font-weight:700;font-display:swap;src:url(../media/e94b8ab81811a983-s.399ca42d.woff2)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:Syne;font-style:normal;font-weight:700;font-display:swap;src:url(../media/0c795a286deabae8-s.p.b6c48e4e.woff2)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:Syne;font-style:normal;font-weight:800;font-display:swap;src:url(../media/ab624315db63c58d-s.028be875.woff2)format("woff2");unicode-range:U+370-377,U+37A-37F,U+384-38A,U+38C,U+38E-3A1,U+3A3-3FF}@font-face{font-family:Syne;font-style:normal;font-weight:800;font-display:swap;src:url(../media/e94b8ab81811a983-s.399ca42d.woff2)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:Syne;font-style:normal;font-weight:800;font-display:swap;src:url(../media/0c795a286deabae8-s.p.b6c48e4e.woff2)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:Syne Fallback;src:local(Arial);ascent-override:93.93%;descent-override:27.93%;line-gap-override:0.0%;size-adjust:98.47%}.syne_d33c593e-module__O1H16a__className{font-family:Syne,Syne Fallback;font-style:normal}.syne_d33c593e-module__O1H16a__variable{--font-syne:"Syne","Syne Fallback"}
@font-face{font-family:DM Mono;font-style:italic;font-weight:300;font-display:swap;src:url(../media/ce8c9d7a56f920bc-s.ce8d954f.woff2)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:DM Mono;font-style:italic;font-weight:300;font-display:swap;src:url(../media/475197ef9cf73ba9-s.p.035d6fd3.woff2)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:DM Mono;font-style:italic;font-weight:400;font-display:swap;src:url(../media/587b2df5ecc06205-s.fb36229b.woff2)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:DM Mono;font-style:italic;font-weight:400;font-display:swap;src:url(../media/bdef460321aa07a0-s.p.c4530df2.woff2)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:DM Mono;font-style:normal;font-weight:300;font-display:swap;src:url(../media/ba8e772932784a28-s.7bb0ada4.woff2)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:DM Mono;font-style:normal;font-weight:300;font-display:swap;src:url(../media/7546fe8f902b88b8-s.p.5f7c9333.woff2)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:DM Mono;font-style:normal;font-weight:400;font-display:swap;src:url(../media/b12e986493c137cf-s.4b5f6188.woff2)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:DM Mono;font-style:normal;font-weight:400;font-display:swap;src:url(../media/36363bfb06833f56-s.p.d8302362.woff2)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:DM Mono Fallback;src:local(Arial);ascent-override:73.71%;descent-override:23.03%;line-gap-override:0.0%;size-adjust:134.59%}.dm_mono_e0106f1c-module__f9gnrq__className{font-family:DM Mono,DM Mono Fallback}.dm_mono_e0106f1c-module__f9gnrq__variable{--font-dm-mono:"DM Mono","DM Mono Fallback"}
@font-face{font-family:Noto Sans Thai;font-style:normal;font-weight:300;font-stretch:100%;font-display:swap;src:url(../media/bfd813093b8ca1bb-s.p.88bd3266.woff2)format("woff2");unicode-range:U+2D7,U+303,U+331,U+E01-E5B,U+200C-200D,U+25CC}@font-face{font-family:Noto Sans Thai;font-style:normal;font-weight:300;font-stretch:100%;font-display:swap;src:url(../media/acc5f86302586f33-s.6a9181d3.woff2)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:Noto Sans Thai;font-style:normal;font-weight:300;font-stretch:100%;font-display:swap;src:url(../media/f304c3cf3765fb5f-s.p.607a00cf.woff2)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:Noto Sans Thai;font-style:normal;font-weight:400;font-stretch:100%;font-display:swap;src:url(../media/bfd813093b8ca1bb-s.p.88bd3266.woff2)format("woff2");unicode-range:U+2D7,U+303,U+331,U+E01-E5B,U+200C-200D,U+25CC}@font-face{font-family:Noto Sans Thai;font-style:normal;font-weight:400;font-stretch:100%;font-display:swap;src:url(../media/acc5f86302586f33-s.6a9181d3.woff2)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:Noto Sans Thai;font-style:normal;font-weight:400;font-stretch:100%;font-display:swap;src:url(../media/f304c3cf3765fb5f-s.p.607a00cf.woff2)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:Noto Sans Thai;font-style:normal;font-weight:600;font-stretch:100%;font-display:swap;src:url(../media/bfd813093b8ca1bb-s.p.88bd3266.woff2)format("woff2");unicode-range:U+2D7,U+303,U+331,U+E01-E5B,U+200C-200D,U+25CC}@font-face{font-family:Noto Sans Thai;font-style:normal;font-weight:600;font-stretch:100%;font-display:swap;src:url(../media/acc5f86302586f33-s.6a9181d3.woff2)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:Noto Sans Thai;font-style:normal;font-weight:600;font-stretch:100%;font-display:swap;src:url(../media/f304c3cf3765fb5f-s.p.607a00cf.woff2)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:Noto Sans Thai Fallback;src:local(Arial);ascent-override:99.79%;descent-override:42.32%;line-gap-override:0.0%;size-adjust:106.33%}.noto_sans_thai_eeccf45a-module__f1VsEa__className{font-family:Noto Sans Thai,Noto Sans Thai Fallback;font-style:normal}.noto_sans_thai_eeccf45a-module__f1VsEa__variable{--font-noto-thai:"Noto Sans Thai","Noto Sans Thai 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-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-border-style:solid;--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}}}@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-mono:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace;--spacing:.25rem;--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)}}@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{.visible{visibility:visible}.static{position:static}.start{inset-inline-start:var(--spacing)}.flex{display:flex}.hidden{display:none}.inline{display:inline}.table{display:table}.transform{transform:var(--tw-rotate-x,)var(--tw-rotate-y,)var(--tw-rotate-z,)var(--tw-skew-x,)var(--tw-skew-y,)}.border{border-style:var(--tw-border-style);border-width:1px}.italic{font-style:italic}.antialiased{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.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)}.transition{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to,opacity,box-shadow,transform,translate,scale,rotate,filter,-webkit-backdrop-filter,backdrop-filter,display,content-visibility,overlay,pointer-events;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}}:root{--bg:#050810;--surface:#0d1220;--surface2:#141928;--accent:#00f5c4;--accent2:#6c63ff;--accent3:#ff6b6b;--text:#e8eaf6;--muted:#8892a4;--border:#ffffff12;--glow:0 0 40px #00f5c426}*{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{background:var(--bg);color:var(--text);font-family:var(--font-noto-thai),var(--font-dm-mono),sans-serif;cursor:none;overflow-x:hidden}.cursor{background:var(--accent);pointer-events:none;z-index:9999;mix-blend-mode:exclusion;border-radius:50%;width:12px;height:12px;transition:transform .1s;position:fixed}.cursor-ring{border:1.5px solid var(--accent);pointer-events:none;z-index:9998;opacity:.5;border-radius:50%;width:36px;height:36px;transition:all .25s;position:fixed}body:before{content:"";pointer-events:none;z-index:1000;opacity:.4;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)' opacity='0.03'/%3E%3C/svg%3E");position:fixed;inset:0}.header-container{z-index:1000;pointer-events:none;justify-content:center;width:100%;padding-top:24px;padding-left:20px;padding-right:20px;transition:all .3s;display:flex;position:fixed;top:0;left:0}nav.site-nav{pointer-events:auto;background:0 0;border:1px solid #0000;border-radius:100px;justify-content:space-between;align-items:center;width:100%;max-width:1200px;padding:16px 0;transition:all .5s cubic-bezier(.4,0,.2,1);display:flex}nav.site-nav.scrolled{-webkit-backdrop-filter:blur(20px);background:#0d1220d9;border-color:#00f5c433;max-width:800px;padding:12px 32px;box-shadow:0 10px 30px #00000080,0 0 20px #00f5c41a}.logo{font-family:var(--font-syne),"Syne",sans-serif;letter-spacing:-.02em;color:var(--text);cursor:pointer;align-items:center;gap:8px;font-size:1.3rem;font-weight:800;text-decoration:none;display:flex}.logo-icon{border:1px solid var(--accent);width:32px;height:32px;color:var(--accent);background:#00f5c41a;border-radius:8px;justify-content:center;align-items:center;font-size:.9rem;transition:all .3s;display:flex}.logo:hover .logo-icon{background:var(--accent);color:var(--bg)}.logo span{color:var(--accent)}.nav-links{align-items:center;gap:8px;list-style:none;display:flex}.nav-links a{color:var(--muted);font-family:var(--font-dm-mono),"DM Mono",monospace;letter-spacing:.1em;text-transform:uppercase;border-radius:100px;padding:8px 16px;font-size:.75rem;text-decoration:none;transition:all .3s}.nav-links a:hover{color:var(--accent);background:#00f5c40d}.nav-links a.active{color:var(--accent);background:#00f5c41a}.nav-cta{margin-left:12px;font-weight:700;box-shadow:0 0 15px #00f5c44d;background:var(--accent)!important;color:var(--bg)!important;font-family:var(--font-syne),"Syne",sans-serif!important;letter-spacing:.05em!important;border-radius:100px!important;padding:10px 24px!important}.nav-cta:hover{transform:translateY(-2px);box-shadow:0 0 25px #00f5c480;background:#fff!important}#hero{align-items:center;min-height:100vh;padding:120px 40px 80px;display:flex;position:relative;overflow:hidden}.hero-grid{background-image:linear-gradient(#00f5c40a 1px,#0000 1px),linear-gradient(90deg,#00f5c40a 1px,#0000 1px);background-size:60px 60px;animation:20s linear infinite gridShift;position:absolute;inset:0}@keyframes gridShift{0%{transform:perspective(500px)rotateX(10deg)translateY(0)}to{transform:perspective(500px)rotateX(10deg)translateY(60px)}}.hero-orb{filter:blur(80px);pointer-events:none;border-radius:50%;position:absolute}.orb1{background:#00f5c414;width:500px;height:500px;top:-100px;right:-100px}.orb2{background:#6c63ff14;width:400px;height:400px;bottom:0;left:20%}.orb3{background:#ff6b6b0d;width:300px;height:300px;top:30%;left:-50px}.hero-content{width:100%;max-width:1200px;margin:0 auto;position:relative}.hero-tag{font-family:var(--font-dm-mono),"DM Mono",monospace;letter-spacing:.15em;text-transform:uppercase;color:var(--accent);background:#00f5c414;border:1px solid #00f5c433;border-radius:100px;align-items:center;gap:8px;margin-bottom:32px;padding:6px 16px;font-size:.7rem;display:inline-flex}.hero-tag:before{content:"";background:var(--accent);border-radius:50%;width:6px;height:6px;animation:2s infinite pulse}@keyframes pulse{50%{opacity:.5}}.hero-name{font-family:var(--font-syne),"Syne",sans-serif;letter-spacing:-.04em;margin-bottom:24px;font-size:clamp(2.8rem,6.5vw,6.5rem);font-weight:800;line-height:.95}.hero-name .line2{color:var(--accent)}.hero-sub{color:var(--muted);max-width:560px;font-size:clamp(1rem,2vw,1.3rem);line-height:1.7;font-family:var(--font-noto-thai),"Noto Sans Thai",sans-serif;margin-bottom:48px;font-weight:300}.hero-actions{flex-wrap:wrap;gap:16px;display:flex}.btn-primary{background:var(--accent);color:var(--bg);font-family:var(--font-syne),"Syne",sans-serif;letter-spacing:.05em;cursor:none;border:none;border-radius:6px;align-items:center;gap:8px;padding:14px 32px;font-size:.9rem;font-weight:700;text-decoration:none;transition:all .3s;display:inline-flex}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 12px 32px #00f5c44d}.btn-outline{color:var(--text);border:1px solid var(--border);font-family:var(--font-syne),"Syne",sans-serif;letter-spacing:.05em;cursor:none;background:0 0;border-radius:6px;padding:14px 32px;font-size:.9rem;font-weight:700;text-decoration:none;transition:all .3s}.btn-outline:hover{border-color:var(--accent);color:var(--accent);transform:translateY(-2px)}.hero-stats{flex-direction:column;gap:24px;display:flex;position:absolute;top:50%;right:0;transform:translateY(-50%)}.stat-item{text-align:right}.stat-num{font-family:var(--font-syne),"Syne",sans-serif;color:var(--accent);font-size:2.5rem;font-weight:800;line-height:1}.stat-label{font-family:var(--font-dm-mono),"DM Mono",monospace;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin-top:4px;font-size:.65rem}@keyframes fadeUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeLeft{0%{opacity:0;transform:translateY(-50%)translate(30px)}to{opacity:1;transform:translateY(-50%)translate(0)}}section{padding:100px 40px}.section-header{justify-content:space-between;align-items:flex-end;margin-bottom:64px;display:flex}.section-label{font-family:var(--font-dm-mono),"DM Mono",monospace;letter-spacing:.2em;text-transform:uppercase;color:var(--accent);margin-bottom:12px;font-size:.7rem}.section-title{font-family:var(--font-syne),"Syne",sans-serif;letter-spacing:-.03em;font-size:clamp(2rem,4vw,3.5rem);font-weight:800;line-height:1.05}.max-container{max-width:1200px;margin:0 auto}#about{background:var(--surface)}.about-grid{grid-template-columns:1fr 1fr;align-items:center;gap:80px;display:grid}.about-visual{position:relative}.avatar-frame{background:linear-gradient(135deg,var(--surface2),#1e2540);border:1px solid var(--border);border-radius:24px;justify-content:center;align-items:center;width:300px;height:300px;display:flex;position:relative;overflow:hidden}.avatar-frame:before{content:"";background:linear-gradient(135deg,var(--accent),var(--accent2));z-index:-1;opacity:.5;border-radius:24px;position:absolute;inset:-1px}.avatar-initials{font-family:var(--font-syne),"Syne",sans-serif;color:var(--accent);letter-spacing:-.05em;font-size:5rem;font-weight:800}.floating-badge{background:var(--bg);border:1px solid var(--accent);font-family:var(--font-dm-mono),"DM Mono",monospace;color:var(--accent);letter-spacing:.05em;border-radius:12px;padding:10px 16px;font-size:.7rem;animation:3s ease-in-out infinite float;position:absolute}.badge1{animation-delay:0s;top:-20px;right:-30px}.badge2{animation-delay:1s;bottom:30px;right:-40px}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}.about-text p{color:var(--muted);font-size:1rem;line-height:1.8;font-family:var(--font-noto-thai),"Noto Sans Thai",sans-serif;margin-bottom:20px;font-weight:300}.skills-grid{flex-wrap:wrap;gap:10px;margin-top:32px;display:flex}.skill-tag{font-family:var(--font-dm-mono),"DM Mono",monospace;color:var(--accent);letter-spacing:.05em;background:#00f5c40f;border:1px solid #00f5c426;border-radius:4px;padding:6px 14px;font-size:.72rem}#portfolio{background:var(--bg)}.portfolio-grid{grid-template-columns:repeat(3,1fr);gap:24px;display:grid}.portfolio-card{background:var(--surface);border:1px solid var(--border);cursor:none;border-radius:16px;transition:all .4s;position:relative;overflow:hidden}.portfolio-card:hover{border-color:var(--accent);box-shadow:0 24px 60px #0006,var(--glow);transform:translateY(-6px)}.card-thumb{height:200px;position:relative;overflow:hidden}.card-bg{justify-content:center;align-items:center;font-size:4rem;transition:transform .4s;display:flex;position:absolute;inset:0}.portfolio-card:hover .card-bg{transform:scale(1.1)}.card-body{padding:24px}.card-type{font-family:var(--font-dm-mono),"DM Mono",monospace;letter-spacing:.15em;text-transform:uppercase;color:var(--accent);margin-bottom:10px;font-size:.65rem}.card-title{font-family:var(--font-syne),"Syne",sans-serif;margin-bottom:10px;font-size:1.2rem;font-weight:700}.card-desc{color:var(--muted);font-size:.85rem;line-height:1.6;font-family:var(--font-noto-thai),"Noto Sans Thai",sans-serif;font-weight:300}.card-tags{flex-wrap:wrap;gap:8px;margin-top:16px;display:flex}.tag{font-family:var(--font-dm-mono),"DM Mono",monospace;color:var(--accent2);background:#6c63ff1f;border-radius:3px;padding:3px 10px;font-size:.65rem}.blog-grid{grid-template-columns:repeat(3,1fr);gap:24px;display:grid}.blog-card{background:var(--surface2);border:1px solid var(--border);cursor:none;border-radius:16px;transition:all .3s;overflow:hidden}.blog-card:hover{border-color:#6c63ff80;transform:translateY(-4px)}.blog-header-area{border-bottom:1px solid var(--border);padding:28px 24px 16px}.blog-category{font-family:var(--font-dm-mono),"DM Mono",monospace;letter-spacing:.1em;color:var(--accent2);background:#6c63ff26;border-radius:3px;margin-bottom:14px;padding:3px 10px;font-size:.65rem;display:inline-block}.blog-title{font-family:var(--font-syne),"Syne",sans-serif;font-size:1.1rem;font-weight:700;line-height:1.4}.blog-body{padding:16px 24px 24px}.blog-excerpt{color:var(--muted);font-size:.82rem;line-height:1.7;font-family:var(--font-noto-thai),"Noto Sans Thai",sans-serif;margin-bottom:20px;font-weight:300}.blog-meta{font-family:var(--font-dm-mono),"DM Mono",monospace;color:var(--muted);justify-content:space-between;align-items:center;font-size:.65rem;display:flex}.read-more{color:var(--accent2);cursor:none;align-items:center;gap:6px;text-decoration:none;transition:gap .3s;display:flex}.read-more:hover{gap:10px}.pf-grid{grid-template-columns:repeat(3,1fr);align-items:stretch;gap:28px;display:grid}.pf-card{background:var(--surface);border:1px solid var(--border);cursor:none;border-radius:20px;flex-direction:column;height:100%;transition:transform .35s,box-shadow .35s,border-color .35s;display:flex;position:relative;overflow:hidden}.pf-card-glow{background:linear-gradient(135deg,var(--card-accent,#00f5c4),transparent 60%);opacity:0;z-index:0;pointer-events:none;border-radius:20px;transition:opacity .35s;position:absolute;inset:-1px}.pf-card.hovered{transform:translateY(-8px);box-shadow:0 32px 80px #00000080}.pf-card.hovered .pf-card-glow{opacity:.15}.pf-card.hovered{border-color:#ffffff1f}.pf-thumb{z-index:1;justify-content:center;align-items:center;height:180px;display:flex;position:relative;overflow:hidden}.pf-emoji{filter:drop-shadow(0 8px 24px #0006);font-size:4rem;transition:transform .4s}.pf-card.hovered .pf-emoji{transform:scale(1.15)translateY(-4px)}.pf-year{font-family:var(--font-dm-mono),"DM Mono",monospace;color:var(--muted);letter-spacing:.1em;font-size:.65rem;position:absolute;top:14px;left:16px}.pf-status{font-family:var(--font-dm-mono),"DM Mono",monospace;letter-spacing:.08em;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#050810b3;border:1px solid;border-radius:100px;align-items:center;gap:5px;padding:3px 10px;font-size:.6rem;display:flex;position:absolute;top:12px;right:14px}.pf-status-dot{border-radius:50%;width:5px;height:5px}.pf-body{z-index:1;flex-direction:column;flex:1;padding:22px;display:flex;position:relative}.pf-type{font-family:var(--font-dm-mono),"DM Mono",monospace;letter-spacing:.15em;text-transform:uppercase;margin-bottom:8px;font-size:.62rem}.pf-title{font-family:var(--font-syne),"Syne",sans-serif;color:var(--text);margin-bottom:10px;font-size:1.15rem;font-weight:700}.pf-desc{color:var(--muted);font-size:.82rem;line-height:1.65;font-family:var(--font-noto-thai),"Noto Sans Thai",sans-serif;flex:1;margin-bottom:16px;font-weight:300}.pf-tags{flex-wrap:wrap;gap:6px;margin-bottom:20px;display:flex}.pf-tag{font-family:var(--font-dm-mono),"DM Mono",monospace;letter-spacing:.05em;background:0 0;border:1px solid;border-radius:4px;padding:3px 10px;font-size:.6rem}.pf-footer{border-top:1px solid var(--border);align-items:center;gap:16px;padding-top:16px;display:flex}.pf-link{font-family:var(--font-dm-mono),"DM Mono",monospace;color:var(--accent);letter-spacing:.05em;gap:4px;font-size:.7rem;text-decoration:none;transition:gap .3s;display:flex}.pf-link:hover{gap:8px}.pf-link-muted{color:var(--muted)}.pf-link-muted:hover{color:var(--text)}#blog{background:var(--surface)}.bl-grid{grid-template-columns:repeat(3,1fr);align-items:stretch;gap:28px;display:grid}.bl-card{background:var(--surface2);border:1px solid var(--border);cursor:none;border-radius:20px;flex-direction:column;height:100%;transition:transform .35s,box-shadow .35s,border-color .35s;display:flex;overflow:hidden}.bl-card:hover{border-color:#6c63ff59;transform:translateY(-6px);box-shadow:0 24px 64px #0006}.bl-cover{justify-content:center;align-items:center;height:140px;display:flex;position:relative;overflow:hidden}.bl-cover-emoji{filter:drop-shadow(0 8px 20px #00000080);font-size:3.2rem;transition:transform .4s}.bl-card:hover .bl-cover-emoji{transform:scale(1.2)rotate(-5deg)}.bl-cover-cat{font-family:var(--font-dm-mono),"DM Mono",monospace;letter-spacing:.1em;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#05081099;border:1px solid;border-radius:4px;padding:3px 10px;font-size:.6rem;position:absolute;top:12px;left:14px}.bl-body{flex-direction:column;flex:1;padding:20px 22px 22px;display:flex}.bl-title{font-family:var(--font-syne),"Syne",sans-serif;color:var(--text);margin-bottom:10px;font-size:1.05rem;font-weight:700;line-height:1.45}.bl-excerpt{color:var(--muted);font-size:.8rem;line-height:1.7;font-family:var(--font-noto-thai),"Noto Sans Thai",sans-serif;flex:1;margin-bottom:18px;font-weight:300}.bl-meta{border-top:1px solid var(--border);justify-content:space-between;align-items:center;padding-top:14px;display:flex}.bl-meta-left{font-family:var(--font-dm-mono),"DM Mono",monospace;color:var(--muted);align-items:center;gap:6px;font-size:.62rem;display:flex}.bl-dot{color:var(--border)}.bl-read{font-family:var(--font-dm-mono),"DM Mono",monospace;color:var(--accent2);letter-spacing:.05em;font-size:.68rem;text-decoration:none;transition:color .3s,letter-spacing .3s}.bl-read:hover{color:var(--accent);letter-spacing:.1em}#ai-chat{background:var(--bg)}.chat-container{background:var(--surface);border:1px solid var(--border);border-radius:20px;max-width:800px;margin:0 auto;overflow:hidden;box-shadow:0 0 80px #00f5c40d}.chat-header-bar{background:var(--surface2);border-bottom:1px solid var(--border);align-items:center;gap:12px;padding:20px 28px;display:flex}.chat-avatar{background:linear-gradient(135deg,var(--accent),var(--accent2));border-radius:10px;justify-content:center;align-items:center;width:36px;height:36px;font-size:1.1rem;display:flex}.chat-info h3{font-family:var(--font-syne),"Syne",sans-serif;font-size:.95rem;font-weight:700}.chat-info p{font-family:var(--font-dm-mono),"DM Mono",monospace;color:var(--accent);align-items:center;gap:6px;font-size:.65rem;display:flex}.chat-info p:before{content:"";background:var(--accent);border-radius:50%;width:5px;height:5px;animation:2s infinite pulse;display:inline-block}.chat-messages{scrollbar-width:thin;scrollbar-color:var(--surface2)transparent;flex-direction:column;gap:16px;height:360px;padding:24px 28px;display:flex;overflow-y:auto}.chat-messages::-webkit-scrollbar{width:4px}.chat-messages::-webkit-scrollbar-thumb{background:var(--surface2);border-radius:2px}.msg{align-items:flex-start;gap:12px;animation:.3s msgIn;display:flex}@keyframes msgIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.msg.user{flex-direction:row-reverse}.msg-avatar{border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:.85rem;display:flex}.msg-avatar.ai-av{background:linear-gradient(135deg,var(--accent),var(--accent2))}.msg-avatar.user-av{background:var(--surface2);border:1px solid var(--border)}.msg-bubble{max-width:70%;font-size:.875rem;line-height:1.6;font-family:var(--font-noto-thai),"Noto Sans Thai",sans-serif;border-radius:14px;padding:12px 16px;font-weight:300}.msg.ai .msg-bubble{background:var(--surface2);border:1px solid var(--border);border-top-left-radius:4px}.msg.user .msg-bubble{color:var(--text);background:#00f5c41f;border:1px solid #00f5c433;border-top-right-radius:4px}.typing-indicator{background:var(--surface2);border:1px solid var(--border);border-radius:4px 14px 14px;gap:4px;width:fit-content;padding:14px 16px;display:flex}.typing-dot{background:var(--muted);border-radius:50%;width:6px;height:6px;animation:1.2s infinite typingDot}.typing-dot:nth-child(2){animation-delay:.2s}.typing-dot:nth-child(3){animation-delay:.4s}@keyframes typingDot{0%,80%,to{opacity:.4;transform:translateY(0)}40%{opacity:1;transform:translateY(-6px)}}.chat-input-area{border-top:1px solid var(--border);background:var(--surface);gap:12px;padding:20px 28px;display:flex}.chat-input{background:var(--surface2);border:1px solid var(--border);color:var(--text);font-family:var(--font-noto-thai),"Noto Sans Thai",sans-serif;cursor:none;border-radius:10px;outline:none;flex:1;padding:12px 16px;font-size:.875rem;transition:border-color .3s}.chat-input:focus{border-color:var(--accent)}.chat-input::placeholder{color:var(--muted)}.chat-send{background:var(--accent);color:var(--bg);font-family:var(--font-syne),"Syne",sans-serif;cursor:none;border:none;border-radius:10px;align-items:center;gap:6px;padding:12px 20px;font-size:.85rem;font-weight:700;transition:all .3s;display:flex}.chat-send:hover{transform:scale(1.05);box-shadow:0 8px 24px #00f5c44d}#contact{background:var(--surface)}.contact-grid{grid-template-columns:1fr 1fr;align-items:start;gap:64px;display:grid}.contact-info h3{font-family:var(--font-syne),"Syne",sans-serif;margin-bottom:16px;font-size:1.5rem;font-weight:800}.contact-info p{color:var(--muted);line-height:1.8;font-family:var(--font-noto-thai),"Noto Sans Thai",sans-serif;margin-bottom:40px;font-weight:300}.contact-links{flex-direction:column;gap:16px;display:flex}.contact-link{background:var(--surface2);border:1px solid var(--border);color:var(--text);cursor:none;border-radius:12px;align-items:center;gap:14px;padding:16px 20px;text-decoration:none;transition:all .3s;display:flex}.contact-link:hover{border-color:var(--accent);transform:translate(6px)}.contact-link-icon{border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;font-size:1.1rem;display:flex}.contact-link-text small{font-family:var(--font-dm-mono),"DM Mono",monospace;color:var(--muted);letter-spacing:.1em;text-transform:uppercase;margin-bottom:2px;font-size:.65rem;display:block}.contact-form{flex-direction:column;gap:16px;display:flex}.form-row{grid-template-columns:1fr 1fr;gap:16px;display:grid}.form-group{flex-direction:column;gap:8px;display:flex}.form-group label{font-family:var(--font-dm-mono),"DM Mono",monospace;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);font-size:.7rem}.form-input,.form-textarea{background:var(--bg);border:1px solid var(--border);color:var(--text);font-family:var(--font-noto-thai),"Noto Sans Thai",sans-serif;cursor:none;border-radius:8px;outline:none;padding:12px 16px;font-size:.875rem;transition:border-color .3s}.form-input:focus,.form-textarea:focus{border-color:var(--accent)}.form-textarea{resize:vertical;min-height:120px}.form-input::placeholder,.form-textarea::placeholder{color:var(--muted)}footer{background:var(--bg);position:relative;overflow:hidden}.bl-card-link{color:inherit;height:100%;text-decoration:none;display:block}.bl-card-link:hover .bl-card{border-color:#6c63ff59;transform:translateY(-6px);box-shadow:0 24px 64px #0006}.bl-card{transition:transform .35s,box-shadow .35s,border-color .35s}.detail-page{min-height:100vh;padding-bottom:80px}.detail-hero{justify-content:center;align-items:center;height:280px;display:flex;position:relative;overflow:hidden}.detail-hero-emoji{filter:drop-shadow(0 16px 40px #0009);z-index:1;font-size:6rem;position:relative}.detail-hero-overlay{background:linear-gradient(to bottom,transparent 40%,var(--bg)100%);position:absolute;inset:0}.detail-container{padding-top:32px}.detail-back{font-family:var(--font-dm-mono),"DM Mono",monospace;letter-spacing:.08em;color:var(--muted);align-items:center;gap:8px;margin-bottom:32px;font-size:.72rem;text-decoration:none;transition:color .3s;display:inline-flex}.detail-back:hover{color:var(--accent)}.detail-header{margin-bottom:40px}.detail-meta-row{flex-wrap:wrap;align-items:center;gap:12px;margin-bottom:14px;display:flex}.detail-type{font-family:var(--font-dm-mono),"DM Mono",monospace;letter-spacing:.15em;text-transform:uppercase;font-size:.68rem}.detail-status{font-family:var(--font-dm-mono),"DM Mono",monospace;letter-spacing:.08em;border:1px solid;border-radius:100px;align-items:center;gap:5px;padding:3px 10px;font-size:.6rem;display:flex}.detail-status-dot{border-radius:50%;width:5px;height:5px}.detail-year{font-family:var(--font-dm-mono),"DM Mono",monospace;color:var(--muted);font-size:.68rem}.detail-title{font-family:var(--font-syne),"Syne",sans-serif;margin-bottom:18px;font-size:clamp(1.8rem,4vw,2.8rem);font-weight:800;line-height:1.15}.detail-tags{flex-wrap:wrap;gap:8px;display:flex}.detail-body{grid-template-columns:1fr 300px;align-items:start;gap:40px;display:grid}.detail-desc{color:var(--muted);font-size:1rem;line-height:1.8;font-family:var(--font-noto-thai),"Noto Sans Thai",sans-serif;margin-bottom:36px;font-weight:300}.detail-section-title{font-family:var(--font-syne),"Syne",sans-serif;color:var(--text);margin-bottom:16px;font-size:1.1rem;font-weight:700}.detail-features{flex-direction:column;gap:12px;list-style:none;display:flex}.detail-feature-item{font-family:var(--font-noto-thai),"Noto Sans Thai",sans-serif;color:var(--text);align-items:center;gap:12px;font-size:.92rem;display:flex}.detail-feature-dot{border-radius:50%;flex-shrink:0;width:7px;height:7px}.detail-sidebar-card{background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:24px}.detail-sidebar-card h3{font-family:var(--font-syne),"Syne",sans-serif;color:var(--muted);text-transform:uppercase;letter-spacing:.1em;margin-bottom:16px;font-size:.9rem;font-weight:700}.detail-cta-btn{text-align:center;width:100%;font-family:var(--font-dm-mono),"DM Mono",monospace;letter-spacing:.05em;border-radius:10px;margin-bottom:10px;padding:13px 20px;font-size:.75rem;font-weight:700;text-decoration:none;transition:opacity .2s,transform .2s;display:block}.detail-cta-btn:hover{opacity:.85;transform:translateY(-1px)}.detail-cta-outline{border:1px solid;background:0 0!important}.sidebar-info-row{font-family:var(--font-dm-mono),"DM Mono",monospace;color:var(--muted);border-bottom:1px solid var(--border);justify-content:space-between;padding:8px 0;font-size:.68rem;display:flex}.blog-content{color:var(--text)}.blog-detail-h2{font-family:var(--font-syne),"Syne",sans-serif;color:var(--text);margin:32px 0 12px;font-size:1.3rem;font-weight:700}.blog-detail-p{color:var(--muted);font-size:.95rem;line-height:1.8;font-family:var(--font-noto-thai),"Noto Sans Thai",sans-serif;margin-bottom:8px;font-weight:300}.blog-detail-li{color:var(--muted);font-size:.9rem;line-height:1.8;font-family:var(--font-noto-thai),"Noto Sans Thai",sans-serif;margin-left:20px;list-style:outside}.blog-detail-li.numbered{list-style:decimal}.blog-code-block{background:var(--surface2);border:1px solid var(--border);font-family:var(--font-dm-mono),"DM Mono",monospace;color:var(--accent);border-radius:12px;margin:20px 0;padding:20px 24px;font-size:.8rem;line-height:1.6;overflow-x:auto}.blog-inline-code{color:var(--accent);font-family:var(--font-dm-mono),"DM Mono",monospace;background:#00f5c41a;border-radius:4px;padding:2px 6px;font-size:.85em}.blog-table-row{border-bottom:1px solid var(--border);gap:0;display:flex}.blog-table-cell{font-family:var(--font-dm-mono),"DM Mono",monospace;color:var(--muted);flex:1;padding:8px 12px;font-size:.75rem}@media (max-width:768px){.detail-body{grid-template-columns:1fr}.detail-hero{height:200px}.detail-hero-emoji{font-size:4rem}}.footer-glow{background:linear-gradient(90deg,transparent,var(--accent),transparent);width:600px;height:1px;position:absolute;top:0;left:50%;transform:translate(-50%)}.footer-glow:after{content:"";background:radial-gradient(#00f5c414 0%,#0000 70%);width:200px;height:80px;margin-top:-40px;position:absolute;top:0;left:50%;transform:translate(-50%)}.footer-main{border-bottom:1px solid var(--border);grid-template-columns:1.8fr 1fr 1fr 1fr;gap:64px;max-width:1200px;margin:0 auto;padding:80px 40px 48px;display:grid}.footer-brand .logo{font-family:var(--font-syne),"Syne",sans-serif;letter-spacing:-.02em;margin-bottom:16px;font-size:1.4rem;font-weight:800;display:block}.footer-brand .logo span{color:var(--accent)}.footer-brand p{font-family:var(--font-noto-thai),"Noto Sans Thai",sans-serif;color:var(--muted);max-width:280px;margin-bottom:28px;font-size:.875rem;font-weight:300;line-height:1.7}.footer-socials{gap:10px;display:flex}.footer-social-btn{background:var(--surface);border:1px solid var(--border);cursor:none;border-radius:10px;justify-content:center;align-items:center;width:38px;height:38px;font-size:1rem;text-decoration:none;transition:all .3s;display:flex}.footer-social-btn:hover{border-color:var(--accent);background:#00f5c414;transform:translateY(-3px)}.footer-col h4{font-family:var(--font-syne),"Syne",sans-serif;letter-spacing:.1em;text-transform:uppercase;color:var(--text);margin-bottom:20px;font-size:.8rem;font-weight:700}.footer-col ul{flex-direction:column;gap:12px;padding:0;list-style:none;display:flex}.footer-col ul li a{font-family:var(--font-dm-mono),"DM Mono",monospace;color:var(--muted);letter-spacing:.03em;cursor:none;align-items:center;gap:8px;font-size:.75rem;text-decoration:none;transition:all .3s;display:flex}.footer-col ul li a:before{content:"";background:var(--accent);width:0;height:1px;transition:width .3s;display:inline-block}.footer-col ul li a:hover{color:var(--accent)}.footer-col ul li a:hover:before{width:12px}.footer-status{font-family:var(--font-dm-mono),"DM Mono",monospace;color:var(--accent);letter-spacing:.1em;background:#00f5c412;border:1px solid #00f5c426;border-radius:100px;align-items:center;gap:8px;margin-top:20px;padding:6px 14px;font-size:.65rem;display:inline-flex}.footer-status-dot{background:var(--accent);border-radius:50%;width:6px;height:6px;animation:2s infinite pulse}.footer-bottom{justify-content:space-between;align-items:center;gap:24px;max-width:1200px;margin:0 auto;padding:28px 40px;display:flex}.footer-bottom p{font-family:var(--font-dm-mono),"DM Mono",monospace;color:var(--muted);letter-spacing:.05em;font-size:.68rem}.footer-bottom p span{color:var(--accent)}.footer-tech{align-items:center;gap:10px;display:flex}.footer-tech span{font-family:var(--font-dm-mono),"DM Mono",monospace;color:var(--muted);letter-spacing:.08em;font-size:.65rem}.tech-badge{background:var(--surface);border:1px solid var(--border);font-family:var(--font-dm-mono),"DM Mono",monospace;color:var(--muted);letter-spacing:.05em;border-radius:4px;padding:3px 10px;font-size:.62rem}.footer-marquee{border-top:1px solid var(--border);border-bottom:1px solid var(--border);background:var(--surface);padding:16px 0;overflow:hidden}.marquee-track{white-space:nowrap;gap:0;animation:25s linear infinite marquee;display:flex}.marquee-track span{font-family:var(--font-syne),"Syne",sans-serif;color:var(--muted);letter-spacing:.15em;text-transform:uppercase;padding:0 32px;font-size:.75rem;font-weight:700}.marquee-track span.accent{color:var(--accent)}@keyframes marquee{0%{transform:translate(0)}to{transform:translate(-50%)}}.float-chat{z-index:400;background:var(--accent);cursor:none;border:none;border-radius:16px;justify-content:center;align-items:center;width:56px;height:56px;font-size:1.4rem;transition:all .3s;animation:3s ease-in-out infinite floatBtn;display:flex;position:fixed;bottom:32px;right:32px;box-shadow:0 8px 32px #00f5c466}.float-chat:hover{transform:scale(1.1)translateY(-4px)}@keyframes floatBtn{0%,to{box-shadow:0 8px 32px #00f5c466}50%{box-shadow:0 16px 48px #00f5c499}}.scroll-indicator{flex-direction:column;align-items:center;gap:8px;display:flex;position:absolute;bottom:40px;left:50%;transform:translate(-50%)}.scroll-indicator p{font-family:var(--font-dm-mono),"DM Mono",monospace;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);font-size:.6rem}.scroll-line{background:linear-gradient(to bottom,var(--accent),transparent);width:1px;height:48px;animation:2s ease-in-out infinite scrollLine}@keyframes scrollLine{0%{transform-origin:top;transform:scaleY(0)}50%{transform-origin:top;transform:scaleY(1)}51%{transform-origin:bottom;transform:scaleY(1)}to{transform-origin:bottom;transform:scaleY(0)}}.reveal{opacity:0;transition:all .8s;transform:translateY(40px)}.reveal.visible{opacity:1;transform:translateY(0)}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:var(--bg)}::-webkit-scrollbar-thumb{background:var(--surface2);border-radius:3px}@media (max-width:900px){.nav-links{display:none}.header-container{padding:12px 16px 0}nav.site-nav{padding:12px 20px}section{padding:80px 24px}#hero{padding:100px 24px 80px}.hero-stats{display:none}.about-grid,.contact-grid{grid-template-columns:1fr;gap:48px}.portfolio-grid,.blog-grid{grid-template-columns:1fr}.pf-grid,.bl-grid{grid-template-columns:repeat(2,1fr)}.footer-main{grid-template-columns:1fr 1fr;gap:40px;padding:60px 24px 40px}.footer-bottom{text-align:center;flex-direction:column;gap:12px;padding:24px}}@media (max-width:600px){.footer-main{grid-template-columns:1fr}}.floatchat-popup{z-index:399;opacity:0;pointer-events:none;background:#0d1a14;border:1px solid #00f5c426;border-radius:20px;flex-direction:column;width:380px;max-height:640px;transition:opacity .25s,transform .25s;display:flex;position:fixed;bottom:104px;right:32px;overflow:hidden;transform:translateY(20px)scale(.96);box-shadow:0 24px 80px #0009,0 0 40px #00f5c414}.floatchat-popup.open{opacity:1;pointer-events:all;transform:translateY(0)scale(1)}.floatchat-header{background:#0a1510;border-bottom:1px solid #00f5c41a;flex-shrink:0;align-items:center;gap:10px;padding:14px 16px;display:flex}.floatchat-header-left{flex:1;align-items:center;gap:10px;display:flex}.floatchat-avatar-wrap{flex-shrink:0;width:36px;height:36px;position:relative}.floatchat-avatar-circle{background:linear-gradient(135deg,var(--accent),#00b894);color:#000;border-radius:50%;justify-content:center;align-items:center;width:36px;height:36px;font-size:.9rem;font-weight:800;display:flex}.floatchat-online-dot{background:#00f5c4;border:2px solid #0a1510;border-radius:50%;width:10px;height:10px;animation:2s ease-in-out infinite pulse-dot;position:absolute;bottom:1px;right:1px}@keyframes pulse-dot{0%,to{box-shadow:0 0 #00f5c466}50%{box-shadow:0 0 0 4px #00f5c400}}.floatchat-name{color:var(--fg);font-size:.9rem;font-weight:600;font-family:var(--font-syne),"Syne",sans-serif}.floatchat-header-tabs{gap:4px;display:flex}.floatchat-tab{color:var(--muted);cursor:pointer;font-size:.72rem;font-family:var(--font-noto-thai),"Noto Sans Thai",sans-serif;white-space:nowrap;background:0 0;border:none;border-radius:8px;padding:5px 10px;transition:all .2s}.floatchat-tab.active{color:var(--accent);border-bottom:2px solid var(--accent);background:#00f5c41f}.floatchat-tab:hover:not(.active){color:var(--fg);background:#ffffff0d}.floatchat-close{color:var(--muted);cursor:pointer;background:0 0;border:none;border-radius:6px;padding:4px 6px;font-size:1rem;line-height:1;transition:color .2s,background .2s}.floatchat-close:hover{color:var(--fg);background:#ffffff0f}.floatchat-messages{scrollbar-width:thin;scrollbar-color:#00f5c433 transparent;flex-direction:column;flex:1;gap:12px;padding:16px;display:flex;overflow-y:auto}.floatchat-messages::-webkit-scrollbar{width:4px}.floatchat-messages::-webkit-scrollbar-thumb{background:#00f5c433;border-radius:4px}.floatchat-msg{align-items:flex-end;gap:8px;display:flex}.floatchat-msg.user{flex-direction:row-reverse}.floatchat-msg-avatar{background:linear-gradient(135deg,var(--accent),#00b894);color:#000;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;font-size:.75rem;font-weight:800;display:flex}.floatchat-bubble{max-width:75%;font-size:.82rem;line-height:1.5;font-family:var(--font-noto-thai),"Noto Sans Thai",sans-serif;border-radius:16px;padding:10px 14px}.floatchat-msg.ai .floatchat-bubble{color:var(--fg);background:#ffffff0f;border-bottom-left-radius:4px}.floatchat-msg.user .floatchat-bubble{background:var(--accent);color:#000;border-bottom-right-radius:4px;font-weight:600}.floatchat-typing{align-items:center;gap:4px;padding:2px 0;display:flex}.floatchat-typing span{background:var(--accent);border-radius:50%;width:6px;height:6px;animation:1.2s ease-in-out infinite typing-bounce}.floatchat-typing span:nth-child(2){animation-delay:.2s}.floatchat-typing span:nth-child(3){animation-delay:.4s}@keyframes typing-bounce{0%,80%,to{opacity:.5;transform:translateY(0)}40%{opacity:1;transform:translateY(-5px)}}.floatchat-input-area{background:#0a1510;border-top:1px solid #00f5c414;flex-shrink:0;align-items:center;gap:8px;padding:12px 14px;display:flex}.floatchat-input{color:var(--fg);font-size:.82rem;font-family:var(--font-noto-thai),"Noto Sans Thai",sans-serif;background:#ffffff0d;border:1px solid #00f5c41f;border-radius:10px;outline:none;flex:1;padding:9px 14px;transition:border-color .2s}.floatchat-input::placeholder{color:var(--muted)}.floatchat-input:focus{border-color:#00f5c459}.floatchat-send{background:var(--accent);cursor:pointer;color:#000;border:none;border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;transition:background .2s,transform .2s;display:flex}.floatchat-send:hover{background:#fff;transform:scale(1.05)}@media (max-width:480px){.floatchat-popup{width:calc(100vw - 24px);max-height:75vh;bottom:90px;right:12px}}.floatchat-livechat{text-align:center;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:12px;padding:32px 24px;display:flex}.floatchat-live-icon{opacity:.7;font-size:2.5rem}.floatchat-live-title{color:var(--fg);font-size:1rem;font-weight:700;font-family:var(--font-syne),"Syne",sans-serif;margin:0}.floatchat-live-desc{color:var(--muted);font-size:.82rem;line-height:1.6;font-family:var(--font-noto-thai),"Noto Sans Thai",sans-serif;margin:0}.floatchat-live-btn{background:var(--accent);color:#000;font-size:.82rem;font-weight:700;font-family:var(--font-syne),"Syne",sans-serif;border-radius:100px;margin-top:8px;padding:10px 22px;text-decoration:none;transition:background .2s,transform .2s;display:inline-block}.floatchat-live-btn:hover{background:#fff;transform:translateY(-2px)}@property --tw-rotate-x{syntax:"*";inherits:false}@property --tw-rotate-y{syntax:"*";inherits:false}@property --tw-rotate-z{syntax:"*";inherits:false}@property --tw-skew-x{syntax:"*";inherits:false}@property --tw-skew-y{syntax:"*";inherits:false}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-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}
