:root{--ink: #1a1a1a;--muted: #555;--rule: #d9d9d9;--bg: #fdfdfd;--max: 720px;--font-body: "Sarabun", "TH Sarabun New", "TH Sarabun PSK", "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;--font-mono: "JetBrains Mono", "Fira Code", Consolas, monospace}*,*:before,*:after{box-sizing:border-box}html{-webkit-text-size-adjust:100%}body{margin:0;background:var(--bg);color:var(--ink);font-family:var(--font-body);font-size:16px;line-height:1.6;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}.wrap{max-width:var(--max);margin:0 auto;padding:24px 20px 64px}h1,h2,h3,h4{font-weight:600;letter-spacing:-.01em;line-height:1.25;color:var(--ink);margin:0 0 12px}h1{font-size:32px}h2{font-size:20px;text-transform:uppercase;letter-spacing:.08em;color:var(--ink);font-weight:700;border-bottom:1.5px solid var(--ink);padding-bottom:8px;margin-top:40px;margin-bottom:20px}@media(min-width:720px){h2{margin-top:56px;margin-bottom:24px}}h3{font-size:18px;font-weight:700;margin-bottom:4px}h4{font-size:15px;margin-bottom:4px}p{margin:0 0 12px}a{color:var(--ink);text-decoration:underline;text-decoration-thickness:1px;text-underline-offset:2px;transition:text-decoration-thickness .12s ease,text-underline-offset .12s ease}a:hover{color:var(--ink);text-decoration-thickness:2px;text-underline-offset:3px}a:focus-visible{outline:2px solid var(--ink);outline-offset:2px;border-radius:1px}summary:focus-visible{outline:2px solid var(--ink);outline-offset:2px;border-radius:1px}.muted{color:var(--muted)}.small{font-size:14px}.mono{font-family:var(--font-mono)}ul{padding-left:20px;margin:4px 0 12px}li{margin-bottom:6px}hr{border:0;border-top:1px solid var(--rule);margin:32px 0}.hero{display:grid;grid-template-columns:1fr;gap:20px;align-items:center;padding:16px 0 8px}.hero-photo{width:140px;aspect-ratio:4 / 5;object-fit:cover;object-position:center top;border-radius:4px;display:block}.hero-name{font-family:-apple-system,BlinkMacSystemFont,"SF Pro Display","SF Pro Text","Helvetica Neue","Sarabun","TH Sarabun New","TH Sarabun PSK",var(--font-body);font-weight:600;font-size:34px;letter-spacing:0;margin-bottom:4px}.hero-sub{color:var(--muted);font-size:15px;margin-bottom:12px}.contact-bar{display:flex;flex-wrap:wrap;gap:14px;font-size:14px;color:var(--muted);margin-top:6px}.contact-bar a{color:var(--muted);padding:6px 0}@media(min-width:720px){.hero{grid-template-columns:160px 1fr;gap:32px}.hero-photo{width:160px}.hero-name{font-size:42px}}.entry{margin-bottom:28px}.entry-meta{color:var(--ink);font-size:14.5px;font-weight:500;margin-bottom:8px}.entry-meta a{color:inherit;text-decoration-color:var(--rule)}.entry-note{color:var(--muted);font-size:13px;font-style:italic;margin-bottom:6px}.entry>p{margin-bottom:4px}.entry>p:last-child{margin-bottom:0}.entry p:not(.small),section>p{text-align:left}.project-actions{margin-top:8px;font-size:14px}.project-actions a+a:before{content:" · ";color:var(--muted);text-decoration:none}details>summary{cursor:pointer;list-style:none;display:inline-block}details>summary::-webkit-details-marker{display:none}details>summary:before{display:inline-block;width:1em;font-size:.85em;color:var(--muted);content:"▶";margin-right:4px;transition:transform .12s ease}details[open]>summary:before{transform:rotate(90deg)}details.demo{margin-top:10px}details.demo>summary{font-size:14px;color:var(--ink);text-decoration:underline;text-underline-offset:2px}.demo-media{margin-top:12px}.demo-media video,.demo-media img{width:100%;height:auto;display:block;border:1px solid var(--rule);border-radius:2px}.yt-embed{position:relative;width:100%;aspect-ratio:16 / 9;border:1px solid var(--rule);border-radius:2px;overflow:hidden}.yt-embed iframe{position:absolute;inset:0;width:100%;height:100%;border:0}.status-tag{display:inline-block;font-size:12px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--ink);border:1px solid var(--ink);background:var(--bg);padding:2px 8px;margin-right:10px;border-radius:2px;vertical-align:middle}.award-badge{display:inline-block;font-size:12px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--ink);background:var(--ink);color:var(--bg);padding:2px 8px;margin-right:10px;border-radius:2px;vertical-align:middle}.pub-list{list-style:none;padding:0;margin:0}.pub-list li{margin-bottom:14px;font-size:15px}.pub-title{font-weight:500}.pub-meta{color:var(--muted);font-size:14px}details.all-pubs>summary{color:var(--ink);font-size:14px;margin-top:8px}.year-group{margin-bottom:16px}.year-group+.year-group{border-top:1px solid var(--rule);padding-top:14px;margin-top:14px}.year-label{font-size:14px;font-weight:700;color:var(--ink);letter-spacing:.06em;text-transform:uppercase;margin:0 0 10px}.skill-grid{display:grid;grid-template-columns:1fr;gap:16px}@media(min-width:720px){.skill-grid{grid-template-columns:1fr 1fr}}.skill-grid h4{font-size:13px;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);margin-bottom:6px}.skill-grid ul{padding-left:16px}.skill-grid li{font-size:14px}.site-footer{border-top:1px solid var(--rule);margin-top:64px;padding-top:20px;font-size:14px;color:var(--muted);display:flex;flex-wrap:wrap;justify-content:space-between;gap:12px}.site-footer a{color:var(--muted);padding:6px 0;display:inline-block}@media print{:root{--bg: #fff}body{font-size:11pt}.wrap{max-width:100%;padding:0}h2{margin-top:16pt}.hero-photo{width:90px}.project-actions,details.demo,.demo-media{display:none}details.all-pubs[open]>summary,details.all-pubs:not([open])>summary{display:none}details.all-pubs[open]>*{display:block}details{display:block}details>summary{display:none}.site-footer{display:none}a{color:var(--ink);text-decoration:none}}
