@font-face{font-family:Anton;src:url(/fonts/Anton-Regular.woff2) format("woff2");font-weight:400;font-style:normal;font-display:swap}@font-face{font-family:Satoshi;src:url(/fonts/Satoshi-Variable.woff2) format("woff2");font-weight:300 900;font-style:normal;font-display:swap}@font-face{font-family:Satoshi;src:url(/fonts/Satoshi-VariableItalic.woff2) format("woff2");font-weight:300 900;font-style:italic;font-display:swap}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility}body{font-family:Satoshi,sans-serif;font-weight:400;background:#0a0a0a;color:#f0f0f0;overflow-x:hidden;cursor:none}a{color:inherit;text-decoration:none}img{max-width:100%;display:block}button{border:none;background:none;font:inherit;color:inherit;cursor:none}:root{--color-bg: #0a0a0a;--color-text: #f0f0f0;--color-text-muted: #888;--color-accent: #e0e0e0;--color-white: #fff;--font-display: "Anton", sans-serif;--font-body: "Satoshi", sans-serif;--space-xs: .5rem;--space-sm: 1rem;--space-md: 2rem;--space-lg: 4rem;--space-xl: 8rem;--space-2xl: 12rem;--ease-out: cubic-bezier(.16, 1, .3, 1)}.font-display{font-family:var(--font-display);text-transform:uppercase;line-height:1.05;letter-spacing:.08em}.font-body{font-family:var(--font-body);line-height:1.6}.section{padding:var(--space-xl) var(--space-md);min-height:100vh;display:flex;flex-direction:column;justify-content:center;position:relative}.container{max-width:1400px;margin:0 auto;width:100%;padding:0 var(--space-md)}.cursor{position:fixed;top:0;left:0;width:20px;height:20px;border:2px solid var(--color-text);border-radius:50%;pointer-events:none;z-index:9999;transform:translate(-50%,-50%);transition:width .3s var(--ease-out),height .3s var(--ease-out),border-color .3s,background .3s;mix-blend-mode:difference}.cursor.is-hover{width:60px;height:60px;background:#ffffff1a}.cursor.is-text{width:4px;height:40px;border-radius:2px;background:var(--color-text);border:none}.cursor.is-crosshair{width:40px;height:40px;border:none;background:none}.cursor.is-crosshair:before,.cursor.is-crosshair:after{content:"";position:absolute;background:red}.cursor.is-crosshair:before{width:2px;height:100%;left:50%;transform:translate(-50%)}.cursor.is-crosshair:after{width:100%;height:2px;top:50%;transform:translateY(-50%)}.cursor-dot{position:fixed;top:0;left:0;width:6px;height:6px;background:var(--color-text);border-radius:50%;pointer-events:none;z-index:10000;transform:translate(-50%,-50%)}.intro-screen{position:fixed;inset:0;background:var(--color-bg);z-index:1000;display:flex;align-items:center;justify-content:center}.intro-text{font-family:var(--font-body);font-size:clamp(1.2rem,2.5vw,2rem);font-weight:500;color:var(--color-text);white-space:nowrap}.intro-cursor{display:inline-block;width:2px;height:1.2em;background:var(--color-text);margin-left:4px;vertical-align:middle;animation:blink .8s step-end infinite}@keyframes blink{0%,to{opacity:1}50%{opacity:0}}.hero{min-height:100vh;display:flex;align-items:center;padding:var(--space-xl) var(--space-md)}.hero .container{max-width:1600px}.hero-title{font-size:clamp(2.5rem,8vw,8rem)}.hero-line{display:block;white-space:nowrap}.hero-line-inner{display:block;transform:translateY(110%)}.text-section{padding:var(--space-2xl) var(--space-md);min-height:100vh;display:flex;align-items:center}.text-section__heading{font-size:clamp(2rem,5vw,4.5rem);margin-bottom:var(--space-lg);line-height:1.1}.text-section__body{font-size:clamp(1.1rem,2vw,1.5rem);font-weight:300;line-height:1.8;color:var(--color-text-muted);max-width:800px}.text-section__body p{margin-bottom:var(--space-sm)}.horizontal-section{overflow:hidden}.horizontal-wrapper{display:flex;flex-wrap:nowrap;width:fit-content}.project-slide{width:80vw;max-width:900px;height:100vh;display:flex;flex-direction:column;justify-content:center;padding:var(--space-lg);flex-shrink:0;position:relative}.project-slide__number{font-family:var(--font-body);font-size:.875rem;font-weight:500;color:var(--color-text-muted);margin-bottom:var(--space-sm);letter-spacing:.1em}.project-slide__title{font-size:clamp(2.5rem,6vw,6rem);cursor:none;transition:opacity .3s}.project-slide__title:hover{opacity:.7}.project-slide__tag{font-family:var(--font-body);font-size:.8rem;font-weight:500;color:var(--color-accent);letter-spacing:.08em;text-transform:uppercase;margin-top:var(--space-xs)}.project-slide__desc{font-size:1rem;color:var(--color-text-muted);margin-top:var(--space-sm);max-width:420px;line-height:1.6}.project-slide__link{margin-top:var(--space-md);display:inline-flex;width:fit-content}.project-link{color:var(--color-text);text-decoration:none;border-bottom:1px solid var(--color-text-muted);transition:border-color .3s}.project-link:hover{border-color:var(--color-text)}.project-slide__divider{width:60px;height:2px;background:var(--color-text-muted);margin-top:var(--space-md);transform-origin:left}@media(max-width:768px){.project-slide{width:85vw;padding:var(--space-md)}.project-slide__title{font-size:clamp(2rem,10vw,3.5rem)}}.tech-section__intro{font-size:clamp(1rem,1.8vw,1.3rem);color:var(--color-text-muted);margin-bottom:var(--space-xl);font-weight:300}.tech-section .container{max-width:100%;padding:0}.tech-section .text-section__heading,.tech-section .tech-section__intro{padding:0 var(--space-md)}.tech-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:0;width:100%}.tech-card{border:1px solid rgba(255,255,255,.08);border-radius:0;padding:var(--space-lg) var(--space-md);display:flex;flex-direction:column;align-items:flex-start;gap:var(--space-sm);transition:border-color .4s,background .4s,transform .4s var(--ease-out);position:relative;overflow:hidden}.tech-card:before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 50% 0%,rgba(255,255,255,.04),transparent 70%);opacity:0;transition:opacity .4s}.tech-card:hover{border-color:#fff3;background:#ffffff08;transform:translateY(-4px)}.tech-card:hover:before{opacity:1}.tech-card__icon{width:48px;height:48px;margin-bottom:var(--space-xs)}.tech-card__icon svg{width:100%;height:100%}.tech-card__name{font-size:1.1rem;font-weight:700;letter-spacing:.02em}.tech-card__desc{font-size:.85rem;color:var(--color-text-muted);line-height:1.6;font-weight:300}@media(max-width:1024px){.tech-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:600px){.tech-grid{grid-template-columns:1fr}}.magnetic-btn{display:inline-flex;align-items:center;gap:var(--space-xs);padding:var(--space-sm) var(--space-md);border:1px solid var(--color-text);border-radius:100px;font-family:var(--font-body);font-size:.875rem;font-weight:500;letter-spacing:.05em;text-transform:uppercase;transition:background .3s,color .3s;position:relative}.magnetic-btn:hover{background:var(--color-text);color:var(--color-bg)}.footer{padding:var(--space-2xl) var(--space-md) var(--space-lg);text-align:center}.footer__text{font-size:clamp(1.5rem,4vw,3.5rem);line-height:1.4;margin-bottom:var(--space-xl)}.footer__bottom{display:flex;justify-content:space-between;align-items:center;font-size:.75rem;color:var(--color-text-muted);border-top:1px solid rgba(255,255,255,.1);padding-top:var(--space-md)}.jumpjet-cheat{position:fixed;top:20px;left:20px;font-family:monospace;font-size:.75rem;color:#0f0;z-index:10001;opacity:0;pointer-events:none}.jumpjet-jet{position:fixed;z-index:10000;pointer-events:none;font-size:4rem;filter:drop-shadow(0 0 20px rgba(255,200,0,.5))}.jumpjet-badge{position:fixed;bottom:20px;right:20px;font-family:monospace;font-size:.7rem;color:var(--color-text-muted);z-index:10001;opacity:0;letter-spacing:.05em}.scramble-text{display:inline-block}.fab-btn{position:fixed;bottom:30px;right:30px;width:44px;height:44px;border-radius:50%;border:1px solid rgba(255,255,255,.2);background:#ffffff0d;color:var(--color-text-muted);display:flex;align-items:center;justify-content:center;z-index:999;cursor:none;opacity:0;pointer-events:none;transition:border-color .3s,background .3s,color .3s;backdrop-filter:blur(4px)}.fab-btn:hover{border-color:#ffffff80;background:#ffffff1a;color:var(--color-text)}.fab-btn.is-visible{opacity:1;pointer-events:auto}.fab-btn--mail{bottom:30px;right:30px}.wipe-overlay{position:fixed;inset:0;background:var(--color-bg);z-index:1001;transform:translateY(100%);pointer-events:none}.gold-btn{display:inline-flex;align-items:center;gap:var(--space-xs);padding:var(--space-sm) var(--space-lg);border:none;border-radius:100px;font-family:var(--font-body);font-size:.875rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase;text-decoration:none;color:#0a0a0a;background:linear-gradient(105deg,#8b6914,#daa520,gold 40%,#fff1a8,gold 60%,#daa520,#8b6914);background-size:200% 100%;animation:gold-shine 3s ease-in-out infinite;position:relative;cursor:none;box-shadow:0 0 20px #daa52026,inset 0 1px #ffffff4d;transition:box-shadow .3s,transform .3s var(--ease-out)}.gold-btn:hover{box-shadow:0 0 30px #daa52059,inset 0 1px #fff6;transform:scale(1.02)}@keyframes gold-shine{0%{background-position:200% center}to{background-position:-200% center}}.easter-list{list-style:none;margin-top:var(--space-lg);display:flex;flex-direction:column;gap:var(--space-md)}.easter-list__item{display:flex;align-items:flex-start;gap:var(--space-md);padding:var(--space-md) 0;border-bottom:1px solid rgba(255,255,255,.08)}.easter-list__number{font-family:var(--font-body);font-size:.75rem;font-weight:500;color:var(--color-text-muted);letter-spacing:.1em;flex-shrink:0;padding-top:2px}.easter-list__hint{font-family:var(--font-body);font-size:clamp(1rem,1.5vw,1.2rem);font-weight:300;color:var(--color-text-muted);line-height:1.6}::selection{background:var(--color-text);color:var(--color-bg)}@media(max-width:768px){.cursor,.cursor-dot{display:none!important}body{cursor:auto}button{cursor:pointer}.project-slide{width:90vw;padding:var(--space-md)}.project-preview{display:none}.hero-title{font-size:clamp(1.4rem,7vw,2.8rem)}.hero-line{white-space:nowrap;padding-right:4px}.hero .container{max-width:100%;padding:0 var(--space-sm)}.hero{padding:var(--space-lg) var(--space-sm)}.hero .container{padding:0 var(--space-sm)}.intro-text{font-size:clamp(.85rem,4.5vw,1.2rem);padding:0 var(--space-sm);white-space:normal;text-align:center;line-height:1.8}.text-section__heading{font-size:clamp(1.8rem,10vw,3rem)}.footer__text{font-size:clamp(1.2rem,6vw,2rem)}.footer__bottom{flex-direction:column;gap:var(--space-sm)}}
