@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/2c55a0e60120577a-s.2a48534a.woff2)format("woff2");unicode-range:U+460-52F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/9c72aa0f40e4eef8-s.18a48cbc.woff2)format("woff2");unicode-range:U+301,U+400-45F,U+490-491,U+4B0-4B1,U+2116}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/ad66f9afd8947f86-s.7a40eb73.woff2)format("woff2");unicode-range:U+1F??}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/5476f68d60460930-s.c995e352.woff2)format("woff2");unicode-range:U+370-377,U+37A-37F,U+384-38A,U+38C,U+38E-3A1,U+3A3-3FF}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/2bbe8d2671613f1f-s.76dcb0b2.woff2)format("woff2");unicode-range:U+102-103,U+110-111,U+128-129,U+168-169,U+1A0-1A1,U+1AF-1B0,U+300-301,U+303-304,U+308-309,U+323,U+329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/1bffadaabf893a1e-s.7cd81963.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/83afe278b6a6bb3c-s.p.3a6ba036.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Inter Fallback;src:local(Arial);ascent-override:90.44%;descent-override:22.52%;line-gap-override:0.0%;size-adjust:107.12%}.inter_5972bc34-module__OU16Qa__className{font-family:Inter,Inter Fallback;font-style:normal}
@font-face{font-family:Outfit;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/b2ea385cb5ae8625-s.866357a4.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Outfit;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/1b99372b3eaef0c8-s.p.758e15a8.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Outfit Fallback;src:local(Arial);ascent-override:100.18%;descent-override:26.05%;line-gap-override:0.0%;size-adjust:99.82%}.outfit_8778cd42-module__wRojWG__className{font-family:Outfit,Outfit Fallback;font-style:normal}.outfit_8778cd42-module__wRojWG__variable{--font-outfit:"Outfit","Outfit Fallback"}
*{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;overflow:hidden auto}:root{--bg-primary:#050505;--bg-secondary:#0e0e0e;--text-primary:#fff;--text-secondary:#c8c8d0;--text-gray:#8d8d95;--border-color:#3c3c44;--border-dotted:#4a4a4f;--line-color:#3c3c44;--accent:#22c55e;--font-heading:var(--font-outfit),Inter,sans-serif}[data-theme=light]{--bg-primary:#fafafa;--bg-secondary:#fff;--text-primary:#000;--text-secondary:#3f3f46;--text-gray:#71717a;--border-color:#d4d4d7;--border-dotted:#cfd8e3;--line-color:#d4d4d7}body{background-color:var(--bg-primary);color:var(--text-primary);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Helvetica,Arial,sans-serif;font-size:1rem;line-height:1.6;overflow:hidden auto}html.theme-color-transition *,html.theme-color-transition :before,html.theme-color-transition :after{transition:background-color .45s,color .45s,border-color .45s,box-shadow .45s,fill .45s,stroke .45s}@supports (view-transition-name:root){::view-transition-old(root){animation-duration:.62s;animation-timing-function:cubic-bezier(.22,1,.36,1)}::view-transition-new(root){animation-duration:.62s;animation-timing-function:cubic-bezier(.22,1,.36,1)}html.theme-reveal-active::view-transition-old(root){animation-name:theme-fade-soft}html.theme-reveal-active::view-transition-new(root){animation-name:theme-reveal-down}}@keyframes theme-reveal-down{0%{clip-path:inset(0 0 100%);filter:blur(2px)}to{clip-path:inset(0);filter:blur()}}@keyframes theme-fade-soft{0%{opacity:1}to{opacity:.6}}.main-wrapper{background-color:var(--bg-primary);max-width:clamp(360px,85.5vw,864px);min-height:100vh;margin:0 auto;padding:.75rem 1.5rem 1.5rem;position:relative}.main-wrapper:before,.main-wrapper:after{content:"";background:var(--line-color);pointer-events:none;z-index:300;width:1px;position:absolute;top:0;bottom:0}.main-wrapper:before{left:0}.main-wrapper:after{right:0}.container{z-index:1;width:100%;max-width:1100px;margin:0 auto;padding:0 1.5rem;position:relative}.theme-toggle{border-left:1px dashed var(--border-dotted);border-bottom:1px dashed var(--border-dotted);background-color:var(--bg-primary);cursor:pointer;z-index:100;width:44px;height:44px;color:var(--text-secondary);border-top:none;border-right:none;justify-content:center;align-items:center;transition:all .3s cubic-bezier(.16,1,.3,1);display:flex;position:absolute;top:0;right:0}.theme-toggle:hover{color:var(--text-primary);background-color:var(--bg-secondary)}.header{border-bottom:1px solid var(--line-color);z-index:50;margin:1rem 0;padding:2.25rem 0 1.75rem;position:relative}.header-content{z-index:20;flex-direction:column;align-items:stretch;gap:1.25rem;display:flex;position:relative}.header-main{align-items:center;gap:2.5rem;min-height:240px;display:flex}.profile-img-container{border:1px solid var(--border-color);border-radius:20px;flex-shrink:0;width:200px;height:200px;position:relative;overflow:hidden}.header-info{flex:1;min-width:0}.profile-image{transition:opacity .32s,transform .32s}.profile-image-default{opacity:1;transform:scale(1)}.profile-image-hover,.profile-image-swap:hover .profile-image-default{opacity:0;transform:scale(1.03)}.profile-image-swap:hover .profile-image-hover{opacity:1;transform:scale(1)}.header-info h1{font-family:var(--font-heading);letter-spacing:-.04em;font-size:clamp(2rem,5vw,3.5rem);font-weight:800;line-height:1.1}.subtitle{color:var(--text-secondary);margin:.5rem 0;font-size:clamp(.9rem,1.5vw,1.1rem);font-weight:500}.hero-socials{z-index:30;flex-wrap:wrap;gap:.9rem;margin-top:.2rem;display:flex;position:relative}.hero-link-anchor{margin-right:.2rem;text-decoration:none;display:inline-flex;position:relative}.hero-link-gradient{border-radius:999px}.hero-link{color:var(--text-primary);background-color:var(--bg-secondary);border:none;border-radius:999px;justify-content:center;align-items:center;gap:0;width:100%;min-width:96px;min-height:44px;padding:.68rem 1.2rem;font-size:.875rem;font-weight:500;transition:transform .2s,box-shadow .2s;display:inline-flex;box-shadow:inset 0 0 0 1px #ffffff12,0 8px 20px #00000040}.hero-link>span{z-index:2;position:relative}.hero-link-tooltip{opacity:0;pointer-events:none;z-index:220;background:#0f0f0ff2;border:1px solid #ffffff0f;border-radius:12px;width:220px;padding:.75rem 1rem;transition:opacity .2s,transform .2s;position:absolute;top:110%;left:50%;transform:translate(-50%);box-shadow:0 8px 32px #00000073}[data-theme=light] .hero-link-tooltip{background:linear-gradient(#faf5ea 0%,#f6efe0 100%);border:1px solid #e8ddc7;box-shadow:0 6px 16px #5f4b231a}.hero-link-tooltip p{color:var(--text-gray);margin:0;font-size:.8rem}.hero-link-tooltip span{color:var(--text-secondary);margin-top:.25rem;font-size:.75rem;display:block}[data-theme=light] .hero-link-tooltip p{color:#605438}[data-theme=light] .hero-link-tooltip span{color:#7d6b46}.hero-link-anchor:hover .hero-link{transform:translateY(-1px);box-shadow:inset 0 0 0 1px #ffffff17,0 10px 22px #0000004d}.hero-link-anchor:hover .hero-link-tooltip{opacity:1;transform:translate(-50%,4px)}.hero-link-anchor:first-child .hero-link-tooltip{left:0;transform:translate(0)}.hero-link-anchor:first-child:hover .hero-link-tooltip{transform:translateY(4px)}.hero-link-anchor:last-child .hero-link-tooltip{left:auto;right:0;transform:translate(0)}.hero-link-anchor:last-child:hover .hero-link-tooltip{transform:translateY(4px)}[data-theme=light] .hero-link{color:var(--text-primary);background-color:var(--bg-secondary);box-shadow:inset 0 0 0 1px #ffffff59,0 8px 18px #00000014}.tech-stack-line{color:var(--text-gray);flex-wrap:wrap;align-items:center;gap:.3rem .35rem;margin-top:.35rem;font-size:.875rem;font-weight:500;display:flex}.tech-item{align-items:center;gap:.35rem;display:inline-flex}.tech-separator{color:var(--text-gray);font-weight:600}.section-minimal{z-index:1;padding:3rem 0;position:relative}.footer-section{border-top:1px solid var(--line-color);z-index:10;margin:1rem 0;padding:1.5rem 0;position:relative}.section-title{text-transform:uppercase;letter-spacing:.1em;color:var(--text-gray);align-items:center;gap:1rem;margin-bottom:2rem;font-size:.75rem;font-weight:700;display:flex}.section-title:after{content:"";background:linear-gradient(90deg,transparent,var(--line-color),transparent);flex:1;height:1px}.section-content{z-index:1;position:relative}.section-divider{border:none;border-top:1px solid var(--line-color);opacity:.5;margin:2.5rem 0 0}.section-description{color:var(--text-secondary);max-width:720px;margin-bottom:1.5rem;line-height:1.5}.skill-pill-grid{grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1rem;margin-top:1rem;display:grid}.skill-pill{border:1px solid var(--line-color);cursor:pointer;background:#ffffff05;border-radius:999px;justify-content:center;align-items:center;padding:.65rem 1.2rem;transition:border-color .2s,background-color .2s;display:flex;box-shadow:inset 0 0 0 1px #ffffff0d}.skill-pill:hover{border-color:var(--accent);background:#22c55e1f}.section-minimal{padding:3rem 0;position:relative;overflow:hidden}.section-minimal:after{content:"";opacity:.08;pointer-events:none;background-image:radial-gradient(circle,#ffffff0d 1px,#0000 1px);background-size:16px 16px;position:absolute;inset:0}.project-grid{border:1px solid var(--border-color);grid-template-columns:repeat(2,1fr);gap:0;display:grid}.project-card{border:.5px solid var(--border-color);cursor:pointer;color:var(--text-primary);flex-direction:column;padding:clamp(1.5rem,4vw,3rem);text-decoration:none;transition:all .4s cubic-bezier(.16,1,.3,1);display:flex}.project-card:visited{color:var(--text-primary)}.project-card:hover{background-color:var(--bg-secondary);transform:translateY(-2px)}.project-card-image{aspect-ratio:1;border:1px solid var(--border-color);background-color:var(--bg-secondary);border-radius:12px;width:100%;margin-bottom:2rem;position:relative;overflow:hidden}.project-image-inner{transition:transform .5s cubic-bezier(.16,1,.3,1)}.project-card:hover .project-image-inner{transform:scale(1.05)}.project-header-row{justify-content:space-between;align-items:flex-start;margin-bottom:.5rem;display:flex}.project-name{font-family:var(--font-heading);color:var(--text-primary);font-size:clamp(1.1rem,2vw,1.5rem);font-weight:700}.project-status{color:var(--text-secondary);align-items:center;gap:.5rem;font-size:.75rem;font-weight:600;display:flex}.status-dot{border-radius:50%;width:8px;height:8px}.status-dot.live{background-color:#22c55e;box-shadow:0 0 8px #22c55e}.status-dot.building{background-color:#ef4444;box-shadow:0 0 8px #ef4444}.project-desc{color:var(--text-secondary);margin-bottom:1.5rem;font-size:.9375rem;line-height:1.6}.view-project{color:var(--text-secondary);align-items:center;gap:.5rem;margin-top:auto;font-size:.875rem;font-weight:600;display:flex}.project-card:hover .view-project{color:var(--text-primary)}.skills-grid{flex-direction:column;display:flex}.skill-category{border-bottom:1px solid var(--border-color);justify-content:space-between;padding:1rem 0;display:flex}.skill-category:last-child{border-bottom:none}.skill-label{color:var(--text-primary);min-width:120px;font-weight:600}.skill-items{color:var(--text-secondary);text-align:right}.underline-link{border-bottom:2px solid var(--text-primary);color:var(--text-primary);font-weight:600;text-decoration:none}.modal-overlay{background-color:var(--bg-primary);z-index:5000;overscroll-behavior:contain;-webkit-overflow-scrolling:touch;width:100vw;height:100vh;animation:.4s cubic-bezier(.16,1,.3,1) fadeIn;position:fixed;top:0;left:0;overflow-y:auto}.modal-container{border-left:1px dashed var(--border-dotted);border-right:1px dashed var(--border-dotted);max-width:800px;min-height:100vh;margin:0 auto;padding:4rem 2rem}.modal-hero{aspect-ratio:16/9;border:1px solid var(--border-color);background-color:#000;border-radius:12px;width:100%;margin-bottom:2rem;position:relative;overflow:hidden}.modal-action-bar{border:1px dashed var(--border-dotted);grid-template-columns:repeat(3,1fr);margin-bottom:3rem;display:grid}.modal-action-btn{color:var(--text-secondary);cursor:pointer;border:none;border-right:1px dashed var(--border-dotted);background:0 0;justify-content:center;align-items:center;gap:.75rem;padding:1.25rem;font-size:.9rem;font-weight:600;text-decoration:none;transition:all .2s;display:flex}.modal-action-btn:last-child{border-right:none}.modal-action-btn:hover{background-color:var(--bg-secondary);color:var(--text-primary)}.project-page{min-height:100vh;padding:1rem 0 2rem}.project-page-shell{border-left:1px dashed var(--border-dotted);border-right:1px dashed var(--border-dotted);max-width:860px;margin:0 auto;padding:1rem 2rem 3rem}.project-page-back{color:var(--text-secondary);align-items:center;gap:.45rem;margin-bottom:1.25rem;font-size:.85rem;text-decoration:none;display:inline-flex}.project-page-back:hover{color:var(--text-primary)}.project-page-hero{aspect-ratio:16/9;border:1px solid var(--border-color);background-color:#000;border-radius:12px;width:100%;margin-bottom:1.5rem;position:relative;overflow:hidden}.project-page-action-bar{border:1px dashed var(--border-dotted);grid-template-columns:repeat(2,minmax(0,1fr));margin-bottom:2rem;display:grid}.project-page-action-btn{color:var(--text-secondary);border:none;border-right:1px dashed var(--border-dotted);background:0 0;justify-content:center;align-items:center;gap:.75rem;padding:1rem;font-size:.9rem;font-weight:600;text-decoration:none;transition:all .2s;display:flex}.project-page-action-btn:last-child{border-right:none}.project-page-action-btn:hover{background-color:var(--bg-secondary);color:var(--text-primary)}.project-page-title-row{justify-content:space-between;align-items:baseline;gap:1rem;margin-bottom:1rem;display:flex}.project-page-title{letter-spacing:-.03em;font-size:clamp(2rem,4vw,2.6rem);font-weight:800;line-height:1.1}.project-page-description{color:var(--text-secondary);margin-bottom:2rem;font-size:1rem;line-height:1.8}.project-page-case-study{grid-template-columns:repeat(2,minmax(0,1fr));gap:1rem;margin-bottom:2rem;display:grid}.project-page-stack-section{border-top:1px dashed var(--border-dotted);padding-top:1.5rem}.project-page-stack-title{margin-bottom:1rem;font-size:1rem;font-weight:700}.modal-title-row{justify-content:space-between;align-items:baseline;margin-bottom:1.5rem;display:flex}.modal-title{letter-spacing:-.04em;font-size:2.5rem;font-weight:800}.modal-description{color:var(--text-secondary);margin-bottom:2rem;font-size:1.125rem;line-height:1.8}.modal-case-study{grid-template-columns:repeat(2,minmax(0,1fr));gap:1.5rem;margin-bottom:2.25rem;display:grid}.case-study-block{border:1px dashed var(--border-dotted);background:#ffffff05;padding:1rem 1.1rem}.case-study-title{text-transform:uppercase;letter-spacing:.08em;color:var(--text-gray);margin-bottom:.55rem;font-size:.9rem}.case-study-text{color:var(--text-secondary);font-size:.95rem;line-height:1.7}.modal-stack-section{border-top:1px dashed var(--border-dotted);padding-top:2rem}.modal-stack-title{margin-bottom:1.5rem;font-size:1rem;font-weight:700}.stack-pill-grid{flex-wrap:wrap;gap:.75rem;display:flex}.stack-pill{border:1px solid var(--border-color);background-color:var(--bg-secondary);border-radius:8px;padding:.5rem 1rem;font-size:.875rem;font-weight:500}.github-graph-outer{width:100%;margin:2rem 0;position:relative}.github-graph-scroll{scrollbar-width:none;width:100%;padding-bottom:1rem;position:relative;overflow-x:auto}.github-graph-scroll::-webkit-scrollbar{display:none}.github-heatmap-svg{display:block}.gh-day{transition:all .2s}.github-minimal .gh-day.level-0{fill:#f1f3f5;stroke:#d1d5db;stroke-width:.8px}.github-minimal .gh-day.level-1{fill:#9be9a8}.github-minimal .gh-day.level-2{fill:#40c463}.github-minimal .gh-day.level-3{fill:#30a14e}.github-minimal .gh-day.level-4{fill:#216e39}[data-theme=dark] .github-minimal .gh-day.level-0{fill:#161b22;stroke:#0000}[data-theme=dark] .github-minimal .gh-day.level-1{fill:#0e4429}[data-theme=dark] .github-minimal .gh-day.level-2{fill:#006d32}[data-theme=dark] .github-minimal .gh-day.level-3{fill:#26a641}[data-theme=dark] .github-minimal .gh-day.level-4{fill:#39d353}.gh-tooltip{color:#fff;white-space:nowrap;z-index:10;background:#000;border:1px solid #333;border-radius:6px;padding:.5rem .75rem;font-size:.75rem;animation:.1s ease-out fadeIn;box-shadow:0 10px 20px #0000004d}.github-title-wrapper{align-items:center;gap:2rem;display:flex}.year-pill-nav{border:1px dashed var(--border-dotted);border-radius:4px;gap:0;display:flex;overflow:hidden}.year-pill{color:var(--text-gray);cursor:pointer;border:none;border-right:1px dashed var(--border-dotted);background:0 0;padding:.25rem 1rem;font-size:.75rem;font-weight:800;transition:all .2s}.year-pill:last-child{border-right:none}.year-pill.active{background-color:var(--text-primary);color:var(--bg-primary)}.count-accent{color:var(--accent);font-weight:800}@keyframes fadeIn{0%{opacity:0;filter:blur(4px)}to{opacity:1;filter:blur()}}@keyframes animate-cell-ripple{0%{opacity:.4;transform:scale(1)}50%{opacity:.8;transform:scale(1.05)}to{opacity:.4;transform:scale(1)}}.animate-cell-ripple{animation:animate-cell-ripple var(--duration)var(--delay)ease-out 2}.mask-radial-at-top{-webkit-mask-image:radial-gradient(circle at top,#000,#0000);mask-image:radial-gradient(circle at top,#000,#0000)}.mask-radial-from-20{-webkit-mask-image:radial-gradient(circle,#000 20%,#0000 80%);mask-image:radial-gradient(circle,#000 20%,#0000 80%)}@media (max-width:1100px){.main-wrapper{max-width:81%}}@media (max-width:768px){.main-wrapper{max-width:100%;padding:.75rem .35rem 1.25rem}.main-wrapper:before,.main-wrapper:after{display:none}.container{padding:0 .35rem}.project-grid,.modal-action-bar{grid-template-columns:1fr}.modal-action-btn{border-right:none;border-bottom:1px dashed var(--border-dotted)}.modal-action-btn:last-child{border-bottom:none}.modal-title{font-size:2rem}.modal-case-study{grid-template-columns:1fr}.project-page-shell{border-left:none;border-right:none;padding:.5rem .75rem 2rem}.project-page-action-bar{grid-template-columns:1fr}.project-page-action-btn{border-right:none;border-bottom:1px dashed var(--border-dotted)}.project-page-action-btn:last-child{border-bottom:none}.project-page-title-row{flex-direction:column;align-items:flex-start}.project-page-case-study{grid-template-columns:1fr}.header-content{padding:2.25rem 0 2rem}.header-main{align-items:center;gap:1.25rem;min-height:0}.profile-img-container{border-radius:20px;flex-shrink:0;align-self:flex-start;width:150px!important;height:150px!important}.header-info{flex:1;width:auto;min-width:0}.header-info h1{margin-bottom:.25rem;font-size:clamp(1.5rem,6vw,2rem)}.tech-stack-line{row-gap:.4rem;font-size:.82rem}.hero-socials{grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;width:100%;margin-top:1rem;display:grid}.hero-link-anchor{min-width:0;max-width:none;margin-right:0;display:block}.hero-link{white-space:nowrap;min-width:0;min-height:46px;padding:.65rem .9rem;font-size:.8rem}.hero-link-anchor:nth-child(odd) .hero-link-tooltip{left:0;right:auto;transform:translate(0)}.hero-link-anchor:nth-child(2n) .hero-link-tooltip{left:auto;right:0;transform:translate(0)}.hero-link-anchor:nth-child(odd):hover .hero-link-tooltip,.hero-link-anchor:nth-child(2n):hover .hero-link-tooltip{transform:translateY(4px)}}
