:root{--page: #f7f8f5;--canvas: #f7f8f5;--surface: #ffffff;--surface-soft: #fafafa;--ink: #08090a;--ink-2: #34383f;--muted: #66707c;--muted-2: #a6adb5;--line: #dde1e6;--line-strong: #cdd3da;--accent: #0a0a0a;--success: #1c9b69;--font-body: "Geist", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-display: "Geist Mono", "SFMono-Regular", "SF Mono", ui-monospace, monospace;--font-mono: "Geist Mono", "SFMono-Regular", "SF Mono", ui-monospace, monospace;--space-xs: .5rem;--space-sm: .75rem;--space-md: 1rem;--space-lg: 1.5rem;--space-xl: 2rem;--space-2xl: 3.5rem;--space-3xl: 5.5rem;--text-xs: .75rem;--text-sm: .875rem;--text-base: 1rem;--text-md: 1.08rem;--text-lg: 1.35rem;--text-xl: 2rem;--text-2xl: 3.1rem;--text-display: 3.85rem;--radius-sm: .35rem;--radius-md: .5rem;--radius-lg: .75rem;--content-max: 78rem;--page-pad: 2rem;--ease-out: cubic-bezier(.16, 1, .3, 1);--dur: .18s}*{box-sizing:border-box}html{background:var(--page);color:var(--ink);font-family:var(--font-body);scroll-behavior:smooth;scrollbar-gutter:stable}body{min-width:320px;margin:0;overflow-x:clip;background:var(--page);color:var(--ink);font-size:var(--text-base);line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}::selection{background:#0000001f}a{color:inherit}a,button{-webkit-tap-highlight-color:transparent}:focus{outline:none}:focus-visible{outline:2px solid rgb(0 0 0 / .25);outline-offset:3px}h1,h2,h3,p{margin:0}img{display:block;max-width:100%}.page-shell{position:relative;width:100%;min-height:100dvh;background:var(--canvas)}.navbar,.hero,.tech-marquee,.split-section,.section{position:relative}.navbar:after,.hero:after,.tech-marquee:after,.split-section:after,.section:after{content:"";position:absolute;left:50%;bottom:0;width:100vw;height:1px;background:var(--line);transform:translate(-50%);pointer-events:none}.navbar{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:var(--space-lg);width:min(var(--content-max),calc(100% - 2rem));min-height:4.75rem;margin:0 auto;padding:0 var(--page-pad);border-left:1px solid var(--line);border-right:1px solid var(--line);background:var(--surface)}.page-shell:before{content:"";position:absolute;left:0;right:0;top:0;height:1px;background:var(--line);z-index:1}.brand{display:inline-flex;align-items:center;gap:var(--space-sm);color:var(--ink);font-weight:800;text-decoration:none}.brand-mark{width:1.25rem;height:1.25rem;background:linear-gradient(45deg,transparent 32%,var(--ink) 32% 68%,transparent 68%),linear-gradient(-45deg,transparent 32%,var(--ink) 32% 68%,transparent 68%);border-radius:.3rem}.navbar nav{display:flex;align-items:center;justify-content:center;gap:var(--space-xl)}.navbar nav a,.nav-cta,.button,.project-links a{font-size:var(--text-sm);font-weight:800;text-decoration:none}.navbar nav a{position:relative;color:var(--ink-2);padding-block:.2rem}.navbar nav a:after{content:"";position:absolute;left:0;right:0;bottom:0;height:1.5px;background:var(--ink);transform:scaleX(0);transform-origin:left center;transition:transform .32s var(--ease-out)}.navbar nav a:hover{color:var(--ink)}.navbar nav a:hover:after,.navbar nav a:focus-visible:after{transform:scaleX(1)}.project-links a:hover{color:var(--muted)}.nav-cta{justify-self:end;display:inline-flex;align-items:center;justify-content:center;min-height:2.6rem;border:1px solid var(--ink);background:var(--ink);color:var(--surface);padding:0 var(--space-lg)}main{width:100%;margin:0;overflow:hidden;background:var(--canvas)}.hero{position:relative;display:grid;grid-template-columns:minmax(0,1fr);place-items:center;min-height:36rem;width:min(var(--content-max),calc(100% - 2rem));margin:0 auto;padding:7rem var(--page-pad);border-left:1px solid var(--line);border-right:1px solid var(--line);background:linear-gradient(180deg,rgb(255 255 255 / .58),transparent 38%),var(--canvas)}.hero-copy{display:grid;justify-items:center;max-width:62rem;text-align:center}.hero h1{max-width:22ch;font-family:"Sora",var(--font-display);font-size:var(--text-display);font-weight:600;letter-spacing:-.02em;line-height:1}.hero-typed{display:inline-block;overflow:hidden;white-space:nowrap;vertical-align:bottom;color:var(--ink);font-weight:700;max-width:0;border-right:.06em solid var(--ink);animation:hero-type 1.4s steps(14,end) .4s forwards,hero-blink .75s step-end 1.85s infinite}@keyframes hero-type{to{max-width:14ch}}@keyframes hero-blink{50%{border-right-color:transparent}}.hero-tagline{max-width:40rem;margin-top:var(--space-md);font-family:"Manrope",var(--font-body);font-size:clamp(.92rem,1.3vw,1.08rem);font-style:italic;font-weight:400;line-height:1.55;letter-spacing:0;color:var(--muted)}.hero-lede{max-width:38rem;margin-top:var(--space-md);color:var(--muted);font-family:"Manrope",var(--font-body);font-size:var(--text-md);line-height:1.55}.brand,.navbar nav a,.nav-cta,.eyebrow,.sheet-cell,.tool-item,.project-links a,.footer{font-family:var(--font-mono)}.brand,.navbar nav a,.nav-cta{font-family:"Manrope",var(--font-body)}.hero-actions{display:flex;flex-wrap:wrap;justify-content:center;gap:var(--space-sm);margin-top:var(--space-xl)}.button{display:inline-flex;align-items:center;justify-content:center;gap:.55rem;min-height:2.8rem;border:1px solid var(--line-strong);padding:0 var(--space-lg);font-family:"Manrope",var(--font-body);font-weight:800;transition:background-color var(--dur) var(--ease-out),border-color var(--dur) var(--ease-out)}.button:hover{border-color:var(--ink)}.btn-icon{display:inline-block;flex:0 0 auto;transition:transform var(--dur) var(--ease-out)}.button-primary:hover .btn-icon{transform:translate(2px)}.button-primary{border-color:var(--ink);background:var(--ink);color:var(--surface)}.button-secondary{background:var(--surface);color:var(--ink)}.button-secondary:hover{border-color:var(--muted-2);background:var(--surface-soft)}.tech-marquee{width:min(var(--content-max),calc(100% - 2rem));margin:0 auto;padding:var(--space-2xl) 0 0;border-left:1px solid var(--line);border-right:1px solid var(--line);background:var(--surface);overflow:hidden}.marquee-heading{padding:0 var(--page-pad) var(--space-xl)}.marquee-title{font-family:var(--font-display);font-size:var(--text-xl);font-weight:600;letter-spacing:-.01em;line-height:1.1;max-width:none;white-space:nowrap}.sheet{position:relative;overflow:hidden;border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:#fafbfc;mask-image:linear-gradient(90deg,transparent,black 5%,black 95%,transparent)}.sheet-track{display:flex;width:max-content;animation:sheet-scroll 60s linear infinite;transform:translateZ(0);will-change:transform}.sheet:hover .sheet-track,.sheet:focus-within .sheet-track{animation-play-state:paused}.sheet-cell{position:relative;display:inline-flex;align-items:center;justify-content:center;flex:0 0 auto;min-width:12rem;min-height:3.6rem;padding:0 var(--space-xl);border-right:1px solid var(--line);background:linear-gradient(var(--ink),var(--ink)) 0 0 / 0 100% no-repeat,transparent;color:var(--ink-2);font-family:var(--font-display);font-size:.95rem;font-weight:600;letter-spacing:-.005em;white-space:nowrap;overflow:hidden;transition:background-size .28s var(--ease-out),color .22s var(--ease-out)}.sheet-cell:hover{background-size:100% 100%,auto;color:var(--surface)}@keyframes sheet-scroll{0%{transform:translate(0)}to{transform:translate(-312rem)}}.projects-section{width:min(var(--content-max),calc(100% - 2rem));margin:0 auto;padding:var(--space-3xl) var(--page-pad);border-left:1px solid var(--line);border-right:1px solid var(--line);background:#f7f8f5;position:relative;contain:layout paint}.projects-section:after{content:"";position:absolute;left:50%;bottom:0;width:100vw;height:1px;background:var(--line);transform:translate(-50%);pointer-events:none}.projects-heading{margin-bottom:var(--space-2xl)}.project-mosaic{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));align-items:stretch;gap:var(--space-md);isolation:isolate}.fonts-loading .project-mosaic{visibility:hidden}.project-start{position:relative;display:flex;align-items:center;min-height:14rem;padding:var(--space-xl);color:var(--ink);font-family:var(--font-mono);font-size:var(--text-xs);font-weight:700}.project-start span{position:relative;z-index:1;display:inline-flex;align-items:center;height:1rem;background:#f7f8f5;padding-right:var(--space-sm)}.project-start i{position:relative;display:block;width:min(12rem,70%);height:1px;background:var(--ink)}.project-start i:after{content:"";position:absolute;width:.45rem;height:.45rem;border-top:1px solid var(--ink);border-right:1px solid var(--ink);transform:rotate(45deg);translate:-.45rem -.22rem}.project-tile{position:relative;display:grid;grid-template-rows:2rem 5.8rem 2rem 8.25rem auto;row-gap:0;height:100%;min-height:25rem;padding:var(--space-xl);border:1px solid var(--line);outline:1px solid transparent;outline-offset:-1px;background:#ecebe5;color:var(--ink);overflow:hidden;text-decoration:none;transition:outline-color var(--dur) var(--ease-out),border-color var(--dur) var(--ease-out)}.project-tile:hover{border-color:#08090a2e;outline-color:#08090a2e}.project-tile.tone-coral{background:#ed8f72}.project-tile.tone-sage{background:#c7d9ad}.project-tile.tone-lavender{background:#c8d0ff}.tile-index{color:#08090a9e;font-family:var(--font-mono);font-size:var(--text-xs);font-weight:400}.project-github{display:inline-block;width:1.2rem;height:1.2rem;margin-left:.5rem;color:#08090ac7;vertical-align:-.02em}.project-tile h3{align-self:end;max-width:none;margin-top:0;font-family:var(--font-display);font-size:1.5rem;font-weight:700;line-height:.98;letter-spacing:-.04em;white-space:nowrap}.project-tile strong{display:block;margin-top:var(--space-sm);color:#08090a94;font-family:var(--font-mono);font-size:.78rem;font-weight:400;line-height:1.5}.project-tile p{align-self:start;max-width:32rem;margin-top:var(--space-xl);margin-bottom:0;color:#08090ab8;font-size:var(--text-sm);line-height:1.55}.project-tile small{display:block;align-self:start;margin-top:0;color:#08090a94;font-family:var(--font-mono);font-size:.7rem;line-height:1.5}.project-tile .project-links{flex-direction:row;flex-wrap:wrap;align-items:end;margin-top:var(--space-lg)}.project-tile .project-links a{background:#ffffff6b;border-color:#08090a24}.project-tile .project-links a:hover{background:var(--ink);border-color:var(--ink);color:var(--surface)}.tile-hover-link{position:absolute;top:var(--space-xl);right:var(--space-xl);color:#08090a6b;text-decoration:none;display:inline-flex;opacity:0;visibility:hidden;transition:opacity var(--dur) var(--ease-out),color var(--dur) var(--ease-out)}.tile-hover-link svg{display:block;width:1rem;height:1rem;fill:none;stroke:currentColor;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}.project-tile:hover .tile-hover-link{opacity:1;visibility:visible}.trust-strip,.trust-strip span{display:none}.split-section,.section{width:min(var(--content-max),calc(100% - 2rem));margin:0 auto;padding:var(--space-3xl) var(--page-pad);border-left:1px solid var(--line);border-right:1px solid var(--line);background:var(--canvas)}.split-section{display:grid;grid-template-columns:minmax(0,.62fr) minmax(0,1fr);gap:var(--space-2xl);align-items:start}.section-copy{position:sticky;top:var(--space-lg)}.eyebrow{display:inline-flex;margin-bottom:var(--space-md);color:var(--muted);font-size:var(--text-xs);font-weight:800;letter-spacing:.04em;text-transform:uppercase}.section-copy h2,.section-head h2{max-width:15ch;font-family:var(--font-display);font-size:var(--text-2xl);font-weight:600;letter-spacing:0;line-height:1}.section-copy p,.section-head p{max-width:42rem;margin-top:var(--space-lg);color:var(--muted);font-size:var(--text-md)}.service-grid{display:grid;gap:var(--space-md)}.service-card,.skill-card,.project-card{border:1px solid var(--line);border-radius:var(--radius-md);background:var(--surface)}.service-card{position:relative;display:grid;grid-template-columns:3rem minmax(0,1fr) minmax(12rem,.5fr);gap:var(--space-lg);align-items:start;min-height:auto;padding:var(--space-xl) var(--space-lg);overflow:hidden;transition:border-color var(--dur) var(--ease-out),box-shadow var(--dur) var(--ease-out)}.service-card:after{content:"";position:absolute;left:0;right:0;bottom:0;height:2px;background:var(--ink);transform:scaleX(0);transform-origin:0 50%;transition:transform .36s var(--ease-out)}.service-card:hover:after{transform:scaleX(1)}.service-index{display:grid;place-items:center;width:2.4rem;height:2.4rem;border:1px solid var(--line);border-radius:.55rem;background:var(--surface-soft);color:var(--ink);font-family:var(--font-display);font-size:.85rem;font-weight:700;letter-spacing:0}.service-card:hover,.skill-card:hover,.project-card:hover{border-color:var(--line-strong);box-shadow:0 18px 40px #1b24300f}.service-card:hover .service-index{background:var(--ink);color:var(--surface);border-color:var(--ink)}.service-card h3,.skill-card h3,.project-card h3{font-size:var(--text-lg);font-weight:800;letter-spacing:0;line-height:1.15}.service-card p{margin-top:var(--space-md);color:var(--muted)}.service-card small{display:inline-flex;align-self:start;justify-self:end;color:var(--ink-2);font-size:var(--text-xs);font-weight:900;text-align:right}.section-head{display:flex;justify-content:space-between;gap:var(--space-xl);align-items:end;margin-bottom:var(--space-xl)}.section-head p{margin-top:0}.tool-matrix{display:grid;grid-template-columns:repeat(9,minmax(0,1fr));padding:0;margin:var(--space-lg) 0 0;list-style:none;border-top:1px solid var(--line);border-left:1px solid var(--line)}.tool-cell{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-md);padding:var(--space-lg) var(--space-sm);min-height:7.5rem;border-right:1px solid var(--line);border-bottom:1px solid var(--line);background:#fff6;cursor:default;transition:background-color var(--dur) var(--ease-out)}.tool-cell:hover{background:var(--surface)}@media(min-width:64.01rem){.tool-matrix{border-left:0}.tool-cell:nth-child(9n+1){border-left:1px solid var(--line)}.tool-cell:nth-child(19){grid-column-start:2}}.tool-cell-logo{display:grid;place-items:center;width:2.75rem;height:2.75rem}.tool-cell-logo img{width:2.5rem;height:2.5rem;object-fit:contain;display:block;transition:transform var(--dur) var(--ease-out)}.tool-cell:hover .tool-cell-logo img{transform:scale(1.08)}.tool-cell-logo>span{display:grid;place-items:center;width:100%;height:100%;color:var(--ink-2);font-family:var(--font-display);font-size:.9rem;font-weight:800;letter-spacing:-.02em}.tool-cell.cell-express .tool-cell-logo{width:3.75rem;height:2.5rem}.tool-cell.cell-express .tool-cell-logo img{width:100%;height:100%;object-fit:contain}.tool-cell-name{font-family:var(--font-mono);font-size:.78rem;font-weight:500;letter-spacing:-.005em;color:var(--muted);text-align:center;line-height:1.2;transition:color var(--dur) var(--ease-out)}.tool-cell:hover .tool-cell-name{color:var(--ink)}.tone-blue{background:#3977d4}.tone-cyan{background:#1f9fbd}.tone-orange{background:#e47b34}.tone-violet{background:#7f5bd6}.tone-green{background:#2d9b67}.tone-dark{background:#242932}.tone-red{background:#d24b57}.tone-pink{background:#d34f8a}.project-list{display:grid;gap:var(--space-md)}.project-card{position:relative;display:grid;grid-template-columns:minmax(12rem,.55fr) minmax(0,1fr) minmax(12rem,.75fr) auto;gap:var(--space-lg);align-items:center;padding:var(--space-xl) var(--space-lg);overflow:hidden;transition:border-color var(--dur) var(--ease-out),box-shadow var(--dur) var(--ease-out)}.project-card:before{content:"";position:absolute;left:0;top:var(--space-lg);bottom:var(--space-lg);width:2px;border-radius:2px;background:var(--ink);transform:scaleY(.35);transform-origin:50% 0;transition:transform .36s var(--ease-out)}.project-card:hover:before{transform:scaleY(1)}.project-card>div:first-child h3{margin-top:.2rem}.project-card span{display:inline-flex;align-items:center;margin-bottom:var(--space-xs);padding:.2rem .55rem;border:1px solid var(--line);border-radius:999px;background:var(--surface-soft);color:var(--ink-2);font-size:.65rem;font-weight:800;letter-spacing:.05em;text-transform:uppercase}.project-card p{color:var(--muted)}.stack-line{position:relative;font-family:var(--font-display);font-size:var(--text-sm);font-weight:600;color:var(--ink-2);letter-spacing:-.005em;padding-left:.85rem}.stack-line:before{content:"";position:absolute;left:0;top:.45rem;width:.35rem;height:.35rem;border-radius:999px;background:var(--ink)}.project-links{display:flex;flex-direction:column;gap:var(--space-xs);white-space:nowrap}.project-links a{display:inline-flex;align-items:center;gap:.4rem;padding:.4rem .7rem;border:1px solid var(--line);border-radius:.45rem;background:var(--surface);color:var(--ink);transition:background-color var(--dur) var(--ease-out),border-color var(--dur) var(--ease-out)}.project-links a:hover{background:var(--ink);border-color:var(--ink);color:var(--surface)}.project-links a:after{content:"→";font-weight:700}.footer{display:flex;flex-wrap:wrap;justify-content:space-between;gap:var(--space-sm);width:min(var(--content-max),calc(100% - 2rem));margin:0 auto;padding:var(--space-lg) var(--page-pad);border-left:1px solid var(--line);border-right:1px solid var(--line);color:var(--muted);font-family:"Manrope",var(--font-body);font-size:.8rem;font-weight:500;letter-spacing:0}@media(max-width:68rem){:root{--page-pad: 1.5rem;--text-display: 3.05rem;--text-2xl: 2.35rem}.page-shell{width:100%;margin:0}.navbar{grid-template-columns:1fr auto}.navbar nav{order:3;grid-column:1 / -1;justify-content:flex-start;overflow-x:auto;padding-bottom:var(--space-md)}.hero,.split-section{grid-template-columns:1fr}.section-copy{position:static}.tool-matrix{grid-template-columns:repeat(4,minmax(0,1fr))}.project-card{grid-template-columns:1fr}.project-mosaic{grid-template-columns:repeat(2,minmax(0,1fr))}.marquee-title{white-space:normal}.project-start{min-height:10rem}.project-links{flex-direction:row;flex-wrap:wrap}}@media(max-width:42rem){:root{--page-pad: 1rem;--text-display: 2.3rem;--text-2xl: 1.85rem}.page-shell{width:100%;margin:0;border-left:0;border-right:0}.navbar{min-height:auto;padding-block:var(--space-md)}.nav-cta{padding:0 var(--space-md)}.hero{padding-top:var(--space-xl)}.trust-strip,.service-grid{grid-template-columns:1fr}.tool-matrix{grid-template-columns:repeat(3,minmax(0,1fr))}.tool-cell{padding:var(--space-md) var(--space-sm);gap:var(--space-sm);min-height:6.5rem}.tool-cell-logo{width:2.4rem;height:2.4rem}.tool-cell-logo img{width:2.2rem;height:2.2rem}.tool-cell-name{font-size:.72rem}.project-mosaic{grid-template-columns:1fr}.project-start{min-height:5rem;padding:var(--space-lg) 0}.project-tile{min-height:17rem}.project-tile h3{white-space:normal}.section-head{display:block}.section-head p{margin-top:var(--space-md)}.split-section,.section{padding-block:var(--space-2xl)}}@media(pointer:coarse){.navbar nav a,.nav-cta,.button,.project-links a{min-height:2.75rem;display:inline-flex;align-items:center}}.now-band{position:relative;width:min(var(--content-max),calc(100% - 2rem));margin:0 auto;padding:var(--space-2xl) var(--page-pad);border-left:1px solid var(--line);border-right:1px solid var(--line);background:var(--canvas)}.now-band:after{content:"";position:absolute;left:50%;bottom:0;width:100vw;height:1px;background:var(--line);transform:translate(-50%);pointer-events:none}.now-content{max-width:60rem}.now-statement{margin:0;font-family:var(--font-display);font-size:clamp(1.3rem,2.2vw,1.75rem);font-weight:400;line-height:1.4;letter-spacing:-.015em;color:var(--ink-2)}.now-statement strong{color:var(--ink);font-weight:600}.contact-eyebrow{display:block}.contact-layout{display:grid;grid-template-columns:minmax(0,1.3fr) auto;gap:var(--space-2xl);align-items:start}.contact-intro{display:grid;gap:var(--space-md);max-width:44rem}.contact-lede{margin:var(--space-sm) 0 0;color:var(--muted);font-size:var(--text-md);line-height:1.55}.contact-actions{display:flex;flex-direction:column;gap:var(--space-sm);align-self:start;min-width:12rem}.contact-actions .button{justify-content:center}.contact-actions .button-secondary{position:relative;overflow:hidden;isolation:isolate;transition:color .32s var(--ease-out),border-color .32s var(--ease-out)}.contact-actions .button-secondary:before{content:"";position:absolute;inset:0;background:var(--ink);transform:translate(-101%);transition:transform .42s var(--ease-out);z-index:-1}.contact-actions .button-secondary:hover,.contact-actions .button-secondary:focus-visible{color:var(--surface);border-color:var(--ink)}.contact-actions .button-secondary:hover:before,.contact-actions .button-secondary:focus-visible:before{transform:translate(0)}@media(max-width:64rem){.contact-layout{grid-template-columns:1fr;gap:var(--space-xl)}.contact-actions{flex-direction:row;flex-wrap:wrap;min-width:0}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{scroll-behavior:auto!important;transition-duration:1ms!important}.hero-typed{max-width:none;animation:none;border-right-color:transparent}}
