:root{--c-bg: #F2F0EB;--c-ink: #000000;--c-mid: #3E3E3A;--c-rule: #D8D5CE;--c-accent: #2D5B8E;--c-accent-lt: #EBF1F8;--font-display: "Space Grotesk", "Inter", system-ui, sans-serif;--font-body: "Inter", system-ui, sans-serif;--font-mono: "Space Mono", "Courier New", monospace;--text-xs: .75rem;--text-sm: .875rem;--text-base: 1rem;--text-lg: 1.125rem;--text-xl: 1.375rem;--text-2xl: 1.75rem;--text-3xl: clamp(1.75rem, 5vw, 2.25rem);--text-4xl: clamp(2rem, 6vw, 3rem);--text-5xl: clamp(2.5rem, 8vw, 4rem);--tracking-tight: -.025em;--tracking-wide: .08em;--leading-tight: 1.15;--leading-body: 1.65;--container-max: 1120px;--gutter: clamp(1.5rem, 5vw, 3rem);--section-gap: clamp(5rem, 10vw, 8rem);--radius-sm: 4px;--radius-md: 8px}*,*:before,*:after{box-sizing:border-box}*{margin:0}html{-webkit-text-size-adjust:100%}body{min-height:100vh;overflow-x:hidden}img,picture,svg{display:block;max-width:100%}ul,ol{list-style:none;padding:0}a{color:inherit;text-decoration:none}button{background:none;border:none;padding:0;cursor:pointer;color:inherit}input,button,textarea,select{font:inherit}html{font-family:var(--font-body);font-size:100%;line-height:var(--leading-body)}body{background-color:var(--c-bg);color:var(--c-ink);font-weight:400;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}h1,h2,h3{font-family:var(--font-display);font-weight:400;line-height:var(--leading-tight);letter-spacing:var(--tracking-tight)}h4,h5,h6{font-family:var(--font-body);font-weight:500;line-height:var(--leading-tight)}p{max-width:70ch}::selection{background:var(--c-accent);color:var(--c-bg)}html{scroll-behavior:smooth}@media (prefers-reduced-motion: reduce){html{scroll-behavior:auto}}.container{width:100%;max-width:var(--container-max);margin-inline:auto;padding-inline:var(--gutter)}.section{padding-block:var(--section-gap)}.grid-2,.grid-3{display:grid;gap:clamp(2rem,5vw,4rem)}@media (min-width: 768px){.grid-2{grid-template-columns:1fr 1fr}.grid-3{grid-template-columns:repeat(3,1fr)}}.section-head{border-top:1px solid var(--c-rule);padding-top:1rem;margin-bottom:clamp(2.5rem,5vw,4rem)}.section-head__label{font-family:var(--font-mono);font-size:var(--text-xs);font-weight:400;letter-spacing:var(--tracking-wide);text-transform:uppercase;color:var(--c-mid);opacity:.65}#bg-layer{position:fixed;top:0;right:0;bottom:0;left:0;z-index:-1;pointer-events:none;overflow:hidden}#bg-layer img,#bg-layer .bg-blank{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;will-change:opacity,transform}#bg-layer img{object-fit:cover}#bg-layer .bg-blank{background:var(--c-bg)}#bg-layer:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:var(--c-bg);opacity:.5;pointer-events:none}.logo{position:fixed;top:2rem;left:2rem;z-index:100;pointer-events:auto;display:inline-flex;padding:.5rem;margin:-.5rem;color:var(--c-ink);transition:color .2s ease}.logo:hover{color:var(--c-accent)}.logo__mark{display:block;width:28px;height:28px}.dot-nav{position:fixed;right:2rem;top:50%;transform:translateY(-50%);z-index:100;pointer-events:auto}.dot-nav ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:1.5rem;align-items:flex-end}.dot-nav a{position:relative;display:flex;flex-direction:row-reverse;align-items:center;gap:.75rem;text-decoration:none}.dot{width:8px;height:8px;border-radius:50%;border:1.5px solid var(--c-mid);background:transparent;flex-shrink:0;transition:background .2s ease,border-color .2s ease,transform .2s ease}.dot-nav li.is-active .dot{background:var(--c-ink);border-color:var(--c-ink);transform:scale(1.35)}.dot-nav a:hover .dot{border-color:var(--c-ink)}.dot-label{font-family:var(--font-mono);font-size:var(--text-xs);color:var(--c-ink);letter-spacing:var(--tracking-wide);text-transform:uppercase;white-space:nowrap;opacity:0;transform:translate(6px);transition:opacity .2s ease,transform .2s ease;pointer-events:none}.dot-nav a:hover .dot-label,.dot-nav a:focus-visible .dot-label{opacity:1;transform:translate(0)}@media (max-width: 640px){.dot-nav{right:auto;top:auto;bottom:1.5rem;left:50%;transform:translate(-50%);padding:1rem}.dot-nav ul{flex-direction:row;align-items:center;gap:1.25rem}.dot-nav a{padding:.5rem;margin:-.5rem}.dot-label{display:none}.dot{width:10px;height:10px}}@media (prefers-reduced-motion: reduce){.dot,.dot-label{transition:none}}.hero{min-height:100vh;min-height:100svh;display:flex;align-items:center}.hero__inner{padding-block:4rem}.hero__eyebrow{font-family:var(--font-mono);font-size:var(--text-xs);letter-spacing:var(--tracking-wide);text-transform:uppercase;color:var(--c-mid);margin-bottom:1.5rem}.hero__name{font-size:clamp(var(--text-4xl),13vw,6rem);font-weight:600;letter-spacing:-.02em;color:var(--c-ink);margin-bottom:1.5rem}.hero__subtext{font-weight:300;font-size:var(--text-lg);color:var(--c-mid);max-width:40ch;margin-bottom:2.5rem}.link-underline{position:relative;display:inline-flex;align-items:center;gap:.5rem;font-family:var(--font-mono);font-size:var(--text-sm);text-transform:uppercase;letter-spacing:var(--tracking-wide);color:var(--c-ink);padding-bottom:2px;border-bottom:1px solid var(--c-ink);transition:color .2s ease,border-color .2s ease,gap .2s ease}.link-underline:after{content:"";position:absolute;left:0;right:0;top:50%;transform:translateY(-50%);height:max(100%,44px)}.link-underline:hover{color:var(--c-accent);border-color:var(--c-accent);gap:.85rem}.about-grid{display:grid;gap:clamp(2rem,5vw,4rem)}@media (min-width: 768px){.about-grid{grid-template-columns:5fr 3fr}}.about__body p{color:var(--c-ink);max-width:60ch;margin-bottom:1.25rem}.about__body p:last-child{margin-bottom:0}.facts{font-family:var(--font-mono);font-size:var(--text-sm)}.facts__item{display:grid;gap:.2rem;padding-block:.9rem;border-top:1px solid var(--c-rule)}.facts__item:last-child{border-bottom:1px solid var(--c-rule)}.facts__term{font-size:var(--text-xs);text-transform:uppercase;letter-spacing:var(--tracking-wide);color:var(--c-mid)}.facts__desc{color:var(--c-ink)}.exp{border-top:1px solid var(--c-rule)}.exp__item{display:grid;gap:.75rem 2rem;padding-block:clamp(1.75rem,4vw,2.5rem);border-bottom:1px solid var(--c-rule)}@media (min-width: 768px){.exp__item{grid-template-columns:1fr 2fr}}.exp__meta{font-family:var(--font-mono);font-size:var(--text-sm)}.exp__period{color:var(--c-ink)}.exp__company{color:var(--c-mid);margin-top:.2rem}.exp__location{color:var(--c-mid);font-size:var(--text-xs);margin-top:.2rem}.exp__role{font-size:var(--text-3xl);font-weight:600;color:var(--c-ink);margin-bottom:1rem}.exp__bullets li{position:relative;padding-left:1.4rem;margin-bottom:.7rem;color:var(--c-mid);font-size:var(--text-base)}.exp__bullets li:last-child{margin-bottom:0}.exp__bullets li:before{content:"—";position:absolute;left:0;color:var(--c-accent)}.work{border-top:1px solid var(--c-rule)}.work__link{display:grid;grid-template-columns:2.5rem 1fr auto;align-items:start;gap:.5rem 1.25rem;padding-block:clamp(1.75rem,4vw,2.5rem);border-bottom:1px solid var(--c-rule)}.work__num{font-family:var(--font-mono);font-size:var(--text-sm);color:var(--c-mid);padding-top:.4rem}.work__body{display:grid;gap:.55rem}.work__title{font-family:var(--font-display);font-size:var(--text-3xl);font-weight:600;color:var(--c-ink);letter-spacing:var(--tracking-tight);transition:color .2s ease}.work__period{font-family:var(--font-mono);font-size:var(--text-xs);color:var(--c-mid)}.work__desc{color:var(--c-mid);font-size:var(--text-base);max-width:60ch}.work__tags{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.35rem}.work__arrow{font-size:var(--text-xl);color:var(--c-ink);padding-top:.3rem;transition:transform .2s ease,color .2s ease}.work__link:hover .work__title{color:var(--c-accent)}.work__link:hover .work__arrow{transform:translate(3px,-3px);color:var(--c-accent)}.tag{font-family:var(--font-mono);font-size:var(--text-xs);color:var(--c-mid);border:1px solid var(--c-rule);border-radius:var(--radius-sm);padding:.2em .6em}.skills-dl__row{display:grid;gap:.5rem 2rem;padding-block:1.5rem;border-top:1px solid var(--c-rule)}.skills-dl__row:last-child{border-bottom:1px solid var(--c-rule)}@media (min-width: 768px){.skills-dl__row{grid-template-columns:1fr 3fr}}.skills-dl__term{font-family:var(--font-mono);font-size:var(--text-xs);text-transform:uppercase;letter-spacing:var(--tracking-wide);color:var(--c-mid)}.skills-dl__desc{color:var(--c-ink);font-size:var(--text-base)}.contact__lead{font-weight:300;font-size:var(--text-lg);color:var(--c-mid);max-width:40ch;margin-bottom:2rem}.contact__email{display:inline-block;font-family:var(--font-display);font-size:clamp(var(--text-3xl),7vw,var(--text-5xl));font-weight:600;color:var(--c-ink);letter-spacing:var(--tracking-tight);word-break:break-word;border-bottom:2px solid transparent;transition:color .2s ease,border-color .2s ease}.contact__email:hover{color:var(--c-accent);border-color:var(--c-accent)}.contact__socials{display:flex;flex-wrap:wrap;gap:1.5rem;margin-top:2.5rem}.contact__social{position:relative;font-family:var(--font-mono);font-size:var(--text-sm);text-transform:uppercase;letter-spacing:var(--tracking-wide);color:var(--c-mid);padding-bottom:2px;border-bottom:1px solid var(--c-rule);transition:color .2s ease,border-color .2s ease}.contact__social:after{content:"";position:absolute;left:0;right:0;top:50%;transform:translateY(-50%);height:max(100%,44px)}.contact__social:hover{color:var(--c-accent);border-color:var(--c-accent)}.contact__note{margin-top:2.5rem;font-family:var(--font-mono);font-size:var(--text-xs);letter-spacing:var(--tracking-wide);color:var(--c-mid)}.footer{border-top:1px solid var(--c-rule);padding-block:2rem}.footer__text{font-family:var(--font-mono);font-size:var(--text-xs);letter-spacing:var(--tracking-wide);color:var(--c-mid)}.reveal{opacity:0;transform:translateY(20px);transition:opacity .5s ease,transform .5s ease}.reveal.is-visible{opacity:1;transform:none}@media (prefers-reduced-motion: reduce){html{scroll-behavior:auto}.reveal{opacity:1;transform:none;transition:none}}.sr-only,.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.text-mono{font-family:var(--font-mono)}.text-accent{color:var(--c-accent)}:focus-visible{outline:2px solid var(--c-accent);outline-offset:3px}
