:root{--bg:#fff;--bg-2:#f5f3ef;--ink:#15130f;--ink-2:#2c2925;--muted:#6b6660;--line:#15130f1a;--line-strong:#15130f2e;--pill:#15130f0f;--pill-line:#15130f1a;--ghost:#15130f12;--accent:oklch(58% .13 35)}body.dark{--bg:#14130f;--bg-2:#1c1a16;--ink:#f1ece4;--ink-2:#d6d0c5;--muted:#8b857c;--line:#f1ece41a;--line-strong:#f1ece433;--pill:#f1ece40f;--pill-line:#f1ece41f;--ghost:#f1ece40f}*{box-sizing:border-box}html,body,#root{min-height:100vh;margin:0;padding:0}body{background:var(--bg);color:var(--ink);-webkit-font-smoothing:antialiased;font-family:Inter,system-ui,-apple-system,Helvetica Neue,Arial,sans-serif;transition:background .4s,color .4s;overflow-x:hidden}a{color:inherit;text-decoration:none}button{font:inherit;color:inherit;cursor:pointer;background:0 0;border:0}.page{flex-direction:column;min-height:100vh;padding:clamp(20px,3vw,36px) clamp(24px,6vw,96px) clamp(60px,8vh,100px);display:flex;position:relative}.home-page{padding-bottom:clamp(20px,3vw,36px)}.top{z-index:5;justify-content:space-between;align-items:center;display:flex;position:relative}.logo{letter-spacing:-.01em;align-items:baseline;gap:1px;font-family:Fraunces,Times New Roman,serif;font-size:28px;font-style:italic;font-weight:500;line-height:1;display:inline-flex}.logo .dot{color:var(--accent);font-style:normal}nav.main{color:var(--ink-2);align-items:center;gap:clamp(20px,3vw,44px);font-size:14px;display:flex}nav.main a{padding:8px 2px;transition:color .2s;position:relative}nav.main a:after{content:"";background:currentColor;height:1px;transition:right .25s;position:absolute;bottom:4px;left:0;right:100%}nav.main a:hover,nav.main a.active{color:var(--ink)}nav.main a:hover:after,nav.main a.active:after{right:0}.mode{border:1px solid var(--line);border-radius:50%;place-items:center;width:32px;height:32px;transition:transform .25s,background .2s;display:inline-grid}.mode:hover{background:var(--pill);transform:rotate(-12deg)}.mode svg{display:block}.marquee-stack{pointer-events:none;z-index:0;flex-direction:column;justify-content:center;gap:clamp(8px,2vh,24px);padding-top:60px;display:flex;position:absolute;inset:0;overflow:hidden}.marquee{white-space:nowrap;color:var(--ghost);letter-spacing:-.03em;will-change:transform;font-family:Archivo Black,Helvetica Neue,Helvetica,Arial,sans-serif;font-size:clamp(80px,13vw,200px);font-weight:900;line-height:.95;display:flex}.marquee .track{flex-shrink:0;gap:clamp(40px,6vw,100px);padding-right:clamp(40px,6vw,100px);animation:38s linear infinite scroll-l;display:flex}.marquee.rev .track{animation:44s linear infinite scroll-r}.marquee.italic{font-family:Fraunces,Times New Roman,serif;font-style:italic;font-weight:500}.marquee .word{align-items:center;gap:clamp(24px,4vw,56px);display:inline-flex}.marquee .word:after{content:"";background:var(--ghost);border-radius:50%;width:clamp(10px,1.4vw,18px);height:clamp(10px,1.4vw,18px);display:inline-block}.marquee.italic .word:after{border-radius:2px}@keyframes scroll-l{0%{transform:translate(0)}to{transform:translate(-100%)}}@keyframes scroll-r{0%{transform:translate(-100%)}to{transform:translate(0)}}.hero{z-index:2;grid-template-columns:1fr;align-items:end;gap:24px;max-width:1200px;margin:clamp(40px,8vh,90px) 0 clamp(40px,6vh,64px);display:grid;position:relative}.home-hero{max-width:980px;margin-bottom:0;display:block}@media (width>=900px){.hero:not(.home-hero){grid-template-columns:minmax(0,1.4fr) minmax(0,1fr);gap:56px}}h1.name{letter-spacing:-.035em;color:var(--ink);margin:0 0 18px;font-family:Archivo Black,Helvetica Neue,Helvetica,Arial,sans-serif;font-size:clamp(44px,7.2vw,108px);font-weight:900;line-height:.95}.contact-line{color:var(--ink-2);flex-wrap:wrap;align-items:center;gap:12px;margin:0 0 28px;font-family:JetBrains Mono,ui-monospace,Menlo,monospace;font-size:14px;display:flex}.contact-line a{color:var(--ink);border-bottom:1px solid var(--line);padding-bottom:2px;transition:border-color .2s,color .2s}.contact-line a:hover{border-color:var(--accent);color:var(--accent)}.contact-line .sep{color:var(--muted);opacity:.6}.intro{color:var(--ink-2);max-width:720px;font-size:clamp(15px,1.15vw,17px);line-height:1.7}.intro p{margin:0 0 14px}.pill{background:var(--pill);border:1px solid var(--pill-line);color:var(--ink);white-space:nowrap;border-radius:999px;align-items:center;gap:6px;margin:0 2px;padding:3px 10px;font-size:.92em;transition:background .2s,transform .2s;display:inline-flex}.pill:hover{background:var(--bg-2);transform:translateY(-1px)}.pill .dot-s{background:var(--accent);border-radius:50%;width:6px;height:6px;display:inline-block}.cta{color:var(--ink);border-bottom:1px solid var(--line);align-items:center;gap:10px;margin-top:14px;padding:10px 0;font-weight:500;display:inline-flex}.cta .arrow{transition:transform .25s;display:inline-block}.cta:hover .arrow{transform:translate(6px)}.socials{color:var(--ink-2);align-items:center;gap:18px;margin-top:28px;display:flex}.socials a{border-radius:50%;place-items:center;width:34px;height:34px;transition:background .2s,color .2s,transform .2s;display:inline-grid}.socials a:hover{background:var(--pill);color:var(--ink);transform:translateY(-2px)}.corner{z-index:3;color:var(--muted);letter-spacing:.14em;text-transform:uppercase;align-items:center;gap:10px;font-size:11px;display:flex;position:absolute;top:clamp(28px,4vw,56px);right:clamp(28px,6vw,96px);transform:translateY(54px)}.corner .ring{border:1px dashed var(--line);border-radius:50%;width:36px;height:36px;position:relative}.corner .ring:before{content:"";border:1px solid var(--line);border-radius:50%;position:absolute;inset:6px}.corner .ring:after{content:"";background:var(--accent);border-radius:50%;width:4px;height:4px;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.footer{z-index:2;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);justify-content:space-between;align-items:center;margin-top:auto;padding-top:32px;font-size:12px;display:flex;position:relative}.footer .blink{vertical-align:middle;background:oklch(70% .16 145);border-radius:50%;width:7px;height:7px;margin-right:8px;animation:1.6s ease-in-out infinite blink;display:inline-block}@keyframes blink{0%,to{opacity:1;transform:scale(1)}50%{opacity:.35;transform:scale(.85)}}h1.title{letter-spacing:-.04em;color:var(--ink);margin:0;font-family:Archivo Black,Helvetica Neue,Helvetica,Arial,sans-serif;font-size:clamp(48px,10vw,147px);font-weight:900;line-height:.9}.subtitle{color:var(--ink-2);border-left:1px solid var(--line);max-width:460px;padding-bottom:16px;padding-left:20px;font-family:Fraunces,Times New Roman,serif;font-size:clamp(18px,1.6vw,24px);font-style:italic;font-weight:400;line-height:1.45}.subtitle .lede{color:var(--ink);font-weight:500}.meta{border-top:1px solid var(--line);border-bottom:1px solid var(--line);letter-spacing:.12em;text-transform:uppercase;color:var(--muted);flex-wrap:wrap;gap:24px 36px;margin-bottom:clamp(48px,8vh,96px);padding:18px 0;font-size:12px;display:flex}.meta .key{color:var(--muted);margin-bottom:6px;display:block}.meta .val{letter-spacing:normal;text-transform:none;color:var(--ink);font-family:Inter,sans-serif;font-size:14px;font-weight:500;display:block}section.block{border-top:1px solid var(--line);grid-template-columns:1fr;gap:28px;padding:clamp(40px,7vh,80px) 0;display:grid}@media (width>=900px){section.block{grid-template-columns:260px minmax(0,1fr);gap:64px}}.block-head{flex-direction:column;gap:12px;display:flex}.block-num{color:var(--muted);letter-spacing:.1em;font-family:JetBrains Mono,ui-monospace,Menlo,monospace;font-size:12px}.block-title{letter-spacing:-.03em;color:var(--ink);margin:0;font-family:Archivo Black,Helvetica Neue,Helvetica,Arial,sans-serif;font-size:clamp(32px,4vw,52px);line-height:.95}.block-title .em{font-family:Fraunces,serif;font-style:italic;font-weight:500}.block-sub{color:var(--muted);max-width:220px;font-size:14px;line-height:1.55}.skill-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:28px 40px;display:grid}.skill-grid h4{letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin:0 0 12px;font-size:12px;font-weight:500}.skill-grid ul{color:var(--ink-2);flex-direction:column;gap:8px;margin:0;padding:0;font-size:16px;list-style:none;display:flex}.skill-grid li{align-items:center;gap:10px;display:flex}.skill-grid li:before{content:"";background:var(--ink);border-radius:50%;flex-shrink:0;width:5px;height:5px}.timeline{flex-direction:column;display:flex}.item{border-top:1px solid var(--line);grid-template-columns:100px 1fr auto;align-items:start;gap:24px;padding:24px 0;display:grid}.item:first-child{border-top:0;padding-top:0}.item .year{color:var(--muted);padding-top:4px;font-family:JetBrains Mono,monospace;font-size:13px}.item .body h3{color:var(--ink);letter-spacing:-.01em;margin:0 0 4px;font-size:19px;font-weight:600}.item .body .role{color:var(--ink-2);margin-bottom:8px;font-family:Fraunces,serif;font-size:14px;font-style:italic}.item .body p{color:var(--muted);max-width:640px;margin:0;font-size:14.5px;line-height:1.6}.item .body a.co{color:var(--ink);border-bottom:1px solid var(--line-strong);transition:border-color .2s,color .2s}.item .body a.co:hover{border-color:var(--accent);color:var(--accent)}.item .body .stack{flex-wrap:wrap;gap:6px;margin-top:12px;display:flex}.tag{background:var(--pill);border:1px solid var(--pill-line);color:var(--ink-2);border-radius:999px;padding:4px 9px;font-family:JetBrains Mono,ui-monospace,Menlo,monospace;font-size:11.5px}.item .place{color:var(--muted);text-align:right;white-space:nowrap;padding-top:4px;font-size:13px}.certs{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px;display:grid}.cert{border:1px solid var(--line);background:var(--bg);border-radius:14px;flex-direction:column;gap:10px;min-height:130px;padding:20px;transition:transform .25s,border-color .25s,background .25s;display:flex}.cert:hover{border-color:var(--line-strong);background:var(--bg-2);transform:translateY(-3px)}.cert .badge{border:1px solid var(--line-strong);width:28px;height:28px;color:var(--accent);border-radius:50%;place-items:center;display:inline-grid}.cert h3{letter-spacing:-.01em;margin:0;font-size:16px;font-weight:600}.cert .issuer{color:var(--muted);font-size:13px}.cert .when{color:var(--muted);margin-top:auto;font-family:JetBrains Mono,monospace;font-size:12px}.projects{flex-direction:column;display:flex}.project{border-top:1px solid var(--line);grid-template-columns:1fr;gap:24px;padding:clamp(40px,7vh,72px) 0;display:grid;position:relative}@media (width>=900px){.project{grid-template-columns:minmax(320px,460px) minmax(0,1fr);align-items:start;gap:56px}}.p-num{color:var(--muted);letter-spacing:.12em;margin-bottom:14px;font-family:JetBrains Mono,ui-monospace,Menlo,monospace;font-size:12px;display:block}.p-body h2{letter-spacing:-.03em;color:var(--ink);margin:0 0 6px;font-family:Archivo Black,Helvetica Neue,Helvetica,Arial,sans-serif;font-size:clamp(28px,3.6vw,48px);line-height:.95}.p-sub{color:var(--ink-2);margin:0 0 16px;font-family:Fraunces,serif;font-size:clamp(15px,1.3vw,18px);font-style:italic;font-weight:400;line-height:1.4}.p-body p{color:var(--ink-2);max-width:560px;margin:0 0 16px;font-size:15.5px;line-height:1.65}.p-body p a{color:var(--ink);border-bottom:1px solid var(--line-strong);transition:border-color .2s,color .2s}.p-body p a:hover{border-color:var(--accent);color:var(--accent)}.p-stack{flex-wrap:wrap;gap:6px;margin-bottom:18px;display:flex}.p-links{flex-wrap:wrap;gap:18px;display:flex}.p-links a{color:var(--ink);border-bottom:1px solid var(--line-strong);align-items:center;gap:6px;padding-bottom:2px;font-size:14px;transition:border-color .2s,color .2s;display:inline-flex}.p-links a:hover{border-color:var(--accent);color:var(--accent)}.p-links a .arr{transition:transform .25s;display:inline-block}.p-links a:hover .arr{transform:translate(2px,-2px)}.p-preview{aspect-ratio:4/3;border:1px solid var(--line);background:repeating-linear-gradient(45deg, var(--bg-2) 0 12px, transparent 12px 24px), var(--bg);color:var(--muted);letter-spacing:.1em;text-transform:uppercase;text-align:center;border-radius:14px;justify-content:center;align-items:center;padding:24px;font-family:JetBrains Mono,monospace;font-size:12px;transition:transform .35s,border-color .25s;display:flex;position:relative;overflow:hidden}.project:hover .p-preview{border-color:var(--line-strong);transform:translateY(-3px)}.p-preview img{object-fit:cover;width:100%;height:100%;display:block}.p-preview.has-img{background:var(--bg-2);aspect-ratio:16/9;padding:0}footer.bottom{border-top:1px solid var(--line);color:var(--muted);letter-spacing:.08em;text-transform:uppercase;justify-content:space-between;align-items:center;margin-top:clamp(60px,10vh,120px);padding-top:24px;font-size:12px;display:flex}footer.bottom a{color:var(--ink);border-bottom:1px solid var(--line);padding-bottom:2px}footer.bottom a:hover{border-color:var(--accent)}@media (width<=720px){nav.main .hide-sm,.corner{display:none}.item{grid-template-columns:1fr;gap:6px}.item .place{text-align:left}footer.bottom{flex-direction:column;align-items:flex-start;gap:20px}}
