:root{--color-bg: #0d0d0f;--color-bg-elevated: #141418;--color-bg-card: #1a1a1f;--color-border: rgba(232, 230, 227, .12);--color-border-strong: rgba(232, 230, 227, .22);--color-text: #e8e6e3;--color-text-muted: #9a9690;--color-text-faint: #6b6762;--color-accent: #7c6fe8;--color-accent-bright: #5eead4;--color-accent-muted: rgba(124, 111, 232, .35);--font-display: "Instrument Serif", Georgia, serif;--font-body: "DM Sans", system-ui, sans-serif;--font-mono: "JetBrains Mono", ui-monospace, monospace;--text-hero: clamp(2.75rem, 8vw, 5.5rem);--text-section: clamp(1.75rem, 4vw, 2.75rem);--text-body: 1.0625rem;--text-small: .875rem;--text-eyebrow: .75rem;--leading-tight: 1.1;--leading-body: 1.65;--space-xs: .25rem;--space-sm: .5rem;--space-md: 1rem;--space-lg: 1.5rem;--space-xl: 2.5rem;--space-2xl: 4rem;--space-3xl: 6rem;--space-section: clamp(4rem, 12vw, 7rem);--max-width: 72rem;--max-width-narrow: 38rem;--nav-height: 4rem;--radius-sm: 4px;--radius-md: 8px;--ease-out: cubic-bezier(.22, 1, .36, 1);--duration-fast: .15s;--duration-normal: .3s;--z-grain: 1;--z-content: 2;--z-nav: 100}*,*:before,*:after{box-sizing:border-box}html{scroll-behavior:smooth}@media (prefers-reduced-motion: reduce){html{scroll-behavior:auto}}body{margin:0;min-height:100vh;font-family:var(--font-body);font-size:var(--text-body);line-height:var(--leading-body);color:var(--color-text);background-color:var(--color-bg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{position:relative;z-index:var(--z-content);min-height:100vh}body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;z-index:var(--z-grain);pointer-events:none;opacity:.04;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");background-repeat:repeat;background-size:128px 128px}@media (prefers-reduced-motion: no-preference){body:before{animation:grain-shift 8s steps(10) infinite}}@keyframes grain-shift{0%,to{transform:translate(0)}10%{transform:translate(-2%,-2%)}30%{transform:translate(1%,-1%)}50%{transform:translate(-1%,2%)}70%{transform:translate(2%,1%)}90%{transform:translate(-2%,1%)}}::selection{background:var(--color-accent-muted);color:var(--color-text)}a{color:var(--color-accent-bright);text-decoration-thickness:1px;text-underline-offset:3px;transition:color var(--duration-fast) var(--ease-out)}a:hover{color:var(--color-text)}a:focus-visible,button:focus-visible,input:focus-visible{outline:2px solid var(--color-accent);outline-offset:3px}h1,h2,h3,h4{font-family:var(--font-display);font-weight:400;line-height:var(--leading-tight);margin:0}p{margin:0 0 var(--space-md)}p:last-child{margin-bottom:0}code{font-family:var(--font-mono);font-size:.9em;color:var(--color-accent-bright)}img{max-width:100%;height:auto}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.page-internal{max-width:var(--max-width-narrow);margin:0 auto;padding:var(--space-2xl) var(--space-lg)}.page-internal__title{font-family:var(--font-display);font-size:var(--text-section);margin-bottom:var(--space-sm)}.page-internal__subtitle{color:var(--color-text-muted);font-size:var(--text-small);margin-bottom:var(--space-xl)}.page-internal__panel{border:1px solid var(--color-border);background:var(--color-bg-elevated);border-radius:var(--radius-md);padding:var(--space-lg)}.page-internal input,.page-internal textarea,.page-internal button[type=submit],.page-internal__panel textarea{font-family:var(--font-body);font-size:var(--text-body);color:var(--color-text);background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-sm);padding:var(--space-sm) var(--space-md)}.page-internal button[type=submit]:not(:disabled){cursor:pointer;background:var(--color-accent);border-color:transparent;color:var(--color-bg)}.page-internal button[type=submit]:disabled{opacity:.5;cursor:not-allowed}.error-banner{margin-top:var(--space-md);padding:var(--space-md);border-radius:var(--radius-sm);background:#dc50501f;border:1px solid rgba(220,80,80,.3);color:#f0a0a0;font-size:var(--text-small)}.text-button{padding:0;border:none;background:none;color:var(--color-accent-bright);cursor:pointer;font:inherit;text-decoration:underline;text-underline-offset:3px}.text-button:hover{color:var(--color-text)}@media (prefers-reduced-motion: no-preference){.reveal{animation:reveal-up .7s var(--ease-out) both}.reveal-delay-1{animation-delay:.1s}.reveal-delay-2{animation-delay:.2s}.reveal-delay-3{animation-delay:.3s}}@keyframes reveal-up{0%{opacity:0;transform:translateY(1.25rem)}to{opacity:1;transform:translateY(0)}}@media (prefers-reduced-motion: reduce){.reveal,.reveal-delay-1,.reveal-delay-2,.reveal-delay-3{animation:none}}.site-shell{display:flex;flex-direction:column;min-height:100vh}.site-nav{position:sticky;top:0;z-index:var(--z-nav);height:var(--nav-height);display:flex;align-items:center;justify-content:space-between;gap:var(--space-md);padding:0 clamp(var(--space-md),4vw,var(--space-xl));background:#0d0d0fd9;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid var(--color-border)}.site-nav__brand{display:flex;align-items:center;gap:var(--space-sm);font-family:var(--font-mono);font-size:var(--text-small);color:var(--color-text);text-decoration:none;letter-spacing:.02em}.site-nav__brand:hover{color:var(--color-accent-bright)}.site-nav__logo{width:28px;height:28px;border-radius:var(--radius-sm)}.site-nav__links{display:flex;align-items:center;gap:clamp(var(--space-sm),2vw,var(--space-lg));list-style:none;margin:0;padding:0;overflow-x:auto;scrollbar-width:none}.site-nav__links::-webkit-scrollbar{display:none}.site-nav__link{font-family:var(--font-mono);font-size:var(--text-eyebrow);text-transform:uppercase;letter-spacing:.08em;color:var(--color-text-muted);text-decoration:none;white-space:nowrap;padding:var(--space-xs) 0;position:relative}.site-nav__link:after{content:"";position:absolute;left:0;bottom:0;width:0;height:1px;background:var(--color-accent-bright);transition:width var(--duration-normal) var(--ease-out)}.site-nav__link:hover{color:var(--color-text)}.site-nav__link:hover:after{width:100%}.site-main{flex:1}.site-footer{padding:var(--space-2xl) clamp(var(--space-md),4vw,var(--space-xl));border-top:1px solid var(--color-border);display:flex;flex-wrap:wrap;align-items:baseline;justify-content:space-between;gap:var(--space-md);font-family:var(--font-mono);font-size:var(--text-eyebrow);color:var(--color-text-faint);letter-spacing:.04em}.site-footer a{color:var(--color-text-muted);text-decoration:none}.site-footer a:hover{color:var(--color-accent-bright)}.portfolio-section{scroll-margin-top:calc(var(--nav-height) + var(--space-md));padding:var(--space-section) clamp(var(--space-md),4vw,var(--space-xl));max-width:var(--max-width);margin:0 auto}.portfolio-section--narrow{max-width:calc(var(--max-width-narrow) + var(--space-xl) * 2)}.portfolio-section__eyebrow{font-family:var(--font-mono);font-size:var(--text-eyebrow);text-transform:uppercase;letter-spacing:.12em;color:var(--color-accent);margin-bottom:var(--space-md)}.portfolio-section__title{font-size:var(--text-section);margin-bottom:var(--space-lg);max-width:16ch}.portfolio-section__intro{color:var(--color-text-muted);max-width:var(--max-width-narrow);font-size:1.125rem;margin-bottom:var(--space-2xl)}.portfolio-section__rule{border:none;border-top:1px solid var(--color-border);margin:0 0 var(--space-2xl)}.hero{min-height:calc(100vh - var(--nav-height));display:flex;flex-direction:column;justify-content:flex-end;padding:var(--space-section) clamp(var(--space-md),4vw,var(--space-xl));max-width:var(--max-width);margin:0 auto}.hero__eyebrow{font-family:var(--font-mono);font-size:var(--text-eyebrow);text-transform:uppercase;letter-spacing:.14em;color:var(--color-text-muted);margin-bottom:var(--space-lg)}.hero__name{font-size:var(--text-hero);line-height:.95;letter-spacing:-.02em;margin-bottom:var(--space-lg)}.hero__name em{font-style:italic;color:var(--color-accent-bright)}.hero__role{font-family:var(--font-mono);font-size:var(--text-small);color:var(--color-text-muted);letter-spacing:.06em;margin-bottom:var(--space-xl)}.hero__tagline{font-size:clamp(1.125rem,2.5vw,1.375rem);color:var(--color-text-muted);max-width:32rem;margin-bottom:var(--space-2xl)}.hero__cta{display:inline-flex;align-items:center;gap:var(--space-sm);font-family:var(--font-mono);font-size:var(--text-small);text-transform:uppercase;letter-spacing:.1em;color:var(--color-bg);background:var(--color-text);padding:var(--space-md) var(--space-xl);border-radius:var(--radius-sm);text-decoration:none;transition:background var(--duration-fast) var(--ease-out),color var(--duration-fast) var(--ease-out)}.hero__cta:hover{background:var(--color-accent-bright);color:var(--color-bg)}.hero__cta-arrow{transition:transform var(--duration-normal) var(--ease-out)}.hero__cta:hover .hero__cta-arrow{transform:translate(4px)}.project-list{display:flex;flex-direction:column;gap:0}.project-card{display:grid;grid-template-columns:1fr;gap:var(--space-md);padding:var(--space-xl) 0;border-top:1px solid var(--color-border);text-decoration:none;color:inherit;transition:background var(--duration-fast) var(--ease-out)}@media (min-width: 640px){.project-card{grid-template-columns:6rem 1fr auto;align-items:start;gap:var(--space-xl)}}.project-card:hover{background:#ffffff05}.project-card:last-child{border-bottom:1px solid var(--color-border)}.project-card__year{font-family:var(--font-mono);font-size:var(--text-eyebrow);color:var(--color-text-faint);letter-spacing:.06em}.project-card__title{font-family:var(--font-display);font-size:clamp(1.5rem,3vw,2rem);margin-bottom:var(--space-sm);transition:color var(--duration-fast) var(--ease-out)}.project-card:hover .project-card__title{color:var(--color-accent-bright)}.project-card__blurb{color:var(--color-text-muted);font-size:var(--text-small);max-width:36rem}.project-card__tags{display:flex;flex-wrap:wrap;gap:var(--space-xs);margin-top:var(--space-md)}.project-card__meta{display:flex;flex-direction:column;align-items:flex-start;gap:var(--space-sm)}@media (min-width: 640px){.project-card__meta{align-items:flex-end;text-align:right}}.project-card__link-label{font-family:var(--font-mono);font-size:var(--text-eyebrow);text-transform:uppercase;letter-spacing:.1em;color:var(--color-accent)}.tag{display:inline-block;font-family:var(--font-mono);font-size:.6875rem;text-transform:uppercase;letter-spacing:.06em;padding:.2em .55em;border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text-muted)}.skill-grid{display:grid;grid-template-columns:1fr;gap:var(--space-xl)}@media (min-width: 640px){.skill-grid{grid-template-columns:repeat(3,1fr);gap:var(--space-2xl)}}.skill-cluster__label{font-family:var(--font-mono);font-size:var(--text-eyebrow);text-transform:uppercase;letter-spacing:.1em;color:var(--color-text-faint);margin-bottom:var(--space-md);padding-bottom:var(--space-sm);border-bottom:1px solid var(--color-border)}.skill-cluster__pills{display:flex;flex-wrap:wrap;gap:var(--space-sm)}.contact-strip{display:flex;flex-direction:column;gap:var(--space-xl)}.contact-strip__links{display:flex;flex-wrap:wrap;gap:var(--space-lg) var(--space-2xl)}.contact-strip__link{font-family:var(--font-display);font-size:clamp(1.25rem,3vw,1.75rem);color:var(--color-text);text-decoration:none;position:relative}.contact-strip__link:after{content:"";position:absolute;left:0;bottom:.1em;width:100%;height:1px;background:var(--color-accent);transform:scaleX(0);transform-origin:left;transition:transform var(--duration-normal) var(--ease-out)}.contact-strip__link:hover{color:var(--color-accent-bright)}.contact-strip__link:hover:after{transform:scaleX(1)}.contact-strip__note{color:var(--color-text-muted);font-size:var(--text-small);max-width:var(--max-width-narrow)}.prose-block{max-width:var(--max-width-narrow);font-size:1.125rem;color:var(--color-text-muted)}.prose-block p+p{margin-top:var(--space-lg)}.prose-block strong{color:var(--color-text);font-weight:500}
