:root{--bg:#0b0e13;--panel:#11151d;--panel-2:#161b25;--ink:#e7ecf3;--muted:#8c97a8;--accent:#9be84d;--accent-dim:rgba(155,232,77,.14);--hairline:rgba(231,236,243,.12);--hairline-soft:rgba(231,236,243,.07);--display:"Syne","Avenir Next",sans-serif;--body:"Archivo","Helvetica Neue",sans-serif;--mono:"JetBrains Mono","SFMono-Regular",Menlo,monospace;--measure:40rem;--gutter:clamp(1.25rem,5vw,4rem)}*,:after,:before{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;background-color:var(--bg);background-image:radial-gradient(ellipse 90% 55% at 75% -12%,rgba(155,232,77,.07) 0,transparent 60%),linear-gradient(rgba(231,236,243,.028) 1px,transparent 0),linear-gradient(90deg,rgba(231,236,243,.028) 1px,transparent 0);background-size:100% 100%,44px 44px,44px 44px;background-attachment:fixed;color:var(--ink);font-family:var(--body);font-size:1.0625rem;line-height:1.65;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}::-moz-selection{background:var(--accent);color:var(--bg)}::selection{background:var(--accent);color:var(--bg)}a{color:inherit}:focus-visible{outline:2px solid var(--accent);outline-offset:3px}.grain{position:fixed;inset:0;z-index:60;pointer-events:none;opacity:.035;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='a'%3E%3CfeTurbulence baseFrequency='.85' numOctaves='2' type='fractalNoise'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23a)'/%3E%3C/svg%3E")}.wrap{max-width:74rem;margin:0 auto;padding-inline:var(--gutter)}.site-header{position:sticky;top:0;z-index:50;background:#0b0e13d1;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid var(--hairline-soft)}.site-header .wrap{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding-block:.9rem}.monogram{font-family:var(--mono);font-weight:500;font-size:.92rem;letter-spacing:.02em;text-decoration:none;color:var(--ink)}.monogram .prompt{color:var(--accent)}.monogram .cursor{display:inline-block;width:.55em;height:1.05em;margin-left:.18em;vertical-align:text-bottom;background:var(--accent)}@media(prefers-reduced-motion:no-preference){.monogram .cursor{animation:blink 1.1s steps(2,start) infinite}@keyframes blink{to{visibility:hidden}}}.site-nav{display:flex;align-items:center;gap:clamp(.9rem,2.5vw,2rem)}.site-nav a{font-family:var(--mono);font-size:.72rem;letter-spacing:.14em;text-transform:lowercase;text-decoration:none;color:var(--muted);transition:color .2s ease}.site-nav a:hover{color:var(--accent)}.lang-switch{display:flex;align-items:center;gap:.45rem;font-family:var(--mono);font-size:.72rem;letter-spacing:.1em}.lang-switch .sep{color:var(--hairline)}.lang-switch a,.lang-switch span.current{text-decoration:none;text-transform:lowercase;color:var(--muted)}.lang-switch span.current{color:var(--accent);border-bottom:1px solid var(--accent)}.lang-switch a:hover{color:var(--ink)}@media(max-width:40rem){.site-nav .nav-link{display:none}}.hero{padding-block:clamp(3.5rem,10vh,7rem) clamp(3.5rem,9vh,6rem)}.hero-grid{display:grid;grid-template-columns:minmax(0,1.15fr) minmax(15rem,.85fr);gap:clamp(2.5rem,6vw,5.5rem);align-items:center}.kicker{font-family:var(--mono);font-size:.76rem;letter-spacing:.12em;color:var(--accent);margin:0 0 1.3rem}.hero h1{margin:0;font-family:var(--display);font-weight:800;font-size:clamp(2.7rem,7.2vw,5.2rem);line-height:1;letter-spacing:-.03em}.hero h1 .dot{color:var(--accent)}.hero .role{margin:1.4rem 0 0;font-family:var(--display);font-weight:600;font-size:clamp(1.1rem,2.2vw,1.45rem);letter-spacing:-.01em;color:var(--muted)}.hero .role strong{color:var(--ink);font-weight:600}.hero-bio{max-width:var(--measure);margin:1.6rem 0 0;font-size:1.05rem;color:var(--muted)}.hero-bio strong{color:var(--ink);font-weight:500}.hero-ctas{display:flex;flex-wrap:wrap;gap:.9rem;margin-top:2.2rem}.btn{display:inline-block;font-family:var(--mono);font-size:.74rem;font-weight:500;letter-spacing:.12em;text-transform:lowercase;text-decoration:none;padding:.85rem 1.5rem;border-radius:4px;transition:transform .15s ease,background .2s ease,border-color .2s ease,color .2s ease}.btn:active{transform:translateY(1px)}.btn-primary{background:var(--accent);color:var(--bg);border:1px solid var(--accent)}.btn-primary:hover{background:#b3f56e;border-color:#b3f56e}.btn-ghost{background:transparent;color:var(--ink);border:1px solid var(--hairline)}.btn-ghost:hover{border-color:var(--accent);color:var(--accent)}.stats{display:flex;flex-wrap:wrap;gap:clamp(1.6rem,4vw,3.2rem);margin-top:2.6rem;padding-top:1.6rem;border-top:1px solid var(--hairline-soft)}.stat .num{display:block;font-family:var(--display);font-weight:700;font-size:1.9rem;letter-spacing:-.02em}.stat .num em{font-style:normal;color:var(--accent)}.stat .label{display:block;margin-top:.15rem;font-family:var(--mono);font-size:.66rem;letter-spacing:.12em;color:var(--muted)}.photo-card{margin:0;position:relative;background:var(--panel);border:1px solid var(--hairline);border-radius:6px;padding:.8rem}.photo-card:after,.photo-card:before{content:"";position:absolute;width:1.1rem;height:1.1rem;border:2px solid var(--accent)}.photo-card:before{top:-2px;left:-2px;border-right:0;border-bottom:0}.photo-card:after{bottom:-2px;right:-2px;border-left:0;border-top:0}.photo-card img{display:block;width:100%;height:auto;border-radius:3px;filter:saturate(.92) contrast(1.03)}.photo-meta{display:flex;align-items:center;justify-content:space-between;gap:.8rem;margin-top:.75rem;font-family:var(--mono);font-size:.66rem;letter-spacing:.08em;color:var(--muted)}.photo-meta .status{display:inline-flex;align-items:center;gap:.45rem;white-space:nowrap}.photo-meta .status:before{content:"";width:.5rem;height:.5rem;border-radius:50%;background:var(--accent);box-shadow:0 0 8px var(--accent)}@media(max-width:52rem){.hero-grid{grid-template-columns:1fr}.hero-grid .photo-col{order:-1;max-width:17rem}}@media(prefers-reduced-motion:no-preference){.rise{opacity:0;transform:translateY(18px);animation:rise .8s cubic-bezier(.22,1,.36,1) forwards}.rise-1{animation-delay:.05s}.rise-2{animation-delay:.14s}.rise-3{animation-delay:.23s}.rise-4{animation-delay:.32s}.rise-5{animation-delay:.45s}.rise-6{animation-delay:.58s}@keyframes rise{to{opacity:1;transform:none}}}.section{padding-block:clamp(3.2rem,9vh,6rem)}.section-head{display:flex;align-items:baseline;gap:1.2rem;border-top:1px solid var(--hairline);padding-top:1.2rem;margin-bottom:clamp(2rem,5vh,3.2rem)}.section-head .tag{font-family:var(--mono);font-size:.76rem;letter-spacing:.08em;color:var(--accent);white-space:nowrap}.section-head h2{margin:0;font-family:var(--display);font-weight:700;font-size:clamp(1.7rem,4vw,2.5rem);letter-spacing:-.02em}.section-head .lede{margin:0 0 0 auto;max-width:26rem;font-size:.92rem;color:var(--muted);text-align:right}@media(max-width:52rem){.section-head{flex-wrap:wrap}.section-head .lede{margin-left:0;text-align:left;flex-basis:100%}}.project{position:relative;display:grid;grid-template-columns:minmax(4.5rem,7rem) 1fr;gap:clamp(1.2rem,4vw,3.5rem);padding:clamp(1.8rem,5vh,2.8rem) 1rem;margin-inline:-1rem;border-top:1px solid var(--hairline-soft);border-radius:6px;transition:background .25s ease}.project:hover{background:#e7ecf306}.project:first-of-type{border-top:0;padding-top:.5rem}.project-aside .index{font-family:var(--mono);font-weight:700;font-size:clamp(1.3rem,2.6vw,1.8rem);color:var(--accent)}.project-aside .role{display:block;margin-top:.8rem;font-size:.62rem;letter-spacing:.1em;max-width:9rem}.project-aside .role,.project-kind{font-family:var(--mono);color:var(--muted)}.project-kind{display:inline-flex;align-items:center;gap:.5rem;font-size:.68rem;letter-spacing:.14em;text-transform:lowercase}.project-kind:before{content:"";width:.55rem;height:.55rem;border-radius:2px;background:var(--project-hue,var(--accent))}.project-stat{display:inline-block;margin-left:.7rem;font-family:var(--mono);font-size:.66rem;font-weight:500;letter-spacing:.1em;text-transform:lowercase;color:var(--accent);background:var(--accent-dim);border:1px solid rgba(155,232,77,.3);border-radius:4px;padding:.18rem .55rem;vertical-align:middle}.project h3{margin:.55rem 0 0;font-family:var(--display);font-weight:700;font-size:clamp(1.6rem,3.8vw,2.4rem);letter-spacing:-.02em;line-height:1.08}.project h3 a{text-decoration:none;background-image:linear-gradient(var(--accent),var(--accent));background-repeat:no-repeat;background-size:0 2px;background-position:0 100%;transition:background-size .35s cubic-bezier(.22,1,.36,1)}.project h3 a:hover{background-size:100% 2px}.project .domain{display:inline-block;margin-top:.45rem;font-family:var(--mono);font-size:.76rem;letter-spacing:.03em;color:var(--accent);text-decoration:none}.project .domain:hover{text-decoration:underline}.project .desc{max-width:var(--measure);margin:1rem 0 0;font-size:1rem;color:var(--muted)}.stack{display:flex;flex-wrap:wrap;gap:.45rem;margin:1.2rem 0 0;padding:0;list-style:none}.stack li{font-family:var(--mono);font-size:.66rem;letter-spacing:.05em;padding:.24rem .6rem;border:1px solid var(--hairline);border-radius:4px;color:var(--muted);background:#e7ecf308}.project .visit{display:inline-block;margin-top:1.3rem;font-family:var(--mono);font-size:.72rem;letter-spacing:.12em;text-transform:lowercase;text-decoration:none;color:var(--ink)}.project .visit .arrow{display:inline-block;color:var(--accent);transition:transform .25s ease}.project .visit:hover .arrow{transform:translate(.4em)}@media(max-width:44rem){.project{grid-template-columns:1fr;gap:.6rem}.project-aside{display:flex;align-items:baseline;gap:1rem}.project-aside .role{margin-top:0;max-width:none}}.about-grid{display:grid;grid-template-columns:minmax(0,1.25fr) minmax(0,1fr);gap:clamp(2rem,6vw,5rem)}.about-grid .prose p{max-width:var(--measure);margin:0 0 1.4rem;font-size:1.02rem;color:var(--muted)}.about-grid .prose strong{color:var(--ink);font-weight:500}.facet{background:var(--panel);border:1px solid var(--hairline-soft);border-radius:6px;padding:1.3rem 1.4rem;margin-bottom:1.2rem}.facet h4{margin:0 0 .8rem;font-family:var(--mono);font-size:.68rem;font-weight:500;letter-spacing:.14em;color:var(--accent)}.facet ul{margin:0;padding:0;list-style:none}.facet li{position:relative;padding-left:1.2rem;margin-bottom:.4rem;font-size:.95rem;color:var(--muted)}.facet li:before{content:">";position:absolute;left:0;font-family:var(--mono);color:var(--accent)}.facet .pair{display:grid;grid-template-columns:6.5rem 1fr;gap:.45rem 1rem;margin:0;font-size:.95rem}.facet .pair dt{font-family:var(--mono);font-size:.66rem;letter-spacing:.1em;color:var(--muted);padding-top:.2rem}.facet .facet-text,.facet .pair dd{margin:0;color:var(--ink)}.facet .facet-text{font-size:.95rem}@media(max-width:52rem){.about-grid{grid-template-columns:1fr}}.contact-body{text-align:center;padding-block:clamp(1rem,4vh,2.5rem)}.contact-headline{max-width:46rem;margin:0 auto}.contact-headline p{margin:0 0 .6rem;font-family:var(--display);font-weight:700;font-size:clamp(1.6rem,4vw,2.6rem);line-height:1.15;letter-spacing:-.02em}.contact-headline .sub{font-family:var(--body);font-weight:400;font-size:1.05rem;color:var(--muted);letter-spacing:0;line-height:1.6}.contact-email{display:inline-block;margin-top:1.8rem;font-family:var(--mono);font-size:clamp(1rem,2.6vw,1.35rem);letter-spacing:.02em;color:var(--ink);text-decoration:none;border-bottom:2px solid var(--accent);padding-bottom:.18em;transition:color .2s ease}.contact-email:hover{color:var(--accent)}.cv-block{margin-top:clamp(2.6rem,7vh,4rem)}.cv-block .comment{display:block;margin-bottom:1rem;font-family:var(--mono);font-size:.78rem;letter-spacing:.04em;color:var(--muted)}.contact-links{display:flex;justify-content:center;flex-wrap:wrap;gap:clamp(1.2rem,4vw,2.6rem);margin-top:clamp(2.4rem,6vh,3.6rem);padding:0;list-style:none}.contact-links a{font-family:var(--mono);font-size:.72rem;letter-spacing:.12em;text-transform:lowercase;text-decoration:none;color:var(--muted);transition:color .2s ease}.contact-links .ext,.contact-links a:hover{color:var(--accent)}.site-footer{border-top:1px solid var(--hairline);margin-top:clamp(2rem,6vh,4rem)}.site-footer .wrap{padding-block:2.2rem 2.8rem;text-align:center}.site-footer p{margin:.3rem 0;font-family:var(--mono);font-size:.68rem;letter-spacing:.06em;color:var(--muted)}.site-footer .sigil{font-family:var(--mono);color:var(--accent);font-size:.9rem;margin-bottom:.9rem}.reveal{opacity:1;transform:none}@media(prefers-reduced-motion:no-preference){.reveal{opacity:0;transform:translateY(22px);transition:opacity .7s ease,transform .7s cubic-bezier(.22,1,.36,1)}.reveal.is-visible{opacity:1;transform:none}}
