.nav{position:sticky;top:0;z-index:50;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:color-mix(in srgb,var(--bg) 78%,transparent);border-bottom:1px solid var(--line)}.nav__inner{display:flex;align-items:center;justify-content:space-between;height:64px}.nav__brand{font-family:var(--font-mono);font-weight:700;font-size:1.05rem;letter-spacing:.06em;color:var(--text)}.nav__brand:hover{color:var(--text)}.nav__bracket{color:var(--green)}.nav__links{display:flex;align-items:center;gap:.35rem}.nav__link{position:relative;font-family:var(--font-mono);font-size:.82rem;letter-spacing:.02em;color:var(--text-dim);padding:.45rem .7rem;border-radius:var(--radius);transition:color .15s ease,background .15s ease}.nav__link:hover{color:var(--text);background:var(--green-faint)}.nav__link.is-active{color:var(--green)}.nav__link.is-active:after{content:"";position:absolute;left:.7rem;right:.7rem;bottom:.1rem;height:1px;background:var(--green);box-shadow:0 0 8px var(--green-glow)}.nav__toggle{display:none;flex-direction:column;gap:4px;background:none;border:none;cursor:pointer;padding:6px}.nav__toggle span{width:22px;height:2px;background:var(--text);transition:background .15s ease}@media (max-width: 720px){.nav__toggle{display:flex}.nav__links{position:absolute;top:64px;left:0;right:0;flex-direction:column;align-items:stretch;gap:0;background:var(--bg-2);border-bottom:1px solid var(--line);padding:.5rem var(--gutter) 1rem;transform:translateY(-8px);opacity:0;pointer-events:none;transition:opacity .18s ease,transform .18s ease}.nav__links.is-open{transform:none;opacity:1;pointer-events:auto}.nav__link{padding:.8rem .4rem;border-bottom:1px solid var(--line)}.nav__link.is-active:after{display:none}}.footer{border-top:1px solid var(--line);margin-top:4rem}.footer__inner{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:.75rem;height:auto;padding-block:1.5rem;font-family:var(--font-mono);font-size:.78rem;color:var(--text-dim)}.footer__meta{display:inline-flex;align-items:center;gap:1rem}.footer__status{display:inline-flex;align-items:center;gap:.5ch;color:var(--green)}.footer__dot{width:7px;height:7px;border-radius:50%;background:var(--green);box-shadow:0 0 8px var(--green);animation:pulse 2s ease-in-out infinite}@keyframes pulse{50%{opacity:.35}}.home{display:flex;align-items:center}.home__grid{display:grid;grid-template-columns:1.5fr 1fr;gap:clamp(2rem,5vw,4rem);align-items:center;width:100%}.home__avatar{--avatar-size: clamp(5.5rem, 12vw, 7.5rem);position:relative;width:var(--avatar-size);height:var(--avatar-size);margin-bottom:1.25rem;border-radius:50%;overflow:hidden;flex-shrink:0;background:var(--panel);border:2px solid var(--green-dim);box-shadow:0 0 0 4px var(--green-faint),0 0 28px -6px var(--green-glow)}.home__avatar-img{position:absolute;left:0;top:-30%;width:100%;height:auto;display:block}.home__avatar-fallback{font-family:var(--font-mono);font-size:calc(var(--avatar-size) * .32);font-weight:500;letter-spacing:.04em;color:var(--green);line-height:1;-webkit-user-select:none;user-select:none}.home__name{font-size:clamp(2.6rem,8vw,4.6rem);font-weight:700;letter-spacing:-.02em;line-height:1;margin:.4rem 0 .6rem}.home__role{font-family:var(--font-mono);color:var(--green);font-size:1rem;letter-spacing:.04em}.home__typed{font-family:var(--font-mono);font-size:clamp(1.05rem,2.5vw,1.35rem);margin:1.5rem 0 1rem;color:var(--text)}.home__typed-prefix{color:var(--text-dim)}.home__typed-word{color:var(--green)}.home__tagline{color:var(--text-dim);max-width:48ch;margin-bottom:2rem}.home__cta{display:flex;flex-wrap:wrap;gap:.75rem}.home__spec{padding:1.5rem 1.75rem}.spec{list-style:none;font-family:var(--font-mono);font-size:.85rem}.spec li{display:flex;justify-content:space-between;gap:1rem;padding:.6rem 0;border-bottom:1px dashed var(--line)}.spec li:last-child{border-bottom:none}.spec__k{color:var(--text-faint)}.spec__v{color:var(--text);text-align:right}.spec__v--green,.spec__v--link{color:var(--green)}@media (max-width: 820px){.home__grid{grid-template-columns:1fr}.home__spec{order:-1;max-width:420px}}.about__grid{display:grid;grid-template-columns:1.4fr 1fr;gap:clamp(2rem,5vw,4rem)}.about__bio p{color:var(--text-dim);margin-bottom:1.1rem;max-width:60ch}.about__bio p:first-child{color:var(--text);font-size:1.1rem}.skillgroup{margin-bottom:1.4rem}.skillgroup__label{display:block;font-family:var(--font-mono);font-size:.75rem;color:var(--text-faint);margin-bottom:.5rem;letter-spacing:.04em}@media (max-width: 760px){.about__grid{grid-template-columns:1fr}}.projects__head{display:flex;align-items:flex-end;justify-content:space-between;flex-wrap:wrap;gap:1rem;margin-bottom:clamp(1.75rem,4vw,2.75rem)}.projects__head .section-head{margin-bottom:0}.proj-filter{display:flex;flex-wrap:wrap;gap:.35rem;padding:.25rem;border:1px solid var(--line);border-radius:var(--radius);background:var(--bg-2)}.proj-filter__btn{font-family:var(--font-mono);font-size:.72rem;letter-spacing:.02em;color:var(--text-dim);padding:.45rem .75rem;border-radius:calc(var(--radius) - 2px);border:1px solid transparent;background:transparent;cursor:pointer;transition:color .15s ease,background .15s ease,border-color .15s ease;white-space:nowrap}.proj-filter__btn:hover{color:var(--text);background:var(--green-faint)}.proj-filter__btn.is-active{color:var(--green);background:var(--green-faint);border-color:color-mix(in srgb,var(--green) 35%,transparent);box-shadow:inset 0 0 20px -12px var(--green-glow)}.proj__meta{font-family:var(--font-mono);font-size:.78rem;color:var(--text-faint)}.proj__placement{color:var(--green)}.proj-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}.proj--featured{grid-column:span 2}.proj__top{display:flex;align-items:baseline;justify-content:space-between;gap:1rem}.proj__title{font-size:1.2rem}.proj--featured .proj__title{font-size:1.5rem}.proj__year{font-family:var(--font-mono);font-size:.75rem;color:var(--text-faint)}.proj__desc{color:var(--text-dim);font-size:.95rem}.proj__links{display:flex;gap:1.2rem;margin-top:auto;padding-top:.4rem}.proj__link{font-family:var(--font-mono);font-size:.8rem}.oss{list-style:none;border-top:1px solid var(--line)}.oss__item{padding:1.25rem 0;border-bottom:1px solid var(--line);transition:padding-left .2s ease}.oss__item:hover{padding-left:.5rem}.oss__main{display:flex;align-items:baseline;justify-content:space-between;flex-wrap:wrap;gap:.5rem}.oss__project{font-family:var(--font-mono);font-size:1rem;color:var(--text)}.oss__project:hover{color:var(--green)}.oss__role{font-family:var(--font-mono);font-size:.78rem;color:var(--green)}.oss__desc{color:var(--text-dim);font-size:.92rem;margin:.4rem 0 .7rem;max-width:70ch}@media (max-width: 680px){.proj-grid{grid-template-columns:1fr}.proj--featured{grid-column:span 1}}.exp-toggle{display:inline-flex;gap:0;margin-bottom:2rem;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}.exp-toggle__btn{background:transparent;border:none;color:var(--text-dim);cursor:pointer;font-family:var(--font-mono);font-size:.78rem;letter-spacing:.02em;padding:.55rem 1rem;transition:background .15s ease,color .15s ease}.exp-toggle__btn+.exp-toggle__btn{border-left:1px solid var(--line)}.exp-toggle__btn:hover{color:var(--text);background:var(--green-faint)}.exp-toggle__btn--active{background:var(--green-faint);color:var(--green)}.timeline{list-style:none;position:relative;margin-left:.5rem}.timeline:before{content:"";position:absolute;left:5px;top:6px;bottom:6px;width:1px;background:linear-gradient(180deg,var(--green-dim),var(--line) 80%)}.timeline__item{position:relative;padding-left:2.2rem;padding-bottom:2.5rem}.timeline__item:last-child{padding-bottom:0}.timeline__marker{position:absolute;left:0;top:6px;width:11px;height:11px;border-radius:50%;background:var(--bg);border:2px solid var(--green);box-shadow:0 0 10px var(--green-glow)}.timeline__top{display:flex;align-items:flex-start;gap:1rem}.timeline__logo{width:52px;height:52px;object-fit:contain;border-radius:var(--radius);border:1px solid var(--line);background:#fff;padding:4px;flex-shrink:0}.timeline__info{flex:1;min-width:0}.timeline__body:has(.timeline__logo) .timeline__summary,.timeline__body:has(.timeline__logo) .timeline__highlights,.timeline__body:has(.timeline__logo) .chips{margin-left:calc(52px + 1rem)}.timeline__head{display:flex;align-items:baseline;justify-content:space-between;flex-wrap:wrap;gap:.5rem}.timeline__role{font-size:1.2rem}.timeline__period{font-family:var(--font-mono);font-size:.78rem;color:var(--text-faint)}.timeline__company{font-family:var(--font-mono);color:var(--green);font-size:.85rem;margin-top:.15rem}.timeline__loc{color:var(--text-faint)}.timeline__summary{color:var(--text-dim);margin:.7rem 0;max-width:66ch}.timeline__highlights{list-style:none;margin:.6rem 0 .9rem}.timeline__highlights li{position:relative;padding-left:1.2rem;color:var(--text-dim);margin-bottom:.4rem;max-width:68ch}.timeline__highlights li:before{content:"▸";position:absolute;left:0;color:var(--green-dim)}.resume__head{display:flex;align-items:flex-end;justify-content:space-between;flex-wrap:wrap;gap:1rem}.resume__head .section-head{margin-bottom:0}.resume__actions{display:flex;gap:.6rem;flex-wrap:wrap}.resume__frame{margin-top:1.75rem;padding:6px;background:var(--panel-2)}.resume__object{display:block;width:100%;height:78vh;min-height:480px;border:none;border-radius:2px;background:#1a1a1a}.resume__fallback{display:flex;flex-direction:column;justify-content:center;align-items:center;height:100%;text-align:center;padding:2rem;color:var(--text-dim);gap:.5rem}.resume__fallback-hint{font-size:.85rem;color:var(--text-faint)}.resume__fallback code{font-family:var(--font-mono);color:var(--green)}.contact__grid{display:grid;grid-template-columns:1.4fr 1fr;gap:clamp(2rem,5vw,4rem)}.contact__form{display:flex;flex-direction:column;gap:1.1rem;max-width:520px}.field{display:flex;flex-direction:column;gap:.4rem}.field__label{font-family:var(--font-mono);font-size:.75rem;color:var(--text-faint);letter-spacing:.04em}.field__input{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);color:var(--text);font-family:var(--font-body);font-size:.95rem;padding:.7rem .9rem;transition:border-color .15s ease,box-shadow .15s ease}.field__input::placeholder{color:var(--text-faint)}.field__input:focus{outline:none;border-color:var(--green);box-shadow:0 0 0 1px var(--green-faint)}.field__input--area{resize:vertical;font-family:var(--font-body)}.contact__form .btn{align-self:flex-start}.links{list-style:none}.links__row{display:flex;justify-content:space-between;align-items:center;padding:.85rem 0;border-bottom:1px solid var(--line);color:var(--text);font-family:var(--font-mono);font-size:.9rem}.links__row:hover{color:var(--green)}.links__label{display:flex;align-items:center;gap:.6rem}.links__icon{width:1rem;height:1rem;flex-shrink:0;color:var(--text-faint)}.links__row:hover .links__icon{color:var(--green)}.links__handle{color:var(--text-faint);font-size:.8rem}.links__row:hover .links__handle{color:var(--green-dim)}@media (max-width: 760px){.contact__grid{grid-template-columns:1fr}}.notfound{text-align:center;padding-block:8rem}.notfound h1{font-family:var(--font-mono);font-size:4rem;color:var(--green)}.notfound p{color:var(--text-dim);margin:1rem 0 2rem}:root{--bg: #070a08;--bg-2: #0b0f0c;--panel: #0e130f;--panel-2: #121911;--line: #1b281f;--line-bright: #2a4031;--green: #4dffa6;--green-dim: #1f8a5b;--green-deep: #0c3b26;--green-glow: rgba(77, 255, 166, .18);--green-faint: rgba(77, 255, 166, .06);--text: #d7ded9;--text-dim: #76857b;--text-faint: #46524b;--font-display: "Space Grotesk", system-ui, sans-serif;--font-mono: "JetBrains Mono", ui-monospace, monospace;--font-body: "Inter", system-ui, sans-serif;--maxw: 1080px;--gutter: clamp(1.25rem, 4vw, 3rem);--radius: 4px;color-scheme:dark}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{background:var(--bg);color:var(--text);font-family:var(--font-body);font-size:16px;line-height:1.65;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;min-height:100vh;overflow-x:hidden}.backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:-1;pointer-events:none;background:radial-gradient(1200px 600px at 70% -10%,var(--green-faint),transparent 60%),linear-gradient(180deg,var(--bg-2),var(--bg))}.backdrop:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background-image:linear-gradient(var(--green-faint) 1px,transparent 1px),linear-gradient(90deg,var(--green-faint) 1px,transparent 1px);background-size:44px 44px;-webkit-mask-image:radial-gradient(ellipse 90% 70% at 50% 0%,#000 30%,transparent 80%);mask-image:radial-gradient(ellipse 90% 70% at 50% 0%,#000 30%,transparent 80%);opacity:.6}.backdrop:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:repeating-linear-gradient(0deg,#0000,#0000 2px,#0000002e,#0000 4px);opacity:.5}h1,h2,h3,h4{font-family:var(--font-display);font-weight:600;line-height:1.1;letter-spacing:-.01em;color:var(--text)}a{color:var(--green);text-decoration:none;transition:color .15s ease}a:hover{color:#fff}::selection{background:var(--green);color:var(--bg)}.container{width:100%;max-width:var(--maxw);margin-inline:auto;padding-inline:var(--gutter)}.page{padding-block:clamp(4rem,9vw,7rem) clamp(4rem,8vw,6rem);min-height:70vh;animation:page-in .5s ease both}@keyframes page-in{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}.eyebrow{font-family:var(--font-mono);font-size:.78rem;letter-spacing:.04em;color:var(--green);display:inline-flex;align-items:center;gap:.5ch;margin-bottom:1rem}.eyebrow:before{content:"›";color:var(--green-dim)}.section-head{margin-bottom:clamp(1.75rem,4vw,2.75rem)}.section-head h2{font-size:clamp(1.7rem,4.5vw,2.6rem)}.section-head .lead{color:var(--text-dim);max-width:56ch;margin-top:.75rem}.subhead{display:flex;align-items:baseline;gap:1rem;margin:clamp(2.5rem,5vw,3.5rem) 0 1.5rem}.subhead h3{font-size:1.15rem;white-space:nowrap}.subhead .rule{flex:1;height:1px;background:linear-gradient(90deg,var(--line-bright),transparent)}.subhead .count{font-family:var(--font-mono);font-size:.75rem;color:var(--text-faint)}.panel{position:relative;background:var(--panel);border:1px solid var(--line);border-radius:var(--radius)}.panel:before,.panel:after{content:"";position:absolute;width:10px;height:10px;border:1px solid var(--green-dim);opacity:.7}.panel:before{top:-1px;left:-1px;border-right:none;border-bottom:none}.panel:after{bottom:-1px;right:-1px;border-left:none;border-top:none}.card{position:relative;display:flex;flex-direction:column;gap:.75rem;background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:1.5rem;transition:border-color .2s ease,transform .2s ease,box-shadow .2s ease}.card:hover{border-color:var(--line-bright);transform:translateY(-2px);box-shadow:0 0 0 1px var(--green-faint),0 18px 40px -28px var(--green-glow)}.chips{display:flex;flex-wrap:wrap;gap:.4rem}.chip{font-family:var(--font-mono);font-size:.72rem;color:var(--text-dim);border:1px solid var(--line);border-radius:999px;padding:.18rem .6rem;background:var(--bg-2)}.btn{display:inline-flex;align-items:center;gap:.6ch;font-family:var(--font-mono);font-size:.85rem;letter-spacing:.02em;padding:.7rem 1.2rem;border-radius:var(--radius);border:1px solid var(--line-bright);background:transparent;color:var(--text);cursor:pointer;transition:all .18s ease}.btn:hover{border-color:var(--green);color:var(--green);box-shadow:0 0 0 1px var(--green-faint),inset 0 0 24px -16px var(--green-glow)}.btn--primary{background:var(--green);color:var(--bg);border-color:var(--green);font-weight:700}.btn--primary:hover{color:var(--bg);background:#fff;border-color:#fff;box-shadow:0 0 24px -6px var(--green-glow)}.cursor{display:inline-block;width:.6ch;height:1.05em;background:var(--green);margin-left:2px;translate:0 .12em;animation:blink 1.1s steps(1) infinite}@keyframes blink{50%{opacity:0}}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation:none!important;transition:none!important;scroll-behavior:auto!important}}
