:root{--bg: #ffffff;--bg-subtle: #fafaf8;--surface: #f4f4f1;--text: #171717;--text-secondary: #3f3f46;--text-muted: #71717a;--border: #e4e4e7;--border-strong: #d4d4d8;--accent: #ea580c;--accent-hover: #c2410c;--accent-soft-bg: #fff7ed;--accent-soft-border: #fed7aa;--success: #16a34a;--font-body: "DM Sans", "Noto Sans Thai", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;--font-display: "DM Sans", "Noto Sans Thai", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;--font-mono: "IBM Plex Mono", ui-monospace, "SF Mono", Menlo, Consolas, monospace;--fs-body: 17px;--lh-body: 1.7;--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 24px;--space-6: 32px;--space-7: 48px;--space-8: 64px;--space-9: 96px;--space-10: 128px;--radius: 6px;--radius-lg: 8px}*,*:before,*:after{box-sizing:border-box}html{scroll-behavior:smooth}@media(prefers-reduced-motion:reduce){html{scroll-behavior:auto}}html,body{margin:0;padding:0;background:var(--bg);color:var(--text);font-family:var(--font-body);font-size:var(--fs-body);line-height:var(--lh-body);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility}body{min-height:100vh;display:flex;flex-direction:column}main{flex:1 0 auto}a{color:var(--text);text-decoration:underline;text-decoration-color:var(--border-strong);text-decoration-thickness:1px;text-underline-offset:3px;transition:color .15s ease,text-decoration-color .15s ease}a:hover{color:var(--accent);text-decoration-color:var(--accent)}a:focus-visible{outline:2px solid var(--accent);outline-offset:3px;border-radius:2px}button{font-family:inherit;cursor:pointer}button:focus-visible{outline:2px solid var(--accent);outline-offset:2px}::selection{background:var(--accent-soft-bg);color:var(--accent-hover)}.container,.container-wide,.container-narrow{width:100%;margin-inline:auto;padding-inline:24px}.container{max-width:960px}.container-wide{max-width:1080px}.container-narrow{max-width:680px}.skip-link{position:absolute;left:12px;top:12px;padding:8px 12px;background:var(--text);color:var(--bg);border-radius:var(--radius);text-decoration:none;transform:translateY(-200%);transition:transform .12s ease;z-index:100}.skip-link:focus{transform:translateY(0);color:var(--bg)}.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.section{padding:72px 0;border-bottom:1px solid var(--border)}.section:last-of-type{border-bottom:0}.section--subtle{background:var(--bg-subtle)}.section-header{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:36px;gap:16px}.section-title{font-family:var(--font-display);font-weight:600;font-size:13px;letter-spacing:.12em;text-transform:uppercase;color:var(--text-muted);margin:0}.section-link{font-size:14px;color:var(--text-secondary);text-decoration:none}.section-link:after{content:" →";color:var(--text-muted)}.section-link:hover{color:var(--accent)}.section-link:hover:after{color:var(--accent)}.tag{display:inline-block;padding:3px 10px;background:var(--accent-soft-bg);color:var(--accent-hover);border:1px solid var(--accent-soft-border);border-radius:999px;font-size:12px;font-weight:500;letter-spacing:.01em;text-decoration:none;font-family:var(--font-body)}@media(max-width:760px){.section{padding:48px 0}.section-header{flex-direction:column;align-items:flex-start;gap:4px}}.site-header[data-astro-cid-ctg3m53h]{border-bottom:1px solid var(--border);background:#ffffffeb;position:sticky;top:0;z-index:10;-webkit-backdrop-filter:saturate(180%) blur(8px);backdrop-filter:saturate(180%) blur(8px)}.site-header[data-astro-cid-ctg3m53h].reveal{position:fixed;left:0;right:0;transform:translateY(-100%);transition:transform .3s ease;box-shadow:0 1px 12px #0000000f}.site-header[data-astro-cid-ctg3m53h].reveal.is-visible{transform:translateY(0)}@media(prefers-reduced-motion:reduce){.site-header[data-astro-cid-ctg3m53h].reveal{transition:none}}.site-header-inner[data-astro-cid-ctg3m53h]{display:flex;align-items:center;justify-content:space-between;padding:18px 24px;gap:16px}.brand[data-astro-cid-ctg3m53h]{font-family:var(--font-display);font-weight:400;font-size:26px;text-decoration:none;letter-spacing:-.005em;color:var(--text);display:inline-flex;align-items:baseline;gap:2px}.brand[data-astro-cid-ctg3m53h] .dot[data-astro-cid-ctg3m53h]{color:var(--accent);font-weight:700}.brand[data-astro-cid-ctg3m53h]:hover{color:var(--text)}.site-nav[data-astro-cid-ctg3m53h]{display:flex;gap:28px;align-items:center}.site-nav[data-astro-cid-ctg3m53h] a[data-astro-cid-ctg3m53h]{text-decoration:none;color:var(--text-secondary);font-size:15px;font-weight:500;padding:6px 0;position:relative}.site-nav[data-astro-cid-ctg3m53h] a[data-astro-cid-ctg3m53h]:hover,.site-nav[data-astro-cid-ctg3m53h] a[data-astro-cid-ctg3m53h].active{color:var(--text)}.site-nav[data-astro-cid-ctg3m53h] a[data-astro-cid-ctg3m53h].active:after{content:"";position:absolute;left:0;right:0;bottom:-19px;height:2px;background:var(--accent)}.site-nav[data-astro-cid-ctg3m53h] .rss[data-astro-cid-ctg3m53h]{color:var(--text-muted);font-size:13px;letter-spacing:.04em;text-transform:uppercase;font-weight:500}.site-nav[data-astro-cid-ctg3m53h] .rss[data-astro-cid-ctg3m53h]:hover{color:var(--accent)}@media(max-width:760px){.brand[data-astro-cid-ctg3m53h]{font-size:22px}.site-nav[data-astro-cid-ctg3m53h]{gap:18px}.site-nav[data-astro-cid-ctg3m53h] a[data-astro-cid-ctg3m53h]{font-size:14px}}.site-footer[data-astro-cid-gcn2mc3v]{border-top:1px solid var(--border);margin-top:auto;padding:48px 0;color:var(--text-muted);font-size:14px;flex-shrink:0}.site-footer__meta[data-astro-cid-gcn2mc3v]{font-size:12px;color:var(--text-muted);font-family:var(--font-mono)}
