@font-face{font-family:JetBrains Mono;font-style:normal;font-weight:400;font-display:swap;src:url(../media/04c5164763c40239-s.0h-nw9_c8d~-_.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:JetBrains Mono;font-style:normal;font-weight:400;font-display:swap;src:url(../media/26f284dcc38c84c0-s.10hk62x1-0d9n.woff2)format("woff2");unicode-range:U+301,U+400-45F,U+490-491,U+4B0-4B1,U+2116}@font-face{font-family:JetBrains Mono;font-style:normal;font-weight:400;font-display:swap;src:url(../media/7e7f32a39836f228-s.0bmyfaahigzds.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:JetBrains Mono;font-style:normal;font-weight:400;font-display:swap;src:url(../media/fa39153a3fc630ba-s.0-0ft90hthv3~.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:JetBrains Mono;font-style:normal;font-weight:400;font-display:swap;src:url(../media/6a5386fd6038edbe-s.16fk0g~ypa53a.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:JetBrains Mono;font-style:normal;font-weight:400;font-display:swap;src:url(../media/051742360c26797e-s.p.0f97p8c3305p~.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:JetBrains Mono;font-style:normal;font-weight:500;font-display:swap;src:url(../media/04c5164763c40239-s.0h-nw9_c8d~-_.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:JetBrains Mono;font-style:normal;font-weight:500;font-display:swap;src:url(../media/26f284dcc38c84c0-s.10hk62x1-0d9n.woff2)format("woff2");unicode-range:U+301,U+400-45F,U+490-491,U+4B0-4B1,U+2116}@font-face{font-family:JetBrains Mono;font-style:normal;font-weight:500;font-display:swap;src:url(../media/7e7f32a39836f228-s.0bmyfaahigzds.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:JetBrains Mono;font-style:normal;font-weight:500;font-display:swap;src:url(../media/fa39153a3fc630ba-s.0-0ft90hthv3~.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:JetBrains Mono;font-style:normal;font-weight:500;font-display:swap;src:url(../media/6a5386fd6038edbe-s.16fk0g~ypa53a.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:JetBrains Mono;font-style:normal;font-weight:500;font-display:swap;src:url(../media/051742360c26797e-s.p.0f97p8c3305p~.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:JetBrains Mono Fallback;src:local(Arial);ascent-override:75.79%;descent-override:22.29%;line-gap-override:0.0%;size-adjust:134.59%}.jetbrains_mono_3b084999-module__FXx-AW__className{font-family:JetBrains Mono,JetBrains Mono Fallback;font-style:normal}.jetbrains_mono_3b084999-module__FXx-AW__variable{--font-mono:"JetBrains Mono", "JetBrains Mono Fallback"}
@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial}}}@layer theme{:root,:host{--font-sans:ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";--font-mono:ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;--ease-out:cubic-bezier(0, 0, .2, 1);--default-transition-duration:.15s;--default-transition-timing-function:cubic-bezier(.4, 0, .2, 1);--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono)}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab, red, red)){::placeholder{color:color-mix(in oklab, currentcolor 50%, transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){appearance:button}::file-selector-button{appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer components;@layer utilities{.visible{visibility:visible}.static{position:static}.flex{display:flex}.grid{display:grid}.hidden{display:none}.inline{display:inline}.inline-block{display:inline-block}.transform{transform:var(--tw-rotate-x,) var(--tw-rotate-y,) var(--tw-rotate-z,) var(--tw-skew-x,) var(--tw-skew-y,)}.uppercase{text-transform:uppercase}.underline{text-decoration-line:underline}.transition{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to,opacity,box-shadow,transform,translate,scale,rotate,filter,-webkit-backdrop-filter,backdrop-filter,display,content-visibility,overlay,pointer-events;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}}:root{--sans:-apple-system, BlinkMacSystemFont, "SF Pro Display", "SF Pro Text", "Helvetica Neue", Helvetica, Arial, sans-serif;--mono:var(--font-mono,"JetBrains Mono"), ui-monospace, SFMono-Regular, monospace;--serif:"Songti SC", "Noto Serif CJK SC", "Noto Serif SC", Georgia, "Times New Roman", serif;--max:1080px;--ease:cubic-bezier(.4, 0, .2, 1);--ease-out:cubic-bezier(.16, 1, .3, 1)}html[data-theme=light]{--bg:#fbfbfd;--bg-2:#f5f5f7;--surface:#fff;--surface-2:#fff;--text:#1d1d1f;--text-2:#6e6e73;--text-3:#86868b;--line:#d2d2d7;--line-2:#c7c7cc;--accent:#0071e3;--accent-soft:#0071e31a;--nav-bg:#fbfbfdb8;--pill-bg:#ffffffa8;--card-shadow:0 1px 2px #0000000a, 0 10px 30px #0000000f;--pop-shadow:0 8px 24px #0000001a, 0 30px 70px #00000029;--ph-grad:linear-gradient(135deg, #eceef2, #e3e6ec)}html[data-theme=dark]{--bg:#000;--bg-2:#0a0a0b;--surface:#1c1c1e;--surface-2:#161617;--text:#f5f5f7;--text-2:#a1a1a6;--text-3:#86868b;--line:#2c2c2e;--line-2:#3a3a3c;--accent:#2997ff;--accent-soft:#2997ff24;--nav-bg:#0000009e;--pill-bg:#1c1c1e94;--card-shadow:0 1px 2px #00000080, 0 12px 32px #0000008c;--pop-shadow:0 10px 30px #0009, 0 40px 90px #000000b3;--ph-grad:linear-gradient(135deg, #232326, #19191b)}*{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{font-family:var(--sans);background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;text-rendering:optimizelegibility;letter-spacing:-.011em;transition:background .5s var(--ease), color .5s var(--ease);line-height:1.5}a{color:inherit;text-decoration:none}button{cursor:pointer;color:inherit;background:0 0;border:none;font-family:inherit}img{max-width:100%;display:block}::selection{background:var(--accent-soft)}.wrap{max-width:var(--max);margin:0 auto;padding:0 28px}.eyebrow{font-family:var(--mono);letter-spacing:.18em;text-transform:uppercase;color:var(--text-3);font-size:12px}section{padding:120px 0;position:relative}.sec-head{align-items:center;gap:16px;margin-bottom:54px;display:flex}.sec-head .num{font-family:var(--mono);color:var(--text-3);border:1px solid var(--line);border-radius:20px;flex-shrink:0;padding:4px 12px;font-size:13px}.sec-head h2{letter-spacing:-.03em;font-size:clamp(32px,4.4vw,50px);font-weight:680;line-height:1}.divider{background:var(--line);height:1px;max-width:var(--max);margin:0 auto}.reveal{opacity:0;transition:opacity .8s var(--ease-out), transform .8s var(--ease-out);transform:translateY(26px)}.reveal.in{opacity:1;transform:none}.topnav{z-index:90;background:var(--nav-bg);-webkit-backdrop-filter:saturate(180%)blur(20px);border-bottom:1px solid var(--line);align-items:center;gap:14px;height:56px;padding:0 28px;display:flex;position:fixed;top:0;left:0;right:0}@supports (color:color-mix(in lab, red, red)){.topnav{border-bottom:1px solid color-mix(in srgb, var(--line) 70%, transparent)}}.topnav{transition:opacity .4s var(--ease), transform .4s var(--ease)}.topnav.hide{opacity:0;pointer-events:none;transform:translateY(-100%)}.brand{align-items:center;gap:11px;display:flex}.glyph{font-family:var(--serif);border:1px solid var(--line);background:var(--surface);border-radius:11px;justify-content:center;align-items:center;width:38px;height:38px;font-size:23px;font-weight:600;line-height:1;display:flex}.brand .nm{letter-spacing:-.01em;font-size:15px;font-weight:600}.topnav .links{gap:2px;margin-left:auto;display:flex}.topnav .links a{color:var(--text-2);transition:.18s var(--ease);border-radius:9px;padding:7px 14px;font-size:14px;font-weight:430}.topnav .links a:hover{color:var(--text);background:var(--text)}@supports (color:color-mix(in lab, red, red)){.topnav .links a:hover{background:color-mix(in srgb, var(--text) 6%, transparent)}}.topnav .links a.active{color:var(--text);font-weight:550}.theme-btn{width:36px;height:36px;color:var(--text-2);transition:.18s var(--ease);border-radius:50%;justify-content:center;align-items:center;display:flex}.theme-btn:hover{color:var(--text);background:var(--text)}@supports (color:color-mix(in lab, red, red)){.theme-btn:hover{background:color-mix(in srgb, var(--text) 7%, transparent)}}.theme-btn svg{width:18px;height:18px}.pillnav{z-index:95;background:var(--pill-bg);-webkit-backdrop-filter:saturate(180%)blur(26px);border:1px solid var(--line);align-items:center;gap:3px;padding:6px;display:flex;position:fixed;top:18px;left:50%;transform:translate(-50%)translateY(-160%)}@supports (color:color-mix(in lab, red, red)){.pillnav{border:1px solid color-mix(in srgb, var(--line) 80%, transparent)}}.pillnav{box-shadow:var(--pop-shadow);opacity:0;transition:transform .55s var(--ease-out), opacity .4s var(--ease);border-radius:999px}.pillnav.in{opacity:1;transform:translate(-50%)translateY(0)}.pillnav .cur{white-space:nowrap;text-align:right;min-width:84px;padding:0 8px 0 16px;font-size:14px;font-weight:600;overflow:hidden}.cur-text{text-align:center;animation:pillFade .3s var(--ease) both;display:block}@keyframes pillFade{0%{opacity:0}to{opacity:1}}.pillnav .ico{width:38px;height:38px;color:var(--text-2);transition:.2s var(--ease);border-radius:50%;justify-content:center;align-items:center;display:flex;position:relative}.pillnav .ico:hover{background:var(--text)}@supports (color:color-mix(in lab, red, red)){.pillnav .ico:hover{background:color-mix(in srgb, var(--text) 8%, transparent)}}.pillnav .ico:hover{color:var(--text)}.pillnav .ico.active{background:var(--text);color:var(--bg)}.pillnav .ico svg{width:18px;height:18px}.pillnav .sep{background:var(--line);width:1px;height:22px;margin:0 4px}.hero{text-align:center;padding:150px 0 40px}.hero .photo{object-fit:cover;width:132px;height:132px;box-shadow:0 0 0 1px var(--line), 0 14px 40px #00000029;border-radius:50%;margin:0 auto 30px}@supports (color:color-mix(in lab, red, red)){.hero .photo{box-shadow:0 0 0 1px color-mix(in srgb, var(--line) 90%, transparent), 0 14px 40px #00000029}}.hero .photo{animation:pop .9s var(--ease-out) both}@keyframes pop{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:none}}.hero h1{letter-spacing:-.045em;margin-bottom:18px;font-size:clamp(48px,8vw,86px);font-weight:680;line-height:.96}.hero .role{color:var(--text-2);margin-bottom:22px;font-size:clamp(19px,2.4vw,24px);font-weight:430}.hero .meta{color:var(--text-2);flex-wrap:wrap;justify-content:center;gap:10px 22px;margin-bottom:34px;font-size:15px;display:flex}.hero .meta span{align-items:center;gap:7px;display:inline-flex}.hero .meta svg{opacity:.75;width:20px;height:20px}.meta-link{color:inherit;transition:font-size .2s var(--ease), font-weight .2s var(--ease);text-decoration:none;display:inline-block;position:relative}.meta-link:after{content:"";transform-origin:0;width:100%;height:1.5px;transition:transform .3s var(--ease-out);background:currentColor;position:absolute;bottom:-1px;left:0;transform:scaleX(0)}.meta-link:hover{font-weight:600}.meta-link:hover:after{transform:scaleX(1)}.meta-link:not(:hover):after{transform-origin:100%}.social{flex-wrap:wrap;justify-content:center;gap:11px;display:flex}.social a,.social button{color:var(--text);border:1px solid var(--line);background:var(--surface);box-shadow:var(--card-shadow);transition:.22s var(--ease);border-radius:999px;align-items:center;gap:8px;padding:10px 19px;font-size:14px;font-weight:500;display:inline-flex}.social a:hover,.social button:hover{border-color:var(--line-2);transform:translateY(-3px);box-shadow:0 10px 26px #0000001f}.social a.primary{background:var(--accent);color:#fff;border-color:var(--accent)}.social a.primary:hover{box-shadow:0 12px 30px var(--accent-soft)}.social a svg,.social button svg{width:15px;height:15px}#about{padding-top:80px;padding-bottom:80px}.about-grid{grid-template-columns:minmax(0,1fr) minmax(0,2fr);align-items:start;gap:0 64px;display:grid}.about-eyebrow{letter-spacing:.14em;grid-area:1/2;margin-bottom:16px;font-size:18px}.greeting{text-align:right;grid-area:2/1}.about-copy{grid-area:2/2}.greet-sub{text-align:right}.greet-window{height:96px;position:relative;overflow:hidden}.greet-track{transition:transform .62s var(--ease-out);flex-direction:column;display:flex}.greet-track .w{letter-spacing:-.04em;color:#0000;background:linear-gradient(96deg,#ff5f6d,#ff9166,#ffc24b,#5fd0a6,#4c9df0,#a36bff,#ff5f6d) 0 0/340% 100%;-webkit-background-clip:text;background-clip:text;justify-content:flex-end;align-items:flex-start;height:96px;font-size:clamp(46px,6vw,76px);font-weight:720;line-height:1;animation:11s linear infinite hue;display:flex}@keyframes hue{to{background-position:340% 0}}.greet-sub{color:var(--text-3);margin-top:14px;font-size:15px}.about-copy{color:var(--text);letter-spacing:-.012em;text-align:left;max-width:540px;font-size:clamp(18px,2vw,22px);font-weight:430;line-height:1.55}.about-copy b{font-weight:600}.tl{max-width:920px;padding-left:34px;position:relative}.tl:before{content:"";background:linear-gradient(var(--line), var(--line) 60%, transparent);width:2px;position:absolute;top:14px;bottom:14px;left:8px}.tl-item{margin-bottom:20px;position:relative}.tl-item:before{content:"";background:var(--bg);border:2px solid var(--line-2);width:16px;height:16px;transition:.3s var(--ease);z-index:2;border-radius:50%;position:absolute;top:32px;left:-34px}.tl-item:hover:before{border-color:var(--text);box-shadow:0 0 0 5px var(--text)}@supports (color:color-mix(in lab, red, red)){.tl-item:hover:before{box-shadow:0 0 0 5px color-mix(in srgb, var(--text) 12%, transparent)}}.work-card{background:var(--surface);box-shadow:var(--card-shadow);transition:transform .35s var(--ease-out), box-shadow .35s var(--ease), border-color .35s var(--ease);border-radius:20px;grid-template:"logo co date""logo body body"1fr/54px 1fr auto;align-items:start;gap:6px 20px;padding:26px 28px;display:grid;position:relative;overflow:hidden}.work-card:hover{border-color:var(--line-2);box-shadow:var(--pop-shadow);transform:translateY(-5px)}.work-logo{background:var(--surface-2);border:1px solid var(--line);border-radius:14px;flex:none;grid-area:logo;justify-content:center;align-self:start;align-items:center;width:54px;height:54px;display:flex;overflow:hidden}.work-logo img{object-fit:cover;width:100%;height:100%}.work-logo .mono{letter-spacing:-.03em;color:var(--text);font-size:22px;font-weight:680}.work-co-block{grid-area:co;align-self:center}.work-co{letter-spacing:-.02em;color:var(--text);font-size:19px;font-weight:680}@supports (color:color-mix(in lab, red, red)){.work-co{color:color-mix(in srgb, var(--text) 88%, var(--text-2))}}.work-co-link{align-items:center;gap:7px;text-decoration:none;display:inline-flex}.work-co-ext{color:var(--text-3);transition:color .2s var(--ease);flex:none;display:inline-flex}.work-co-ext svg{width:14px;height:14px}.work-co-link:hover .work-co{text-underline-offset:3px;text-decoration:underline}.work-co-link:hover .work-co-ext{color:var(--text)}.work-date{font-family:var(--mono);color:var(--text-2);white-space:nowrap;text-align:right;grid-area:date;align-self:center;font-size:13.5px}.work-body{grid-area:body}.work-role{color:var(--text-2);margin:4px 0 10px;font-size:14px;font-weight:450}.work-body p{color:var(--text-2);max-width:560px;margin-bottom:14px;font-size:14.5px;line-height:1.55}.stack{flex-wrap:wrap;gap:7px;display:flex}.tag{color:var(--text-2);background:var(--bg-2);border:1px solid var(--line);border-radius:999px;padding:4px 11px;font-size:12px;font-weight:500}html[data-theme=dark] .tag{background:var(--surface-2)}.tl-item:hover .work-card{z-index:3;position:relative}.proj-grid{grid-template-columns:repeat(3,1fr);gap:22px;display:grid}.proj-card{background:var(--surface);border:1px solid var(--line);box-shadow:var(--card-shadow);transition:transform .35s var(--ease-out), box-shadow .35s var(--ease), border-color .35s;border-radius:20px;overflow:hidden}.proj-card:hover{border-color:var(--line-2);box-shadow:var(--pop-shadow);transform:translateY(-6px)}.proj-card-btn{text-align:left;cursor:pointer;background:0 0;border:none;width:100%;padding:0;display:block}.proj-thumb{aspect-ratio:16/10;border-bottom:1px solid var(--line);background:var(--ph-grad);width:100%;position:relative;overflow:hidden}.pc-body{text-align:left;justify-content:space-between;align-items:center;width:100%;padding:17px 20px;display:flex}.pc-body h3{letter-spacing:-.02em;font-size:17px;font-weight:600}.pc-body .eyebrow{margin-top:5px;font-size:11px}.pc-body .arrow{color:var(--text-3);transition:color .25s var(--ease), transform .25s var(--ease)}.proj-card:hover .pc-body .arrow{color:var(--text);transform:translate(3px)}.res-list{border-top:1px solid var(--line)}.res-row{border-bottom:1px solid var(--line);cursor:pointer;transition:padding .3s var(--ease), background .3s var(--ease);grid-template-columns:1fr auto;align-items:center;gap:28px;padding:30px 6px;display:grid}.res-row:hover{background:var(--surface);box-shadow:var(--card-shadow);border-color:#0000;border-radius:18px;padding-left:24px;padding-right:24px}.res-content{min-width:0}.res-title-row{justify-content:space-between;align-items:flex-start;gap:12px;display:flex}.res-row h3{letter-spacing:-.025em;margin-bottom:8px;font-size:clamp(19px,2.2vw,24px);font-weight:600}.res-row p{color:var(--text-2);max-width:680px;font-size:14.5px;line-height:1.55}.res-row .badges{gap:7px;margin-top:14px;display:flex}.res-right{flex-shrink:0;align-items:center;gap:18px;display:flex}.res-right .yr{font-family:var(--mono);color:var(--text-2);white-space:nowrap;font-size:14px;font-weight:500}.go{border:1px solid var(--line);width:38px;height:38px;color:var(--text-2);transition:.25s var(--ease);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:flex}.res-row:hover .go{background:var(--text);border-color:var(--text);color:var(--bg)}.res-yr-mob{display:none}.res-go-mob{border:1px solid var(--line);width:34px;height:34px;color:var(--text-2);transition:.25s var(--ease);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:none}.res-row:hover .res-go-mob{background:var(--text);border-color:var(--text);color:var(--bg)}.carousel-wrap{align-items:center;gap:18px;display:flex}.carousel{border:1px solid var(--line);min-width:0;box-shadow:var(--card-shadow);border-radius:26px;flex:1;position:relative;overflow:hidden}.car-track{transition:transform .8s var(--ease-out);display:flex}.car-slide{flex:0 0 100%;position:relative}.car-cap{color:#fff;background:linear-gradient(#0000,#000000b8 20%,#000000fa);padding:52px 40px 38px;position:absolute;bottom:0;left:0;right:0}.car-cap .k{font-family:var(--mono);letter-spacing:.16em;text-transform:uppercase;opacity:.8;font-size:11px}.car-cap h3{letter-spacing:-.02em;margin:8px 0 4px;font-size:clamp(22px,3vw,30px);font-weight:600}.car-cap p{opacity:.85;width:100%;max-width:none;font-size:15px}.car-slide-img{aspect-ratio:20/16;width:100%;position:relative;overflow:hidden}.car-slide-img img{object-fit:cover}.car-arrow{width:44px;height:44px;transition:background .18s var(--ease);cursor:pointer;border:none;border-radius:50%;flex:none;justify-content:center;align-items:center;display:flex}html[data-theme=light] .car-arrow{color:#3a3a3c;background:#e5e5ea}html[data-theme=light] .car-arrow:hover{background:#d1d1d6}html[data-theme=dark] .car-arrow{color:#e5e5ea;background:#3a3a3c}html[data-theme=dark] .car-arrow:hover{background:#48484a}.car-arrow svg{stroke-width:2.2px;width:16px;height:16px}.car-arrow.prev{transform:rotate(180deg)}.car-dots{justify-content:center;gap:8px;margin-top:24px;display:flex}.car-dot{background:var(--text);border-radius:50%;width:8px;height:8px}@supports (color:color-mix(in lab, red, red)){.car-dot{background:color-mix(in srgb, var(--text) 24%, transparent)}}.car-dot{cursor:pointer;transition:.4s var(--ease);position:relative;overflow:hidden}.car-dot.on{background:var(--text);border-radius:5px;width:34px}@supports (color:color-mix(in lab, red, red)){.car-dot.on{background:color-mix(in srgb, var(--text) 24%, transparent)}}.car-dot .fill{background:var(--text);transform-origin:0;position:absolute;inset:0;transform:scaleX(0)}.car-dot.on .fill{animation:5s linear forwards dotfill}@keyframes dotfill{to{transform:scaleX(1)}}footer{text-align:center;border-top:1px solid var(--line);padding:20px 0 64px}footer .glyph{margin:0 auto 16px}footer .fnav{flex-wrap:wrap;justify-content:center;gap:20px;margin-bottom:22px;display:flex}footer .fnav a{color:var(--text-2);font-size:13px}footer .fnav a:hover{color:var(--text)}footer .cc{color:var(--text-3);font-size:13px}.overlay{z-index:200;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);opacity:0;pointer-events:none;transition:opacity .3s var(--ease);background:#00000073;justify-content:center;align-items:flex-start;padding:5vh 20px;display:flex;position:fixed;inset:0;overflow-y:auto}.overlay.show{opacity:1;pointer-events:auto}.panel{background:var(--surface);border:1px solid var(--line);width:100%;max-width:760px;box-shadow:var(--pop-shadow);transition:transform .4s var(--ease-out);border-radius:26px;margin:auto;overflow:hidden;transform:translateY(28px)scale(.98)}.overlay.show .panel{transform:none}.pclose{background:var(--surface);border:1px solid var(--line);width:36px;height:36px;color:var(--text-2);box-shadow:var(--card-shadow);z-index:5;border-radius:50%;justify-content:center;align-items:center;font-size:15px;transition:all .2s;display:flex;position:absolute;top:16px;right:16px}.pclose:hover{color:var(--text);transform:rotate(90deg)}.phead{position:relative}.phead img{width:100%;display:block}.pbody{padding:30px 34px 36px}.pbody .ptag{margin-bottom:14px}.pbody h3{letter-spacing:-.03em;margin-bottom:10px;font-size:28px;font-weight:660;line-height:1.1}.pbody .sub{color:var(--text-2);margin-bottom:24px;font-size:15.5px;line-height:1.6}.pbody h4{font-family:var(--mono);letter-spacing:.14em;text-transform:uppercase;color:var(--text-3);margin:0 0 13px;font-size:11px}.gallery{grid-template-columns:1fr 1fr;gap:13px;margin-bottom:26px;display:grid}.plinks{flex-wrap:wrap;gap:11px;margin-top:6px;display:flex}.plinks a{border:1px solid var(--line);transition:.2s var(--ease);border-radius:999px;align-items:center;gap:8px;padding:10px 18px;font-size:14px;font-weight:500;display:inline-flex}.plinks a:hover{border-color:var(--line-2);background:var(--bg-2)}.plinks a.primary{background:var(--text);color:var(--bg);border-color:var(--text)}.plinks a svg{width:18px;height:18px}.pbody .stack{margin-bottom:8px}@media (max-width:880px){section{padding:88px 0}.hero{padding:104px 0 20px}.topnav .links{display:none}.topnav .theme-btn{margin-left:auto}#about{padding-top:20px;padding-bottom:40px}.about-grid{text-align:center;grid-template-columns:1fr;gap:0}.greeting{text-align:center;flex-direction:column;order:1;grid-area:auto;align-items:center;padding-bottom:0;display:flex}.about-eyebrow{text-align:center;order:2;grid-area:auto;margin:28px 0 14px}.about-copy{text-align:center;order:3;grid-area:auto;margin:0 auto}.greet-window{width:100%}.greet-track .w{justify-content:center}.greet-sub{text-align:center;margin-top:0}.work-card{grid-template:"logo co""body body""date date"/48px 1fr;gap:10px 14px;padding:20px 18px}.work-logo{border-radius:12px;width:48px;height:48px}.work-logo .mono{font-size:18px}.work-co{font-size:17px}.work-date{text-align:left;white-space:normal}.work-body p{max-width:100%}.proj-grid{grid-template-columns:1fr 1fr}.res-row{padding:24px 6px;display:block}.res-row:hover{padding-left:18px;padding-right:18px}.res-right{display:none}.res-go-mob{display:flex}.res-yr-mob{font-family:var(--mono);color:var(--text-2);margin-top:12px;font-size:13px;font-weight:500;display:block}.car-slide-img{aspect-ratio:4/5}.car-arrow{display:none}}@media (max-width:560px){.proj-grid{grid-template-columns:1fr}.pillnav .cur,.pillnav .sep-l{display:none}.pbody{padding:24px 20px 28px}.car-cap{padding:26px 22px}}@property --tw-rotate-x{syntax:"*";inherits:false}@property --tw-rotate-y{syntax:"*";inherits:false}@property --tw-rotate-z{syntax:"*";inherits:false}@property --tw-skew-x{syntax:"*";inherits:false}@property --tw-skew-y{syntax:"*";inherits:false}
