:root{--bg: #0e1116;--bg-2: #141922;--txt: #edeae2;--body-txt: #b9b4a9;--dim: #8e8a82;--line: rgba(237, 234, 226, .1);--line-mid: rgba(237, 234, 226, .26);--accent: #ffa733;--accent-soft: rgba(255, 167, 51, .12);--font-sans: system-ui, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;--font-display: Bahnschrift, "Avenir Next Condensed", "Roboto Condensed", "Arial Narrow", "Segoe UI", system-ui, sans-serif;--font-mono: ui-monospace, "Cascadia Mono", "SF Mono", SFMono-Regular, Menlo, Consolas, "Liberation Mono", monospace;--rail: clamp(20px, 4.5vw, 64px);--shell: 1360px;--ease-out: cubic-bezier(.16, 1, .3, 1)}*,*:before,*:after{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;background:var(--bg);color:var(--body-txt);font-family:var(--font-sans);font-size:17px;line-height:1.6;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;overflow-x:hidden}body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;z-index:0;pointer-events:none;background:radial-gradient(1200px 620px at 70% -220px,rgba(58,82,120,.16),transparent 65%)}body:after{content:"";position:fixed;top:0;right:0;bottom:0;left:0;z-index:60;pointer-events:none;opacity:.4;mix-blend-mode:screen;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/%3E%3CfeColorMatrix type='matrix' values='0 0 0 0 0.85 0 0 0 0 0.82 0 0 0 0 0.74 0 0 0 0.03 0'/%3E%3C/filter%3E%3Crect width='160' height='160' filter='url(%23n)'/%3E%3C/svg%3E")}h1,h2,h3,p,ul,ol,dl,dd,figure{margin:0;padding:0}ul,ol{list-style:none}img{max-width:100%;height:auto;display:block}a{color:inherit}button{font:inherit;color:inherit;background:none;border:0;padding:0;cursor:pointer}::-moz-selection{background:#ffa73359;color:var(--txt)}::selection{background:#ffa73359;color:var(--txt)}:focus-visible{outline:2px solid var(--accent);outline-offset:3px;border-radius:2px}section[id]{scroll-margin-top:72px}.mono{font-family:var(--font-mono)}.shell{max-width:var(--shell);margin-inline:auto;padding-inline:var(--rail)}.arr{display:inline-block;margin-left:6px;transition:transform .2s var(--ease-out)}a:hover .arr,button:hover .arr{transform:translate(2px,-2px)}.skip{position:absolute;left:-9999px;z-index:100}.skip:focus-visible{left:12px;top:12px;background:var(--accent);color:var(--bg);padding:10px 16px;border-radius:6px;text-decoration:none;font-family:var(--font-mono);font-size:13px}[data-speed],[data-shift],.strip__track{will-change:transform}.topbar{position:sticky;top:0;z-index:40;background:#0e1116cc;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}.topbar__in{display:flex;align-items:center;gap:clamp(16px,3vw,36px);height:58px}.topbar__brand{font-family:var(--font-display);font-stretch:82%;font-weight:700;font-size:19px;letter-spacing:.06em;color:var(--txt);text-decoration:none;transition:color .2s}.topbar__brand:hover{color:var(--accent)}.topbar__nav{margin-left:auto;display:flex;gap:clamp(14px,2vw,28px)}.topbar__nav a{font-size:12px;text-transform:uppercase;letter-spacing:.14em;color:var(--dim);text-decoration:none;transition:color .2s}.topbar__nav a:hover{color:var(--txt)}.odo{font-size:12px;letter-spacing:.1em;color:var(--dim);background:#00000059;border:1px solid var(--line-mid);border-radius:5px;padding:4px 10px;white-space:nowrap;font-variant-numeric:tabular-nums}.odo__val{color:var(--accent)}html:not(.js) .odo{display:none}.lang{display:flex;align-items:center;gap:6px}.lang__btn{font-size:12px;letter-spacing:.1em;color:var(--dim);padding:4px 2px;transition:color .2s}.lang__btn:hover{color:var(--txt)}.lang__btn[aria-pressed=true]{color:var(--accent);text-decoration:underline;text-underline-offset:5px}.lang__sep{color:var(--line-mid);font-size:12px}.hero{position:relative;overflow:hidden}.hero__in{position:relative;z-index:1;display:flex;flex-direction:column;justify-content:center;min-height:calc(100svh - 58px);padding-block:clamp(40px,6vh,72px)}.hero__ghost{position:absolute;left:0;right:0;top:16%;z-index:0;text-align:center;white-space:nowrap;pointer-events:none;font-family:var(--font-display);font-stretch:76%;font-weight:700;font-size:clamp(44px,8.5vw,140px);letter-spacing:.06em;color:transparent;-webkit-text-stroke:1px rgba(237,234,226,.12)}.hero__eyebrow{font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--dim);margin-bottom:clamp(20px,3.5vh,36px)}.hero__eyebrow:before{content:"";display:inline-block;width:28px;height:1px;background:var(--accent);vertical-align:middle;margin-right:14px}.hero__name{font-family:var(--font-display);font-stretch:75%;font-weight:700;text-transform:uppercase;font-size:clamp(84px,17vw,256px);line-height:.9;letter-spacing:.002em;color:var(--txt)}.hero__row{display:block}.hero__row--r{text-align:right}.hero__word{display:inline-block}.ast{color:var(--accent);text-decoration:none;font-size:.48em;vertical-align:super;margin-left:.05em;display:inline-block;transition:transform .2s var(--ease-out)}.ast:hover{transform:scale(1.15)}.hero__base{display:grid;grid-template-columns:minmax(0,1.25fr) auto auto;gap:clamp(28px,4vw,64px);align-items:end;margin-top:clamp(40px,8vh,96px)}.lede{font-size:clamp(17px,1.5vw,21px);line-height:1.65;color:#dfdace;max-width:44ch}.hero__foot{margin-top:16px;font-size:12px;letter-spacing:.04em;color:var(--dim)}.hero__links{display:flex;gap:22px}.hero__links a{font-size:12px;text-transform:uppercase;letter-spacing:.12em;color:var(--txt);text-decoration:none;border-bottom:1px solid var(--line-mid);padding-bottom:4px;transition:color .2s,border-color .2s}.hero__links a:hover{color:var(--accent);border-color:var(--accent)}.hero__scroll{font-size:11px;letter-spacing:.14em;color:var(--dim)}.hero__arrow{display:inline-block;margin-left:4px}html.js:not(.static) .hero__arrow{animation:bob 2.2s ease-in-out infinite}@keyframes bob{0%,to{transform:translateY(0)}50%{transform:translateY(5px)}}.sec{position:relative;z-index:1;padding-top:clamp(96px,14vh,176px)}.sec__head{display:grid;grid-template-columns:auto 1fr auto;align-items:baseline;gap:10px clamp(20px,3vw,40px);border-bottom:1px solid var(--line-mid);padding-bottom:20px;margin-bottom:clamp(36px,6vh,64px)}.sec__idx{font-size:12px;letter-spacing:.2em;color:var(--accent)}.sec__title{font-family:var(--font-display);font-stretch:78%;font-weight:700;text-transform:uppercase;font-size:clamp(48px,7.5vw,112px);line-height:.9;color:var(--txt)}.sec__tag{font-size:11px;letter-spacing:.18em;color:var(--dim);justify-self:end}.proj{display:grid;grid-template-columns:minmax(0,1.15fr) minmax(0,.85fr);gap:clamp(32px,5vw,72px);align-items:center;padding-block:clamp(40px,6vh,72px)}.proj+.proj{border-top:1px solid var(--line)}.proj__chips{display:flex;gap:10px;margin-bottom:18px}.chip{display:inline-flex;align-items:center;gap:8px;font-size:10px;letter-spacing:.16em;color:var(--dim);border:1px solid var(--line-mid);border-radius:999px;padding:5px 12px}.chip--live{color:var(--txt);border-color:#ffa73373}.chip__dot{width:7px;height:7px;border-radius:50%;background:var(--accent);flex-shrink:0}html.js:not(.static) .chip__dot{animation:pulse 2.4s ease-in-out infinite}@keyframes pulse{0%,to{box-shadow:0 0 6px 1px #ffa73399}50%{box-shadow:0 0 14px 4px #ffa73333}}.proj__title{font-family:var(--font-display);font-stretch:80%;font-weight:700;text-transform:uppercase;font-size:clamp(40px,5vw,72px);line-height:.92;color:var(--txt)}.proj--feat .proj__title{font-size:clamp(54px,7.5vw,110px)}.proj__title .thin{color:var(--accent);font-weight:400}.proj__desc{margin-top:16px;max-width:52ch;font-size:16.5px;color:var(--body-txt)}.proj__stack{margin-top:14px;font-size:11.5px;letter-spacing:.08em;color:var(--dim)}.proj__acts{display:flex;flex-wrap:wrap;gap:24px;margin-top:24px}.lnk{font-size:12.5px;text-transform:uppercase;letter-spacing:.1em;color:var(--txt);text-decoration:none;border-bottom:1px solid var(--line-mid);padding-bottom:5px;transition:color .2s,border-color .2s}.lnk:hover{color:var(--accent);border-color:var(--accent)}.proj__media{justify-self:end}.proj--alt .proj__media{order:-1;justify-self:start}.proj__media img{width:clamp(170px,21vw,290px);filter:drop-shadow(0 30px 60px rgba(0,0,0,.5))}.arch{margin-top:clamp(56px,8vh,88px);padding-bottom:4px}.arch__title{font-size:11px;letter-spacing:.18em;color:var(--dim);margin-bottom:10px}.arch__hint{color:#8e8a828c;letter-spacing:.08em}@media (hover: none){.arch__hint{display:none}}.arch__list li{border-top:1px solid var(--line)}.arch__list li:last-child{border-bottom:1px solid var(--line)}.arch__list .row{display:grid;grid-template-columns:64px 200px 1fr auto;gap:18px;align-items:baseline;padding:15px 6px;transition:background .2s}.arch__list .row:hover{background:#ffa7330a}.arch__list .no{font-size:11px;letter-spacing:.1em;color:var(--dim)}.arch__list .name{font-family:var(--font-display);font-stretch:85%;font-weight:600;text-transform:uppercase;font-size:18px;letter-spacing:.03em;color:var(--txt);transition:color .2s}.arch__list .row:hover .name{color:var(--accent)}.arch__list .desc{font-size:14px;color:#aba69b}.arch__list .stack{font-size:11px;letter-spacing:.06em;color:var(--dim);text-align:right}.peek{position:fixed;left:0;top:0;width:230px;z-index:50;pointer-events:none;opacity:0;transition:opacity .18s ease-out}.peek.is-on{opacity:1}.peek img{width:100%;border-radius:12px;border:1px solid var(--line-mid);box-shadow:0 26px 60px #0009}.exp{display:grid;grid-template-columns:minmax(240px,320px) 1fr;gap:clamp(40px,6vw,88px);align-items:start}.exp__side{position:sticky;top:96px;display:flex;flex-direction:column;gap:12px}.exp__side .sec__title{font-size:clamp(40px,4.5vw,64px)}.exp__side .sec__tag{justify-self:start}.entry{padding-block:clamp(28px,4vh,40px)}.entry:first-child{padding-top:6px}.entry+.entry{border-top:1px solid var(--line)}.entry__when{display:flex;align-items:center;gap:14px;flex-wrap:wrap;font-size:12px;letter-spacing:.12em;color:var(--dim);margin-bottom:12px}.tag-now{font-size:10px;letter-spacing:.14em;color:var(--accent);border:1px solid rgba(255,167,51,.5);border-radius:999px;padding:3px 10px}.entry h3{font-family:var(--font-display);font-stretch:82%;font-weight:700;text-transform:uppercase;font-size:clamp(26px,3vw,40px);line-height:1;color:var(--txt)}.entry__role{margin-top:7px;font-size:12px;text-transform:uppercase;letter-spacing:.12em;color:var(--accent)}.entry__desc{margin-top:12px;max-width:66ch;font-size:15.5px;color:var(--body-txt)}.entry__tools{margin-top:12px;font-size:11.5px;letter-spacing:.06em;color:var(--dim)}.about{display:grid;grid-template-columns:minmax(220px,320px) 1fr;gap:clamp(40px,6vw,80px);align-items:start}.about__photo img{width:100%;border-radius:16px;border:1px solid var(--line);filter:grayscale(1) contrast(1.05);transition:filter .4s ease-out}.about__photo:hover img{filter:none}.sheet__row{display:grid;grid-template-columns:200px 1fr;gap:20px;padding:15px 0;border-top:1px solid var(--line)}.sheet__row:last-child{border-bottom:1px solid var(--line)}.sheet__row dt{font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--dim);align-self:center}.sheet__row dd{font-size:15.5px;color:var(--txt)}.fn{color:var(--accent)}.sheet__note{margin-top:16px;font-size:12px;letter-spacing:.03em;color:var(--dim)}.strip{margin-top:clamp(96px,14vh,176px);border-block:1px solid var(--line);padding:24px 0;overflow:hidden}.strip__track{display:flex;width:-moz-max-content;width:max-content}.strip__half{display:flex;flex-shrink:0}.strip__half span{font-family:var(--font-display);font-stretch:78%;font-weight:700;text-transform:uppercase;font-size:clamp(44px,7vw,96px);line-height:1;white-space:nowrap;color:transparent;-webkit-text-stroke:1px rgba(237,234,226,.32);padding-right:44px}.strip__half span:after{content:"✦";-webkit-text-stroke:0;color:var(--accent);margin-left:44px;font-size:.55em;vertical-align:.2em}.contact{position:relative;z-index:1;padding-block:clamp(110px,16vh,200px) clamp(90px,12vh,150px)}.contact__title{margin-top:20px;font-family:var(--font-display);font-stretch:76%;font-weight:700;text-transform:uppercase;font-size:clamp(72px,13vw,220px);line-height:.88;color:var(--txt)}.contact__sub{margin-top:26px;max-width:46ch;color:var(--body-txt)}.contact__mail{margin-top:clamp(36px,6vh,64px)}.mail{font-family:var(--font-display);font-stretch:80%;font-weight:600;font-size:clamp(25px,4.6vw,72px);letter-spacing:.01em;color:var(--txt);text-align:left;border-bottom:2px solid var(--line-mid);padding-bottom:8px;overflow-wrap:anywhere;transition:color .2s,border-color .2s}.mail:hover,.mail.is-copied{color:var(--accent);border-color:var(--accent)}.mail__meta{display:flex;flex-wrap:wrap;gap:12px 28px;margin-top:14px;font-size:12px;letter-spacing:.08em;color:var(--dim)}.mail__open{text-transform:uppercase;letter-spacing:.1em;color:var(--dim);text-decoration:none;transition:color .2s}.mail__open:hover{color:var(--accent)}.contact__base{display:flex;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:20px 32px;margin-top:clamp(48px,8vh,84px)}.contact__links{display:flex;gap:24px}.contact__links a{font-size:12px;text-transform:uppercase;letter-spacing:.12em;color:var(--txt);text-decoration:none;border-bottom:1px solid var(--line-mid);padding-bottom:4px;transition:color .2s,border-color .2s}.contact__links a:hover{color:var(--accent);border-color:var(--accent)}.contact__avail{display:inline-flex;align-items:center;gap:10px;font-size:12px;letter-spacing:.06em;color:var(--dim)}.footer{position:relative;z-index:1;border-top:1px solid var(--line)}.footer__in{display:flex;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px 28px;padding-block:24px;font-size:11.5px;letter-spacing:.08em;color:var(--dim)}.footer__top{letter-spacing:.14em;color:var(--dim);text-decoration:none;transition:color .2s}.footer__top:hover{color:var(--accent)}html.js:not(.static) .hero__word{opacity:0;transform:translateY(.32em)}html.js.is-ready:not(.static) .hero__word{opacity:1;transform:none;transition:transform .95s var(--ease-out),opacity .6s ease-out;transition-delay:calc(var(--d, 0) * .11s)}html.js:not(.static) [data-load]{opacity:0}html.js.is-ready:not(.static) [data-load]{opacity:1;transition:opacity .8s ease-out;transition-delay:calc(var(--d, 0) * .1s)}html.js:not(.static) [data-reveal]{opacity:0;transform:translateY(20px);transition:opacity .7s ease-out,transform .7s var(--ease-out);transition-delay:calc(var(--d, 0) * 90ms)}html.js:not(.static) [data-reveal].is-in{opacity:1;transform:none}@media (max-width: 1024px){.exp{grid-template-columns:1fr;gap:0}.exp__side{position:static;display:grid;grid-template-columns:auto 1fr auto;align-items:baseline;gap:10px 20px;border-bottom:1px solid var(--line-mid);padding-bottom:20px;margin-bottom:20px}.exp__side .sec__tag{justify-self:end}}@media (max-width: 900px){.hero__base{grid-template-columns:1fr;gap:26px;align-items:start}.hero__scroll{display:none}.proj,.proj--alt{grid-template-columns:1fr;gap:28px}.proj__media,.proj--alt .proj__media{order:2;justify-self:start}.proj__media img{width:clamp(140px,32vw,220px)}.arch__list .row{grid-template-columns:56px 1fr;gap:6px 16px;padding-block:16px}.arch__list .desc,.arch__list .stack{grid-column:2;text-align:left}.about{grid-template-columns:1fr}.about__photo{max-width:280px}.exp__side,.sec__head{grid-template-columns:1fr;gap:8px}.sec__tag,.exp__side .sec__tag{justify-self:start}}@media (max-width: 700px){.sheet__row{grid-template-columns:1fr;gap:4px}.hero__ghost{top:12%}}@media (max-width: 560px){.hide-xs{display:none}.topbar__in{gap:12px}.odo{font-size:11px;padding:3px 7px}.hero__name{font-size:clamp(64px,19vw,110px)}.contact__title{font-size:clamp(56px,16vw,96px)}}@media (prefers-reduced-motion: reduce){html{scroll-behavior:auto}html.js .hero__word,html.js.is-ready .hero__word,html.js [data-load],html.js.is-ready [data-load],html.js [data-reveal]{opacity:1;transform:none;transition:none}html.js .hero__arrow,html.js .chip__dot{animation:none}.arr,.ast,.lnk,.mail,.about__photo img{transition:none}}html.static .hero__word,html.static.is-ready .hero__word,html.static [data-load],html.static.is-ready [data-load],html.static [data-reveal]{opacity:1;transform:none;transition:none}html.static .hero__arrow,html.static .chip__dot{animation:none}html.static *{transition:none!important}
