*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}:root{--cream: #f2ede6;--ink: #0e0d0b;--mid: #6b6560;--lime: #c8ff00;--red: #e8320a;--paper: #e8e2d9}html{scroll-behavior:smooth}#root{isolation:isolate}body{background:var(--cream);color:var(--ink);font-family:DM Mono,monospace;font-weight:300;overflow-x:hidden}body:before{content:"";position:fixed;inset:0;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' 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)' opacity='0.035'/%3E%3C/svg%3E");pointer-events:none;z-index:1000}.section{padding:5.5rem 2.5rem;border-bottom:1px solid var(--ink)}.s-label{font-size:.58rem;letter-spacing:.2em;text-transform:uppercase;color:var(--mid);margin-bottom:.3rem}.s-title{font-family:Bebas Neue;font-size:clamp(3rem,7vw,6rem);line-height:.9;margin-bottom:4rem}@keyframes fadeup{0%{opacity:0;transform:translateY(28px)}to{opacity:1;transform:none}}@keyframes pulse{0%,to{opacity:.35}50%{opacity:1}}@keyframes ctaFloat{0%,to{transform:translateY(0)}50%{transform:translateY(-2px)}}@keyframes marquee{0%{transform:translate(0)}to{transform:translate(-50%)}}@keyframes marqueeGlow{0%,to{opacity:.78}50%{opacity:1}}@media(max-width:768px){.hero-top{grid-template-columns:1fr}.hero-right{padding-bottom:0}.hero-stats{gap:2rem}.nav-right{display:none}.proj-item{grid-template-columns:45px 1fr}.proj-link{display:none}.stack-cols,.proc-grid,.contact-lay{grid-template-columns:1fr;gap:2.5rem}.proc-item{border-right:none;border-bottom:1px solid rgba(14,13,11,.1);padding:2rem 0}}nav{position:fixed;top:0;left:0;right:0;z-index:3000;display:flex;justify-content:space-between;align-items:center;padding:.95rem 2.5rem;background:#f2ede6f0;border-bottom:1px solid rgba(14,13,11,.1);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.nav-mark{font-family:Bebas Neue;font-size:1rem;letter-spacing:.15em;color:var(--ink);text-decoration:none}.nav-right{display:flex;gap:2.5rem;list-style:none}.nav-right a{font-size:.62rem;letter-spacing:.12em;text-transform:uppercase;color:var(--mid);text-decoration:none;transition:color .2s}.nav-right a:hover{color:var(--ink)}@media(max-width:768px){nav{padding-left:1.25rem;padding-right:1.25rem}.nav-right{display:none}}.hero{min-height:100vh;padding:3.6rem 2.5rem 3rem;display:flex;flex-direction:column;justify-content:center;gap:3.5rem;border-bottom:1px solid var(--ink)}.hero-top{display:grid;grid-template-columns:1.1fr .9fr;gap:3rem;align-items:end}.hero-name{font-family:Bebas Neue;font-size:clamp(5.5rem,13vw,12rem);line-height:.87;letter-spacing:-.01em;animation:fadeup .8s ease both}.stroke{-webkit-text-stroke:2px var(--ink);color:transparent}.hero-right{display:flex;flex-direction:column;justify-content:flex-end;gap:1.8rem;padding-bottom:.4rem;animation:fadeup .8s .15s ease both}.hero-role{font-family:"DM Serif Display";font-style:italic;font-size:clamp(1.1rem,2.2vw,1.7rem);color:var(--mid);line-height:1.35}.hero-desc{font-size:.76rem;line-height:1.85;color:var(--mid);max-width:360px}.hero-cta{display:inline-flex;align-items:center;gap:.75rem;background:#d8d0c5;color:var(--ink);font-family:DM Mono;font-size:.68rem;letter-spacing:.12em;text-transform:uppercase;padding:.95rem 1.8rem;text-decoration:none;width:fit-content;transition:background .2s ease,color .2s ease,transform .2s ease,box-shadow .2s ease;animation:ctaFloat 3.2s ease-in-out infinite}.hero-cta:hover{background:#cec5b8;color:var(--ink);transform:translateY(-2px);box-shadow:0 10px 24px #0e0d0b14}.hero-bottom{display:flex;justify-content:space-between;align-items:flex-end;padding-top:2rem;border-top:1px solid rgba(14,13,11,.12);animation:fadeup .8s .28s ease both}.hero-stats{display:flex;gap:4rem}.stat{display:flex;flex-direction:column;gap:.25rem}.stat-n{font-family:Bebas Neue;font-size:2.6rem;line-height:1}.stat-l{font-size:.58rem;letter-spacing:.12em;text-transform:uppercase;color:var(--mid)}.hero-scroll{font-size:.58rem;letter-spacing:.15em;text-transform:uppercase;color:var(--mid);writing-mode:vertical-rl;animation:pulse 2.5s ease-in-out infinite}@media(max-width:768px){.hero-top{grid-template-columns:1fr}.hero-right{padding-bottom:0}.hero-stats{gap:2rem}}.marquee-wrap{background:#dcd4c9;padding:.9rem 0;overflow:hidden;border-bottom:1px solid rgba(14,13,11,.12)}.marquee-track{display:flex;width:max-content;animation:marquee 20s linear infinite}.marquee-wrap:hover .marquee-track{animation-duration:16s}.marquee-item{font-family:Bebas Neue;font-size:1.05rem;letter-spacing:.18em;color:var(--ink);padding:0 1.5rem;white-space:nowrap;animation:marqueeGlow 2.8s ease-in-out infinite}.marquee-sep{color:#0e0d0b59;padding:0 .3rem;font-family:Bebas Neue;font-size:1.05rem}.proj-list{display:flex;flex-direction:column}.proj-item{display:grid;grid-template-columns:70px 1fr auto;gap:2rem;align-items:start;padding:2.5rem 0;border-top:1px solid rgba(14,13,11,.1);text-decoration:none;color:var(--ink);transition:background .18s,transform .18s}.proj-item:hover{background:linear-gradient(90deg,#ffffffc7,#e8e2d9eb);margin:0 -2.5rem;padding-left:2.5rem;padding-right:2.5rem}.proj-num{font-family:Bebas Neue;font-size:1.15rem;color:var(--mid);padding-top:.15rem}.proj-body{display:flex;flex-direction:column;gap:.7rem}.proj-name{font-family:"DM Serif Display";font-size:clamp(1.35rem,2.4vw,1.9rem);line-height:1.1}.proj-impact{font-size:.68rem;letter-spacing:.05em;color:var(--red);font-weight:500}.proj-desc{font-size:.76rem;line-height:1.78;color:var(--mid);max-width:550px}.proj-tags{display:flex;flex-wrap:wrap;gap:.35rem;margin-top:.2rem}.proj-tag{font-size:.56rem;letter-spacing:.1em;text-transform:uppercase;border:1px solid rgba(14,13,11,.18);padding:.18rem .5rem;color:var(--mid)}.proj-link{font-size:.58rem;letter-spacing:.12em;text-transform:uppercase;color:var(--ink);border:1px solid rgba(14,13,11,.3);padding:.5rem .85rem;text-decoration:none;white-space:nowrap;height:fit-content;margin-top:.15rem;transition:background .15s,color .15s,border-color .15s;background:#ffffffad}.proj-link:hover{background:var(--ink);color:var(--cream);border-color:var(--ink)}@media(max-width:768px){.proj-item{grid-template-columns:45px 1fr}.proj-link{display:none}}.stack-cols{display:grid;grid-template-columns:1fr 1fr;gap:5rem}.stack-col h3{font-family:"DM Serif Display";font-style:italic;font-size:1rem;color:var(--mid);margin-bottom:1.5rem}.stack-row{display:flex;justify-content:space-between;align-items:center;gap:1rem;min-height:4.4rem;padding:.9rem 0;border-bottom:1px solid rgba(14,13,11,.08);font-size:.73rem}.stack-row:first-of-type{border-top:1px solid rgba(14,13,11,.08)}.stack-copy{position:relative;display:grid;align-items:center;min-height:2.6rem}.stack-name,.stack-description{grid-area:1 / 1;transition:opacity .22s ease,transform .22s ease}.stack-name{opacity:1;transform:translateY(0)}.stack-description{opacity:0;transform:translateY(6px);color:var(--mid);line-height:1.7;max-width:28rem}.stack-row:hover .stack-name{opacity:0;transform:translateY(-6px)}.stack-row:hover .stack-description{opacity:1;transform:translateY(0)}.dot{width:8px;height:8px;border-radius:50%;background:var(--lime);box-shadow:0 0 7px #c8ff00cc;border:1px solid rgba(14,13,11,.12);flex-shrink:0}@media(max-width:768px){.stack-cols{grid-template-columns:1fr;gap:2.5rem}.stack-description{position:static;opacity:1;transform:none;margin-top:.25rem;font-size:.67rem}.stack-row{align-items:flex-start}.stack-copy{display:block}.stack-row:hover .stack-name,.stack-row:hover .stack-description{opacity:1;transform:none}}.proc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:0}.proc-item{padding:2.5rem;border-right:1px solid rgba(14,13,11,.1)}.proc-item:last-child{border-right:none}.proc-n{font-family:Bebas Neue;font-size:4rem;line-height:1;color:#0e0d0b12;margin-bottom:1rem}.proc-title{font-family:"DM Serif Display";font-size:1.05rem;margin-bottom:.7rem}.proc-desc{font-size:.71rem;line-height:1.78;color:var(--mid)}@media(max-width:768px){.proc-grid{grid-template-columns:1fr;gap:2.5rem}.proc-item{border-right:none;border-bottom:1px solid rgba(14,13,11,.1);padding:2rem 0}}.contact-lay{display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:center}.contact-big{font-family:Bebas Neue;font-size:clamp(3.5rem,8vw,7rem);line-height:.9}.contact-big em{font-family:"DM Serif Display";font-style:italic;color:var(--mid)}.c-links{display:flex;flex-direction:column;gap:.85rem}.c-link{display:flex;justify-content:space-between;align-items:center;padding:1.2rem 1.4rem;border:1px solid rgba(14,13,11,.15);text-decoration:none;color:var(--ink);transition:background .15s,border-color .15s,color .15s}.c-link:hover{background:var(--ink);color:var(--cream);border-color:var(--ink)}.c-link:hover .cl-type{color:#f2ede666}.c-link:hover .cl-arrow{color:var(--lime)}.cl-type{font-size:.56rem;letter-spacing:.15em;text-transform:uppercase;color:var(--mid);display:block;margin-bottom:.2rem}.cl-val{font-size:.82rem}.cl-arrow{font-size:1rem;flex-shrink:0}footer{padding:1.8rem 2.5rem;display:flex;justify-content:space-between;align-items:center}footer span{font-size:.62rem;letter-spacing:.1em;color:var(--mid)}.f-mark{font-family:Bebas Neue;font-size:.95rem;letter-spacing:.15em}@media(max-width:768px){.contact-lay{grid-template-columns:1fr;gap:2.5rem}}.project-page{min-height:100vh}.project-hero{padding:5.5rem 2.5rem 2.8rem;border-bottom:1px solid var(--ink);background:var(--cream)}.project-hero.accent-lime{background:radial-gradient(circle at top right,rgba(200,255,0,.28),transparent 28rem),var(--cream)}.project-hero-top{max-width:56rem}.project-id{display:inline-block;margin-bottom:.7rem;font-family:Bebas Neue;font-size:1.2rem;letter-spacing:.14em;color:var(--mid)}.project-title{font-family:Bebas Neue;font-size:clamp(3.6rem,9vw,7rem);line-height:.92;margin-bottom:1rem}.project-impact{font-family:"DM Serif Display";font-size:clamp(1.1rem,2vw,1.7rem);line-height:1.35;max-width:36rem;margin-bottom:1rem}.project-summary,.project-copy{font-size:.78rem;line-height:1.9;color:var(--mid);max-width:46rem}.project-actions{display:flex;flex-wrap:wrap;gap:.8rem;align-items:center;margin-top:1.4rem}.project-github{display:inline-flex;align-items:center;justify-content:center;min-height:2.8rem;padding:0 1.2rem;border:1px solid rgba(14,13,11,.18);color:var(--ink);text-decoration:none;text-transform:uppercase;letter-spacing:.12em;font-size:.62rem;background:#ffffff80}.project-github{background:#d8d0c5;color:var(--ink);transition:transform .2s ease,background .2s ease,border-color .2s ease}.project-github:hover{transform:translateY(-2px);background:#cec5b8;border-color:#0e0d0b47}.project-private{background:#ffffff80;color:var(--ink);border-color:#0e0d0b2e;cursor:default;pointer-events:none}.project-section{padding-top:3rem}.project-content{display:grid;gap:1.2rem;max-width:46rem}.project-tags{display:flex;flex-wrap:wrap;gap:.55rem;max-width:52rem}.project-highlights{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.7rem;max-width:52rem}.project-highlight{padding:.9rem 1rem;border:1px solid rgba(14,13,11,.1);background:#ffffff57;font-size:.72rem;line-height:1.7}.project-tag{border:1px solid rgba(14,13,11,.14);padding:.45rem .7rem;font-size:.6rem;letter-spacing:.12em;text-transform:uppercase;background:#ffffff73}.project-stack-label{margin-top:2rem}.project-footer-nav{margin-top:2.5rem;padding-top:1.4rem;border-top:1px solid rgba(14,13,11,.08);display:flex;justify-content:flex-end}.project-next{display:grid;gap:.5rem}.project-next-label{color:var(--mid);font-size:.58rem;letter-spacing:.15em;text-transform:uppercase}.project-next-links{display:flex;flex-wrap:wrap;gap:.55rem}.project-next-link{color:var(--ink);text-decoration:none;border-bottom:1px solid rgba(14,13,11,.2);padding-bottom:.15rem;font-size:.72rem}.project-missing{min-height:calc(100vh - 6rem);display:flex;flex-direction:column;justify-content:center;gap:1rem}@media(max-width:768px){.project-hero{padding-top:5rem}.project-highlights{grid-template-columns:1fr}}
