:root{--bg:#080808;--bg-elevated:#0f0f0f;--bg-card:#121212;--surface:#1a1a1a;--surface-hover:#222;--fg:#f0f0f0;--fg-dim:#888;--fg-faint:#555;--fg-subtle:#3a3a3a;--accent:#e8e6e3;--accent-hover:#fff;--border:#ffffff0f;--border-hover:#ffffff24;--border-strong:#ffffff38;--shadow-sm:0 1px 2px #0006;--shadow-md:0 4px 20px #00000080;--shadow-lg:0 8px 40px #0009;--shadow-glow:0 0 40px #ffffff0a;--font-d:"Space Grotesk",-apple-system,sans-serif;--font-b:"Inter",-apple-system,sans-serif;--font-m:"JetBrains Mono","SF Mono",monospace;--ease-out-expo:cubic-bezier(.16,1,.3,1);--ease-out-quart:cubic-bezier(.25,1,.5,1);--ease-in-out-quint:cubic-bezier(.83,0,.17,1);--ease-spring:cubic-bezier(.175,.885,.32,1.275);--max-w:1240px;--gutter:clamp(1.25rem,4vw,3rem);--section-pad:clamp(5rem,12vh,9rem);--radius:6px}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:16px}::selection{color:#fff;background:#f0f0f01f}body{font-family:var(--font-b);color:var(--fg-dim);background:var(--bg);min-height:100vh;font-size:1rem;font-weight:400;line-height:1.7;overflow-x:hidden}body:before{content:"";z-index:9999;pointer-events:none;opacity:.035;background-image:url("data:image/svg+xml,%3Csvg viewBox=%270 0 256 256%27 xmlns=%27http://www.w3.org/2000/svg%27%3E%3Cfilter id=%27noise%27%3E%3CfeTurbulence type=%27fractalNoise%27 baseFrequency=%270.85%27 numOctaves=%274%27 stitchTiles=%27stitch%27/%3E%3C/filter%3E%3Crect width=%27100%25%27 height=%27100%25%27 filter=%27url%28%23noise%29%27/%3E%3C/svg%3E");position:fixed;top:0;bottom:0;left:0;right:0}::-webkit-scrollbar{width:5px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:#ffffff14;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#ffffff29}main{z-index:1;width:100%;max-width:var(--max-w);padding:0 var(--gutter);margin:0 auto;position:relative}a{color:var(--fg-dim);transition:color .35s var(--ease-out-quart);text-decoration:none}a:hover{color:var(--fg)}a:focus-visible{outline:1px solid var(--fg-faint);outline-offset:3px;border-radius:2px}h1,h2,h3,h4,h5{font-family:var(--font-d);color:var(--fg);letter-spacing:-.03em;font-weight:500;line-height:1.1}h1{font-size:max(2.8rem,min(6vw,5rem));font-weight:600}h2{font-size:max(1.6rem,min(3.2vw,2.6rem));font-weight:500}h3{font-size:max(1.15rem,min(2vw,1.4rem));font-weight:500}h4{letter-spacing:-.01em;font-size:1rem;font-weight:600}.mono{font-family:var(--font-m);letter-spacing:.08em;text-transform:uppercase;color:var(--fg-faint);font-size:.7rem;line-height:1}p{line-height:1.75}.labels{flex-wrap:wrap;gap:.4rem;margin:.3rem 0 0;font-size:.7rem;display:flex}.label{border:1px solid var(--border);width:auto;height:auto;color:var(--fg-faint);letter-spacing:.02em;border-radius:var(--radius);font-size:.65rem;font-family:var(--font-m);justify-content:center;align-items:center;padding:.3rem .6rem;display:flex}.reveal{opacity:0;transition:opacity .8s var(--ease-out-expo),transform .8s var(--ease-out-expo);transform:translateY(28px)}.reveal.visible{opacity:1;transform:translateY(0)}.reveal-delay-1{transition-delay:80ms}.reveal-delay-2{transition-delay:.16s}.reveal-delay-3{transition-delay:.24s}.reveal-delay-4{transition-delay:.32s}.reveal-delay-5{transition-delay:.4s}.nav{z-index:100;padding:1.25rem var(--gutter);background:0 0;border-bottom:1px solid #0000;transition:background .4s,border-color .4s,-webkit-backdrop-filter .4s,backdrop-filter .4s;position:fixed;top:0;left:0;right:0}.nav.scrolled{-webkit-backdrop-filter:blur(20px)saturate(1.2);border-color:var(--border);background:#080808d1}.nav-inner{max-width:var(--max-w);justify-content:space-between;align-items:center;margin:0 auto;display:flex}.nav-logo{opacity:0;transition:opacity .5s var(--ease-out-expo),transform .5s var(--ease-out-expo);align-items:center;display:flex;transform:translateY(-6px)}.nav.scrolled .nav-logo{opacity:1;transform:translateY(0)}.nav-logo-svg{width:auto;height:1rem;display:block}.st0{fill:var(--fg)}.st1{display:none}.st2{fill:var(--fg);display:inline}.nav-links{gap:2.2rem;display:flex}.nav-links a{font-family:var(--font-m);letter-spacing:.07em;text-transform:uppercase;color:var(--fg-faint);padding:.25rem 0;font-size:.7rem;position:relative}.nav-links a:after{content:"";background:var(--fg);width:0;height:1px;transition:width .4s var(--ease-out-expo);position:absolute;bottom:0;left:0}.nav-links a:hover{color:var(--fg)}.nav-links a:hover:after{width:100%}.hero{flex-direction:column;justify-content:center;align-items:flex-start;min-height:100vh;padding:8rem 0 5rem;display:flex;position:relative}.hero-kicker{font-family:var(--font-m);letter-spacing:.12em;text-transform:uppercase;color:var(--fg-faint);align-items:center;gap:.75rem;margin-bottom:1.5rem;font-size:.7rem;display:flex}.hero-kicker:before{content:"";background:var(--fg-faint);width:24px;height:1px;display:inline-block}.hero-title{letter-spacing:-.04em;color:var(--fg);max-width:800px;margin-bottom:1.5rem;font-size:max(3rem,min(7.5vw,6.5rem));font-weight:600;line-height:1.05}.hero-title .accent{color:var(--fg-dim)}.hero-body{max-width:540px;color:var(--fg-dim);margin-bottom:2.5rem;font-size:max(1rem,min(1.5vw,1.2rem));line-height:1.7}.hero-cta{font-family:var(--font-m);letter-spacing:.08em;text-transform:uppercase;color:var(--bg);background:var(--fg);border:1px solid var(--fg);border-radius:var(--radius);cursor:pointer;transition:all .35s var(--ease-out-quart);align-items:center;gap:.6rem;padding:.85rem 1.5rem;font-size:.75rem;display:inline-flex}.hero-cta:hover{color:var(--fg);background:0 0;box-shadow:0 0 30px #ffffff0f}.hero-subline{font-family:var(--font-m);color:var(--fg-faint);letter-spacing:.05em;margin-top:1.5rem;font-size:.7rem}.hero-scroll{font-family:var(--font-m);letter-spacing:.1em;text-transform:uppercase;color:var(--fg-faint);opacity:0;animation:fadeInUp 1s var(--ease-out-expo)1.5s forwards;flex-direction:column;align-items:center;gap:.5rem;font-size:.65rem;display:flex;position:absolute;bottom:2.5rem;left:50%;transform:translate(-50%)}.hero-scroll-line{background:linear-gradient(to bottom,var(--fg-faint),transparent);width:1px;height:40px;animation:2s ease-in-out infinite scrollPulse}@keyframes fadeInUp{0%{opacity:0;transform:translate(-50%)translateY(10px)}to{opacity:1;transform:translate(-50%)translateY(0)}}@keyframes scrollPulse{0%,to{opacity:.3;height:40px}50%{opacity:.7;height:55px}}.section{padding:var(--section-pad)0}.section-header{margin-bottom:max(2.5rem,min(5vh,4rem))}.section-header .mono{margin-bottom:.75rem;display:block}.section-header h2{max-width:600px}.section-header h2 span{color:var(--fg-dim)}.services-grid{background:var(--border);border:1px solid var(--border);border-radius:var(--radius);grid-template-columns:repeat(1,1fr);gap:1px;display:grid;overflow:hidden}@media (min-width:640px){.services-grid{grid-template-columns:repeat(2,1fr)}}@media (min-width:1024px){.services-grid{grid-template-columns:repeat(3,1fr)}}.service-card{background:var(--bg);transition:background .4s var(--ease-out-quart);cursor:default;padding:2.2rem 2rem 2.5rem}.service-card:hover{background:var(--bg-card)}.service-icon{opacity:.5;transition:opacity .4s var(--ease-out-quart);margin-bottom:1rem;font-size:1.25rem}.service-card:hover .service-icon{opacity:1}.service-card h3{letter-spacing:-.01em;margin-bottom:.6rem;font-size:1rem;font-weight:600;transition:color .3s}.service-card:hover h3{color:var(--accent-hover)}.service-card p{color:var(--fg-faint);font-size:.9rem;line-height:1.65}.clients-grid{background:var(--border);border:1px solid var(--border);border-radius:var(--radius);grid-template-columns:repeat(2,1fr);gap:1px;display:grid;overflow:hidden}@media (min-width:640px){.clients-grid{grid-template-columns:repeat(3,1fr)}}@media (min-width:1024px){.clients-grid{grid-template-columns:repeat(6,1fr)}}.client-cell{background:var(--bg);font-family:var(--font-d);color:var(--fg-faint);letter-spacing:.02em;transition:background .4s var(--ease-out-quart),color .4s var(--ease-out-quart);justify-content:center;align-items:center;padding:1.8rem 1.2rem;font-size:.85rem;font-weight:500;display:flex}.client-cell:hover{background:var(--bg-card);color:var(--fg)}.work-grid{grid-template-columns:1fr;gap:max(1.5rem,min(3vw,2.5rem));display:grid}@media (min-width:768px){.work-grid{grid-template-columns:repeat(2,1fr)}}.work-card{border-radius:var(--radius);cursor:pointer;aspect-ratio:16/10;background:var(--bg-card);border:1px solid var(--border);transition:border-color .4s var(--ease-out-quart),box-shadow .4s var(--ease-out-quart);position:relative;overflow:hidden}.work-card:hover{border-color:var(--border-hover);box-shadow:var(--shadow-md)}.work-card-image{object-fit:cover;filter:brightness(.65)saturate(.85);width:100%;height:100%;transition:filter .6s var(--ease-out-quart),transform .6s var(--ease-out-quart);will-change:filter,transform}.work-card:hover .work-card-image{filter:brightness(.8)saturate(.95);transform:scale(1.04)}.work-card-overlay{background:linear-gradient(#0000001a 0%,#0000008c 100%);flex-direction:column;justify-content:flex-end;padding:1.5rem;display:flex;position:absolute;top:0;bottom:0;left:0;right:0}.work-card-title{font-family:var(--font-d);color:#fff;letter-spacing:-.02em;transition:transform .4s var(--ease-out-quart);margin-bottom:.5rem;font-size:max(1.1rem,min(2vw,1.4rem));font-weight:500}.work-card:hover .work-card-title{transform:translateY(-2px)}.work-card-labels{flex-wrap:wrap;gap:.35rem;display:flex}.work-card-labels .label{color:#fff9;border-color:#ffffff1f;padding:.25rem .5rem;font-size:.6rem}.about-body{max-width:700px;color:var(--fg-dim);margin-bottom:3rem;font-size:max(1.15rem,min(2vw,1.45rem));line-height:1.65}.about-body em{color:var(--fg);font-style:normal;font-weight:500}.grid-item h3{letter-spacing:-.01em;font-size:1rem;font-weight:600}.cta-section{padding:var(--section-pad)0;text-align:center;flex-direction:column;align-items:center;display:flex}.cta-headline{color:var(--fg);letter-spacing:-.03em;max-width:600px;margin-bottom:1.25rem;font-size:max(2rem,min(4.5vw,3.5rem));font-weight:500}.cta-sub{color:var(--fg-dim);max-width:420px;margin-bottom:2rem;font-size:1rem;line-height:1.7}.cta-btn{font-family:var(--font-m);letter-spacing:.08em;text-transform:uppercase;color:var(--bg);background:var(--fg);border:1px solid var(--fg);border-radius:var(--radius);cursor:pointer;transition:all .35s var(--ease-out-quart);align-items:center;gap:.6rem;padding:1rem 2rem;font-size:.75rem;display:inline-flex}.cta-btn:hover{color:var(--fg);background:0 0;box-shadow:0 0 40px #ffffff0f}.cta-email{font-family:var(--font-m);color:var(--fg-faint);border-bottom:1px solid var(--border);margin-top:1.25rem;padding-bottom:.1rem;font-size:.8rem;transition:color .3s,border-color .3s}.cta-email:hover{color:var(--fg);border-color:var(--fg-faint)}.footer{font-family:var(--font-m);color:var(--fg-subtle);letter-spacing:.03em;border-top:1px solid var(--border);flex-direction:row;justify-content:space-between;align-items:center;padding:2rem 0 2.5rem;font-size:.7rem;display:flex}@media (max-width:480px){.footer{flex-direction:column;align-items:flex-start;gap:.5rem}.footer span:empty{display:none}}.work-item-backdrop{z-index:200;-webkit-backdrop-filter:blur(8px);background:#000000d9;position:fixed;top:0;bottom:0;left:0;right:0}.work-item-detail{background:var(--bg);box-sizing:border-box;z-index:201;border-left:1px solid var(--border);border-right:1px solid var(--border);flex-direction:column;justify-content:space-between;width:65vw;max-width:1000px;height:100vh;padding:1.5rem;display:flex;position:fixed;top:0;left:50%;transform:translate(-50%)}@media (min-width:1920px){.work-item-detail{width:55vw;max-width:1100px;padding:2rem}}@media (min-width:2560px){.work-item-detail{width:50vw;max-width:1300px;padding:2rem}}@media (max-width:768px){.work-item-detail{width:92vw;padding:1rem}}@media (max-width:480px){.work-item-detail{border:none;width:100vw}}.detail-header{flex-direction:row;justify-content:space-between;align-items:flex-start;display:flex}.detail-title p{color:var(--fg-dim);margin:0;font-weight:400}.detail-title-wrapper{align-items:center;gap:.75rem;display:flex}.detail-title-wrapper h2{margin:0;font-size:max(1.3rem,min(2vw,1.7rem))}.work-item-children{flex-direction:column;flex:1;align-items:flex-start;margin:1rem 0;display:flex;overflow:hidden auto}.work-item-body{flex-direction:column;gap:.75rem;padding:1.25rem 0 .5rem;display:flex}.work-item-hook{font-size:max(1rem,min(1.5vw,1.2rem));font-family:var(--font-d);color:var(--fg);letter-spacing:-.01em;margin:0;font-weight:500;line-height:1.35}.work-item-overview p{color:var(--fg-dim);margin:0;line-height:1.7}.work-item-overview a{color:var(--fg);border-bottom:1px solid var(--border);transition:border-color .3s}.work-item-overview a:hover{border-color:var(--fg-faint)}.work-item-role{border-top:1px solid var(--border);flex-direction:column;gap:.35rem;margin-top:.25rem;padding-top:.75rem;display:flex}.work-item-role-label{font-family:var(--font-m);letter-spacing:.1em;text-transform:uppercase;color:var(--fg-faint);font-size:.65rem}.work-item-role p{color:var(--fg-dim);margin:0;font-size:.9rem;line-height:1.65}.detail-footer{justify-content:space-between;gap:1rem;display:flex}.gallery{border-radius:var(--radius);background:var(--bg-card);border:1px solid var(--border);flex-shrink:0;width:100%;height:60%;min-height:260px;max-height:560px;position:relative;overflow:hidden}.gallery-nav{pointer-events:none;z-index:10;justify-content:space-between;display:flex;position:absolute;top:0;bottom:0;left:0;right:0}.gallery-nav button{width:3.5rem;height:100%;color:var(--fg);cursor:pointer;pointer-events:auto;opacity:0;font-size:1.1rem;font-family:var(--font-m);background:#00000026;border:none;transition:opacity .3s,background .3s}.gallery:hover .gallery-nav button{opacity:1}.gallery-nav button:hover{background:#00000059}.gallery img{object-fit:cover;cursor:pointer;width:100%;height:100%}.fs-viewer{z-index:300;cursor:zoom-out;background:#000000eb;border:none;justify-content:center;align-items:center;padding:0;display:flex;position:fixed;top:0;bottom:0;left:0;right:0}.fs-viewer img{object-fit:contain;max-width:92vw;max-height:92vh}.button{background:var(--fg);min-width:2.2rem;height:2.2rem;color:var(--bg);border:1px solid var(--fg);font-family:var(--font-m);cursor:pointer;border-radius:var(--radius);justify-content:center;align-items:center;padding:0 .7rem;font-size:.8rem;transition:all .3s;display:inline-flex}.button:hover{color:var(--fg);background:0 0}.inverted-button{min-width:2.2rem;height:2.2rem;color:var(--fg);border:1px solid var(--fg-subtle);font-family:var(--font-m);cursor:pointer;border-radius:var(--radius);background:0 0;padding:0 1.25rem;font-size:.8rem;transition:all .3s}.inverted-button:hover{background:var(--fg);color:var(--bg);border-color:var(--fg)}.scroll-to-top{z-index:90;background:var(--bg-card);border:1px solid var(--border);color:var(--fg-faint);font-family:var(--font-m);cursor:pointer;letter-spacing:.06em;border-radius:var(--radius);padding:.5rem .8rem;font-size:.7rem;transition:all .3s;position:fixed;bottom:2rem;right:2rem}.scroll-to-top:hover{background:var(--surface);color:var(--fg);border-color:var(--border-hover)}@media (max-width:768px){.hero{padding:7rem 0 4rem}.nav-links{gap:1.5rem}.work-grid,.services-grid{grid-template-columns:1fr}.clients-grid{grid-template-columns:repeat(2,1fr)}.detail-header{flex-direction:column;gap:1rem}}@media (max-width:480px){.hero{padding:6rem 0 3rem}.nav{padding:1rem var(--gutter)}.nav-links{gap:1rem}.nav-links a{font-size:.65rem}.section{padding:max(3rem,min(8vh,5rem)) 0}.work-card-overlay{padding:1.2rem}}.imageContainer-MFsV2x{width:100%;display:contents;position:relative;overflow:hidden}.image-eCDj1I{opacity:0;object-fit:cover;width:100%;height:auto;transition:opacity .3s;display:block}.image-eCDj1I.loaded-OU3Yi3{opacity:1}