:root{--bg:oklch(0.16 0.006 250);--bg-2:oklch(0.20 0.006 250);--bg-3:oklch(0.24 0.006 250);--hair:oklch(0.30 0.005 250);--hair-strong:oklch(0.42 0.005 250);--text:oklch(0.96 0.005 90);--text-2:oklch(0.78 0.005 90);--text-dim:oklch(0.55 0.005 90);--text-faint:oklch(0.40 0.005 90);--accent:oklch(0.82 0.16 76);--accent-dim:oklch(0.68 0.14 76);--bad:oklch(0.72 0.18 25);--good:oklch(0.78 0.16 145);--font-display:"Space Grotesk","Helvetica Neue",Helvetica,Arial,sans-serif;--font-mono:"JetBrains Mono",ui-monospace,"SF Mono",Menlo,monospace;--gut:clamp(24px,4vw,56px);--maxw:1240px}html[data-route=about]{--bg:oklch(0.17 0.008 60)}html[data-route=experience]{--bg:oklch(0.16 0.006 250)}html[data-route=projects]{--bg:oklch(0.16 0.008 220)}html[data-route=writing]{--bg:oklch(0.17 0.006 90)}html[data-route=skills]{--bg:oklch(0.16 0.006 250)}html[data-route=contact]{--bg:oklch(0.17 0.010 30)}*{box-sizing:border-box}body,html{margin:0;padding:0;background:var(--bg);color:var(--text);transition:background .6s ease}body{font-family:var(--font-display);font-weight:400;letter-spacing:-.005em;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;min-height:100vh;overflow-x:hidden}::selection{background:var(--accent);color:var(--bg)}a{color:inherit;text-decoration:none}.app{min-height:100vh}.topnav{position:-webkit-sticky;position:sticky;top:0;z-index:20;background:color-mix(in oklab,var(--bg) 88%,transparent);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);display:grid;grid-template-columns:1fr auto 1fr;align-items:center;padding:18px var(--gut);grid-gap:24px;gap:24px}.topnav:after{content:"";position:absolute;left:var(--gut);right:var(--gut);bottom:0;height:1px;background:var(--hair)}.topnav .brand{font-family:var(--font-display);font-weight:500;font-size:16px;letter-spacing:-.015em;color:var(--text)}.topnav .navlist{display:flex;gap:4px;list-style:none;margin:0;padding:0;justify-self:center}.topnav .navlist a{background:transparent;border:0;color:var(--text-dim);font-family:var(--font-display);font-size:14px;font-weight:400;letter-spacing:-.005em;padding:8px 14px;cursor:pointer;transition:color .15s ease;position:relative;text-decoration:none}.topnav .navlist a.active,.topnav .navlist a:hover{color:var(--text)}.topnav .navlist a.active:after{content:"";position:absolute;left:14px;right:14px;bottom:-1px;height:1px;background:var(--accent)}.topnav .end{justify-self:end;display:flex;align-items:center;gap:18px;font-size:13px;color:var(--text-dim)}.topnav .avail{display:inline-flex;align-items:center;gap:8px;color:var(--text-2)}.topnav .avail-dot{width:7px;height:7px;border-radius:999px;background:var(--good);box-shadow:0 0 0 4px color-mix(in oklab,var(--good) 18%,transparent);animation:pulse 2.4s ease-in-out infinite}@keyframes pulse{0%,to{box-shadow:0 0 0 4px color-mix(in oklab,var(--good) 18%,transparent)}50%{box-shadow:0 0 0 7px color-mix(in oklab,var(--good) 6%,transparent)}}.topnav .end .cta{padding:9px 16px;border:1px solid var(--text);color:var(--text);font-size:13px;font-weight:500;letter-spacing:-.005em;transition:background .15s ease,color .15s ease}.topnav .end .cta:hover{background:var(--text);color:var(--bg)}.page-wrap{min-height:calc(100vh - 60px);display:flex;flex-direction:column}.page{padding:80px var(--gut) 96px;max-width:var(--maxw);width:100%;margin:0 auto;flex:1 1}.page-head{margin-bottom:72px;max-width:28ch}.page-head h1{font-family:var(--font-display);font-weight:500;font-size:clamp(40px,5.6vw,76px);letter-spacing:-.035em;line-height:1.02;margin:0;text-wrap:balance}.page-head .dek{margin:20px 0 0;font-size:17px;line-height:1.5;color:var(--text-2);letter-spacing:-.005em;max-width:44ch}.footer{padding:28px var(--gut);display:grid;grid-template-columns:1fr 1fr;font-size:13px;color:var(--text-dim);border-top:1px solid var(--hair);max-width:var(--maxw);margin:0 auto;width:100%}.footer .end{text-align:right}.footer a:hover{color:var(--text)}.mono{font-family:var(--font-mono)}.dim{color:var(--text-dim)}.accent{color:var(--accent)}.placeholder{background:repeating-linear-gradient(135deg,color-mix(in oklab,var(--text) 4%,transparent) 0 1px,transparent 1px 8px),var(--bg-2);display:grid;place-items:center;font-family:var(--font-mono);font-size:11px;color:var(--text-dim);letter-spacing:.08em;text-transform:uppercase}.section-head{display:grid;grid-template-columns:1fr auto;align-items:baseline;grid-gap:24px;gap:24px;padding-bottom:16px;margin-bottom:32px;border-bottom:1px solid var(--hair)}.section-head h2{font-family:var(--font-display);font-weight:500;font-size:22px;margin:0;letter-spacing:-.015em}.section-head .aside{font-size:13px;color:var(--text-dim)}@keyframes pageIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.route{animation:pageIn .4s cubic-bezier(.25,.46,.45,.94) both}.hero{display:grid;grid-template-columns:1fr;padding:72px 0 80px;position:relative}.hero--with-shot{grid-template-columns:minmax(0,1fr) 380px;gap:64px;align-items:center}.hero-left{min-width:0}.rolecycle{font-family:var(--font-display);font-weight:500;font-size:clamp(48px,7.2vw,104px);letter-spacing:-.04em;line-height:.98;margin:0;text-wrap:balance;overflow-wrap:anywhere}.rolecycle .role-word{color:var(--text-faint);transition:color .45s ease;cursor:pointer;display:inline}.rolecycle .role-word.on{color:var(--text)}.rolecycle .role-word.on:nth-child(2){color:var(--accent)}.rolecycle .role-word .slash{color:var(--text-faint)!important;font-weight:400;margin:0 .12em 0 .08em}.hero-shot{position:relative;align-self:stretch;min-height:480px;overflow:hidden}.hero-shot-img{position:absolute;left:50%;bottom:0;height:100%;width:auto;transform:translateX(-50%) scale(.985);filter:drop-shadow(0 24px 40px rgba(0,0,0,.45));opacity:0;transition:opacity .55s ease,transform .9s cubic-bezier(.2,.7,.2,1)}.hero-shot-img.on{opacity:1;transform:translateX(-50%) scale(1)}.hero .lede{display:grid;grid-template-columns:1fr 320px;grid-gap:56px;gap:56px;margin-top:56px;padding-top:32px;border-top:1px solid var(--hair)}.hero--with-shot .lede{grid-template-columns:1fr;gap:32px}.hero--with-shot .lede p{font-size:19px;max-width:50ch}.hero--with-shot .cardlinks{max-width:480px}.hero .lede p{font-size:20px;line-height:1.5;color:var(--text-2);letter-spacing:-.005em;margin:0;max-width:56ch;text-wrap:pretty}.hero .cardlinks{display:flex;flex-direction:column}.hero .cardlinks .row{display:grid;grid-template-columns:1fr auto;align-items:baseline;grid-gap:16px;gap:16px;padding:14px 0;border-bottom:1px solid var(--hair);cursor:pointer;transition:color .15s ease,padding .2s ease}.hero .cardlinks .row:hover{padding-left:6px}.hero .cardlinks .row--primary .val{color:var(--accent);font-weight:500}.hero .cardlinks .row--primary .arr{color:var(--accent-dim)}.hero .cardlinks .row--primary:hover .val{color:var(--text)}.hero .cardlinks .row--primary:hover .arr{color:var(--accent)}.hero .cardlinks .row .val{color:var(--text);font-size:16px}.hero .cardlinks .row .arr{color:var(--text-dim);transition:transform .2s ease,color .15s ease;font-family:var(--font-mono);font-size:14px}.hero .cardlinks .row:hover .arr{transform:translateX(4px);color:var(--accent)}.hl-wrap{padding:80px 0}.hl{display:grid;grid-template-columns:repeat(3,1fr);grid-gap:24px;gap:24px}.hl .cell{padding:28px 28px 32px;background:color-mix(in oklab,var(--bg-2) 50%,transparent);position:relative;display:flex;flex-direction:column;min-height:220px;transition:background .2s ease,transform .3s ease}.hl .cell:hover{background:var(--bg-2);transform:translateY(-2px)}.hl .cell .kpi{font-family:var(--font-display);font-weight:500;font-size:52px;letter-spacing:-.04em;line-height:1;margin:0 0 4px;color:var(--text)}.hl .cell .unit{font-size:13px;color:var(--text-dim);letter-spacing:-.005em}.hl .cell .blurb{font-size:14.5px;line-height:1.5;color:var(--text-2);margin-top:auto;padding-top:24px;text-wrap:pretty}.hl .cell--0{background:var(--bg-2)}.hl .cell--0 .kpi{color:var(--accent)}.home-now{display:grid;grid-template-columns:160px 1fr;grid-gap:40px;gap:40px;padding:64px 0 80px}.home-now .label{font-size:13px;letter-spacing:-.005em;color:var(--text-dim);padding-top:8px}.home-now .now-rows{display:flex;flex-direction:column;gap:0}.home-now .now-row{display:grid;grid-template-columns:100px 1fr;grid-gap:24px;gap:24px;align-items:baseline;padding:20px 0;border-bottom:1px solid var(--hair)}.home-now .now-row:first-child{padding-top:0}.home-now .now-row:last-child{border-bottom:none;padding-bottom:0}.home-now .now-key{font-size:13px;color:var(--accent);font-weight:500;letter-spacing:-.005em}.home-now .now-val{font-size:18px;line-height:1.45;color:var(--text-2);letter-spacing:-.01em}.about-grid{display:grid;grid-template-columns:1fr 360px;grid-gap:96px;gap:96px}.about-grid .body p{font-size:19px;line-height:1.6;color:var(--text-2);margin:0 0 22px;text-wrap:pretty;max-width:56ch;letter-spacing:-.005em}.about-grid .body p:first-of-type:first-letter{font-size:1.4em;color:var(--text);font-weight:500}.about-grid .facts .row{display:grid;grid-template-columns:110px 1fr;align-items:baseline;grid-gap:14px;gap:14px;padding:12px 0;font-size:14px;letter-spacing:-.005em}.about-grid .facts .row+.row{border-top:1px dashed color-mix(in oklab,var(--hair) 60%,transparent)}.about-grid .facts .row .k{color:var(--text-faint);font-size:13px}.about-grid .facts .row .v{color:var(--text)}.about-grid .body .bio-section-title{font-size:13px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--accent);margin:44px 0 18px}.about-grid .body .bio-section-title:first-child{margin-top:0}.about-grid .body .pull-quote{border-left:2px solid var(--accent);margin:32px 0;padding:4px 0 4px 20px;font-size:21px;font-weight:500;line-height:1.45;color:var(--text);letter-spacing:-.01em;font-style:italic;max-width:46ch}.about-grid .body a{color:var(--accent);text-decoration:underline;text-decoration-thickness:1px;text-underline-offset:3px;-webkit-text-decoration-color:color-mix(in oklab,var(--accent) 45%,transparent);text-decoration-color:color-mix(in oklab,var(--accent) 45%,transparent);transition:-webkit-text-decoration-color .2s ease;transition:text-decoration-color .2s ease;transition:text-decoration-color .2s ease,-webkit-text-decoration-color .2s ease}.about-grid .body a:hover{-webkit-text-decoration-color:var(--accent);text-decoration-color:var(--accent)}.portrait-caption{font-size:12px;color:var(--text-dim);letter-spacing:-.005em;margin-top:8px;text-align:right}.portrait{margin-top:40px;width:100%}.portrait--photo{margin:40px 0 0;padding:0;aspect-ratio:4/5;background:linear-gradient(180deg,color-mix(in oklab,var(--bg-2) 80%,transparent),var(--bg)),var(--bg);position:relative;overflow:hidden}.portrait--photo img{width:100%;height:100%;object-fit:contain;object-position:center bottom;display:block;filter:grayscale(.15) contrast(1.02)}.scenes{margin-top:72px}.scenes-grid{display:grid;grid-template-columns:1.1fr .9fr;grid-gap:18px;gap:18px;margin-top:8px}.scene{margin:0;background:var(--bg-2);position:relative;overflow:hidden;aspect-ratio:4/5}.scene--tall{aspect-ratio:3/4}.scene img{width:100%;height:100%;object-fit:cover;display:block;filter:grayscale(.1) contrast(1.02);transition:transform 1.2s cubic-bezier(.2,.7,.2,1),filter .3s ease}.scene:hover img{transform:scale(1.03);filter:grayscale(0) contrast(1.04)}.scene figcaption{position:absolute;left:0;right:0;bottom:0;padding:12px 14px;display:flex;justify-content:space-between;align-items:baseline;background:linear-gradient(0deg,color-mix(in oklab,#000 70%,transparent),transparent);color:var(--text);font-size:13px}.scene figcaption .dim{color:color-mix(in oklab,var(--text) 65%,transparent)}.xp-timeline{display:grid;grid-template-columns:1fr}.xp-row{display:grid;grid-template-columns:24px 130px 1fr;grid-gap:0 28px;gap:0 28px;padding:0 0 48px}.xp-rail,.xp-row{position:relative}.xp-rail{display:flex;flex-direction:column;align-items:center}.xp-dot{width:10px;height:10px;border-radius:999px;flex-shrink:0;margin-top:7px;z-index:1}.xp-line{width:1px;flex:1 1;background:var(--hair);margin-top:8px}.xp-period{display:flex;flex-direction:column;gap:6px;padding-top:5px}.xp-dates{font-family:var(--font-display);font-weight:500;font-size:14px;color:var(--text);letter-spacing:-.01em;white-space:nowrap}.xp-live{display:inline-flex;align-items:center;gap:5px;width:-moz-fit-content;width:fit-content;font-family:var(--font-mono);font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:var(--good);background:color-mix(in oklab,var(--good) 12%,transparent);padding:3px 8px;border-radius:3px}.xp-live:before{content:"";width:5px;height:5px;border-radius:999px;background:var(--good);animation:pulse 2.4s ease-in-out infinite}.xp-body{min-width:0;padding-bottom:12px}.xp-body+.xp-row{border-top:none}.xp-head{display:flex;align-items:center;gap:14px;flex-wrap:wrap}.xp-mono{width:40px;height:40px;border-radius:8px;display:grid;place-items:center;flex-shrink:0;font-family:var(--font-display);font-weight:600;font-size:13px;letter-spacing:-.01em;color:var(--bg);line-height:1}.xp-mono img{width:28px;height:28px;object-fit:contain;display:block}.xp-title-block{min-width:0}.xp-role{font-family:var(--font-display);font-weight:500;font-size:24px;letter-spacing:-.02em;margin:0 0 3px;line-height:1.15}.xp-org{font-size:13.5px;color:var(--text-2);letter-spacing:-.005em}.xp-where{color:var(--text-dim)}.xp-badge{font-size:13px;color:var(--accent);margin-left:auto;white-space:nowrap;padding:5px 12px;background:color-mix(in oklab,var(--accent) 8%,transparent);border-radius:4px}.xp-badge,.xp-headline{font-family:var(--font-display);font-weight:500;letter-spacing:-.01em}.xp-headline{font-size:17px;line-height:1.45;color:var(--text);margin:20px 0 0;max-width:62ch;text-wrap:pretty}.xp-details{list-style:none;padding:0;margin:14px 0 0;font-size:14.5px;line-height:1.6;color:var(--text-2);max-width:64ch}.xp-details li{padding-left:20px;position:relative;margin-bottom:5px;text-wrap:pretty}.xp-details li:before{content:"▸";position:absolute;left:0;top:0;color:var(--accent-dim);font-size:12px;line-height:1.7}.xp-cta{margin-top:40px;padding-top:32px;border-top:1px solid var(--hair)}.xp-cta-inner{display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap}.xp-cta-text{font-size:18px;color:var(--text-2);letter-spacing:-.01em}.xp-cta-btn{display:inline-flex;align-items:center;gap:10px;padding:12px 22px;border:1px solid var(--text);color:var(--text);font-family:var(--font-display);font-size:14px;font-weight:500;letter-spacing:-.005em;transition:background .15s ease,color .15s ease}.xp-cta-btn:hover{background:var(--text);color:var(--bg)}.xp-cta-arrow{font-family:var(--font-mono);transition:transform .2s ease}.xp-cta-btn:hover .xp-cta-arrow{transform:translateX(3px)}.proj-grid{display:grid;grid-template-columns:repeat(2,1fr);grid-gap:32px;gap:32px}.proj{padding:28px 0 32px;display:flex;flex-direction:column;gap:16px;cursor:pointer;border-top:1px solid var(--hair);transition:border-color .2s ease}.proj:hover{border-top-color:var(--accent)}.proj .head{display:grid;grid-template-columns:auto 1fr auto;align-items:center;grid-gap:16px;gap:16px}.proj .proj-logo{width:40px;height:40px;flex-shrink:0;display:grid;place-items:center;background:var(--bg-2);border-radius:8px;overflow:hidden}.proj .proj-logo img{width:70%;height:70%;object-fit:contain;display:block}.proj .proj-mono{width:100%;height:100%;display:grid;place-items:center;font-family:var(--font-display);font-weight:600;font-size:14px;letter-spacing:-.01em;color:var(--bg);line-height:1}.proj .head-text{min-width:0}.proj .head h3{font-family:var(--font-display);font-weight:500;font-size:24px;letter-spacing:-.02em;margin:0 0 3px;line-height:1.1}.proj .head .sub{font-size:13px;color:var(--text-dim);letter-spacing:-.005em;display:flex;gap:8px;align-items:baseline}.proj .head .sub .sep{color:var(--text-faint)}.proj .blurb{font-size:15.5px;line-height:1.55;color:var(--text-2);text-wrap:pretty;margin:0}.proj .metric{font-family:var(--font-display);font-weight:500;font-size:18px;color:var(--accent);letter-spacing:-.015em}.proj .foot{display:flex;align-items:center;justify-content:space-between;margin-top:4px}.proj .tags{display:flex;gap:12px;flex-wrap:wrap}.proj .tags span{font-size:12.5px;color:var(--text-dim);letter-spacing:-.005em}.proj .tags span+span:before{content:"·";margin-right:12px;color:var(--text-faint)}.proj .status{font-family:var(--font-mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--text-dim);display:inline-flex;align-items:center;gap:8px}.proj .status:before{content:"";width:6px;height:6px;border-radius:999px;background:var(--text-faint)}.proj[data-status=Live] .status:before{background:var(--good);box-shadow:0 0 0 3px color-mix(in oklab,var(--good) 18%,transparent)}.proj[data-status=Live] .status{color:var(--good)}.proj[data-status=Personal] .status:before{background:var(--accent);box-shadow:0 0 0 3px color-mix(in oklab,var(--accent) 14%,transparent)}.proj[data-status=Personal] .status{color:var(--accent-dim)}.proj[data-status=Archived] .status{color:var(--text-faint)}.proj[data-status=Exited] .status:before{background:var(--accent)}.proj[data-status="Open source"] .status:before{background:var(--text)}.writing-controls{display:grid;grid-template-columns:1fr auto;align-items:start;grid-gap:24px;gap:24px;padding-bottom:18px;margin-bottom:0}.writing-controls .filters{display:flex;flex-direction:column;gap:8px}.filter-row{display:flex;align-items:center;gap:4px}.filter-label{font-size:11px;color:var(--text-faint);letter-spacing:.06em;text-transform:uppercase;min-width:32px;margin-right:2px}.writing-controls .filters button{background:transparent;border:0;color:var(--text-dim);font-family:var(--font-display);font-size:13px;letter-spacing:-.005em;padding:6px 12px;cursor:pointer;transition:all .15s ease}.writing-controls .filters button:hover{color:var(--text)}.writing-controls .filters button.active{background:var(--text);color:var(--bg)}.writing-controls .filters button.disabled{opacity:.35;cursor:not-allowed}.writing-controls .filters button.disabled:hover{color:var(--text-dim)}.writing-controls .filters button .ct{margin-left:6px;color:var(--text-faint);font-size:11.5px}.writing-controls .filters button.active .ct{color:color-mix(in oklab,var(--bg) 50%,var(--text))}.writing-controls .search{display:flex;align-items:center;gap:10px;border-bottom:1px solid var(--hair);padding:6px 4px;min-width:260px;margin-top:12px}.writing-controls .search input{background:transparent;border:0;outline:0;color:var(--text);font-family:var(--font-display);font-size:14px;width:100%;letter-spacing:-.005em}.writing-controls .search input::placeholder{color:var(--text-faint)}.writing-controls .search .slash{font-family:var(--font-mono);color:var(--text-faint);font-size:11px}.writing-list{margin-top:16px}.writing-list .post{display:grid;grid-template-columns:100px 1fr 80px;grid-gap:32px;gap:32px;align-items:baseline;padding:24px 0;cursor:pointer;transition:padding .2s ease}.writing-list .post+.post{border-top:1px solid var(--hair)}.writing-list .post:hover{padding-left:8px}.writing-list .post:hover .ttl{color:var(--accent)}.writing-list .post .date{font-family:var(--font-display);font-size:13px;color:var(--text-dim);letter-spacing:-.005em}.writing-list .post .ttl{font-family:var(--font-display);font-weight:500;font-size:22px;letter-spacing:-.02em;line-height:1.2;color:var(--text);transition:color .15s ease}.writing-list .post .ttl .sub{display:block;font-family:var(--font-display);font-weight:400;font-size:14.5px;color:var(--text-dim);margin-top:6px;letter-spacing:-.005em;line-height:1.4}.writing-list .post .kind{font-size:12px;color:var(--text-dim);text-align:right;letter-spacing:-.005em}.writing-list .post .kind-link{cursor:pointer;transition:color .15s ease}.writing-list .post .kind-link:hover{color:var(--accent)}.writing-list .empty{padding:60px 0;text-align:center;font-family:var(--font-mono);font-size:12px;color:var(--text-dim);letter-spacing:.04em}.writing-soon{padding:32px 0;font-size:14px;color:var(--text-dim);font-style:italic}.writing-rss{margin-top:24px;padding-top:16px;border-top:1px solid var(--hair)}.writing-rss a{font-size:12px;color:var(--text-dim);letter-spacing:.04em;text-decoration:none;transition:color .15s ease}.writing-rss a:hover{color:var(--accent)}.skill-legend{display:flex;flex-wrap:wrap;gap:6px 4px;font-size:12.5px;color:var(--text-dim);letter-spacing:-.005em;margin-bottom:28px;line-height:1.7}.skill-legend em{font-style:normal;color:var(--text-faint);font-size:11.5px;margin-left:3px}.skill-legend .sep{color:var(--text-faint);margin:0 4px}.skill-filters{display:flex;gap:4px;flex-wrap:wrap;margin-bottom:48px}.skill-filters button{background:transparent;border:0;color:var(--text-dim);font-family:var(--font-display);font-size:13px;letter-spacing:-.005em;padding:6px 12px;cursor:pointer;transition:all .15s ease}.skill-filters button:hover{color:var(--text)}.skill-filters button.active{background:var(--text);color:var(--bg)}.skill-filters button .ct{margin-left:6px;color:var(--text-faint);font-size:11.5px}.skill-filters button.active .ct{color:color-mix(in oklab,var(--bg) 50%,var(--text))}.skill-groups{display:grid;grid-template-columns:repeat(2,1fr);grid-gap:0 64px;gap:0 64px}.skill-col{display:flex;flex-direction:column;gap:56px}.skill-group h3{font-family:var(--font-display);font-weight:500;font-size:18px;letter-spacing:-.015em;margin:0 0 16px;display:flex;justify-content:space-between;align-items:baseline;padding-bottom:12px;border-bottom:1px solid var(--hair)}.skill-group h3 .ct{font-size:12px;color:var(--text-faint);font-weight:400;white-space:nowrap}.skill-row{display:grid;grid-template-columns:1fr auto;align-items:center;grid-gap:18px;gap:18px;padding:9px 0}.skill-name{font-family:var(--font-display);font-weight:400;font-size:15px;letter-spacing:-.005em;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.skill-meta{display:flex;align-items:center;gap:10px;flex-shrink:0}.skill-pill{font-size:11px;letter-spacing:-.005em;padding:3px 8px;border-radius:3px;white-space:nowrap;font-family:var(--font-display)}.pill-daily{background:color-mix(in oklab,var(--accent) 20%,transparent);color:var(--accent)}.pill-weekly{background:color-mix(in oklab,var(--accent-dim) 15%,transparent);color:var(--accent-dim)}.pill-as-needed{background:color-mix(in oklab,var(--text-2) 10%,transparent);color:var(--text-dim)}.pill-dormant{background:color-mix(in oklab,var(--text-dim) 8%,transparent);color:var(--text-faint)}.pill-foundation{background:color-mix(in oklab,var(--accent) 10%,transparent);color:var(--accent-dim);border:1px solid color-mix(in oklab,var(--accent) 15%,transparent)}.skill-depth{display:flex;gap:3px;flex-shrink:0}.skill-depth i{display:block;width:8px;height:5px;background:var(--hair);border-radius:1px}.skill-depth i.filled{background:var(--text)}.skill-growing{margin-top:72px;padding-top:32px;border-top:1px solid var(--hair);display:flex;align-items:baseline;gap:18px;flex-wrap:wrap}.skill-growing .label{font-family:var(--font-mono);font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--text-faint)}.skill-growing .items{font-size:15px;color:var(--text-2);letter-spacing:-.005em}.skill-growing .items .sep{color:var(--text-faint)}.contact-grid{display:grid;grid-template-columns:1.2fr 1fr;grid-gap:96px;gap:96px;align-items:start}.contact-grid .contact-sublead{font-family:var(--font-display);font-weight:400;font-size:clamp(20px,2.4vw,28px);line-height:1.25;letter-spacing:-.015em;margin:0 0 28px;text-wrap:balance;max-width:38ch;color:var(--text-2)}.contact-side .row{display:grid;grid-template-columns:100px 1fr auto;align-items:baseline;grid-gap:14px;gap:14px;padding:14px 0;font-size:14px;letter-spacing:-.005em;cursor:pointer;transition:color .15s ease,padding .2s ease}.contact-side .row+.row{border-top:1px dashed color-mix(in oklab,var(--hair) 60%,transparent)}.contact-side .row:hover{padding-left:6px}.contact-side .row .k{color:var(--text-faint);font-size:13px;display:flex;align-items:center;gap:6px}.contact-side .row .k .icon-linkedin{flex-shrink:0}.contact-side .row .v{color:var(--text)}.contact-side .row .arr{color:var(--text-dim);font-family:var(--font-mono);transition:transform .2s ease,color .15s ease}.contact-side .row:hover .arr{transform:translateX(4px);color:var(--accent)}.contact-availability{margin-top:40px;padding:20px 0 0;border-top:1px solid var(--hair);display:grid;grid-template-columns:auto 1fr;grid-gap:18px;gap:18px;align-items:start}.contact-availability .dot{margin-top:8px;width:9px;height:9px;background:var(--good);border-radius:999px;box-shadow:0 0 0 5px color-mix(in oklab,var(--good) 18%,transparent)}.contact-availability .h{font-size:12px;letter-spacing:.04em;text-transform:uppercase;color:var(--good);margin-bottom:6px}.contact-availability .t{font-family:var(--font-display);font-weight:500;font-size:17px;letter-spacing:-.01em;line-height:1.35}.contact-availability .sub{font-size:13.5px;color:var(--text-dim);letter-spacing:-.005em;margin-top:6px}@media (max-width:1000px){.hero--with-shot{grid-template-columns:1fr;gap:24px}.hero{padding:48px 0 56px}.hero-shot{min-height:280px}.hero .lede{gap:32px}.about-grid,.hero .lede{grid-template-columns:1fr}.about-grid{gap:48px}.scenes-grid{grid-template-columns:1fr 1fr}.xp .item{grid-template-columns:1fr;gap:12px}.xp .item .period{padding-top:0}.proj-grid,.skill-groups{grid-template-columns:1fr;gap:32px}.skill-col{gap:40px}.skill-row{grid-template-columns:1fr;gap:6px}.skill-meta{justify-self:start}.skill-name{white-space:normal;overflow:visible;text-overflow:unset}.proj .blurb{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.hl{grid-template-columns:1fr}.hl .cell--0{grid-column:auto}.contact-grid{grid-template-columns:1fr;gap:48px}.writing-list .post{grid-template-columns:80px 1fr;gap:16px}.writing-list .post .kind{display:none}.topnav{grid-template-columns:auto 1fr}.topnav .navlist{display:none}.topnav .end{justify-self:end}.home-now{grid-template-columns:1fr;gap:16px}.home-now .now-row{grid-template-columns:1fr;gap:4px}}.fancy-root{pointer-events:none}.fancy-field,.fancy-root{position:fixed;inset:0;z-index:0}.fancy-field{width:100%;height:100%;opacity:.85}.app,.footer,.topnav{position:relative;z-index:2}.fancy-grain{position:fixed;inset:-50%;z-index:1;opacity:.05;pointer-events:none;mix-blend-mode:overlay;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='240' height='240'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 1   0 0 0 0 1   0 0 0 0 1   0 0 0 0.6 0'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");background-size:240px 240px;animation:grain-shift 7s steps(6) infinite}@keyframes grain-shift{0%{transform:translate(0)}20%{transform:translate(-6%,4%)}40%{transform:translate(4%,-2%)}60%{transform:translate(-3%,-5%)}80%{transform:translate(2%,3%)}to{transform:translate(0)}}.route{animation:route-in .4s cubic-bezier(.25,.46,.45,.94) both}@keyframes route-in{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.rolecycle .role-word.on .ch{animation:ch-in .65s cubic-bezier(.2,.8,.2,1) both}.rolecycle .role-word .ch{display:inline-block;opacity:1;transform:none;filter:none}.rolecycle .role-word.on .ch{opacity:0;transform:translateY(.35em);filter:blur(6px)}@keyframes ch-in{0%{opacity:0;transform:translateY(.35em);filter:blur(6px)}60%{opacity:1;filter:blur(0)}to{opacity:1;transform:translateY(0);filter:blur(0)}}.rolecycle .role-word .slash{animation:none;opacity:1;transform:none;filter:none}.cform{display:flex;flex-direction:column;gap:28px;margin-top:36px;max-width:560px}.cfield{display:block;cursor:text}.cfield-top{display:grid;grid-template-columns:auto 1fr auto;align-items:baseline;grid-gap:10px;gap:10px;margin-bottom:8px;font-family:var(--font-mono);font-size:11px;letter-spacing:.04em;text-transform:uppercase}.cfield-idx{color:var(--text-faint)}.cfield-label{color:var(--text-2);letter-spacing:.06em}.cfield-msg{justify-self:end;font-size:11px;text-transform:none;letter-spacing:0}.cfield-msg .err-txt{color:var(--bad);font-family:var(--font-mono)}.cfield-msg .hint-txt{color:var(--text-faint);font-family:var(--font-mono)}.cfield input,.cfield textarea{width:100%;background:transparent;border:0;border-bottom:1px solid var(--hair);color:var(--text);font-family:var(--font-display);font-size:20px;font-weight:400;letter-spacing:-.005em;padding:10px 0 12px;outline:none;transition:border-color .25s ease,padding .25s ease;resize:none}.cfield textarea{font-size:17px;line-height:1.55;min-height:140px;padding-top:14px}.cfield input::placeholder,.cfield textarea::placeholder{color:var(--text-faint);font-weight:400}.cfield input:hover,.cfield textarea:hover{border-bottom-color:var(--hair-strong)}.cfield input:focus,.cfield textarea:focus{border-bottom-color:var(--accent)}.cfield.filled input,.cfield.filled textarea{border-bottom-color:var(--hair-strong)}.cfield.err input,.cfield.err textarea{border-bottom-color:var(--bad)}.cfield-sub{font-size:13px;color:var(--text-faint);line-height:1.45;margin-top:6px;letter-spacing:-.005em}.hp-field{position:absolute;width:0;height:0;overflow:hidden;opacity:0;pointer-events:none}.cform-error{font-family:var(--font-mono);font-size:13px;color:var(--bad);letter-spacing:0;padding:10px 0}.cform-foot{margin-top:8px;display:flex;align-items:flex-start;justify-content:space-between;gap:24px}.cform-foot-left{display:flex;flex-direction:column;gap:6px}.cform-req{display:inline-flex;align-items:center;gap:10px;font-family:var(--font-mono);font-size:11px;letter-spacing:.04em;text-transform:uppercase;color:var(--text-dim)}.cform-req .dot{width:6px;height:6px;border-radius:999px;background:var(--accent);box-shadow:0 0 0 4px color-mix(in oklab,var(--accent) 18%,transparent)}.cform-privacy{font-size:12px;color:var(--text-faint);letter-spacing:-.005em;line-height:1.45}.cform-submit{position:relative;background:transparent;border:1px solid var(--text);color:var(--text);font-family:var(--font-display);font-size:14px;font-weight:500;letter-spacing:-.005em;padding:13px 22px;display:inline-flex;align-items:center;gap:12px;cursor:pointer;transition:background .25s ease,color .25s ease,border-color .25s ease,transform .25s ease;overflow:hidden}.cform-submit .arr{font-size:13px;transition:transform .25s cubic-bezier(.2,.8,.2,1)}.cform-submit:hover{background:var(--text);color:var(--bg);border-color:var(--text)}.cform-submit:hover .arr{transform:translate(3px,-3px)}.cform-submit.ok{border-color:var(--accent);color:var(--accent)}.cform-submit.ok:hover{background:var(--accent);color:var(--bg);border-color:var(--accent)}.cform-submit:disabled{opacity:.55;cursor:progress}.cform-done{margin-top:36px;padding:36px 32px;border:1px solid var(--hair);background:color-mix(in oklab,var(--bg) 70%,var(--bg-2) 30%);max-width:560px;animation:cform-done-in .7s cubic-bezier(.2,.8,.2,1) both}@keyframes cform-done-in{0%{opacity:0;transform:translateY(10px);filter:blur(6px)}to{opacity:1;transform:translateY(0);filter:blur(0)}}.cform-done-mark{width:44px;height:44px;border-radius:999px;display:grid;place-items:center;background:color-mix(in oklab,var(--accent) 18%,transparent);color:var(--accent);font-size:22px;font-weight:500;margin-bottom:18px}.cform-done-h{font-size:24px;font-weight:500;letter-spacing:-.015em;margin-bottom:8px}.cform-done-sub{color:var(--text-2);font-size:16px;line-height:1.55;margin-bottom:22px;max-width:44ch}.cform-reset{background:transparent;border:0;color:var(--accent);font-family:var(--font-mono);font-size:13px;letter-spacing:.02em;padding:0;cursor:pointer}.cform-reset:hover{text-decoration:underline;text-underline-offset:4px}@media (max-width:720px){.cform-foot{flex-direction:column;align-items:flex-start}.cfield input{font-size:18px}}.hero-shot-img.on{animation:shot-in .9s cubic-bezier(.2,.8,.2,1) both}@keyframes shot-in{0%{opacity:0;filter:blur(14px) saturate(.6)}to{opacity:1;filter:blur(0) saturate(1)}}.cardlinks .row{transition:transform .35s cubic-bezier(.2,.8,.2,1),background .25s ease;will-change:transform}.cardlinks .row:hover{transform:translateX(8px)}.hl .cell{transition:transform .4s cubic-bezier(.2,.8,.2,1),box-shadow .4s ease}.hl .cell:hover{transform:translateY(-4px);box-shadow:0 24px 40px -20px color-mix(in oklab,var(--accent) 30%,transparent)}@media (prefers-reduced-motion:reduce){.fancy-grain,.hero-shot-img.on,.rolecycle .role-word.on .ch,.route,.route>.page>*{animation:none!important}.rolecycle .role-word .ch,.rolecycle .role-word.on .ch{opacity:1;transform:none;filter:none}}