@import "https://fonts.googleapis.com/css2?family=JetBrains+Mono:wght@300;400;500&family=Syne:wght@400;500;700;800&display=swap";
:root{--bg:#0a0a0b;--bg2:#111;--bg3:#161616;--bg4:#1a1a1a;--surface:#111113;--surface2:#18181c;--border:#ffffff12;--border2:#ffffff21;--text:#e8e6e0;--text-muted:#6b6964;--text-dim:#3d3c39;--text-body:#c9c7c0;--muted:#6b6a64;--accent:#c8f77c;--accent2:#7cf7c8;--accent-dim:#c8ff571f;--accent-glow:#c8ff570f;--blue:#57b8ff;--blue-dim:#57b8ff1a;--mono:"JetBrains Mono", monospace;--sans:"Syne", sans-serif;--font-display:"Syne", sans-serif;--font-serif:"Lora", Georgia, serif}*{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{background:var(--bg);color:var(--text);font-family:var(--sans);min-height:100vh;font-size:15px;line-height:1.6;overflow-x:hidden}nav{z-index:100;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid var(--border);background:#0a0a0bd9;justify-content:space-between;align-items:center;height:64px;padding:0 40px;display:flex;position:fixed;top:0;left:0;right:0}.nav-logo{font-family:var(--mono);color:var(--accent);letter-spacing:.04em;align-items:center;gap:6px;font-size:13px;text-decoration:none;display:flex}.nav-logo span{color:var(--accent)}.nav-back{color:var(--muted);letter-spacing:.02em;font-size:13px;font-family:var(--mono);align-items:center;gap:8px;text-decoration:none;transition:color .2s;display:flex}.nav-back:hover{color:var(--accent)}.nav-back svg{stroke:currentColor;fill:none;stroke-width:2px;stroke-linecap:round;stroke-linejoin:round;width:14px;height:14px}.nav-actions{align-items:center;gap:16px;display:flex}.nav-share{color:var(--muted);border:1px solid var(--border);cursor:pointer;font-size:13px;font-family:var(--mono);background:0 0;border-radius:4px;align-items:center;gap:6px;padding:6px 12px;transition:all .2s;display:flex}.nav-share:hover{border-color:var(--border2);color:var(--text)}.nav-links{gap:32px;list-style:none;display:flex}.nav-links a{font-family:var(--mono);color:var(--muted);letter-spacing:.06em;text-transform:uppercase;cursor:pointer;background:0 0;border:none;font-size:12px;text-decoration:none;transition:color .2s}.nav-links a:hover{color:var(--text)}.nav-links a.active{color:var(--accent)}.nav-dot{background:var(--accent);border-radius:50%;width:6px;height:6px;animation:2s ease-in-out infinite pulse}@keyframes pulse{0%,to{opacity:1}50%{opacity:.3}}#hero{flex-direction:column;min-height:100vh;padding:64px 0 0;display:flex}.hero-content{flex:1;grid-template-columns:1fr 1fr;align-items:center;gap:60px;width:100%;max-width:1200px;margin:0 auto;padding:0 40px;display:grid}.hero-label{font-family:var(--mono);color:var(--accent);letter-spacing:.12em;text-transform:uppercase;margin-bottom:20px;font-size:11px}.hero-name{font-family:var(--sans);color:var(--text);letter-spacing:-.02em;margin-bottom:16px;font-size:clamp(42px,5vw,64px);font-weight:800;line-height:1.05}.hero-name span{color:var(--accent)}.hero-title{font-family:var(--mono);color:var(--muted);margin-bottom:32px;font-size:13px;line-height:1.8}.hero-title b{color:var(--accent2);font-weight:400}.hero-bio{color:#e8e6e0a6;max-width:440px;margin-bottom:40px;font-size:15px;line-height:1.7}.hero-actions{flex-wrap:wrap;gap:12px;display:flex}.btn-primary{background:var(--accent);color:#0a0a0b;font-family:var(--mono);letter-spacing:.05em;cursor:pointer;text-transform:uppercase;border:none;align-items:center;gap:8px;padding:12px 24px;font-size:12px;font-weight:500;transition:all .2s;display:inline-flex}.btn-primary:hover{background:#d4ff8a;transform:translateY(-1px)}.btn-ghost{color:var(--text);font-family:var(--mono);letter-spacing:.05em;border:1px solid var(--border2);cursor:pointer;text-transform:uppercase;background:0 0;align-items:center;gap:8px;padding:12px 24px;font-size:12px;transition:all .2s;display:inline-flex}.btn-ghost:hover{border-color:var(--accent);color:var(--accent)}.hero-right{position:relative}.terminal{background:var(--surface);border:1px solid var(--border2);border-radius:2px;overflow:hidden}.terminal-header{background:var(--surface2);border-bottom:1px solid var(--border);align-items:center;gap:6px;padding:12px 16px;display:flex}.t-dot{border-radius:50%;width:10px;height:10px}.t-dot.r{background:#ff5f56}.t-dot.y{background:#ffbd2e}.t-dot.g{background:#27c93f}.terminal-title{font-family:var(--mono);color:var(--muted);margin-left:8px;font-size:11px}.terminal-body{padding:24px}.t-line{font-family:var(--mono);color:var(--muted);font-size:12.5px;line-height:1.9}.t-line .prompt{color:var(--accent)}.t-line .cmd{color:var(--text)}.t-line .val{color:var(--accent2)}.t-line .key{color:#f7a56c}.t-line .str{color:#a8c7fa}.t-line .num{color:#c8f77c}.t-line .comment{color:#3d3d38}.t-cursor{background:var(--accent);vertical-align:middle;width:8px;height:14px;animation:1s step-end infinite blink;display:inline-block}@keyframes blink{0%,to{opacity:1}50%{opacity:0}}.hero-stats{border-top:1px solid var(--border);grid-template-columns:repeat(4,1fr);margin-top:auto;display:grid}.stat{border-right:1px solid var(--border);padding:24px 40px}.stat:last-child{border-right:none}.stat-num{font-family:var(--sans);color:var(--text);letter-spacing:-.03em;font-size:28px;font-weight:800}.stat-num span{color:var(--accent)}.stat-label{font-family:var(--mono);color:var(--muted);letter-spacing:.06em;text-transform:uppercase;margin-top:4px;font-size:11px}#work{padding:100px 40px 80px}.section-header{align-items:baseline;gap:16px;max-width:1200px;margin-bottom:60px;margin-left:auto;margin-right:auto;display:flex}.section-num{font-family:var(--mono);color:var(--accent);letter-spacing:.1em;font-size:11px}.section-title{font-family:var(--sans);color:var(--text);letter-spacing:-.02em;font-size:clamp(28px,3vw,38px);font-weight:800}.project-grid{background:var(--border);grid-template-columns:repeat(2,1fr);gap:1px;max-width:1200px;margin:0 auto;display:grid}.project-card{background:var(--bg);cursor:pointer;padding:36px;transition:background .2s;position:relative;overflow:hidden}.project-card:before{content:"";background:var(--accent);transform-origin:0;height:2px;transition:transform .3s;position:absolute;top:0;left:0;right:0;transform:scaleX(0)}.project-card:hover{background:var(--surface)}.project-card:hover:before{transform:scaleX(1)}.project-tag{font-family:var(--mono);color:var(--accent);letter-spacing:.1em;text-transform:uppercase;align-items:center;gap:8px;margin-bottom:14px;font-size:10px;display:flex}.project-tag:before{content:"";background:var(--accent);width:16px;height:1px;display:inline-block}.project-name{font-family:var(--sans);color:var(--text);letter-spacing:-.01em;margin-bottom:10px;font-size:20px;font-weight:700}.project-desc{color:var(--muted);margin-bottom:24px;font-size:13.5px;line-height:1.65}.project-stack{flex-wrap:wrap;gap:6px;display:flex}.tag{font-family:var(--mono);border:1px solid var(--border2);color:var(--muted);letter-spacing:.04em;padding:4px 10px;font-size:10.5px}.project-arrow{color:var(--border2);font-size:18px;transition:color .2s,transform .2s;position:absolute;bottom:36px;right:36px}.project-card:hover .project-arrow{color:var(--accent);transform:translate(3px,-3px)}#blog{padding:100px 40px 80px}.post-list{max-width:800px;margin:0 auto}.post-item{border-bottom:1px solid var(--border);cursor:pointer;grid-template-columns:100px 1fr;align-items:start;gap:24px;padding:28px 0;transition:all .2s;display:grid}.post-item:first-child{border-top:1px solid var(--border)}.post-item:hover .post-title{color:var(--accent)}.post-date{font-family:var(--mono);color:var(--muted);letter-spacing:.04em;padding-top:3px;font-size:11px}.post-meta{align-items:center;gap:10px;margin-bottom:6px;display:flex}.post-badge{font-family:var(--mono);color:var(--accent);letter-spacing:.06em;text-transform:uppercase;background:#c8f77c14;border:1px solid #c8f77c33;padding:2px 8px;font-size:10px}.post-read{font-family:var(--mono);color:var(--muted);font-size:10px}.post-title{font-family:var(--sans);color:var(--text);letter-spacing:-.01em;margin-bottom:8px;font-size:17px;font-weight:700;line-height:1.3;transition:color .2s}.post-excerpt{color:var(--muted);font-size:13px;line-height:1.6}#stack{padding:100px 40px 80px}.stack-grid{background:var(--border);grid-template-columns:repeat(3,1fr);gap:1px;max-width:1200px;margin:0 auto;display:grid}.stack-category{background:var(--bg);padding:36px}.stack-cat-label{font-family:var(--mono);color:var(--accent);letter-spacing:.12em;text-transform:uppercase;align-items:center;gap:8px;margin-bottom:20px;font-size:10px;display:flex}.stack-cat-label:after{content:"";background:var(--border);flex:1;height:1px}.stack-items{flex-direction:column;gap:10px;display:flex}.stack-item{background:var(--surface);border:1px solid var(--border);cursor:default;justify-content:space-between;align-items:center;padding:10px 14px;transition:border-color .2s;display:flex}.stack-item:hover{border-color:var(--border2)}.stack-item-name{font-family:var(--mono);color:var(--text);font-size:12.5px}.stack-level{gap:3px;display:flex}.stack-dot{background:var(--border2);border-radius:50%;width:5px;height:5px}.stack-dot.filled{background:var(--accent)}#about{padding:100px 40px 80px}.about-inner{grid-template-columns:1fr 1fr;align-items:start;gap:80px;max-width:1200px;margin:0 auto;display:grid}.about-intro{color:var(--text);letter-spacing:-.01em;margin-bottom:20px;font-size:18px;font-weight:700;line-height:1.5}.about-intro span{color:var(--accent)}.about-body{color:#e8e6e099;margin-bottom:16px;font-size:14px;line-height:1.8}.timeline{position:relative}.timeline:before{content:"";background:var(--border);width:1px;position:absolute;top:8px;bottom:0;left:0}.tl-item{padding:0 0 32px 28px;position:relative}.tl-item:before{content:"";background:var(--surface2);border:1px solid var(--border2);border-radius:50%;width:7px;height:7px;position:absolute;top:8px;left:-3px}.tl-item.current:before{background:var(--accent);border-color:var(--accent)}.tl-year{font-family:var(--mono);color:var(--muted);letter-spacing:.04em;margin-bottom:6px;font-size:11px}.tl-role{font-family:var(--sans);color:var(--text);margin-bottom:2px;font-size:15px;font-weight:700}.tl-company{color:var(--muted);font-size:13px}.contact-links{flex-wrap:wrap;gap:12px;margin-top:32px;display:flex}.contact-link{font-family:var(--mono);color:var(--muted);letter-spacing:.06em;border:1px solid var(--border);cursor:pointer;text-transform:uppercase;background:0 0;align-items:center;gap:6px;padding:8px 14px;font-size:11px;text-decoration:none;transition:all .2s;display:inline-flex}.contact-link:hover{color:var(--accent);border-color:var(--accent)}@media (max-width:768px){nav{padding:0 20px}.hero-content{grid-template-columns:1fr;gap:40px;padding:0 20px}.hero-stats{grid-template-columns:repeat(2,1fr)}.stat{border-right:none;border-bottom:1px solid var(--border);padding:20px}.stat:nth-child(2n){border-right:none}.stat:last-child{border-bottom:none}.project-grid,.stack-grid{grid-template-columns:1fr}.about-inner{grid-template-columns:1fr;gap:40px}.post-item{grid-template-columns:1fr;gap:8px}.post-date{padding-top:0}#work,#blog,#stack,#about{padding:60px 20px 40px}}.page-wrapper{grid-template-columns:1fr 220px;align-items:start;gap:0 60px;max-width:1080px;margin:0 auto;padding:56px 2rem 0;display:grid}.article-meta-top{flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:24px;display:flex}.meta-tag{background:var(--accent-dim);color:var(--accent);letter-spacing:.08em;text-transform:uppercase;font-size:10px;font-family:var(--mono);border:1px solid #c8ff5740;border-radius:3px;align-items:center;padding:3px 10px;display:inline-flex}.meta-sep{color:var(--text-dim);font-size:10px}.meta-date{color:var(--text-muted);letter-spacing:.06em;font-size:11px;font-family:var(--mono)}.meta-read{color:var(--text-dim);font-size:11px;font-family:var(--mono)}.article-title{font-family:var(--sans);letter-spacing:-.03em;color:var(--text);margin-bottom:20px;font-size:clamp(26px,4vw,40px);font-weight:800;line-height:1.1}.article-subtitle{font-family:var(--font-serif);color:var(--text-muted);border-left:2px solid var(--accent);margin-bottom:32px;padding-left:16px;font-size:17px;font-style:italic;line-height:1.7}.article-divider{background:var(--border);height:1px;margin-bottom:40px}.prose{color:var(--text-body);line-height:1.85}.prose p{font-size:15px;font-family:var(--font-serif);margin-bottom:24px}.prose h2{font-family:var(--sans);color:var(--text);letter-spacing:-.02em;border-top:1px solid var(--border);margin:48px 0 16px;padding-top:48px;font-size:20px;font-weight:700}.prose h2:first-child{border-top:none;margin-top:0;padding-top:0}.prose h3{font-family:var(--mono);color:var(--accent);letter-spacing:.06em;text-transform:uppercase;margin:32px 0 12px;font-size:13px;font-weight:500}.code-block{background:var(--surface);border:1px solid var(--border);border-radius:8px;margin:28px 0;overflow:hidden}.code-header{border-bottom:1px solid var(--border);background:var(--surface2);justify-content:space-between;align-items:center;padding:10px 16px;display:flex}.code-lang{color:var(--accent);letter-spacing:.08em;text-transform:uppercase;font-size:10px;font-family:var(--mono)}.code-dots{gap:5px;display:flex}.code-dots span{border-radius:50%;width:8px;height:8px}.cd-r{background:#ff5f57}.cd-y{background:#febc2e}.cd-g{background:#28c840}.code-body{font-size:12px;line-height:1.7;font-family:var(--font-mono);background:var(--bg);padding:20px;overflow-x:auto}.code-body code{white-space:pre;display:block}.callout{background:var(--surface);border:1px solid var(--border);border-left:3px solid var(--blue);color:var(--text-muted);border-radius:0 6px 6px 0;margin:28px 0;padding:16px 20px;font-size:13px;line-height:1.7}.callout-warn{border-left-color:#febc2e}.callout strong{color:var(--blue);font-weight:500;font-family:var(--mono);text-transform:uppercase;letter-spacing:.06em;margin-bottom:6px;font-size:11px;display:block}.callout-warn strong{color:#febc2e}.prose code{background:var(--surface2);border:1px solid var(--border);color:var(--accent);font-size:12px;font-family:var(--font-mono);border-radius:3px;padding:1px 6px}.prose ul{margin:0 0 24px;padding:0;list-style:none}.prose ul li{font-family:var(--font-serif);color:var(--text-body);border-bottom:1px solid var(--border);padding:6px 0 6px 20px;font-size:15px;position:relative}.prose ul li:before{content:"→";color:var(--accent);font-family:var(--font-mono);font-size:11px;position:absolute;left:0}.prose ul li:last-child{border-bottom:none}.article-footer{border-top:1px solid var(--border);margin-top:56px;padding-top:32px}.tags-row{flex-wrap:wrap;gap:6px;margin-bottom:32px;display:flex}.tag{background:var(--surface);border:1px solid var(--border);color:var(--text-muted);letter-spacing:.04em;cursor:pointer;border-radius:3px;padding:4px 10px;font-size:11px;transition:all .2s;display:inline-block}.tag:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-dim)}.author-card{background:var(--surface);border:1px solid var(--border);border-radius:8px;align-items:flex-start;gap:16px;margin-bottom:32px;padding:20px 24px;display:flex}.author-avatar{background:var(--surface2);border:1px solid var(--border);width:48px;height:48px;font-family:var(--sans);color:var(--accent);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:16px;font-weight:800;display:flex}.author-name{color:var(--text);font-size:14px;font-weight:500;font-family:var(--sans);margin-bottom:4px}.author-bio{color:var(--text-muted);font-size:12px;line-height:1.6}.related-title{font-family:var(--sans);color:var(--text);letter-spacing:-.01em;margin-bottom:12px;font-size:14px;font-weight:700}.related-list{flex-direction:column;gap:1px;display:flex}.related-item{border-bottom:1px solid var(--border);cursor:pointer;align-items:baseline;gap:14px;padding:12px 0;text-decoration:none;transition:all .15s;display:flex}.related-item:hover .ri-title{color:var(--accent)}.ri-date{color:var(--text-dim);font-variant-numeric:tabular-nums;min-width:58px;font-size:10px;font-family:var(--mono);flex-shrink:0}.ri-title{color:var(--text);font-size:13px;transition:color .2s}.sidebar{min-width:0;padding:56px 0 80px;position:sticky;top:80px}.toc-label{color:var(--text-muted);letter-spacing:.1em;text-transform:uppercase;font-size:10px;font-family:var(--mono);align-items:center;gap:8px;margin-bottom:16px;display:flex}.toc-label:after{content:"";background:var(--border);flex:1;height:1px}.toc-list{margin-bottom:40px;list-style:none}.toc-item{margin-bottom:2px}.toc-link{color:var(--text-muted);font-size:12px;line-height:1.4;font-family:var(--mono);border-left:2px solid #0000;border-radius:4px;padding:5px 10px;text-decoration:none;transition:all .15s;display:block}.toc-link:hover{color:var(--text);background:var(--surface)}.toc-link.active{color:var(--accent);border-left-color:var(--accent);background:var(--accent-dim)}.toc-link.sub{padding-left:20px;font-size:11px}.sidebar-section{margin-bottom:32px}.sidebar-label{color:var(--text-muted);letter-spacing:.1em;text-transform:uppercase;font-size:10px;font-family:var(--mono);align-items:center;gap:8px;margin-bottom:12px;display:flex}.sidebar-label:after{content:"";background:var(--border);flex:1;height:1px}.share-btns{flex-direction:column;gap:6px;display:flex}.share-btn{background:var(--surface);border:1px solid var(--border);color:var(--text-muted);cursor:pointer;font-size:12px;font-family:var(--font-mono);text-align:left;border-radius:4px;align-items:center;gap:8px;padding:8px 12px;transition:all .2s;display:flex}.share-btn:hover{border-color:var(--border2);color:var(--text)}.share-btn .icon{text-align:center;width:16px;font-size:14px}@media (max-width:768px){.page-wrapper{grid-template-columns:1fr}.sidebar{display:none}}
