@font-face{font-family:Fraunces Variable;font-style:normal;font-display:swap;font-weight:100 900;src:url(/assets/fraunces-vietnamese-wght-normal-CnvboYUG.woff2) format("woff2-variations");unicode-range:U+0102-0103,U+0110-0111,U+0128-0129,U+0168-0169,U+01A0-01A1,U+01AF-01B0,U+0300-0301,U+0303-0304,U+0308-0309,U+0323,U+0329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Fraunces Variable;font-style:normal;font-display:swap;font-weight:100 900;src:url(/assets/fraunces-latin-ext-wght-normal-Ca2vKHc0.woff2) format("woff2-variations");unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,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:Fraunces Variable;font-style:normal;font-display:swap;font-weight:100 900;src:url(/assets/fraunces-latin-wght-normal-ukD16Tqj.woff2) format("woff2-variations");unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Commit Mono;font-style:normal;font-display:swap;font-weight:400;src:url(/assets/commit-mono-latin-400-normal-wzhe4RuD.woff2) format("woff2"),url(/assets/commit-mono-latin-400-normal-s0S3qwFW.woff) format("woff")}@font-face{font-family:Commit Mono;font-style:normal;font-display:swap;font-weight:700;src:url(/assets/commit-mono-latin-700-normal-DU8mrtj2.woff2) format("woff2"),url(/assets/commit-mono-latin-700-normal-1-GU0IUE.woff) format("woff")}:root{--ink: #0E0E0F;--ink-2: #16161A;--bone: #F4F1EA;--dust: #7E776A;--rule: rgba(244, 241, 234, .1);--rule-strong: rgba(244, 241, 234, .22);--copper: #D8754A;--copper-dim: rgba(216, 117, 74, .55);--copper-glow: rgba(216, 117, 74, .18);--bg: var(--ink);--fg: var(--bone);--fg-dim: var(--dust);--font-display: "Fraunces Variable", "Fraunces", ui-serif, "Iowan Old Style", "Georgia", serif;--font-mono: "Commit Mono", ui-monospace, "Berkeley Mono", "JetBrains Mono", "Menlo", monospace;--t-micro: clamp(.66rem, .62rem + .15vw, .74rem);--t-mono: clamp(.82rem, .78rem + .2vw, .92rem);--t-body: clamp(.94rem, .9rem + .25vw, 1.05rem);--t-h3: clamp(1.4rem, 1.1rem + 1vw, 1.9rem);--t-h2: clamp(2rem, 1.4rem + 2.4vw, 3.4rem);--t-h1: clamp(2.6rem, 1.8rem + 4vw, 5.4rem);--t-display: clamp(4rem, 2.4rem + 8vw, 8.8rem);--pad-x: clamp(1.4rem, 4vw, 3.2rem);--pad-y: clamp(2rem, 5vw, 4rem);--col: min(64ch, 92vw);--gap: clamp(1rem, 2.4vw, 2rem);--ease-out: cubic-bezier(.16, 1, .3, 1);--ease-in-out: cubic-bezier(.65, 0, .35, 1);--dur-instant: .12s;--dur-fast: .22s;--dur-base: .34s;--dur-slow: .58s;--z-base: 1;--z-route: 10;--z-canvas: 20;--z-cursor: 90;--z-chrome: 100;--z-skip: 1000;--nav-h: 60px;--foot-h: 44px}.display{font-family:var(--font-display);font-weight:350;font-variation-settings:"opsz" 144,"SOFT" 100,"WONK" 0;letter-spacing:-.022em;line-height:.95}.serif-h1{font-family:var(--font-display);font-weight:350;font-variation-settings:"opsz" 144,"SOFT" 100,"WONK" 0;font-size:var(--t-h1);letter-spacing:-.022em;line-height:.96;margin:0;color:var(--bone)}.serif-h2{font-family:var(--font-display);font-weight:350;font-variation-settings:"opsz" 120,"SOFT" 100;font-size:var(--t-h2);letter-spacing:-.018em;line-height:1;margin:0;color:var(--bone)}.serif-h3{font-family:var(--font-display);font-weight:350;font-variation-settings:"opsz" 100,"SOFT" 100;font-size:var(--t-h3);letter-spacing:-.014em;line-height:1.1;margin:0;color:var(--bone)}.mono{font-family:var(--font-mono)}.eyebrow{font-family:var(--font-mono);font-size:var(--t-micro);text-transform:uppercase;letter-spacing:.18em;color:var(--fg-dim)}.eyebrow:before{content:"";display:inline-block;width:6px;height:6px;background:var(--copper);margin-right:.6em;vertical-align:.06em;border-radius:50%}.lede{font-size:var(--t-body);line-height:1.7;color:var(--bone);max-width:56ch}.lede+.lede{margin-top:.9rem}.dim{color:var(--fg-dim)}.link{position:relative;display:inline;color:var(--bone);cursor:pointer;transition:color var(--dur-fast) var(--ease-out)}.link:after{content:"";position:absolute;left:0;right:0;bottom:-2px;height:1px;background:var(--copper);transform:scaleX(0);transform-origin:0 50%;transition:transform var(--dur-fast) var(--ease-out)}.link:hover,.link:focus-visible{color:var(--copper)}.link:hover:after,.link:focus-visible:after{transform:scaleX(1)}.link[aria-current=page]:after{transform:scaleX(1);background:var(--copper-dim)}.margin-note{font-family:var(--font-mono);font-size:var(--t-micro);text-transform:uppercase;letter-spacing:.16em;color:var(--fg-dim)}.margin-note .ix{color:var(--copper);margin-right:.4em}kbd{font-family:var(--font-mono);font-size:var(--t-micro);text-transform:uppercase;letter-spacing:.12em;padding:.12em .42em;border:1px solid var(--rule-strong);border-radius:3px;color:var(--bone);background:var(--ink-2)}.skip{position:fixed;top:0;left:0;padding:.5rem .9rem;margin:.5rem;background:var(--ink-2);color:var(--bone);font-family:var(--font-mono);font-size:var(--t-micro);text-transform:uppercase;letter-spacing:.14em;border:1px solid var(--copper);z-index:var(--z-skip);transform:translateY(-200%)}.skip:focus-visible{transform:translateY(0)}.nav{position:fixed;inset:0 0 auto;height:var(--nav-h);display:flex;align-items:center;justify-content:space-between;padding:0 var(--pad-x);background:color-mix(in oklab,var(--ink) 88%,transparent);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border-bottom:1px solid var(--rule);z-index:var(--z-chrome)}.nav__links{display:flex;align-items:center;gap:clamp(.9rem,2.4vw,1.8rem);font-family:var(--font-mono);font-size:var(--t-micro);text-transform:uppercase;letter-spacing:.18em}.nav__links a{position:relative;color:var(--fg-dim);padding:.35rem 0;transition:color var(--dur-fast) var(--ease-out)}.nav__links a:hover,.nav__links a[aria-current=page]{color:var(--bone)}.nav__links a[aria-current=page]:before{content:"";position:absolute;left:-10px;top:50%;transform:translateY(-50%);width:5px;height:5px;border-radius:50%;background:var(--copper)}.wordmark{font-family:var(--font-display);font-weight:350;font-variation-settings:"opsz" 36,"SOFT" 90;font-size:1.25rem;letter-spacing:-.018em;line-height:1;color:var(--bone)}.wordmark .dot{color:var(--copper)}main{padding-top:var(--nav-h)}.section{position:relative;padding:clamp(4.4rem,9vw,7rem) var(--pad-x);max-width:calc(var(--col) + 2 * var(--pad-x));margin:0 auto;scroll-margin-top:var(--nav-h)}.section+.section{border-top:1px solid var(--rule)}.section:last-of-type{padding-bottom:clamp(6rem,12vw,9rem)}.section--hero{min-height:calc(100vh - var(--nav-h));display:flex;flex-direction:column;justify-content:center;padding-top:clamp(4rem,10vw,7rem);padding-bottom:clamp(4rem,10vw,7rem);max-width:calc(var(--col) + 4 * var(--pad-x))}.hero__title{font-size:var(--t-display);margin:1rem 0 1.6rem;max-width:18ch}.hero__lede{margin-top:.4rem;font-size:var(--t-body);color:var(--bone)}.hero__meta{margin-top:1.8rem;display:flex;flex-wrap:wrap;gap:.9rem;align-items:center;font-size:var(--t-micro);text-transform:uppercase;letter-spacing:.18em;color:var(--fg-dim)}.section__head{display:flex;flex-direction:column;gap:1rem;margin-bottom:clamp(2rem,4vw,3rem)}.experience-list{display:flex;flex-direction:column;gap:1.6rem}.exp-row{position:relative;display:grid;grid-template-columns:10rem 1fr;gap:clamp(1.2rem,3vw,2.4rem);padding:1.2rem 0;border-top:1px solid var(--rule)}.exp-row:last-child{border-bottom:1px solid var(--rule)}.exp-row__date{font-family:var(--font-mono);font-size:var(--t-micro);text-transform:uppercase;letter-spacing:.2em;color:var(--fg-dim);align-self:start;padding-top:.15rem}.exp-row__body{display:flex;flex-direction:column;gap:.45rem}.exp-row__company{color:var(--copper)}.exp-row__blurb{margin:0;line-height:1.65;max-width:60ch;font-size:var(--t-mono)}@media(max-width:640px){.exp-row{grid-template-columns:1fr;gap:.45rem}}.work-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column}.work-row{position:relative;display:grid;grid-template-columns:auto 1fr auto auto;gap:clamp(.8rem,2vw,1.6rem);align-items:baseline;padding:1.1rem 0;border-top:1px solid var(--rule);cursor:pointer;isolation:isolate}.work-row:last-child{border-bottom:1px solid var(--rule)}.work-row__ix{font-family:var(--font-mono);font-size:var(--t-micro);text-transform:uppercase;letter-spacing:.18em;color:var(--fg-dim);min-width:2.4ch}.work-row__name{font-family:var(--font-display);font-weight:350;font-variation-settings:"opsz" 144,"SOFT" 100;font-size:clamp(1.4rem,1.05rem + 1.2vw,1.9rem);letter-spacing:-.016em;color:var(--bone);display:inline-flex;align-items:baseline;gap:.8rem;transition:color var(--dur-fast) var(--ease-out)}.work-row__role,.work-row__year{font-family:var(--font-mono);font-size:var(--t-micro);text-transform:uppercase;letter-spacing:.18em;color:var(--fg-dim)}.work-row__copper-dot{position:absolute;left:-.5rem;top:50%;width:4px;height:4px;border-radius:50%;background:var(--copper);transform:translate(-50%,-50%) scale(0);transition:transform var(--dur-fast) var(--ease-out);box-shadow:0 0 10px var(--copper-glow)}.work-row:hover .work-row__copper-dot,.work-row:focus-within .work-row__copper-dot{transform:translate(-50%,-50%) scale(1)}.work-row:hover .work-row__name,.work-row:focus-within .work-row__name{color:var(--copper)}.work-row__arrow{display:inline-block;font-family:var(--font-mono);font-size:.55em;color:var(--copper);opacity:0;transform:translate(-.4rem);transition:opacity var(--dur-fast) var(--ease-out),transform var(--dur-fast) var(--ease-out)}.work-row:hover .work-row__arrow,.work-row:focus-within .work-row__arrow{opacity:1;transform:translate(0)}.artefact-portal{position:fixed;width:280px;height:280px;pointer-events:none;z-index:var(--z-canvas);background:var(--ink-2);border:1px solid var(--rule);border-radius:6px;overflow:hidden}.artefact-portal canvas{width:100%;height:100%}@media(max-width:1100px){.artefact-portal{display:none}}.resume{display:flex;flex-direction:column;gap:1.2rem;align-items:flex-start}.resume__download{display:inline-flex;align-items:center;gap:.8rem;padding:.95rem 1.4rem;font-family:var(--font-mono);font-size:var(--t-micro);text-transform:uppercase;letter-spacing:.2em;color:var(--copper);border:1px solid var(--copper);background:transparent;transition:background var(--dur-fast) var(--ease-out),color var(--dur-fast) var(--ease-out)}.resume__download:hover,.resume__download:focus-visible{background:var(--copper);color:var(--ink)}.resume__download .arrow{transition:transform var(--dur-fast) var(--ease-out)}.resume__download:hover .arrow{transform:translateY(2px)}.resume__note{margin:0;font-size:var(--t-micro);text-transform:uppercase;letter-spacing:.14em}.now{display:flex;flex-direction:column;gap:0;margin-top:.4rem}.now-row{display:grid;grid-template-columns:8.5rem 1fr;gap:1.4rem;padding:1rem 0;border-top:1px solid var(--rule)}.now-row:last-child{border-bottom:1px solid var(--rule)}.now-row time{font-family:var(--font-mono);font-size:var(--t-micro);text-transform:uppercase;letter-spacing:.18em;color:var(--fg-dim)}.now-row__body p{margin:0;font-family:var(--font-mono);font-size:var(--t-mono);color:var(--bone);line-height:1.65}@media(max-width:640px){.now-row{grid-template-columns:1fr;gap:.4rem}}.toolkit{display:flex;flex-direction:column;gap:0;margin-top:.4rem}.toolkit-row{display:grid;grid-template-columns:8.5rem 1fr;gap:1.4rem;padding:1rem 0;border-top:1px solid var(--rule)}.toolkit-row:last-child{border-bottom:1px solid var(--rule)}.toolkit-row__label{font-family:var(--font-mono);font-size:var(--t-micro);text-transform:uppercase;letter-spacing:.18em;color:var(--fg-dim);align-self:start;padding-top:.2rem}.toolkit-row__tags{list-style:none;margin:0;padding:0;display:flex;flex-wrap:wrap;gap:.4rem 1.2rem;font-family:var(--font-mono);font-size:var(--t-mono);color:var(--bone);line-height:1.65}.toolkit-tag{position:relative;transition:color var(--dur-fast) var(--ease-out)}.toolkit-tag:before{content:"";position:absolute;left:0;right:0;bottom:-2px;height:1px;background:var(--copper);transform:scaleX(0);transform-origin:left center;transition:transform var(--dur-fast) var(--ease-out)}.toolkit-tag:hover{color:var(--copper)}.toolkit-tag:hover:before{transform:scaleX(1)}@media(max-width:640px){.toolkit-row{grid-template-columns:1fr;gap:.45rem}}.contact{display:flex;flex-direction:column;gap:1.4rem;max-width:44rem}.contact__field{display:flex;flex-direction:column;gap:.45rem}.contact__field label{font-family:var(--font-mono);font-size:var(--t-micro);text-transform:uppercase;letter-spacing:.2em;color:var(--fg-dim)}.contact__field input,.contact__field textarea{font-family:var(--font-mono);font-size:var(--t-mono);color:var(--bone);background:transparent;border:0;border-bottom:1px solid var(--rule-strong);padding:.55rem .1rem;transition:border-color var(--dur-fast) var(--ease-out)}.contact__field input:focus,.contact__field textarea:focus{outline:none;border-bottom-color:var(--copper)}.contact__field textarea{min-height:7rem;resize:vertical;line-height:1.6}.contact__count{margin:.3rem 0 0;font-family:var(--font-mono);font-size:.72rem;letter-spacing:.04em;text-align:right}.contact__submit{align-self:flex-start;display:inline-flex;align-items:center;gap:.6rem;margin-top:.6rem;padding:.75rem 1.1rem;font-family:var(--font-mono);font-size:var(--t-micro);text-transform:uppercase;letter-spacing:.18em;color:var(--copper);border:1px solid var(--copper);background:transparent;transition:background var(--dur-fast) var(--ease-out),color var(--dur-fast) var(--ease-out)}.contact__submit:hover,.contact__submit:focus-visible{background:var(--copper);color:var(--ink)}.contact__submit:disabled{opacity:.4;cursor:not-allowed}.contact__submit .arrow{transition:transform var(--dur-fast) var(--ease-out)}.contact__submit:hover .arrow{transform:translate(3px)}.contact__status{font-family:var(--font-mono);font-size:var(--t-micro);text-transform:uppercase;letter-spacing:.18em;color:var(--fg-dim);min-height:1.2em}.contact__status.is-ok,.contact__status.is-err{color:var(--copper)}.contact__links{display:flex;flex-wrap:wrap;gap:1.4rem;margin-top:1.4rem;font-family:var(--font-mono);font-size:var(--t-micro);text-transform:uppercase;letter-spacing:.18em}.footer{border-top:1px solid var(--rule);padding:1.6rem var(--pad-x);display:flex;justify-content:space-between;align-items:center;font-family:var(--font-mono);font-size:var(--t-micro);text-transform:uppercase;letter-spacing:.18em;color:var(--fg-dim);max-width:calc(var(--col) + 2 * var(--pad-x));margin:0 auto;gap:1rem;flex-wrap:wrap}.footer .mark{color:var(--copper)}@media(max-width:600px){.nav__links{gap:.9rem}.nav__links a:not([aria-current=page]){color:var(--fg-dim)}}*,*:before,*:after{box-sizing:border-box}html,body,#root{margin:0;padding:0;height:100%}html{background:var(--bg);color:var(--fg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility;scroll-behavior:smooth;scroll-padding-top:calc(var(--nav-h) + 12px)}body{font-family:var(--font-mono);font-size:var(--t-body);line-height:1.6;background:var(--bg);color:var(--fg);overflow-x:hidden}button{font:inherit;color:inherit;background:transparent;border:0;padding:0;cursor:pointer}a{color:inherit;text-decoration:none}img,svg,canvas{display:block;max-width:100%}input,textarea{font:inherit;color:inherit}:focus-visible{outline:1.5px solid var(--copper);outline-offset:3px;border-radius:1px}::selection{background:var(--copper);color:var(--ink)}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important;scroll-behavior:auto!important}}
