.modal-backdrop.svelte-yqs9xm{z-index:9999;-webkit-backdrop-filter:blur(8px);background:#0006;justify-content:center;align-items:center;padding:1.5rem;display:flex;position:fixed;inset:0}.modal-content.svelte-yqs9xm{background:#0f172ab3;border:1px solid #ffffff1a;border-radius:1.25rem;flex-direction:column;width:100%;max-width:800px;max-height:85vh;padding:0;display:flex;position:relative;overflow:hidden;box-shadow:0 25px 50px -12px #00000080}.close-btn.svelte-yqs9xm{color:var(--text-secondary);cursor:pointer;z-index:10;background:#ffffff1a;border:none;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;transition:all .2s;display:flex;position:absolute;top:1rem;right:1rem}.close-btn.svelte-yqs9xm:hover{color:var(--text-primary);background:#fff3}.modal-header.svelte-yqs9xm{border-bottom:1px solid var(--glass-border);flex-shrink:0;padding:2rem 2rem 1rem}.modal-title.svelte-yqs9xm{color:var(--text-primary);margin-bottom:.25rem;padding-right:2rem;font-size:1.4rem;font-weight:700}.modal-subtitle.svelte-yqs9xm{color:var(--accent);font-size:.95rem;font-weight:500}.modal-body.svelte-yqs9xm{flex-direction:column;gap:1.5rem;padding:1.5rem 2rem 2rem;display:flex;overflow-y:auto}.modal-body.svelte-yqs9xm::-webkit-scrollbar{width:6px}.modal-body.svelte-yqs9xm::-webkit-scrollbar-track{background:0 0}.modal-body.svelte-yqs9xm::-webkit-scrollbar-thumb{background:var(--glass-border);border-radius:10px}.modal-body.svelte-yqs9xm::-webkit-scrollbar-thumb:hover{background:var(--text-tertiary)}.modal-desc.svelte-yqs9xm{color:var(--text-primary);font-size:1.05rem;font-weight:600}.modal-details.svelte-yqs9xm{color:var(--text-secondary);font-size:.95rem;line-height:1.6}.modal-gallery.svelte-yqs9xm{flex-direction:column;gap:1rem;margin-top:.5rem;display:flex}.main-image.svelte-yqs9xm{border:1px solid var(--glass-border);background:#0003;border-radius:.75rem;justify-content:center;align-items:center;width:100%;display:flex;overflow:hidden}.main-image.svelte-yqs9xm img:where(.svelte-yqs9xm){object-fit:contain;width:100%;height:auto;max-height:450px;display:block}.thumbnail-strip.svelte-yqs9xm{gap:.75rem;padding-bottom:.5rem;display:flex;overflow-x:auto}.thumbnail-strip.svelte-yqs9xm::-webkit-scrollbar{height:6px}.thumbnail-strip.svelte-yqs9xm::-webkit-scrollbar-track{background:0 0}.thumbnail-strip.svelte-yqs9xm::-webkit-scrollbar-thumb{background:var(--glass-border);border-radius:10px}.thumb-btn.svelte-yqs9xm{cursor:pointer;opacity:.5;background:#0003;border:2px solid #0000;border-radius:.5rem;flex-shrink:0;width:80px;height:60px;padding:0;transition:all .2s;overflow:hidden}.thumb-btn.svelte-yqs9xm:hover{opacity:.8}.thumb-btn.active.svelte-yqs9xm{border-color:var(--accent);opacity:1}.thumb-btn.svelte-yqs9xm img:where(.svelte-yqs9xm){object-fit:cover;width:100%;height:100%;display:block}.item-btn.svelte-1q7lnte{text-align:left;cursor:pointer;background:0 0;border-top:none;border-bottom:none;border-right:none;outline:none;width:100%;font-family:inherit;display:block}.item-btn.svelte-1q7lnte:focus-visible{border-left-color:var(--accent)!important}:root{--font-sans:"Inter", "IBM Plex Sans Thai", sans-serif}.dark.svelte-1uha8ag{--bg-base:#0f1115;--text-primary:#e2e8f0;--text-secondary:#cbd5e1;--text-tertiary:#64748b;--accent:#38bdf8;--ambient-1:oklch(30% .15 260/.4);--ambient-2:oklch(30% .15 300/.3);--glass-bg:#ffffff08;--glass-border:#ffffff14;--glass-hover:#ffffff0f;--glass-shadow:0 10px 40px #0000004d}.light.svelte-1uha8ag{--bg-base:#f8fafc;--text-primary:#0f172a;--text-secondary:#475569;--text-tertiary:#94a3b8;--accent:#0ea5e9;--ambient-1:oklch(85% .1 260/.6);--ambient-2:oklch(85% .1 300/.5);--glass-bg:#fff9;--glass-border:#0000000f;--glass-hover:#ffffffe6;--glass-shadow:0 10px 40px #0000000d}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}.app.svelte-1uha8ag{background-color:var(--bg-base);min-height:100vh;color:var(--text-primary);font-family:var(--font-sans);position:relative;overflow-x:hidden}.ambient-bg.svelte-1uha8ag{background:radial-gradient(circle at 20% 30%, var(--ambient-1) 0%, transparent 60%), radial-gradient(circle at 80% 70%, var(--ambient-2) 0%, transparent 60%);filter:blur(80px);z-index:0;pointer-events:none;position:fixed;inset:0}.cursor-glow.svelte-1uha8ag{background:radial-gradient(circle, var(--accent) 0%, transparent 60%);opacity:.1;filter:blur(60px);z-index:5;pointer-events:none;border-radius:50%;width:400px;height:400px;transition:opacity .5s;position:fixed;top:-200px;left:-200px}.container{flex-direction:column;gap:4rem;max-width:1000px;margin:0 auto;padding:8rem 2rem 4rem;display:flex;position:relative}.glass-box{background:var(--glass-bg);-webkit-backdrop-filter:blur(12px);border:1px solid var(--glass-border);box-shadow:0 8px 32px var(--glass-shadow);border-radius:1.5rem;padding:2.5rem;transition:transform .4s cubic-bezier(.16,1,.3,1),border-color .4s,box-shadow .4s}.glass-box:hover{border-color:#ffffff26;transform:translateY(-4px);box-shadow:0 20px 40px #0006}.light.svelte-1uha8ag .glass-box:hover{border-color:#0000001a;box-shadow:0 20px 40px #00000014}section[id]{scroll-margin-top:8rem}.section-title{align-items:center;gap:.75rem;margin-bottom:2rem;font-size:1.75rem;font-weight:700;display:flex}.navbar-wrapper{z-index:50;pointer-events:none;justify-content:center;padding:0 2rem;display:flex;position:fixed;top:2rem;left:0;right:0}.nav-capsule{pointer-events:auto;background:var(--glass-bg);-webkit-backdrop-filter:blur(24px);border:1px solid var(--glass-border);width:100%;max-width:1200px;height:64px;box-shadow:var(--glass-shadow);border-radius:3rem;justify-content:space-between;align-items:center;padding:0 2rem;display:flex}.logo{letter-spacing:.05em;color:var(--text-primary);font-size:1.25rem;font-weight:800;text-decoration:none}.desktop-nav{align-items:center;gap:1rem;display:flex}.nav-link{color:var(--text-secondary);border-radius:2rem;padding:.4rem .8rem;font-size:.95rem;font-weight:500;text-decoration:none;transition:all .2s;position:relative}.nav-link:hover{color:var(--text-primary);background:var(--glass-hover)}.nav-link.active{color:var(--accent);background:rgba(var(--accent-rgb), .1)}.divider{background:var(--glass-border);width:1px;height:24px;margin:0 .5rem}.icon-btn{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;width:36px;height:36px;transition:all .2s;display:flex}.icon-btn:hover{color:var(--text-primary);background:var(--glass-hover)}.mobile-toggle{color:var(--text-primary);cursor:pointer;background:0 0;border:none;display:none}.mobile-menu{background:var(--glass-bg);-webkit-backdrop-filter:blur(24px);z-index:40;border:1px solid var(--glass-border);border-radius:1.5rem;flex-direction:column;gap:1.5rem;padding:2rem;display:flex;position:fixed;top:100px;left:1rem;right:1rem;box-shadow:0 20px 40px #0000004d}.mobile-link{color:var(--text-primary);font-size:1.5rem;font-weight:600;text-decoration:none}.mobile-controls{gap:1rem;margin-top:auto;display:flex}.icon-btn.outline{border:1px solid var(--glass-border);border-radius:2rem;gap:.5rem;width:auto;padding:0 1.5rem}.hero-box{text-align:center;flex-direction:column;justify-content:center;align-items:center;padding:5rem 2rem;display:flex;position:relative;overflow:hidden}.hero-top{justify-content:center;margin-bottom:2rem;display:flex}.status-indicator{color:#10b981;background:#10b9811a;border:1px solid #10b9814d;border-radius:2rem;align-items:center;gap:.5rem;padding:.4rem 1rem;font-size:.85rem;font-weight:500;display:inline-flex}.dot{background-color:#10b981;border-radius:50%;width:8px;height:8px}.pulse{animation:2s infinite svelte-1uha8ag-pulse;box-shadow:0 0 #10b981b3}@keyframes svelte-1uha8ag-pulse{0%{transform:scale(.95);box-shadow:0 0 #10b981b3}70%{transform:scale(1);box-shadow:0 0 0 6px #10b98100}to{transform:scale(.95);box-shadow:0 0 #10b98100}}.hero-title{letter-spacing:-.02em;margin-bottom:1.5rem;font-size:clamp(3rem,6vw,5rem);font-weight:800;line-height:1.1}.highlight{color:var(--accent)}.hero-desc{color:var(--text-secondary);max-width:600px;margin-bottom:2.5rem;margin-left:auto;margin-right:auto;font-size:1.2rem;line-height:1.6}.hero-actions{flex-wrap:wrap;justify-content:center;gap:1rem;display:flex}.action-btn{background:var(--glass-hover);color:var(--text-primary);border:1px solid var(--glass-border);border-radius:.75rem;align-items:center;gap:.5rem;padding:.75rem 1.5rem;font-weight:600;text-decoration:none;transition:all .2s;display:inline-flex}.action-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.action-btn.primary{background:var(--accent);color:#fff;border:none}.action-btn.primary:hover{filter:brightness(1.1)}.bento-split{gap:1.5rem;display:flex}.flex-1{flex:1}.flex-2{flex:2}.about-content{gap:2rem;display:flex}.profile-pic-container{flex-shrink:0}.profile-placeholder{background:var(--glass-hover);border:1px solid var(--glass-border);border-radius:1.5rem;justify-content:center;align-items:center;width:120px;height:120px;display:flex}.profile-pic{object-fit:cover;border:1px solid var(--glass-border);border-radius:1.5rem;width:120px;height:120px}.prose{color:var(--text-secondary);font-size:1.05rem;line-height:1.7}.info-blocks{flex-direction:column;gap:1.5rem;margin-top:2rem;display:flex}.info-block h4{color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.05em;align-items:center;gap:.5rem;margin-bottom:.75rem;font-size:.9rem;display:flex}.info-block p{color:var(--text-primary);margin-bottom:.25rem;font-size:.95rem}.text-sm{color:var(--text-secondary)!important;font-size:.85rem!important}.skills-wrapper{flex-direction:column;gap:1.5rem;display:flex}.skill-group h3{color:var(--text-tertiary);margin-bottom:.75rem;font-size:.95rem;font-weight:600}.chips{flex-wrap:wrap;gap:.5rem;display:flex}.chip{background:color-mix(in srgb, var(--accent) 15%, transparent);color:var(--accent);border:1px solid color-mix(in srgb, var(--accent) 30%, transparent);cursor:default;border-radius:20px;padding:.35rem .85rem;font-size:.85rem;font-weight:500;transition:all .2s}.chip:hover{background:color-mix(in srgb, var(--accent) 25%, transparent);border-color:color-mix(in srgb, var(--accent) 50%, transparent);transform:translateY(-2px)}.divider-horiz{background:var(--glass-border);width:100%;height:1px}.lang-list{flex-direction:column;gap:.75rem;list-style:none;display:flex}.lang-list li{color:var(--text-secondary);justify-content:space-between;font-size:.95rem;display:flex}.lang-list strong{color:var(--text-primary)}.exp-subsection{margin-bottom:1.5rem}.subsection-title{align-items:center;gap:.75rem;margin-bottom:1.5rem;font-size:1.2rem;font-weight:600;display:flex}.timeline{border-left:2px solid var(--glass-border);flex-direction:column;gap:2rem;padding-left:1rem;display:flex;position:relative}.timeline-row{padding-left:1.5rem;transition:transform .2s;position:relative}.timeline-row:hover{transform:translate(4px)}.timeline-row:before{content:"";background:var(--accent);width:12px;height:12px;box-shadow:0 0 0 4px var(--bg-base);border-radius:50%;position:absolute;top:.2rem;left:-1.5rem;transform:translate(-50%)}.time-col{color:var(--accent);margin-bottom:.25rem;font-size:.9rem;font-weight:600}.content-col{flex-direction:column;display:flex}.exp-title{color:var(--text-primary);margin-bottom:.2rem;font-size:1.1rem;font-weight:700}.exp-org{color:var(--text-tertiary);margin-bottom:.75rem;font-size:.95rem;font-weight:500}.exp-desc{color:var(--text-secondary);font-size:.95rem;line-height:1.6}.academic-list{flex-direction:column;gap:1rem;display:flex}.academic-item{background:var(--glass-hover);border:1px solid #0000;border-radius:1rem;gap:1.5rem;padding:1.5rem;transition:all .2s;display:flex}.academic-item:hover{border-color:var(--glass-border);transform:translate(5px)}.ac-title{color:var(--text-primary);align-items:center;gap:.5rem;margin-bottom:.25rem;font-size:1.1rem;font-weight:600;display:flex}.ac-venue{color:var(--text-secondary);font-size:.95rem}.ac-year{color:var(--accent);font-weight:500}.ac-link{color:var(--text-tertiary);transition:color .2s}.ac-link:hover{color:var(--accent)}.projects-section{z-index:10;flex-direction:column;gap:2rem;display:flex}.projects-header{justify-content:space-between;align-items:flex-end;display:flex}.filter-bar{flex-wrap:wrap;gap:.5rem;display:flex}.filter-btn{background:var(--glass-bg);border:1px solid var(--glass-border);color:var(--text-secondary);cursor:pointer;border-radius:2rem;padding:.5rem 1rem;font-size:.9rem;font-weight:500;transition:all .2s}.filter-btn:hover{color:var(--text-primary)}.filter-btn.active{background:var(--accent);color:#fff;border-color:var(--accent)}.projects-grid{grid-template-columns:repeat(3,1fr);gap:1.5rem;display:grid}.project-card{flex-direction:column;padding:0;display:flex;overflow:hidden}.proj-thumb{border-bottom:1px solid var(--glass-border);background-position:50%;background-size:cover;height:180px;position:relative}.status-badge{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:2rem;align-items:center;gap:.4rem;padding:.35rem .85rem;font-size:.8rem;font-weight:600;display:flex;position:absolute;top:1rem;right:1rem;box-shadow:0 4px 12px #0003}.status-dot{border-radius:50%;width:8px;height:8px}.status-badge.live{color:#4ade80;background:#22c55e33;border:1px solid #22c55e4d}.status-badge.live .status-dot{background:#22c55e;box-shadow:0 0 8px #10b981}.status-badge.code{border:1px solid var(--glass-border);color:var(--text-primary);background:#ffffff1a}.status-badge.code .status-dot{background:var(--text-tertiary);box-shadow:0 0 8px var(--text-tertiary)}.proj-body{flex-direction:column;flex:1;gap:.75rem;padding:1.75rem;display:flex}.proj-header-row{justify-content:space-between;align-items:flex-start;display:flex}.proj-title{color:var(--text-primary);font-size:1.25rem;font-weight:700}.external-link{color:var(--text-tertiary);transition:color .2s}.external-link:hover{color:var(--accent)}.proj-desc{color:var(--text-secondary);flex:1;font-size:.95rem;line-height:1.6}.proj-footer{justify-content:space-between;align-items:center;margin-top:1rem;display:flex}.tags{flex-wrap:wrap;gap:.5rem;display:flex}.tag{color:var(--text-tertiary);background:var(--glass-hover);border-radius:4px;padding:.2rem .6rem;font-size:.75rem}.icon-link{color:var(--text-tertiary);transition:color .2s}.icon-link:hover{color:var(--text-primary)}.fixed-height{align-items:stretch}.fixed-height .glass-box{flex-direction:column;height:450px;display:flex}.fixed-height .list-wrapper{flex-grow:1;margin-right:-.5rem;padding-right:.5rem;overflow-y:auto}.fixed-height .list-wrapper::-webkit-scrollbar{width:6px}.fixed-height .list-wrapper::-webkit-scrollbar-track{background:0 0}.fixed-height .list-wrapper::-webkit-scrollbar-thumb{background:var(--glass-border);border-radius:10px}.fixed-height .list-wrapper::-webkit-scrollbar-thumb:hover{background:var(--text-tertiary)}.list-wrapper{flex-direction:column;gap:1.5rem;display:flex}.list-item{border-left:2px solid var(--glass-border);padding-top:.25rem;padding-bottom:.25rem;padding-left:1rem;transition:all .2s;position:relative}.list-item:hover{border-left-color:var(--accent);transform:translate(4px)}.item-title{color:var(--text-primary);margin-bottom:.25rem;font-size:1.05rem;font-weight:600}.item-sub{color:var(--text-tertiary);margin-bottom:.5rem;font-size:.9rem;font-weight:500}.item-desc{color:var(--text-secondary);font-size:.95rem}.site-footer.svelte-1uha8ag{text-align:center;color:var(--text-tertiary);padding:2rem 0;font-size:.9rem}@media (width<=1024px){.desktop-nav{display:none}.mobile-toggle{justify-content:center;align-items:center;display:flex}.bento-split{flex-direction:column;gap:2rem}.fixed-height .glass-box{height:400px}.about-content{flex-direction:column}.timeline-row{grid-template-columns:1fr;gap:.5rem}.glass-box{padding:2rem}.hero-box{padding:3rem 1.5rem}.projects-grid{grid-template-columns:repeat(2,1fr)}}@media (width<=768px){.projects-grid{grid-template-columns:1fr}.about-content{text-align:center}.profile-pic-container{margin:0 auto}.info-blocks{text-align:left}.projects-header{flex-direction:column;align-items:flex-start;gap:1rem}}
