:root{--bg: #0a0b0d;--panel: rgba(255, 255, 255, .018);--line: rgba(255, 255, 255, .08);--line-soft: rgba(255, 255, 255, .05);--line-bright: rgba(255, 255, 255, .16);--fg: #e8e8e6;--fg-dim: #7c7e84;--fg-faint: #76787d;--green: #7df2b0;--green-soft: rgba(125, 242, 176, .5);--green-glow: rgba(125, 242, 176, .14);--sb-h: 42px;--pad: clamp(20px, 5vw, 96px);--rail-w: 132px;--ease: cubic-bezier(.22, .68, .16, 1)}#root{min-height:100dvh}main{position:relative;z-index:1}@media (min-width: 1080px){main{padding-left:var(--rail-w)}}@keyframes blink{0%,to{opacity:1}50%{opacity:0}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.3}}@keyframes bob{0%,to{transform:translateY(0)}50%{transform:translateY(5px)}}@keyframes sweep{0%{transform:translateY(-140px)}to{transform:translateY(100vh)}}@keyframes pfp-scan{0%{transform:translateY(0)}to{transform:translateY(340%)}}@keyframes boot-type{0%{opacity:0;transform:translate(-6px)}to{opacity:1;transform:none}}.statusbar{position:fixed;top:0;left:0;width:100%;height:var(--sb-h);z-index:100;display:flex;align-items:center;justify-content:space-between;padding:0 clamp(14px,3vw,28px);background:#0a0b0dd1;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid var(--line);font-size:.72rem;letter-spacing:.04em}.statusbar-id{display:flex;align-items:center;gap:1px}.sb-dot{width:7px;height:7px;border-radius:50%;background:var(--green);box-shadow:0 0 8px var(--green);margin-right:10px;animation:pulse 2.4s ease-in-out infinite}.sb-user{color:var(--green)}.sb-at,.sb-path{color:var(--fg-dim)}.sb-host{color:var(--fg)}.sb-caret{color:var(--green);margin-left:2px;animation:blink 1.1s step-start infinite}.statusbar-meta{display:flex;align-items:center;gap:10px;color:var(--fg-dim)}.sb-label{color:var(--fg-faint);letter-spacing:.16em}.sb-val{color:var(--green)}.sb-divider{width:1px;height:12px;background:var(--line-bright)}.clock{color:var(--fg);font-variant-numeric:tabular-nums}.scan-progress{position:fixed;top:var(--sb-h);left:0;width:100%;height:2px;z-index:101}.scan-progress>span{display:block;height:100%;background:linear-gradient(90deg,var(--green-soft),var(--green));box-shadow:0 0 10px var(--green-glow);transform-origin:left;transition:transform .12s linear}.rail{position:fixed;left:0;top:50%;transform:translateY(-50%);z-index:90;width:var(--rail-w);padding-left:clamp(14px,3vw,28px)}.rail-list{list-style:none;display:flex;flex-direction:column;border-left:1px solid var(--line)}.rail-link{display:flex;align-items:center;gap:10px;padding:10px 0 10px 16px;text-decoration:none;color:var(--fg-faint);font-size:.72rem;letter-spacing:.06em;position:relative;transition:color .3s var(--ease)}.rail-link:before{content:"";position:absolute;left:-1px;top:50%;transform:translateY(-50%);width:1px;height:0;background:var(--green);transition:height .3s var(--ease)}.rail-link:hover{color:var(--fg-dim)}.rail-link.is-active{color:var(--green)}.rail-link.is-active:before{height:100%}.rail-num{opacity:.55}.scanlines{position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:200;background:repeating-linear-gradient(0deg,transparent 0px,transparent 2px,rgba(0,0,0,.1) 3px,rgba(0,0,0,.1) 4px)}.vignette{position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:201;background:radial-gradient(ellipse 82% 72% at 50% 42%,transparent 55%,rgba(0,0,0,.62) 100%)}.scan-sweep{position:fixed;left:0;top:0;width:100%;height:120px;pointer-events:none;z-index:202;background:linear-gradient(transparent,rgba(125,242,176,.045),transparent);animation:sweep 9s linear infinite}.boot{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9999;background:var(--bg);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:opacity .55s var(--ease)}.boot--done{opacity:0;pointer-events:none}.boot-inner{width:min(440px,82vw)}.boot-head{font-size:.74rem;letter-spacing:.22em;text-transform:uppercase;color:var(--green);margin-bottom:22px}.boot-log{display:flex;flex-direction:column;gap:5px;margin-bottom:20px;min-height:116px}.boot-line{font-size:.8rem;color:var(--fg-dim);white-space:nowrap;animation:boot-type .2s var(--ease)}.boot-bar{height:2px;background:var(--line);overflow:hidden}.boot-bar-fill{height:100%;background:var(--green);box-shadow:0 0 10px var(--green-glow);transition:width .22s var(--ease)}.boot-status{margin-top:12px;font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--green-soft)}.boot-caret{animation:blink 1.1s step-start infinite}.section{padding:clamp(90px,13vh,168px) var(--pad);border-top:1px solid var(--line);scroll-margin-top:var(--sb-h);position:relative}.sec-head{display:flex;align-items:center;gap:clamp(12px,2vw,24px);margin-bottom:clamp(40px,7vh,82px)}.sec-index{font-size:.72rem;color:var(--green);border:1px solid var(--green-soft);padding:4px 8px;letter-spacing:.1em;flex-shrink:0}.sec-cmd{display:flex;align-items:baseline;gap:10px;font-size:clamp(.82rem,1.5vw,1rem);white-space:nowrap}.sec-prompt{color:var(--fg-dim)}.sec-cmd-text{color:var(--fg);cursor:default}.bracket{color:var(--green)}.sec-rule{flex:1;height:1px;background:var(--line)}.hero{position:relative;min-height:100dvh;display:flex;flex-direction:column;justify-content:space-between;gap:24px;overflow:clip;padding:calc(var(--sb-h) + clamp(20px,3vh,38px)) var(--pad) clamp(22px,4vh,46px)}.hero-canvas{position:absolute;top:0;right:0;bottom:0;left:0;z-index:0}.hero-top{position:relative;z-index:2;display:flex;justify-content:space-between;font-size:.72rem;letter-spacing:.2em;color:var(--fg-faint)}.hero-bottom{position:relative;z-index:2;isolation:isolate;display:grid;grid-template-columns:1.5fr 1fr;gap:clamp(28px,5vw,80px);border-top:1px solid var(--line);padding-top:clamp(18px,2.5vh,32px)}.hero-bottom:before{content:"";position:absolute;left:calc(-1 * var(--pad));right:calc(-1 * var(--pad));top:-60px;bottom:calc(-1*clamp(22px,4vh,46px));background:linear-gradient(transparent,#0a0b0de0 45%);z-index:-1;pointer-events:none}.hero-prompt{font-size:.82rem;color:var(--fg-dim);margin-bottom:16px}.hero-prompt-sym{color:var(--green);margin-right:8px}.hero-role{font-size:clamp(1.1rem,2.4vw,1.7rem);color:var(--fg);font-weight:500;margin-bottom:14px}.hero-desc{font-size:clamp(.86rem,1.3vw,1rem);color:var(--fg-dim);line-height:1.85;max-width:48ch;font-weight:300}.hero-aside{display:flex;flex-direction:column;justify-content:space-between;gap:26px}.hero-stats{list-style:none;display:flex;flex-direction:column;gap:8px;font-size:.74rem}.hero-stats li{display:flex;justify-content:space-between;gap:18px;padding-bottom:8px;border-bottom:1px solid var(--line-soft)}.stat-k{color:var(--fg-faint);letter-spacing:.1em;text-transform:uppercase}.stat-v{color:var(--fg-dim)}.stat-v.is-on{color:var(--green)}.hero-scroll{display:flex;align-items:center;gap:10px;text-decoration:none;color:var(--fg-dim);font-size:.74rem;letter-spacing:.2em;text-transform:uppercase;align-self:flex-start;transition:color .3s var(--ease)}.hero-scroll:hover{color:var(--green)}.hero-scroll-arrow{animation:bob 1.8s ease-in-out infinite}.about-grid{display:grid;grid-template-columns:1.3fr .85fr;gap:clamp(30px,5vw,76px);align-items:start}.file-bar{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:9px 14px;background:#ffffff06;border:1px solid var(--line)}.file-name{font-size:.74rem;color:var(--fg-dim)}.file-meta{font-size:.68rem;color:var(--fg-faint);letter-spacing:.08em}.file-body{border:1px solid var(--line);border-top:none;padding:clamp(16px,2.5vw,26px) clamp(12px,2vw,20px);background:var(--panel)}.code-line{display:flex;gap:clamp(14px,2vw,24px);font-size:clamp(.82rem,1.15vw,.95rem);line-height:2}.code-num{color:var(--fg-faint);-webkit-user-select:none;user-select:none;flex-shrink:0}.code-text{color:var(--fg-dim)}.about-meta{margin-top:24px}.meta-row{display:flex;gap:20px;padding:11px 2px;border-bottom:1px solid var(--line-soft);font-size:.78rem}.meta-row dt{width:96px;flex-shrink:0;color:var(--fg-faint);text-transform:uppercase;letter-spacing:.1em}.meta-row dd{color:var(--fg)}.meta-link,.stat-link{color:var(--fg);text-decoration:none;border-bottom:1px solid var(--line);transition:color .3s var(--ease),border-color .3s var(--ease)}.meta-link:hover,.stat-link:hover{color:var(--green);border-color:var(--green)}.pfp-frame{border:1px solid var(--line);background:var(--panel);position:sticky;top:calc(var(--sb-h) + 30px)}.dotset{display:flex;gap:5px}.dotset i{width:8px;height:8px;border-radius:50%;display:block}.dotset i:nth-child(1){background:#ff5f57}.dotset i:nth-child(2){background:#febc2e}.dotset i:nth-child(3){background:#28c840}.pfp-wrap{position:relative;overflow:hidden}.pfp{width:100%;aspect-ratio:1;object-fit:cover;image-rendering:pixelated;filter:grayscale(.55) contrast(1.05) brightness(.95);transition:filter .5s var(--ease)}.pfp-frame:hover .pfp{filter:grayscale(0) contrast(1.08) brightness(1)}.pfp-scan{position:absolute;left:0;right:0;height:42%;top:-42%;background:linear-gradient(transparent,var(--green-glow),transparent);animation:pfp-scan 4.5s linear infinite;pointer-events:none}.pfp-cap{padding:10px 14px;font-size:.68rem;color:var(--fg-faint);letter-spacing:.06em;border-top:1px solid var(--line)}.work-count{font-size:.78rem;color:var(--fg-faint);letter-spacing:.08em;margin-bottom:clamp(20px,3vh,38px)}.work-list{border-bottom:1px solid var(--line)}.proj{display:block;text-decoration:none;color:inherit;border-top:1px solid var(--line);padding:clamp(22px,3.4vh,40px) clamp(8px,1.5vw,22px);position:relative;transition:background .4s var(--ease)}.proj:before{content:"";position:absolute;left:0;top:0;bottom:0;width:2px;background:var(--green);transform:scaleY(0);transform-origin:top;transition:transform .4s var(--ease)}.proj:hover{background:#7df2b006}.proj:hover:before{transform:scaleY(1)}.proj-head{display:grid;grid-template-columns:auto 1fr auto auto;align-items:center;gap:clamp(14px,2.5vw,36px)}.proj-idx{font-size:.78rem;color:var(--fg-faint);transition:color .3s var(--ease)}.proj:hover .proj-idx{color:var(--green)}.proj-name{font-size:clamp(1.7rem,5vw,4rem);font-weight:600;letter-spacing:-.02em;color:var(--fg);line-height:1;transition:color .3s var(--ease)}.proj:hover .proj-name{color:var(--green)}.proj-tag{font-size:.64rem;letter-spacing:.16em;color:var(--fg-dim);border:1px solid var(--line-bright);padding:5px 9px;white-space:nowrap;transition:border-color .3s var(--ease),color .3s var(--ease)}.proj:hover .proj-tag{border-color:var(--green-soft);color:var(--green)}.proj-arrow{font-size:1.4rem;color:var(--fg-faint);transition:transform .35s var(--ease),color .3s var(--ease)}.proj:hover .proj-arrow{color:var(--green);transform:translate(4px,-4px)}.proj-detail{display:grid;grid-template-rows:0fr;transition:grid-template-rows .5s var(--ease)}.proj:hover .proj-detail{grid-template-rows:1fr}.proj-detail-inner{overflow:hidden;min-height:0}.proj-stack{list-style:none;display:flex;flex-wrap:wrap;gap:7px;padding-top:clamp(16px,2.4vh,28px)}.proj-stack li{font-size:.72rem;color:var(--fg-dim);background:#ffffff0a;border:1px solid var(--line);padding:4px 10px}.proj-host{display:inline-block;margin-top:12px;font-size:.72rem;color:var(--fg-faint)}.proj-host:before{content:"↳ ";color:var(--green-soft)}.connect-list{list-style:none;border-bottom:1px solid var(--line)}.connect-link{display:grid;grid-template-columns:auto auto 1fr auto;align-items:center;gap:clamp(14px,3vw,40px);padding:clamp(20px,3vh,38px) clamp(12px,2vw,28px);text-decoration:none;color:var(--fg);border-top:1px solid var(--line);position:relative;isolation:isolate;overflow:hidden;transition:color .35s var(--ease)}.connect-link:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:var(--green);transform:translate(-101%);transition:transform .45s var(--ease);z-index:-1}.connect-link:hover{color:#0a0b0d}.connect-link:hover:before{transform:translate(0)}.connect-idx{font-size:.74rem;opacity:.5}.connect-label{font-size:clamp(1.1rem,2.6vw,2rem);font-weight:600}.connect-handle{font-size:clamp(.78rem,1.2vw,.95rem);color:var(--fg-dim);justify-self:start;transition:color .35s var(--ease)}.connect-link:hover .connect-handle{color:#0a0b0db3}.connect-arrow{font-size:1.5rem;transition:transform .35s var(--ease)}.connect-link:hover .connect-arrow{transform:translate(6px)}.footer{padding:clamp(70px,11vh,138px) var(--pad) clamp(36px,5vh,60px)}.footer-cta{display:flex;flex-direction:column;align-items:center;gap:clamp(22px,4vh,40px);text-align:center}.footer-prompt{font-size:.82rem;color:var(--fg-dim)}.footer-sym{color:var(--green);margin-right:8px}.resume-btn{display:inline-flex;align-items:center;gap:14px;text-decoration:none;color:var(--fg);padding:clamp(16px,2.4vh,24px) clamp(30px,5vw,58px);border:1px solid var(--line-bright);font-size:clamp(1rem,2.4vw,1.7rem);font-weight:600;letter-spacing:.04em;position:relative;isolation:isolate;overflow:hidden;transition:color .4s var(--ease),border-color .4s var(--ease)}.resume-btn:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:var(--green);transform:translateY(101%);transition:transform .42s var(--ease);z-index:-1}.resume-btn:hover{color:#0a0b0d;border-color:var(--green)}.resume-btn:hover:before{transform:translateY(0)}.resume-btn-arrow{transition:transform .35s var(--ease)}.resume-btn:hover .resume-btn-arrow{transform:translate(4px,-4px)}.footer-bar{display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap;margin-top:clamp(48px,8vh,92px);padding-top:22px;border-top:1px solid var(--line);font-size:.72rem;color:var(--fg-faint);letter-spacing:.06em}.footer-top{text-decoration:none;color:var(--fg-dim);transition:color .3s var(--ease)}.footer-top:hover{color:var(--green)}.reveal{opacity:0;transform:translateY(26px);transition:opacity .8s var(--ease),transform .8s var(--ease)}.reveal.is-visible{opacity:1;transform:none}@media (max-width: 1079px){.rail{display:none}}@media (max-width: 860px){.hero-bottom{grid-template-columns:1fr;gap:32px}.about-grid{grid-template-columns:1fr}.pfp-frame{position:static;max-width:340px}}@media (max-width: 680px){.proj-head{grid-template-columns:auto 1fr;row-gap:14px}.proj-arrow{display:none}.proj-tag{grid-column:1 / -1;justify-self:start}.proj-detail{grid-template-rows:1fr}.connect-link{grid-template-columns:auto 1fr;row-gap:6px}.connect-handle{grid-column:2 / -1}.connect-arrow,.sb-label{display:none}}@font-face{font-family:Jet Brains Mono;src:url(/assets/JetBrainsMono_wght_-DgTxpPXt.ttf) format("truetype");font-weight:100 800;font-display:swap}:root{color-scheme:dark}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html{font-size:16px;scroll-behavior:smooth}body{min-height:100dvh;background-color:#0a0b0d;color:#e8e8e6;font-family:Jet Brains Mono,Courier New,monospace;font-variant-ligatures:none;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow-x:hidden;scrollbar-width:none}body::-webkit-scrollbar{display:none}::selection{background:#7df2b0;color:#0a0b0d}a{color:inherit}img{display:block;max-width:100%}@media (max-width: 768px){html{font-size:14px}}@media (prefers-reduced-motion: reduce){html{scroll-behavior:auto}*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}
