*{box-sizing:border-box}:root{--white:#fff;--black:#0a0a0a;--black-soft:#111;--blue:#1877f2;--blue-light:#5aa3ff;--blue-strong:#0f5bd8;--bg:#fff;--bg-soft:#fafafa;--panel:#fff;--panel-alt:#f5f7fa;--text:#0a0a0a;--text-soft:#1a1a1a;--muted:#6b7280;--muted-light:#9aa3af;--line:#00000014;--line-strong:#0000002e;--line-blue:#1877f240;--accent:#1877f2;--accent-hover:#0f5bd8;--accent-soft:#1877f214;--card-bg:#fff;--card-border:#00000014;--shadow-sm:0 2px 6px #0000000a;--shadow:0 8px 24px #0000000f;--shadow-lg:0 20px 50px #00000014;--radius-sm:4px;--radius-md:8px;--radius-lg:12px;--radius-xl:16px;--content-max:1220px;--sidebar-width:460px;--site-pad:5vw;--project-gap:28px}html{scroll-snap-type:y mandatory;scroll-behavior:smooth;font-size:14px}html,body,#root{height:100%;margin:0}html,body{margin:0;padding:0}body{background:var(--bg);color:var(--text);font-family:Inter,Arial,sans-serif;overflow-x:hidden}button,input,textarea,select{font:inherit}img{max-width:100%;display:block}a{color:inherit;text-decoration:none}.app-shell{flex-direction:column;min-height:100vh;display:flex}.site-header{z-index:1000;width:100%;padding:18px var(--site-pad);background:var(--black);border-bottom:1px solid var(--line);-webkit-backdrop-filter:none;backdrop-filter:none;position:fixed;top:0;left:0}.header-inner{width:100%;padding:0 var(--site-pad);justify-content:space-between;align-items:center;display:flex}.logo img{width:auto;height:32px}.desktop-nav{align-items:center;gap:30px;display:flex;position:relative}.desktop-nav a{color:#949494;cursor:pointer;white-space:nowrap;padding:10px 0;font-family:Verdana,Geneva,Tahoma,sans-serif;font-weight:700;text-decoration:none;transition:color .2s;position:relative}.desktop-nav a:hover,.desktop-nav a.active{color:#fff}.desktop-nav a:before,.desktop-nav a:after{content:"";border-radius:50%;transition:transform .2s;position:absolute;transform:scale(0)}.desktop-nav a:before{width:6px;height:6px;top:0;left:0}.desktop-nav a:after{width:4px;height:4px;top:5px;left:8px}.desktop-nav a:hover:before,.desktop-nav a:hover:after{transform:scale(1)}.desktop-nav a:first-child:before{background-color:#ff0}.desktop-nav a:first-child:after{background-color:red}.desktop-nav a:nth-child(2):before{background-color:#00e2ff}.desktop-nav a:nth-child(2):after{background-color:#89ff00}.desktop-nav a:nth-child(3):before{background-color:purple}.desktop-nav a:nth-child(3):after{background-color:#db7093}.desktop-nav a:nth-child(4):before{background-color:orange}.desktop-nav a:nth-child(4):after{background-color:#ff69b4}#indicator{border-radius:5px;width:30px;height:3px;transition:all .3s;position:absolute;bottom:-4px}#indicator.work{background:linear-gradient(130deg,#ff0,red);left:0}#indicator.about{background:linear-gradient(130deg,#00e2ff,#89ff00);left:90px}#indicator.thoughts{background:linear-gradient(130deg,purple,#db7093);left:200px}#indicator.contact{background:linear-gradient(130deg,orange,#ff69b4);left:320px}.home{scroll-snap-type:y mandatory;flex:1}.home-sections{flex-direction:column;display:flex}@media (width<=720px){.project-image-wrap{overflow:visible}}.page-section{scroll-snap-align:start;min-height:100vh;padding-top:100px;padding:40px var(--site-pad);justify-content:center;align-items:center;display:flex;position:relative;overflow:hidden}.bg-abstract{pointer-events:none;z-index:0;position:absolute;inset:0}.bg-abstract:before{content:"";background:var(--blue);opacity:.12;width:400px;height:400px;position:absolute;top:-120px;left:-120px;transform:rotate(45deg)}.bg-abstract:after{content:"";background:var(--blue-light);opacity:.08;width:300px;height:300px;position:absolute;bottom:-100px;right:-80px;transform:rotate(45deg)}.bg-abstract-stripes{opacity:.15;background:repeating-linear-gradient(0deg,#005eff,#006aff 4px,#0000 4px 10px);width:200px;height:120px;position:absolute;top:20%;left:10%;transform:rotate(-20deg)}.page-section:before{content:"";pointer-events:none;opacity:.08;background:linear-gradient(135deg,#1877f2 0%,#0000 40%),linear-gradient(45deg,#5aa3ff 0%,#0000 50%),linear-gradient(225deg,#0f5bd8 0%,#0000 40%);position:absolute;inset:0}.section-inner{width:90%;max-width:var(--content-max);z-index:1;position:relative}.section-header{margin-bottom:30px}.hero{z-index:2;max-width:1100px;margin:100px auto 88px;padding-top:24px;position:relative}.eyebrow{color:var(--accent-2);letter-spacing:.2em;text-transform:uppercase;opacity:.95;margin-bottom:14px;font-size:11px}.hero-title{letter-spacing:-.045em;max-width:860px;margin:0;font-size:clamp(27px,5vw,44px);line-height:.94}.typing-wrap{width:23ch;margin-left:10px;font-weight:600;display:inline-block;position:relative}.section-websites{background:#0a0a0a}.section-plugins{background:#121212}.section-products{background:#000}.cursor{display:none}.hero-sub{font-size:1.6em}.hero-copy{max-width:600px;color:var(--muted);margin-top:20px;font-size:15px;line-height:1.65}.hero-machines{pointer-events:none;width:260px;height:220px;position:absolute;top:0;right:0}.machine{position:absolute}.machine-a{width:180px;height:180px;top:18px;right:10px}.gear{border:1px solid var(--line-strong);border-radius:50%;position:absolute}.gear:before,.gear:after{content:"";border:1px dashed #1877f238;border-radius:50%;position:absolute;inset:-8px}.gear-lg{width:100px;height:100px;animation:12s linear infinite spin;top:8px;right:0}.gear-sm{width:58px;height:58px;animation:7s linear infinite spinReverse;top:70px;left:24px}.machine-b{width:120px;height:120px;bottom:0;left:0}.ring{border:1px solid #5aa3ff47;border-radius:50%;position:absolute}.ring-1{animation:4s ease-in-out infinite pulse;inset:18px}.ring-2{animation:18s linear infinite spin;inset:0}.logo:hover{opacity:1;transform:translateY(-2px)}.project-mode{width:100%;min-height:100vh;display:flex}.project-view{width:calc(100% - var(--sidebar-width));max-width:calc(100% - var(--sidebar-width));color:#111;background:#fff;margin:0;padding:0!important}.project-view-grid{pointer-events:none;background-image:linear-gradient(#1877f209 1px,#0000 1px),linear-gradient(90deg,#1877f209 1px,#0000 1px);background-size:42px 42px;position:absolute;inset:0}.project-hero{z-index:2;grid-template-columns:minmax(0,1.15fr) minmax(300px,.85fr);align-items:start;gap:34px;display:grid;position:relative}.project-hero-title{letter-spacing:-.04em;margin:0 0 16px;font-size:clamp(24px,4vw,52px);line-height:.95}.project-body{max-width:760px;color:var(--text);font-size:14px;line-height:1.8}.project-body p{color:var(--muted)}.project-hero-media{align-self:start;position:sticky;top:30px}.project-hero-image{object-fit:contain;width:100%;height:auto}.project-slides{z-index:2;gap:80px;margin-top:40px;display:grid;position:relative}.project-slide{border-radius:var(--radius-lg);border:1px solid var(--line);box-shadow:var(--shadow-sm);background:#fff;grid-template-columns:minmax(0,.95fr) minmax(280px,1.05fr);align-items:center;gap:26px;padding:18px;display:grid;overflow:hidden}.project-slide.reverse{grid-template-columns:minmax(280px,1.05fr) minmax(0,.95fr)}.project-slide.reverse .slide-copy{order:2}.project-slide.reverse .slide-media{order:1}.slide-copy h3{margin:0 0 10px;font-size:20px;line-height:1.1}.slide-copy p{color:var(--muted);margin:0;font-size:13.5px;line-height:1.7}.slide-media img{object-fit:cover;border-radius:var(--radius-md);border:1px solid #1877f224;width:100%}.preview-panel{width:var(--sidebar-width);z-index:50;box-sizing:border-box;background:linear-gradient(#05070b 0%,#0a0a0a 45%,#05070b 100%);border-left:1px solid #ffffff14;flex-direction:column;gap:24px;height:100vh;padding:34px 30px;display:flex;position:fixed;top:0;right:0;overflow:hidden auto;box-shadow:-30px 0 80px #000000a6}.preview-panel:before{content:"";pointer-events:none;opacity:.9;background:linear-gradient(135deg,#1877f21f 0%,#0000 38%),linear-gradient(45deg,#5aa3ff14 0%,#0000 45%),linear-gradient(225deg,#0f5bd814 0%,#0000 38%);position:absolute;inset:0}.preview-panel:after{content:"";pointer-events:none;background-image:linear-gradient(#1877f20b 1px,#0000 1px),linear-gradient(90deg,#1877f20b 1px,#0000 1px);background-size:42px 42px;position:absolute;inset:0;-webkit-mask-image:linear-gradient(#000000b3,#0003);mask-image:linear-gradient(#000000b3,#0003)}.preview-panel .bg-abstract{pointer-events:none;z-index:0;position:absolute;inset:0}.preview-panel .bg-abstract:before{content:"";background:var(--blue);opacity:.12;width:360px;height:360px;position:absolute;top:-110px;left:-120px;transform:rotate(45deg)}.preview-panel .bg-abstract:after{content:"";background:var(--blue-light);opacity:.08;width:240px;height:240px;position:absolute;bottom:8%;right:4%;transform:rotate(45deg)}.preview-panel .bg-abstract-stripes{pointer-events:none;z-index:0;opacity:.12;background:repeating-linear-gradient(0deg,#005eff,#006aff 4px,#0000 4px 10px);width:220px;height:110px;position:absolute;top:20%;right:8%;transform:rotate(-18deg)}.preview-panel>*{z-index:2;position:relative}.close-button{color:#b7c3d7;cursor:pointer;background:0 0;border:1px solid #ffffff24;border-radius:999px;padding:6px 10px;transition:all .2s;position:absolute;top:18px;right:18px}.close-button:hover{color:var(--blue-light);background:#1877f214;border-color:#1877f280}.panel-label{letter-spacing:.2em;color:var(--blue-light);text-transform:uppercase;margin-top:50px;margin-bottom:8px;font-size:10px}.panel-title{color:var(--white);max-width:88%;margin:0;font-size:22px;line-height:1.08}.tag{text-transform:uppercase;color:var(--blue-light);background:#1877f214;border:1px solid #1877f240;border-radius:8px;padding:6px 10px;font-size:12px;font-weight:700}.panel-section{margin-top:2px}.panel-sub{letter-spacing:.2em;color:#92a0b7;text-transform:uppercase;margin-bottom:10px;font-size:10px}.panel-text{color:#d6deeb;font-size:15px;line-height:1.65}.panel-grid{grid-template-columns:1fr 1fr;gap:8px 12px;font-size:13px;display:grid}.panel-grid div:nth-child(odd){color:#6e7b8f}.panel-grid div:nth-child(2n){color:#e1e8f7}.panel-decor{pointer-events:none;position:absolute;bottom:34px;right:30px}.panel-decor .line{background:#fff3;width:120px;height:1px}.panel-decor .circle{border:1px solid #1877f24d;border-radius:50%;width:40px;height:40px;margin-top:10px}.section-divider{background:#fff;width:100%;height:1px}.inline-link{color:var(--accent-2);transition:opacity .2s}.inline-link:hover{opacity:.85}.mono{font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace}.surface-card{border:1px solid var(--line);border:1px solid var(--line);box-shadow:none;border-radius:var(--radius-md);background:#fff}.typing{color:var(--accent);display:inline-block;position:relative}.typing:before{color:var(--blue-light);z-index:-1;animation:2.5s linear infinite alternate-reverse glitchShift;transform:translate(1px)}.typing:after{color:var(--blue-strong);z-index:-2;animation:2s linear infinite alternate-reverse glitchShift;transform:translate(-1px)}@keyframes glitchShift{0%{clip-path:inset(0);transform:translate(0)}10%{clip-path:inset(10% 0 60%);transform:translate(-2px,1px)}20%{clip-path:inset(30% 0);transform:translate(2px,-1px)}30%{clip-path:inset(60% 0 10%);transform:translate(-1px,2px)}40%{clip-path:inset(20% 0 50%);transform:translate(1px,-2px)}50%{clip-path:inset(0);transform:translate(0)}to{clip-path:inset(0);transform:translate(0)}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes spinReverse{0%{transform:rotate(360deg)}to{transform:rotate(0)}}@keyframes pulse{0%,to{opacity:.55;transform:scale(.92)}50%{opacity:1;transform:scale(1.04)}}@keyframes blink{0%,to{opacity:1}50%{opacity:0}}@media (width>=1400px){.project-ribbon{gap:80px}.hero{max-width:1160px}.hero-title{max-width:920px}.project-ribbon .project-teaser:first-child .project-image,.project-ribbon .project-teaser:nth-child(4) .project-image,.project-ribbon .project-teaser:nth-child(7) .project-image,.project-ribbon .project-teaser:nth-child(10) .project-image{min-height:100px}}@media (width<=1180px){.hero-machines{opacity:.75;transform-origin:100% 0;transform:scale(.9)}.project-ribbon{grid-template-columns:repeat(8,minmax(0,1fr));gap:80px}.project-ribbon .project-teaser:first-child{grid-area:span 3/1/auto/span 5;margin-top:0}.project-ribbon .project-teaser:nth-child(2){grid-area:span 2/6/auto/span 3;margin-top:28px}.project-ribbon .project-teaser:nth-child(3){grid-area:span 2/1/auto/span 3;margin-top:0}.project-ribbon .project-teaser:nth-child(4){grid-area:span 3/4/auto/span 5;margin-top:0}.project-ribbon .project-teaser:nth-child(5){grid-area:span 2/1/auto/span 4;margin-top:0}.project-ribbon .project-teaser:nth-child(6){grid-area:span 2/5/auto/span 4;margin-top:0}.project-ribbon .project-teaser:nth-child(7){grid-area:span 3/2/auto/span 4;margin-top:0}.project-ribbon .project-teaser:nth-child(8){grid-area:span 2/6/auto/span 3;margin-top:0}.project-ribbon .project-teaser:nth-child(9){grid-area:span 2/1/auto/span 3;margin-top:0}.project-ribbon .project-teaser:nth-child(10){grid-area:span 3/4/auto/span 5;margin-top:0}.preview-panel{width:420px}.project-view{width:calc(100% - 420px);max-width:calc(100% - 420px)}}.panel-logo{z-index:10;position:absolute;top:18px;left:50%;transform:translate(-50%)}.panel-logo img{opacity:.9;width:auto;height:28px}@media (width<=1100px){.project-mode{flex-direction:column}.panel-logo{z-index:10;position:absolute;top:18px;left:20px}.panel-logo img{opacity:.9;width:auto;height:28px}.preview-panel>*{z-index:2;position:relative}.preview-panel{border-left:none;border-bottom:1px solid var(--line);order:-1;width:100%;min-width:0;height:auto;padding:28px 22px 26px;position:relative;overflow:hidden}.panel-title{max-width:100%}.panel-decor{display:none}.project-view{width:100%;max-width:100%;padding:34px 24px 64px}.project-hero{grid-template-columns:1fr;gap:24px}.project-hero-media{position:relative;top:0}.project-slide,.project-slide.reverse{grid-template-columns:1fr}.project-slide.reverse .slide-copy,.project-slide.reverse .slide-media{order:initial}}@media (width<=720px){.page-section{padding-left:16px;padding-right:16px}.home-sections .section-inner{width:70%}.section-inner{width:100%}.project-ribbon{grid-template-columns:1fr;gap:40px;display:block;column-count:1!important}.project-teaser:nth-child(2n) .project-title-overlay{text-align:left;left:200px!important;right:-80px!important}.project-teaser:nth-child(odd) .project-title-overlay{text-align:left;left:-80px!important;right:200px!important}.project-teaser{max-width:100%;margin-bottom:32px;height:auto!important;min-height:320px!important}.project-image-wrap{aspect-ratio:4/5}.project-image{object-fit:contain}.hero{margin-bottom:54px;padding-top:12px}.eyebrow{margin-top:50px;margin-bottom:10px}.hero-title{max-width:100%;font-size:clamp(26px,5vw,32px);line-height:.98}.hero-copy{margin-top:16px;font-size:14px}.hero-machines{display:none}.project-title{font-size:clamp(17px,6vw,24px)}.project-desc{font-size:13px}.project-view{padding:26px 18px 50px}.project-hero-title{font-size:clamp(22px,8vw,34px)}.project-body{font-size:13.5px}.project-slides{gap:20px;margin-top:40px}.project-slide{gap:16px;padding:14px}.slide-copy h3{font-size:18px}.panel-grid{grid-template-columns:1fr}.panel-grid div:nth-child(odd){color:#6e7b8f;margin-top:6px}.close-button{top:14px;right:14px}}@media (width<=460px){html{font-size:13px}.home{padding-left:14px;padding-right:14px}.preview-panel{padding:22px 16px 20px}.project-view{padding-left:14px;padding-right:14px}.project-code-tag,.panel-label,.panel-sub{letter-spacing:.16em}.tag,.project-chip{font-size:10px}}.panel-cta{justify-content:center;margin-top:12px;display:flex}.code-wrp{color:#1a1a1a;background:var(--panel);border:1px solid var(--line);border-radius:var(--radius-md);width:100%;padding:18px 16px;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:clamp(14px,1.2vw,17px);line-height:1.7;overflow-x:auto}.code-l{cursor:text;opacity:0;align-items:flex-start;gap:14px;margin-left:-10px;margin-right:-10px;padding:4px 10px;transition:background .2s;animation:.25s forwards fadeIn;display:flex}.code-l:hover{background:#0000000a}.code-l:active{background:#00000014}.line-number{text-align:right;color:#9aa3af;-webkit-user-select:none;user-select:none;flex-shrink:0;width:32px;font-size:12px}.code-content{white-space:pre}@media (width<=720px){.code-content{white-space:pre-wrap;overflow-wrap:anywhere}}.methods{color:#2563eb}.scope{color:#7c3aed}.fn{color:#dc2626}.number{color:#ea580c}.string{color:#b45309}.comment{color:#6b7280;font-style:italic}.code-l::selection{color:inherit;background:#2563eb2e}.code-content::selection{color:inherit;background:#2563eb2e}@keyframes fadeIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}@media (width<=720px){.code-wrp{padding:14px 12px;font-size:13px;line-height:1.6}.line-number{width:26px;font-size:11px}.code-l{gap:10px;padding:3px 6px}}.about-section{scroll-snap-align:start;height:auto;min-height:100vh;overflow:visible}.panel-top{z-index:10;justify-content:space-between;align-items:center;display:flex;position:absolute;top:18px;left:20px;right:20px}.panel-close{color:#b7c3d7;text-transform:uppercase;letter-spacing:.14em;cursor:pointer;background:0 0;border:none;font-size:12px}.panel-close:hover{color:var(--accent)}.panel-nav{gap:10px;display:flex}.panel-nav button{color:#b7c3d7;cursor:pointer;background:0 0;border:none;font-size:18px;transition:all .2s}.panel-nav button:hover{color:var(--accent-hover)}.transition-line{transform-origin:0;flex:1;animation:.5s cubic-bezier(.8,0,.2,1) forwards lineWipe;transform:scaleX(0)}@keyframes lineWipe{to{transform:scaleX(1)}}.project-image-wrap:after{content:"";z-index:10;pointer-events:none;transform-origin:0;background:repeating-linear-gradient(90deg,#1877f2 0% 3%,#fff 3% 6%,#000 6% 10%);position:absolute;inset:0;transform:scaleX(0)}@keyframes cardWipe{0%{transform:scaleX(0)}to{transform:scaleX(1)}}body.transitioning .project-image-wrap:after{opacity:1;animation:.35s cubic-bezier(.8,0,.2,1) forwards cardWipe}.project-view:after{content:"";z-index:9998;pointer-events:none;background:repeating-linear-gradient(90deg,#1877f2 0% 3%,#fff 3% 6%,#000 6% 10%);position:fixed;inset:0;transform:translateY(-100%)}body.transitioning .project-view:after{animation:.45s cubic-bezier(.9,0,.1,1) forwards projectHorizontalWipe}@keyframes projectHorizontalWipe{to{transform:translateY(0)}}.transition-screen{z-index:99999;pointer-events:none;flex-direction:column;display:flex;position:fixed;inset:0}.transition-line{will-change:transform;flex:1;animation:.55s cubic-bezier(.9,0,.1,1) forwards panelIn;transform:translate(-100%)}.transition-line:nth-child(2n){transform:translate(100%)}.transition-line{animation-delay:calc(var(--i) * 35ms)}.transition-line:nth-child(3n){background:#1877f2}.transition-line:nth-child(3n+1){background:#fff}.transition-line:nth-child(3n+2){background:#05070b}@keyframes panelIn{to{transform:translate(0)}}.project-hero-image-only{z-index:10;position:relative}.project-hero-image{z-index:20;position:relative}body.transitioning{overflow:hidden}.project-ribbon{column-count:3;column-gap:80px}.project-teaser{cursor:pointer;perspective:900px;width:100%;max-width:420px;height:60vh;min-height:420px;margin:0;padding:0;position:relative}.project-tilt{transform-style:preserve-3d;transition:transform .25s}.project-teaser-inner{margin:0;padding:0}.project-image-wrap{aspect-ratio:16/10;width:100%;position:relative;overflow:hidden}.project-image{object-fit:contain;width:100%;height:100%;position:absolute;inset:0;transform:translateZ(-200px)}.project-title-overlay{z-index:5;pointer-events:none;position:absolute;top:50%;transform:translateY(-50%)translateZ(420px)}.project-title{text-shadow:0 30px 80px #000000e6,0 10px 30px #000c,0 2px 6px #000}.project-image{opacity:.85}.project-title{white-space:normal;color:#fff;text-shadow:0 12px 40px #000c,0 4px 12px #000;flex-direction:column;gap:2px;margin:0;font-size:clamp(18px,1.8vw,26px);font-weight:600;line-height:1;display:flex;position:relative}.project-title:before{content:attr(data-text);clip-path:inset(0 80% 0 0);position:absolute;inset:0}.project-title:after{content:attr(data-text);position:absolute;inset:0;transform:translate(22px)}.project-teaser:nth-child(odd) .project-title-overlay{text-align:right;left:-100px;right:150px}.project-teaser:nth-child(2n) .project-title-overlay{text-align:left;left:150px;right:-100px}.project-spotlight{z-index:3;pointer-events:none;opacity:0;background:radial-gradient(220px circle at var(--x,50%) var(--y,50%), #ffffff40 0%, #ffffff14 25%, #00000040 60%, #0000008c 100%);mix-blend-mode:soft-light;mix-blend-mode:overlay;transition:opacity .25s;position:absolute;inset:0;transform:translateZ(-220px)}.project-teaser:hover .project-spotlight{opacity:1}.project-teaser:hover .project-image{opacity:.9;transform:translateZ(-300px)scale(1.25)}.project-teaser:nth-child(3n){transform:scale(1.02)}.project-teaser:nth-child(5n){transform:scale(.98)}.contact-page{min-height:100vh;padding:120px var(--site-pad) 80px;color:var(--white);background:linear-gradient(#05070b 0%,#0a0a0a 45%,#05070b 100%);justify-content:center;align-items:center;display:flex;position:relative;overflow:hidden}.contact-page:before{content:"";pointer-events:none;opacity:.9;background:linear-gradient(135deg,#1877f21f 0%,#0000 38%),linear-gradient(45deg,#5aa3ff14 0%,#0000 45%),linear-gradient(225deg,#0f5bd814 0%,#0000 38%);position:absolute;inset:0}.contact-page:after{content:"";pointer-events:none;background-image:linear-gradient(#1877f20b 1px,#0000 1px),linear-gradient(90deg,#1877f20b 1px,#0000 1px);background-size:42px 42px;position:absolute;inset:0;-webkit-mask-image:linear-gradient(#000000b3,#0003);mask-image:linear-gradient(#000000b3,#0003)}.contact-bg-abstract{pointer-events:none;z-index:0;position:absolute;inset:0}.contact-bg-abstract:before{content:"";background:var(--blue);opacity:.12;width:360px;height:360px;position:absolute;top:-110px;left:-120px;transform:rotate(45deg)}.contact-bg-abstract:after{content:"";background:var(--blue-light);opacity:.08;width:240px;height:240px;position:absolute;bottom:8%;right:4%;transform:rotate(45deg)}.contact-bg-stripes{pointer-events:none;z-index:0;opacity:.12;background:repeating-linear-gradient(0deg,#005eff,#006aff 4px,#0000 4px 10px);width:220px;height:110px;position:absolute;top:20%;right:8%;transform:rotate(-18deg)}.contact-inner{z-index:2;grid-template-columns:minmax(280px,.78fr) minmax(320px,1fr);align-items:start;gap:42px;width:100%;max-width:1080px;display:grid;position:relative}.contact-side{padding:12px 0 0;position:relative}.contact-eyebrow{letter-spacing:.22em;text-transform:uppercase;color:var(--blue-light);margin-bottom:16px;font-size:10px}.contact-title{letter-spacing:-.05em;max-width:420px;margin:0;font-size:clamp(30px,4.8vw,64px);line-height:.95}.contact-copy{color:#96a3b8;max-width:400px;margin-top:22px;font-size:15px;line-height:1.7}.contact-side-meta{gap:12px;margin-top:34px;display:grid}.contact-side-meta-item{color:#dce5f4;align-items:center;gap:10px;font-size:13px;display:flex}.contact-side-meta-item span:first-child{color:#72819a;text-transform:uppercase;letter-spacing:.12em;min-width:92px;font-size:10px}.contact-shell{background:#07090ed1;border:1px solid #ffffff14;border-radius:14px;padding:28px 28px 30px;position:relative;overflow:hidden;box-shadow:0 18px 50px #0000005c,inset 0 1px #ffffff0a}.contact-shell:before{content:"";pointer-events:none;background:linear-gradient(160deg,#1877f214,#0000 30%),radial-gradient(circle at 100% 0,#5aa3ff14,#0000 36%);position:absolute;inset:0}.contact-header{z-index:2;border-bottom:1px solid #ffffff0f;justify-content:space-between;align-items:center;margin-bottom:26px;padding-bottom:16px;display:flex;position:relative}.contact-header h2{letter-spacing:.24em;text-transform:uppercase;color:#8fa2bf;margin:0;font-size:10px}.contact-header button{color:#a4b0c2;cursor:pointer;text-transform:uppercase;letter-spacing:.14em;background:0 0;border:none;padding:0;font-size:11px;transition:color .2s,transform .2s}.contact-header button:hover{color:var(--accent);transform:translate(-2px)}.contact-flow{z-index:2;min-height:360px;padding-top:8px;position:relative}.contact-progress-top{justify-content:space-between;align-items:center;gap:14px;margin-bottom:26px;display:flex}.contact-progress-label{letter-spacing:.18em;text-transform:uppercase;color:#72819a;white-space:nowrap;font-size:10px}.contact-progress{background:#ffffff14;flex:1;height:1px;position:relative;overflow:visible}.contact-progress-bar{background:linear-gradient(90deg,#1877f2 0%,#5aa3ff 100%);border-radius:999px;height:3px;transition:width .35s;position:absolute;top:-1px;left:0;box-shadow:0 0 24px #1877f259}.contact-progress-nodes{gap:8px;display:flex}.contact-progress-node{background:#ffffff26;border:1px solid #ffffff14;border-radius:50%;width:8px;height:8px;transition:all .25s}.contact-progress-node.active{background:var(--blue-light);border-color:#5aa3ffa6;box-shadow:0 0 14px #5aa3ff73}.contact-step{min-height:240px;position:relative}.contact-flow h3{letter-spacing:-.04em;max-width:520px;margin:0 0 10px;font-size:clamp(24px,3vw,38px);line-height:1.02}.contact-flow p{color:#8f9cb0;max-width:480px;margin:0 0 20px;font-size:14px;line-height:1.65}.contact-flow input,.contact-flow textarea{color:#fff;background:#ffffff05;border:1px solid #ffffff14;border-radius:10px;width:100%;margin-top:16px;padding:18px 16px;font-size:15px;transition:border-color .2s,box-shadow .25s,background .2s,transform .2s;display:block}.contact-flow input::placeholder,.contact-flow textarea::placeholder{color:#6f7c90}.contact-flow input:focus,.contact-flow textarea:focus{background:#ffffff08;border-color:#1877f28c;outline:none;transform:translateY(-1px);box-shadow:0 0 0 1px #1877f22e,0 12px 28px #1877f21f}.contact-flow textarea{resize:vertical;min-height:170px}.contact-actions,.contact-flow .row{gap:10px;margin-top:22px;display:flex}.contact-flow .row button,.contact-actions button{flex:1}.contact-flow .row button:first-child,.contact-actions .is-secondary{color:#d9e3f2;box-shadow:none;background:#ffffff08;border:1px solid #ffffff14}.contact-flow button,.contact-actions button{letter-spacing:.14em;text-transform:uppercase;text-align:center;color:#fff;cursor:pointer;background:linear-gradient(#1877f2db,#1877f238);border:1px solid #1877f280;border-radius:8px;padding:14px 18px;font-size:12px;font-weight:800;transition:all .25s;position:relative;overflow:hidden}.contact-flow button:before,.contact-actions button:before{content:"";border-radius:inherit;pointer-events:none;opacity:0;background:linear-gradient(120deg,#0000,#5aa3ff8c,#0000);transition:opacity .25s;position:absolute;inset:-1px}.contact-flow button:hover,.contact-actions button:hover{transform:translateY(-2px);box-shadow:0 10px 30px #1877f252,inset 0 1px #ffffff38}.contact-flow button:hover:before,.contact-actions button:hover:before{opacity:1}.contact-flow button:disabled,.contact-actions button:disabled{opacity:.35;cursor:not-allowed;box-shadow:none;transform:none}.contact-success,.contact-error,.contact-flow .success{border-radius:10px;margin-top:24px;padding:14px 16px;font-size:14px;line-height:1.6}.contact-success,.contact-flow .success{color:#d8ebff;background:#1877f214;border:1px solid #5aa3ff40;box-shadow:0 0 24px #1877f214}.contact-error{color:#ffd6d6;background:#ff5a5a0f;border:1px solid #ff5a5a38}.hamburger{cursor:pointer;background:0 0;border:none;width:30px;height:20px;margin:0;padding:0;display:none;position:relative}.hamburger span{background:#fff;width:100%;height:2px;transition:all .25s;position:absolute;left:0}.hamburger span:first-child{top:0}.hamburger span:nth-child(2){bottom:0}.hamburger.active span:first-child{top:9px;transform:rotate(45deg)}.hamburger.active span:nth-child(2){bottom:9px;transform:rotate(-45deg)}.mobile-menu{z-index:999;background:#0a0a0a;border-bottom:1px solid #ffffff14;border-left:1px solid #ffffff14;flex-direction:column;gap:14px;width:min(340px,100vw);padding:20px 22px 24px;display:flex;position:fixed;top:69px;right:0;box-shadow:-20px 20px 60px #00000059}.mobile-menu:before{content:"";pointer-events:none;background:linear-gradient(160deg,#1877f214,#0000 30%),radial-gradient(circle at 100% 0,#5aa3ff14,#0000 38%);position:absolute;inset:0}.mobile-menu a{z-index:2;letter-spacing:.15em;text-transform:uppercase;color:#a6b2c4;cursor:pointer;font-size:12px;transition:color .2s,transform .2s;position:relative}.mobile-menu a:hover{color:var(--accent);transform:translate(2px)}@media (width<=1100px){.contact-inner{grid-template-columns:1fr;gap:26px;max-width:680px}.contact-side{padding-top:0}.contact-copy,.contact-title{max-width:100%}}@media (width<=720px){.desktop-nav{display:none}.hamburger{margin-left:auto;display:block}.header-inner{justify-content:space-between;padding:0}.contact-page{align-items:flex-start;padding:110px 16px 50px}.contact-bg-stripes{opacity:.08;top:16%;right:-40px}.contact-shell{padding:20px 18px 22px}.contact-header{margin-bottom:20px;padding-bottom:14px}.contact-title{font-size:clamp(28px,10vw,42px)}.contact-flow{min-height:0}.contact-flow h3{font-size:24px}.contact-flow input,.contact-flow textarea{padding:16px 14px}.contact-flow .row,.contact-actions{flex-direction:column}.mobile-menu{border-left:none;width:100%;top:68px}}.find-grid{grid-template-columns:repeat(4,1fr);gap:32px;margin-top:70px;display:grid}.find-tile{color:#8f9cb0;text-align:center;background:#ffffff03;border:1px solid #ffffff0f;flex-direction:column;justify-content:center;align-items:center;height:180px;transition:border .25s,color .25s;display:flex;position:relative;overflow:hidden}.find-tile:hover{color:var(--blue-light);border-color:#1877f273}.logo-wrap{justify-content:center;align-items:center;width:70px;height:70px;margin-bottom:16px;display:flex;position:relative}.find-me-logo{letter-spacing:-.02em;justify-content:center;align-items:center;width:34px;height:34px;font-size:34px;font-weight:900;transition:transform .45s cubic-bezier(.2,.8,.2,1),filter .3s,opacity .3s;display:inline-flex}.find-me-logo.up{color:#6fda44}.find-me-logo.pph{color:#ff4d4d}.tile-label{letter-spacing:.2em;text-transform:uppercase;font-size:11px}.logo-wrap:after{content:"";opacity:.25;background:radial-gradient(circle,#1877f226,#0000 70%);border-radius:50%;animation:3.5s ease-in-out infinite pulseGlow;position:absolute;inset:0}.find-tile:hover .logo-wrap:after{opacity:.6}.find-tile:hover .find-me-logo{filter:drop-shadow(0 6px 18px #1877f259);transform:translateY(-6px)scale(1.18)}.find-me-logo{animation:4.5s ease-in-out infinite logoFloat}.find-tile:hover .find-me-logo{animation:none}@keyframes logoFloat{0%,to{transform:translateY(0)}50%{transform:translateY(-4px)}}@keyframes pulseGlow{0%,to{opacity:.2;transform:scale(.9)}50%{opacity:.4;transform:scale(1.15)}}.site-footer{scroll-snap-align:start;padding:40px var(--site-pad);background:#0a0a0a;border-top:1px solid #ffffff14;position:relative}.site-footer:before{content:"";background:linear-gradient(90deg,#0000,#1877f280,#0000);width:100%;height:1px;position:absolute;top:0;left:0}.footer-inner{letter-spacing:.12em;text-transform:uppercase;color:#ffffffb3;justify-content:space-between;align-items:center;font-size:11px;display:flex}.footer-left{opacity:.9}.footer-right{opacity:.6}@media (width<=720px){.find-grid{grid-template-columns:1fr;gap:16px}.footer-inner{text-align:center;flex-direction:column;gap:10px}}.preview-panel .project-button.pro{--speed:.28;--transition:calc(var(--speed) * 1s);--timing:cubic-bezier(.2, .8, .2, 1);letter-spacing:.16em;text-transform:uppercase;color:#fff;cursor:pointer;background:#0e1116;border:1px solid #ffffff1f;border-radius:8px;justify-content:center;align-items:center;width:100%;padding:34px 22px;font-size:12px;font-weight:700;transition:transform .2s,box-shadow .2s;display:flex;position:relative;overflow:hidden}.preview-panel .project-button.pro:hover{transform:translateY(-2px);box-shadow:0 10px 30px #00000080}.preview-panel .project-button.pro .text{transform-origin:50%;opacity:0;white-space:nowrap;transition:transform var(--transition), opacity var(--transition);transition-timing-function:var(--timing);font-size:1.6em;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)scale(.6)}.preview-panel .project-button.pro:hover .text{opacity:1;transform:translate(-50%,-50%)scale(1)}.preview-panel .project-button.pro:hover svg{transform:translate(-50%,-50%)}.preview-panel .project-button.pro{--mx:50%;--my:50%;position:relative;overflow:hidden}.preview-panel .project-button.pro:before{content:"";pointer-events:none;z-index:0;opacity:0;transition:opacity var(--transition);border-radius:inherit;background:radial-gradient(140px circle at var(--mx) var(--my), color-mix(in srgb, var(--accent) 24%, transparent), transparent 70%);position:absolute;inset:0}.preview-panel .project-button.pro:hover:before{opacity:1}.preview-panel .project-button.pro>*{z-index:1;position:relative}.preview-panel .project-button.pro svg{width:26px;position:absolute;top:50%;left:50%;overflow:visible;translate:-50% -50%}.preview-panel .project-button.pro svg path{stroke:#fff;stroke-width:2.4px;fill:none;transform-box:fill-box;transform-origin:50%;transition:translate var(--transition), scale var(--transition), rotate var(--transition), opacity var(--transition);transition-timing-function:var(--timing)}.preview-panel .project-button.pro svg path:not(:nth-of-type(2)){--offset:20%;--distance:80px;translate:calc((var(--offset) * var(--dir,1)) + (var(--intent,0) * (var(--distance) * var(--dir,1))) + var(--bias-x,0px)) calc(var(--bias-y,0px));scale:calc(1 + var(--intent,0))}.preview-panel .project-button.pro svg path:first-of-type{--dir:1;--bias-x:-5px;stroke:var(--accent);rotate:calc(10deg + (var(--intent,0) * 10deg))}.preview-panel .project-button.pro svg path:nth-of-type(3){--dir:-1;--bias-x:-4px;--bias-y:5px;stroke:var(--accent);rotate:calc(0deg + (var(--intent,0) * 30deg))}.preview-panel .project-button.pro svg path:nth-of-type(2){rotate:calc(10deg + (var(--intent,0) * 50deg));scale:calc(1 + (var(--intent,0) * 1.25)) calc(1 + (var(--intent,0) * 2.15));translate:calc(-5px + (15px * var(--intent,0))) calc(var(--intent,0) * 38px);stroke:var(--accent)}.preview-panel .project-button.pro:hover{--intent:1}.image-loader{z-index:20;opacity:1;justify-content:center;align-items:center;transition:opacity .35s;display:flex;position:absolute;inset:0;transform:translateZ(200px)}.image-loader:after{content:"";will-change:transform;border:2px solid #ffffff26;border-top-color:#1877f2;border-radius:50%;width:28px;height:28px;animation:.8s linear infinite spinLoader;transform:translateZ(0)}.project-image{object-fit:contain;backface-visibility:hidden;width:100%;height:100%;position:absolute;inset:0;transform:translateZ(-80px)}.project-tilt{transform-style:preserve-3d;will-change:transform}.image-loader{z-index:20;opacity:1;justify-content:center;align-items:center;transition:opacity .35s;display:flex;position:absolute;inset:0}.image-loader.hide{opacity:0;pointer-events:none}.image-loader:after{content:"";will-change:transform;backface-visibility:hidden;border:2px solid #ffffff26;border-top-color:#1877f2;border-radius:50%;width:28px;height:28px;animation:.8s linear infinite spinLoader}@keyframes spinLoader{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.project-title-overlay{z-index:5;pointer-events:none;opacity:0;visibility:hidden;transition:opacity .35s,transform .35s;position:absolute;top:50%;transform:translateY(-50%)translateZ(420px)}.project-title-overlay.show{opacity:1;visibility:visible;transform:translateY(-50%)translateZ(420px)scale(1)}.project-hero-image-only:after{content:none;display:none}.section-header{z-index:2;position:relative}.section-header .eyebrow{letter-spacing:-.04em;color:#ffffff0a;text-transform:uppercase;pointer-events:none;-webkit-user-select:none;user-select:none;z-index:0;mix-blend-mode:soft-light;font-size:clamp(80px,14vw,240px);font-weight:800;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)rotate(-20deg)}.panel-tags{flex-wrap:wrap;gap:8px;display:flex}.tag{letter-spacing:.08em;text-transform:lowercase;color:#cfd6e6;background:#ffffff0a;border:1px solid #ffffff14;border-radius:6px;padding:6px 10px;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:11px;transition:all .2s}.tag[data-tag=php]{color:#aeb8ff;background:#777bb314;border-color:#777bb366}.tag[data-tag=wordpress]{color:#6cc0ff;background:#21759b14;border-color:#21759b66}.tag[data-tag=javascript],.tag[data-tag=js]{color:#ffe066;background:#f7df1e14;border-color:#f7df1e66}.tag[data-tag=react]{color:#61dafb;background:#61dafb14;border-color:#61dafb66}.tag[data-tag=css]{color:#6ccfff;background:#264de414;border-color:#264de466}.tag[data-tag=html]{color:#ff8a65;background:#e34f2614;border-color:#e34f2666}.tag[data-tag=woocommerce]{color:#c084fc;background:#7b23ff14;border-color:#7b23ff66}.tag[data-tag=api]{color:#5eead4;background:#14b8a614;border-color:#14b8a666}.tag[data-tag=mysql]{color:#fbbf24;background:#fbbf2414;border-color:#fbbf2466}.project-ribbon .project-teaser{break-inside:avoid}.project-ribbon .project-teaser:nth-child(3n+1){transform:translateY(0)}.project-ribbon .project-teaser:nth-child(3n+2){transform:translateY(220px)}.project-ribbon .project-teaser:nth-child(3n+3){transform:translateY(0)}.project-content{z-index:2;width:100%;max-width:820px;margin:60px auto 120px;padding:0;position:relative}.project-content h1{letter-spacing:-.04em;color:var(--text);margin:0 0 18px;font-size:clamp(28px,4vw,44px);line-height:.95}.post-category{letter-spacing:.2em;text-transform:uppercase;color:var(--blue-light);margin-bottom:28px;font-size:10px;display:inline-block}.post-body{color:var(--text-soft);max-width:720px;font-size:14px;line-height:1.8}.post-body p{color:var(--muted);margin:0 0 18px}.post-body h2{letter-spacing:-.02em;margin:40px 0 14px;font-size:20px}.post-body h3{margin:28px 0 10px;font-size:16px}.post-body ul,.post-body ol{margin:18px 0;padding-left:18px}.post-body li{color:var(--muted);margin-bottom:8px}.post-body a{color:var(--blue);border-bottom:1px solid var(--line-blue);transition:all .2s}.post-body a:hover{color:var(--blue-strong);border-color:var(--blue)}.post-body img{border-radius:var(--radius-md);border:1px solid var(--line);width:100%;box-shadow:var(--shadow-sm);margin:30px 0}.post-body pre{background:0 0;border:none;margin:28px 0;padding:0}.post-body pre code{display:block}.post-body .wp-block-code{margin:28px 0}.post-body .wp-block-code pre,.post-body pre:not(.code-wrp){background:#f8fafc;border:1px solid #0000000f;border-radius:10px;padding:18px;overflow-x:auto;box-shadow:0 4px 14px #00000008}.post-body pre code[class*=language-]{color:#1f2937;font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;font-size:13px;line-height:1.7}.post-body code:not([class*=language-]){color:#111827;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:12px}.token.comment{color:#9ca3af;font-style:italic}.token.keyword{color:#2563eb;font-weight:500}.token.function{color:#c2410c}.token.string{color:#15803d}.token.number,.token.boolean{color:#b45309}.token.operator{color:#6b7280}.token.class-name{color:#7c3aed}.token.property{color:#0284c7}.token.constant{color:#d97706}.token.tag{color:#2563eb}.token.attr-name{color:#0284c7}.token.attr-value{color:#15803d}.post-body p code{background:#0000000a;border:1px solid #0000000f;border-radius:4px;padding:2px 6px;font-size:12px}.post-body blockquote{border-left:2px solid var(--blue);color:var(--muted);margin:28px 0;padding-left:16px;font-style:italic}.post-body hr{background:var(--line);border:none;height:1px;margin:40px 0}.post-body pre::-webkit-scrollbar{height:6px}.post-body pre::-webkit-scrollbar-thumb{background:#00000026;border-radius:3px}@media (width<=720px){.project-content{margin:40px auto 80px;padding:0 10px}.project-content h1{font-size:26px}.post-body{font-size:13.5px}}.content-inner{margin:0 20px 20px 0}.post-card-meta{margin-top:12px;padding:0 4px}.post-card-category{letter-spacing:.18em;text-transform:uppercase;color:var(--blue-light);margin-bottom:6px;font-size:10px}.post-card-title{color:#111;margin:0;font-size:16px;font-weight:600;line-height:1.3}.project-image-wrap{width:100%;max-height:clamp(260px,40vw,320px)}code[class*=language-],pre[class*=language-]{color:#ccc;text-align:left;white-space:pre;word-spacing:normal;word-break:normal;word-wrap:normal;tab-size:4;-webkit-hyphens:none;hyphens:none;background:0 0;font-family:Consolas,Monaco,Andale Mono,Ubuntu Mono,monospace;font-size:1em;line-height:1.5}pre[class*=language-]{margin:.5em 0;padding:1em;overflow:auto}:not(pre)>code[class*=language-],pre[class*=language-]{background:#2d2d2d}:not(pre)>code[class*=language-]{white-space:normal;border-radius:.3em;padding:.1em}.token.comment,.token.block-comment,.token.prolog,.token.doctype,.token.cdata{color:#999}.token.punctuation{color:#ccc}.token.tag,.token.attr-name,.token.namespace,.token.deleted{color:#e2777a}.token.function-name{color:#6196cc}.token.boolean,.token.number,.token.function{color:#f08d49}.token.property,.token.class-name,.token.constant,.token.symbol{color:#f8c555}.token.selector,.token.important,.token.atrule,.token.keyword,.token.builtin{color:#cc99cd}.token.string,.token.char,.token.attr-value,.token.regex,.token.variable{color:#7ec699}.token.operator,.token.entity,.token.url{color:#67cdcc}.token.important,.token.bold{font-weight:700}.token.italic{font-style:italic}.token.entity{cursor:help}.token.inserted{color:green}
