:root{--accent: #f97316;--accent-rgb: 249, 115, 22;--font-display: "Space Grotesk", sans-serif;--font-body: "DM Sans", sans-serif;--font-mono: "JetBrains Mono", monospace;--max-w: 1060px;--grid-size: 80px;--radius: 16px;--ease: cubic-bezier(.16, 1, .3, 1);--dur: .3s}[data-theme=dark]{--bg: #050506;--bg-card: #0a0a0c;--border: rgba(255, 255, 255, .07);--border-hi: rgba(255, 255, 255, .12);--grid-line: rgba(255, 255, 255, .04);--grid-cross: rgba(255, 255, 255, .14);--text-1: #ededef;--text-2: #8b8b9e;--text-3: #4e4e5e;--glow-bg: rgba(255, 255, 255, .015);--noise-opacity: .03;--topbar-bg: rgba(5, 5, 6, .82);color-scheme:dark}[data-theme=light]{--bg: #f6f6f8;--bg-card: #ffffff;--border: rgba(0, 0, 0, .07);--border-hi: rgba(0, 0, 0, .12);--grid-line: rgba(0, 0, 0, .035);--grid-cross: rgba(0, 0, 0, .14);--text-1: #0f0f12;--text-2: #5c5c6e;--text-3: #9e9eaa;--glow-bg: rgba(0, 0, 0, .01);--noise-opacity: .015;--topbar-bg: rgba(246, 246, 248, .82);color-scheme:light}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}html.no-transition,html.no-transition *,html.no-transition *:before,html.no-transition *:after{transition:none!important}body{min-width:320px;font-family:var(--font-body);background:var(--bg);color:var(--text-1);line-height:1.6;overflow-x:hidden;transition:background var(--dur),color var(--dur)}body:before{content:"";position:fixed;inset:0;z-index:0;pointer-events:none;background-image:repeating-linear-gradient(0deg,var(--grid-line) 0 1px,transparent 1px var(--grid-size)),repeating-linear-gradient(90deg,var(--grid-line) 0 1px,transparent 1px var(--grid-size));background-size:var(--grid-size) var(--grid-size);mask-image:radial-gradient(ellipse 80% 70% at 50% 30%,black,transparent);-webkit-mask-image:radial-gradient(ellipse 80% 70% at 50% 30%,black,transparent)}a{color:inherit;text-decoration:none}button{border:0;background:none;color:inherit;cursor:pointer;font:inherit}strong{color:var(--text-1);font-weight:600}::selection{background:rgba(var(--accent-rgb),.2);color:var(--accent)}.noise-overlay{position:fixed;inset:0;z-index:9998;pointer-events:none;opacity:var(--noise-opacity);mix-blend-mode:overlay;background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='300' height='300'%3E%3Cfilter id='n'%3E%3CfeTurbulence baseFrequency='.75' stitchTiles='stitch' type='fractalNoise'/%3E%3C/filter%3E%3Crect width='300' height='300' filter='url(%23n)'/%3E%3C/svg%3E")}.sr{opacity:0;transform:translateY(22px);transition:opacity .7s var(--ease),transform .7s var(--ease)}.sr-v{opacity:1;transform:translateY(0)}.cross-mark{color:var(--grid-cross);display:block;line-height:0}.cm-tl,.cm-tr,.cm-bl,.cm-br{position:absolute;z-index:2}.cm-tl{top:-6px;left:-6px}.cm-tr{top:-6px;right:-6px}.cm-bl{bottom:-6px;left:-6px}.cm-br{bottom:-6px;right:-6px}.grid-divider{display:flex;align-items:center;gap:0;max-width:var(--max-w);margin:0 auto;padding:12px 24px}.gd-line{flex:1;height:.5px;background:var(--border)}.topbar{position:fixed;inset:0 0 auto;z-index:100;height:54px;display:flex;align-items:center;justify-content:center;gap:12px;padding:0 24px;background:var(--topbar-bg);border-bottom:.5px solid var(--border);backdrop-filter:blur(16px) saturate(1.6);-webkit-backdrop-filter:blur(16px) saturate(1.6);transition:background var(--dur)}.tb-logo{flex-shrink:0;font-family:var(--font-display);font-size:18px;font-weight:800;letter-spacing:-.03em}.tb-logo span{color:var(--accent);transition:color var(--dur)}.tb-nav{flex:1;display:flex;justify-content:center;gap:2px}.tb-nav a{border-radius:8px;color:var(--text-3);font-size:13px;font-weight:500;padding:6px 12px;transition:color var(--dur),background var(--dur)}.tb-nav a:hover{color:var(--text-1);background:var(--glow-bg)}.tb-actions{display:flex;align-items:center;gap:10px}.accent-picker{display:flex;align-items:center;gap:5px}.accent-dot{width:14px;height:14px;border-radius:999px;background:var(--dot);border:1px solid var(--border-hi);opacity:.55}.accent-dot-active{opacity:1;box-shadow:0 0 0 3px rgba(var(--accent-rgb),.16)}.tb-theme{width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center;color:var(--text-3);flex-shrink:0;transition:color var(--dur),background var(--dur)}.tb-theme:hover{color:var(--text-1);background:var(--glow-bg)}.site-main{position:relative;z-index:1;max-width:var(--max-w);margin:0 auto;padding:94px 24px 0}.hero{position:relative;padding:48px 0 40px}.hero-glow{position:absolute;inset:-200px -300px;z-index:-1;pointer-events:none}.hero-top-row{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:20px}.hero-badge,.hero-upwork{display:inline-flex;align-items:center;gap:8px;border-radius:100px;font-family:var(--font-mono);font-size:12px;font-weight:500;padding:5px 16px}.hero-badge{color:#22c55e;border:1px solid rgba(34,197,94,.15);background:#22c55e0d}.hero-upwork{color:var(--text-2);border:1px solid rgba(20,168,0,.22);background:#14a8000f}.hero-badge-dot{width:7px;height:7px;border-radius:50%;background:#22c55e;box-shadow:0 0 10px #22c55e80;animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.5)}}.hero-name{max-width:760px;margin-bottom:16px;font-family:var(--font-display);font-size:clamp(36px,6vw,56px);font-weight:700;letter-spacing:-.03em;line-height:1;background:linear-gradient(135deg,var(--text-1) 60%,var(--accent));background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent}.hero-subtitle{max-width:480px;color:var(--text-2);font-size:17px;line-height:1.7;text-wrap:pretty}.hero-socials{display:flex;flex-wrap:wrap;gap:8px;margin-top:20px}.social-link{display:inline-flex;align-items:center;gap:7px;border:.5px solid var(--border);border-radius:10px;color:var(--text-3);font-size:13px;font-weight:500;padding:7px 16px;transition:color var(--dur),border-color var(--dur),background var(--dur),transform .2s}.social-link:hover{color:var(--text-1);border-color:rgba(var(--accent-rgb),.3);background:rgba(var(--accent-rgb),.04);transform:translateY(-1px)}.bento{position:relative;display:grid;grid-template-columns:2fr 1fr;gap:1px;overflow:hidden;margin:0;border:.5px solid var(--border);border-radius:var(--radius);background:var(--border)}.bento-work{grid-template-columns:1.2fr 1fr}.bento-social{grid-template-columns:1fr 1fr}.bento-card{position:relative;overflow:hidden;padding:28px;background:var(--bg-card);transition:background var(--dur)}.bento-card:after{content:"";position:absolute;inset:0;pointer-events:none;opacity:0;background:radial-gradient(600px circle at var(--mouse-x, 50%) var(--mouse-y, 50%),rgba(var(--accent-rgb),.04),transparent 40%);transition:opacity .4s}.bento-card:hover:after{opacity:1}.sec-label{margin-bottom:18px;color:var(--text-3);font-family:var(--font-mono);font-size:11px;font-weight:500;letter-spacing:.12em}.stack-items{display:grid;grid-template-columns:1fr 1fr;gap:4px}.stack-row{display:flex;align-items:center;gap:10px;border-radius:8px;font-size:14px;font-weight:500;padding:8px 10px;transition:background var(--dur)}.stack-row:hover{background:var(--glow-bg)}.stack-sep{height:.5px;margin:18px 0;background:var(--border)}.bento-status{display:flex;align-items:center;justify-content:center}.status-inner{display:flex;flex-direction:column;align-items:center;gap:14px;text-align:center}.status-indicator{width:48px;height:48px;display:flex;align-items:center;justify-content:center;border-radius:50%;border:1.5px solid rgba(34,197,94,.2);background:#22c55e0a}.status-dot{width:12px;height:12px;border-radius:999px;background:#22c55e;box-shadow:0 0 12px #22c55e66;animation:pulse 2.5s ease-in-out infinite}.status-text{font-family:var(--font-display);font-size:16px;font-weight:600;letter-spacing:-.01em;line-height:1.2}.status-sub{color:var(--text-3);font-family:var(--font-mono);font-size:12px}.exp-list{display:flex;flex-direction:column}.exp-item{display:flex;gap:14px}.exp-dot-track{display:flex;flex-direction:column;align-items:center;flex-shrink:0;padding-top:5px}.exp-dot{width:9px;height:9px;flex-shrink:0;z-index:1;border:2px solid var(--text-3);border-radius:50%;background:var(--bg-card);transition:border-color var(--dur),background var(--dur),box-shadow var(--dur)}.exp-dot-on{border-color:var(--accent);background:var(--accent);box-shadow:0 0 10px rgba(var(--accent-rgb),.4)}.exp-line{width:1.5px;flex:1;margin:3px 0;background:var(--border)}.exp-body{padding-bottom:28px}.exp-period{color:var(--text-3);font-family:var(--font-mono);font-size:11px;letter-spacing:.03em}.exp-title{margin-top:1px;font-family:var(--font-display);font-size:16px;font-weight:600;letter-spacing:-.01em}.exp-company{display:block;color:var(--accent);font-size:13px;font-weight:500}.exp-desc{margin-top:3px;color:var(--text-2);font-size:13px}.art-list{display:flex;flex-direction:column}.art-row{display:flex;align-items:center;gap:12px;border-bottom:.5px solid var(--border);padding:12px 0;transition:padding-left .3s var(--ease)}.art-row:first-child{border-top:.5px solid var(--border)}.art-row:hover{padding-left:5px}.art-accent{width:2.5px;height:28px;flex-shrink:0;border-radius:2px;background:var(--accent);opacity:.35;transition:opacity var(--dur)}.art-row:hover .art-accent{opacity:1}.art-text{flex:1}.art-text h4{font-family:var(--font-display);font-size:14px;font-weight:600;letter-spacing:-.01em;transition:color var(--dur)}.art-row:hover .art-text h4{color:var(--accent)}.art-text span{color:var(--text-3);font-family:var(--font-mono);font-size:10px;letter-spacing:.05em}.art-arrow{flex-shrink:0;color:var(--text-3);opacity:0;transform:translate(-4px,4px);transition:opacity var(--dur),transform var(--dur)}.art-row:hover .art-arrow{opacity:1;transform:translate(0)}.projects-section{padding:0}.projects-list{display:grid;gap:18px}.project-card{overflow:hidden;border:.5px solid var(--border);border-radius:var(--radius);background:var(--bg-card);cursor:pointer;transition:border-color var(--dur),transform .2s}.project-card:hover{border-color:var(--border-hi);transform:translateY(-2px)}.project-hit{width:100%;display:block;text-align:left}.pv{position:relative;height:160px;overflow:hidden;display:flex;align-items:flex-end;padding:16px 24px}.pv-1{background:linear-gradient(145deg,#080818,#0a0a14)}.pv-2{background:linear-gradient(145deg,#080a12,#060a0e)}[data-theme=light] .pv-1{background:linear-gradient(145deg,#e8e8f0,#f0f0f8)}[data-theme=light] .pv-2{background:linear-gradient(145deg,#e0eae8,#eef2f0)}.pv-grid{position:absolute;inset:0;background-image:repeating-linear-gradient(0deg,rgba(var(--accent-rgb),.04) 0 .5px,transparent .5px 20px),repeating-linear-gradient(90deg,rgba(var(--accent-rgb),.04) 0 .5px,transparent .5px 20px)}.pv-shapes{position:absolute;inset:0}.pv-orb{position:absolute;border-radius:50%;filter:blur(40px);animation:float 6s ease-in-out infinite}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-12px)}}.pv-orb-1{width:180px;height:180px;top:-30px;left:10%;background:#3b82f62e;animation-delay:0s}.pv-orb-2{width:140px;height:140px;bottom:-20px;right:15%;background:#8b5cf624;animation-delay:-2s}.pv-orb-3{width:160px;height:160px;top:-20px;right:20%;background:#10b98129;animation-delay:-1s}.pv-orb-4{width:120px;height:120px;left:20%;bottom:-10px;background:#06b6d41f;animation-delay:-3s}.pv-bar{position:absolute;height:4px;border-radius:2px;background:#3b82f633;animation:barPulse 3s ease-in-out infinite}@keyframes barPulse{0%,to{opacity:.6;transform:scaleX(1)}50%{opacity:1;transform:scaleX(1.05)}}.pv-bar-a{width:60%;top:30%;left:20%}.pv-bar-b{width:40%;top:50%;left:30%}.pv-bar-c{width:75%;top:70%;left:12%}.pv-node{position:absolute;width:8px;height:8px;border-radius:50%;border:1.5px solid rgba(16,185,129,.4);background:#10b9811a;animation:nodePulse 2.5s ease-in-out infinite}@keyframes nodePulse{0%,to{transform:scale(1);opacity:.7}50%{transform:scale(1.3);opacity:1}}.pv-node-a{top:25%;left:20%}.pv-node-b{top:35%;left:55%}.pv-node-c{top:65%;left:40%}.pv-node-d{top:55%;left:75%}.pv-lines{position:absolute;inset:0;width:100%;height:100%}.pv-lines line{stroke-width:.5}.pv-label{position:relative;z-index:1;font-family:var(--font-mono);font-size:10px;font-weight:500;color:var(--accent);letter-spacing:.12em;opacity:.8}.project-body{padding:20px 24px}.project-body-top{display:flex;justify-content:space-between;gap:28px}.project-body-left{max-width:680px}.project-title{font-family:var(--font-display);font-size:clamp(22px,3.5vw,30px);font-weight:700;letter-spacing:-.03em;line-height:1.1}.project-desc{margin-top:8px;color:var(--text-2);font-size:14px;line-height:1.65;text-wrap:pretty}.project-tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:14px}.tag{border:.5px solid var(--border);border-radius:100px;color:var(--text-2);font-size:11px;font-weight:500;padding:4px 12px;transition:border-color var(--dur)}.project-card:hover .tag{border-color:rgba(var(--accent-rgb),.2)}.project-expand{display:flex;align-items:center;gap:4px;flex-shrink:0;margin-top:14px;color:var(--text-3);font-family:var(--font-mono);font-size:12px;font-weight:500;letter-spacing:.03em;transition:color var(--dur)}.project-card:hover .project-expand{color:var(--accent)}.project-detail{max-height:0;overflow:hidden;opacity:0;transition:max-height .5s var(--ease),opacity .4s ease}.pd-open{max-height:280px;opacity:1}.pd-inner{border-top:.5px solid var(--border);padding:16px 24px 24px}.pd-role{display:flex;align-items:center;gap:10px;margin-bottom:10px}.pd-label{color:var(--text-3);font-family:var(--font-mono);font-size:10px;letter-spacing:.08em}.pd-role span:last-child{color:var(--text-2);font-size:14px}.pd-list{display:flex;flex-direction:column;gap:6px;list-style:none}.pd-list li{position:relative;color:var(--text-2);font-size:13px;padding-left:14px}.pd-list li:before{content:"";position:absolute;left:0;top:8px;width:4px;height:4px;border-radius:50%;background:var(--accent);opacity:.5}.oss-grid{display:flex;flex-direction:column;gap:10px}.oss-item{border:.5px solid var(--border);border-radius:12px;background:var(--glow-bg);padding:18px;transition:border-color var(--dur),transform .2s}.oss-item:hover{border-color:rgba(var(--accent-rgb),.15);transform:translateY(-2px)}.test-list{display:flex;flex-direction:column;gap:12px}.test-item{border:.5px solid var(--border);border-radius:12px;background:var(--glow-bg);padding:20px;transition:border-color var(--dur)}.test-item:hover{border-color:rgba(var(--accent-rgb),.12)}.test-quote-icon{display:block;margin-bottom:6px}.oss-top{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:6px}.oss-repo{display:flex;align-items:center;gap:6px;color:var(--text-3);font-size:12px}.oss-badge{border-radius:100px;font-family:var(--font-mono);font-size:10px;font-weight:600;letter-spacing:.03em;padding:2px 10px}.oss-merged{color:#a78bfa;border:.5px solid rgba(167,139,250,.2);background:#a78bfa14}.oss-closed{color:var(--text-3);border:.5px solid var(--border);background:var(--glow-bg)}.oss-title{font-family:var(--font-display);font-size:14px;font-weight:600;letter-spacing:-.01em}.oss-meta{display:block;margin-top:3px;color:var(--text-3);font-family:var(--font-mono);font-size:11px}.test-item blockquote{color:var(--text-2);font-size:13px;font-style:italic;line-height:1.6;text-wrap:pretty}.test-who{display:flex;align-items:center;gap:10px;margin-top:12px}.test-av{width:28px;height:28px;display:flex;align-items:center;justify-content:center;flex-shrink:0;border-radius:50%;background:rgba(var(--accent-rgb),.1);color:var(--accent);font-family:var(--font-display);font-size:12px;font-weight:700}.test-who strong{display:block;font-family:var(--font-display);font-size:13px;font-weight:600}.test-who span{display:block;color:var(--text-3);font-size:11px}.contact{position:relative;padding:48px 0;text-align:center}.contact-inner{position:relative}.contact-glow{position:absolute;inset:-60px;z-index:-1;pointer-events:none}.contact-heading{font-family:var(--font-display);font-size:clamp(28px,5vw,42px);font-weight:800;letter-spacing:-.03em}.contact-sub{max-width:380px;margin:12px auto 28px;color:var(--text-2);font-size:15px;text-wrap:pretty}.btn-cta{display:inline-flex;align-items:center;gap:8px;border-radius:100px;background:var(--accent);color:#fff;font-family:var(--font-display);font-size:14px;font-weight:600;padding:12px 28px;transition:transform .2s,box-shadow .3s}.btn-cta:hover{transform:translateY(-2px);box-shadow:0 6px 20px rgba(var(--accent-rgb),.35)}.site-footer{max-width:var(--max-w);display:flex;justify-content:center;gap:8px;margin:0 auto;padding:20px 24px 32px;color:var(--text-3);font-size:12px;text-align:center}@media(max-width:720px){.site-main{padding:74px 16px 0}.topbar{justify-content:space-between;padding:0 16px}.tb-nav,.accent-picker{display:none}.hero{padding:32px 0 28px}.hero-name{font-size:clamp(32px,9vw,44px)}.bento,.bento-work,.bento-social{grid-template-columns:1fr}.bento-card{padding:22px}.stack-items{grid-template-columns:1fr 1fr;gap:2px}.grid-divider{padding:0 16px}.cm-tl,.cm-tr,.cm-bl,.cm-br{display:none}.pv{height:130px}.project-body{padding:20px}.project-body-top{flex-direction:column;gap:12px}.project-expand{margin-top:0}}@media(min-width:721px)and (max-width:960px){.bento,.bento-work,.bento-social{grid-template-columns:1.2fr 1fr}.hero-name{font-size:clamp(36px,6vw,52px)}}@media(prefers-reduced-motion:reduce){html{scroll-behavior:auto}*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}
