*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #18181b;--surface: #1f1f25;--surface2: #26262d;--border: rgba(255, 255, 255, .07);--green: oklch(.74 .17 148);--green-dim: oklch(.74 .17 148 / .12);--green-glow: oklch(.74 .17 148 / .25);--text: #eeeef2;--muted: #a1a1aa;--muted2: #52525b;--ff-sans: "Inter", system-ui, -apple-system, "Segoe UI", sans-serif;--ff-display: var(--ff-sans);--ff-mono: var(--ff-sans);color-scheme:dark}[data-theme=light]{--bg: #ffffff;--surface: #f5f5f7;--surface2: #ebebed;--border: rgba(0, 0, 0, .08);--green: oklch(.62 .17 148);--green-dim: oklch(.62 .17 148 / .1);--green-glow: oklch(.62 .17 148 / .2);--text: #18181b;--muted: #52525b;--muted2: #a1a1aa;color-scheme:light}html{scroll-behavior:smooth}body{background-color:var(--bg);background-image:url(/noise.png);background-size:200px 200px;background-repeat:repeat;background-position:0 0;color:var(--text);font-family:var(--ff-sans);font-size:16px;line-height:1.6;overflow-x:hidden;min-height:100vh;-webkit-font-smoothing:antialiased;display:flex;flex-direction:column}h1,h2,h3,h4{font-family:var(--ff-display)}main{flex:1}::selection{background:var(--green-dim);color:var(--green)}::-webkit-scrollbar{width:5px}::-webkit-scrollbar-track{background:var(--bg)}::-webkit-scrollbar-thumb{background:var(--muted2);border-radius:3px}nav.site-nav{position:fixed;top:0;left:0;right:0;z-index:200;height:60px;display:flex;align-items:center;justify-content:space-between;padding:0 48px;background:color-mix(in oklab,var(--bg) 80%,transparent);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);border-bottom:1px solid var(--border)}.nav-logo{width:32px;height:32px;border-radius:50%;background:var(--green);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:14px;color:var(--bg);cursor:pointer;flex-shrink:0;text-decoration:none;transition:box-shadow .2s}.nav-logo:hover{box-shadow:0 0 0 4px var(--green-glow)}.nav-links{display:flex;gap:28px;align-items:center}.nav-link{color:var(--text);text-decoration:none;font-size:14px;font-weight:500;letter-spacing:.01em;transition:color .15s;font-family:var(--ff-sans);background:none;border:none;padding:0;cursor:pointer}.nav-link:hover,.nav-link.active{color:var(--green)}.theme-toggle{display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:50%;background:var(--surface);color:var(--muted);border:1px solid var(--border);cursor:pointer;transition:color .15s,border-color .15s,transform .3s;padding:0}.theme-toggle:hover{color:var(--text);border-color:var(--muted2)}[data-theme=light] .theme-toggle{transform:rotate(-180deg)}[data-theme=light] .theme-icon-moon{display:none}.theme-icon{width:18px;height:18px}:root:not([data-theme=light]) .theme-icon-sun{display:none}.page{flex:1;padding-top:60px}.hero{position:relative;min-height:calc(100vh - 60px);display:flex;align-items:center;overflow:hidden}#particle-canvas{position:absolute;inset:0;width:100%;height:100%;pointer-events:none;z-index:0}.hero-inner{position:relative;z-index:1;max-width:1100px;margin:0 auto;padding:0 48px;width:100%}.hero-eyebrow{font-family:var(--ff-mono);font-size:12.5px;color:var(--green);letter-spacing:.14em;text-transform:uppercase;margin-bottom:28px;display:flex;align-items:center;gap:12px}.hero-eyebrow:before{content:"";width:20px;height:1px;background:var(--green);display:block}.hero-headline{font-size:clamp(44px,5.5vw,76px);font-weight:700;line-height:1.06;letter-spacing:-.035em;margin-bottom:28px;max-width:780px}.hero-headline .accent{color:var(--green)}.hero-body{font-size:17px;color:var(--muted);line-height:1.75;max-width:520px;margin-bottom:44px}.hero-socials{display:flex;align-items:center;gap:20px;flex-wrap:wrap}.social-link{display:flex;align-items:center;gap:9px;color:var(--text);text-decoration:none;font-size:15px;font-weight:500;transition:color .15s}.social-link:hover{color:var(--green)}.social-link svg{opacity:.85;transition:opacity .15s}.social-link:hover svg{opacity:1}.social-sep{width:1px;height:14px;background:var(--muted2)}.section-label{font-family:var(--ff-mono);font-size:16px;color:var(--green);letter-spacing:.14em;text-transform:uppercase;margin-bottom:40px;display:flex;align-items:center;gap:12px}.section-label:after{content:"";flex:1;max-width:36px;height:1px;background:var(--green)}.exp-wrap{border-top:1px solid var(--border)}.exp-section{max-width:1100px;margin:0 auto;padding:80px 48px 100px}.exp-list{display:flex;flex-direction:column}.exp-item{display:grid;grid-template-columns:180px 1fr;gap:0 48px;padding:28px 0;border-bottom:1px solid var(--border)}.exp-item:first-child{border-top:1px solid var(--border)}.exp-meta{padding-top:3px}.exp-date{font-family:var(--ff-mono);font-size:16.5px;color:var(--muted);line-height:1.7}.exp-badge{display:inline-block;margin-top:10px;padding:3px 10px;border-radius:20px;background:var(--green-dim);color:var(--green);font-family:var(--ff-mono);font-size:15px}.exp-company-row{display:flex;align-items:center;gap:14px;margin-bottom:4px}.exp-logo{width:62px;height:62px;border-radius:12px;background:var(--surface2);border:1px solid var(--border);overflow:hidden;flex-shrink:0}.exp-logo img{width:100%;height:100%;object-fit:contain;padding:6px}.exp-company{font-size:21px;font-weight:600}.exp-role{font-size:17.5px;color:var(--muted);margin-bottom:10px;display:flex;align-items:center;gap:8px;flex-wrap:wrap}.exp-type{font-size:15px;font-family:var(--ff-mono);padding:3px 8px;border-radius:4px;background:var(--surface2);color:var(--muted);border:1px solid var(--border)}.exp-desc{font-size:18px;color:var(--muted);line-height:1.75}.exp-desc p{margin:0 0 8px}.exp-desc p:last-child{margin-bottom:0}.exp-desc-list{margin:6px 0 0;padding-left:22px}.exp-desc-list li{margin:2px 0}.about-page{max-width:1100px;margin:0 auto;padding:80px 48px 100px}.about-headline{font-size:clamp(30px,4vw,48px);font-weight:600;letter-spacing:-.025em;line-height:1.15;max-width:720px;margin-bottom:40px}.about-grid{display:grid;grid-template-columns:1.2fr 1fr;gap:56px;align-items:start}.about-bio{font-size:16px;color:var(--muted);line-height:1.7}.about-bio p{margin-bottom:18px}.about-bio strong{color:var(--text);font-weight:600}.about-bio em{font-style:italic}.about-bio code{font-family:var(--ff-mono);font-size:.92em;background:var(--surface);border:1px solid var(--border);border-radius:4px;padding:0 5px}.about-bio a{color:var(--green);text-decoration:none;border-bottom:1px solid var(--green-dim)}.about-bio a:hover{border-bottom-color:var(--green)}.about-bio h2,.about-bio h3,.about-bio h4{color:var(--text);font-weight:600;margin-top:24px;margin-bottom:10px}.about-bio blockquote{border-left:2px solid var(--green);padding-left:16px;color:var(--text);font-style:italic;margin:18px 0}.about-contact{margin-top:36px;display:flex;flex-direction:column;gap:10px}.contact-row{font-family:var(--ff-mono);font-size:13px;color:var(--muted);display:flex;gap:12px;align-items:center}.contact-key{color:var(--muted2);width:68px;flex-shrink:0}.contact-row a{color:var(--muted);text-decoration:none;transition:color .15s}.contact-row a:hover{color:var(--green)}.about-aside{display:flex;flex-direction:column;gap:16px;position:sticky;top:32px}.about-resume-btn{display:flex;align-items:center;justify-content:center;gap:8px;padding:12px 18px;border:1px solid var(--border);border-radius:10px;background:var(--surface);color:var(--text);font-size:18px;font-weight:600;font-family:var(--ff-display);text-decoration:none;transition:color .15s,border-color .15s,background .15s}.about-resume-btn:hover{color:var(--green);border-color:var(--muted2)}.about-email{display:inline-flex;align-items:center;justify-content:center;gap:8px;font-size:16px;color:var(--text);text-decoration:none;transition:color .15s}.about-email:hover{color:var(--green)}.about-photo{width:100%;aspect-ratio:1 / 1;max-height:384px;border-radius:16px;background:var(--surface);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;flex-direction:column;gap:10px;overflow:hidden}.about-photo img{width:100%;height:100%;object-fit:cover}.photo-hint{font-family:var(--ff-mono);font-size:11px;color:var(--muted2)}.stack-section{margin-top:56px}.stack-title{font-size:36px;font-weight:700;letter-spacing:-.025em;color:var(--text);margin-bottom:16px;font-family:var(--ff-display)}.stack-subtitle{font-size:16px;color:var(--muted);margin-bottom:24px;max-width:520px;line-height:1.6}.stack-list{list-style:none;display:flex;flex-direction:column;gap:14px;padding:0;margin:0}.stack-list li{font-size:16px;color:var(--muted);line-height:1.7;position:relative;padding-left:22px}.stack-list li:before{content:"•";color:var(--green);font-size:18px;line-height:1.7;position:absolute;left:0;top:0}.stack-list strong{color:var(--text);font-weight:600}.projects-page{max-width:1100px;margin:0 auto;padding:80px 48px 100px}.projects-headline{font-size:clamp(32px,4vw,52px);font-weight:700;letter-spacing:-.03em;line-height:1.1;margin-bottom:16px}.projects-intro{font-size:15px;color:var(--muted);max-width:540px;line-height:1.75}.projects-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:60px}.project-card{background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:28px;display:flex;flex-direction:column;gap:14px;cursor:pointer;text-decoration:none;color:inherit;position:relative;overflow:hidden;transition:border-color .2s,transform .2s}.project-card:hover{border-color:#50c76a4d;transform:translateY(-3px)}.project-card-glow{position:absolute;inset:0;background:radial-gradient(circle at 0% 0%,var(--green-dim) 0%,transparent 65%);opacity:0;transition:opacity .3s;pointer-events:none}.project-card:hover .project-card-glow{opacity:1}.project-arrow{position:absolute;top:22px;right:22px;font-size:14px;color:var(--muted2);transition:color .2s,transform .2s}.project-card:hover .project-arrow{color:var(--green);transform:translate(2px,-2px)}.project-icon{width:40px;height:40px;border-radius:10px;background:var(--surface2);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;flex-shrink:0;overflow:hidden}.project-icon img{width:100%;height:100%;object-fit:cover}.project-icon-fallback{font-size:18px;color:var(--muted)}.project-name{font-size:15px;font-weight:600;line-height:1.3;padding-right:20px}.project-desc{font-size:13px;color:var(--muted);line-height:1.7;flex:1}.project-detail{max-width:880px;margin:0 auto;padding:80px 48px 100px}.project-detail-back{display:inline-flex;align-items:center;gap:6px;font-family:var(--ff-mono);font-size:13px;color:var(--muted);text-decoration:none;margin-bottom:28px;transition:color .15s}.project-detail-back:hover{color:var(--text)}.project-detail-head{display:flex;align-items:flex-start;justify-content:space-between;flex-wrap:wrap;gap:18px;margin-bottom:8px}.project-detail-title{font-size:clamp(32px,4vw,48px);font-weight:700;letter-spacing:-.03em;line-height:1.08;max-width:580px}.project-detail-tagline{color:var(--muted);font-size:16px;margin-bottom:32px;max-width:640px}.project-detail-actions{display:flex;gap:10px;flex-wrap:wrap}.project-detail-btn{display:inline-flex;align-items:center;gap:8px;padding:9px 16px;border:1px solid var(--border);border-radius:8px;color:var(--muted);font-size:13px;font-weight:500;text-decoration:none;background:var(--surface);transition:color .15s,border-color .15s}.project-detail-btn:hover{color:var(--text);border-color:var(--muted2)}.project-detail-cover{width:100%;aspect-ratio:16 / 9;border-radius:14px;border:1px solid var(--border);background:var(--surface);margin:28px 0 36px;overflow:hidden}.project-detail-cover img{width:100%;height:100%;object-fit:cover}.project-detail-body{color:var(--muted);font-size:16px;line-height:1.8}.project-detail-body p{margin-bottom:18px}.project-detail-body strong{color:var(--text);font-weight:600}.project-detail-body a{color:var(--green);text-decoration:none;border-bottom:1px solid var(--green-dim)}.project-detail-body a:hover{border-bottom-color:var(--green)}.project-detail-body h2,.project-detail-body h3,.project-detail-body h4{color:var(--text);font-weight:600;margin:28px 0 12px}.project-detail-body code{font-family:var(--ff-mono);font-size:.92em;background:var(--surface);border:1px solid var(--border);border-radius:4px;padding:0 5px}.project-detail-body pre{background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:16px;overflow-x:auto;margin:18px 0}.project-detail-body blockquote{border-left:2px solid var(--green);padding-left:16px;color:var(--text);font-style:italic;margin:18px 0}footer.site-footer{border-top:1px solid var(--border);padding:32px 48px;display:flex;align-items:center;justify-content:space-between;margin-top:auto;flex-wrap:wrap;gap:16px}.footer-copy{font-family:var(--ff-mono);font-size:12.5px;color:var(--muted)}.footer-right{display:flex;gap:24px}.footer-link{font-family:var(--ff-mono);font-size:12.5px;color:var(--muted2);text-decoration:none;transition:color .15s}.footer-link:hover{color:var(--green)}.fade-in{animation:fadeIn .5s ease both}@keyframes fadeIn{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:none}}@media(max-width:860px){nav.site-nav{padding:0 20px}.hero-inner,.exp-section,.about-page,.projects-page,.project-detail{padding-left:20px;padding-right:20px}.about-grid{grid-template-columns:1fr;gap:40px}.about-aside{position:static;order:-1;max-width:380px}.about-photo{aspect-ratio:1 / 1;max-height:320px}.projects-grid{grid-template-columns:1fr}.exp-item{grid-template-columns:1fr;gap:6px}footer.site-footer{padding:24px 20px;flex-direction:column;align-items:flex-start}}
