@font-face{font-family:"NB International Pro";src:url("fonts/NBInternationalPro-Regular.woff2") format("woff2"),url("fonts/NBInternationalPro-Regular.woff") format("woff");font-weight:400;font-style:normal;font-display:swap}@font-face{font-family:"NB International Pro";src:url("fonts/NBInternationalPro-Medium.woff2") format("woff2"),url("fonts/NBInternationalPro-Medium.woff") format("woff");font-weight:500;font-style:normal;font-display:swap}@font-face{font-family:"NB International Pro";src:url("fonts/NBInternationalPro-Bold.woff2") format("woff2"),url("fonts/NBInternationalPro-Bold.woff") format("woff");font-weight:700;font-style:normal;font-display:swap}:root{--bg:#0d0d0d;--bg-alt:#141414;--text:#f5f5f5;--text-muted:#888;--accent:#e8c547;--border:rgba(255, 255, 255, 0.08);--font-display:"Syne",sans-serif;--font-hero:"NB International Pro","Archivo",sans-serif;--font-body:"DM Sans",sans-serif;--space:clamp(1.5rem, 4vw, 4rem);--container:min(90vw, 1400px);--hero-header-clearance:clamp(7.5rem, 12vh, 10.5rem)}*,::after,::before{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{font-family:var(--font-body);font-size:1rem;line-height:1.5;color:var(--text);background:var(--bg);overflow-x:hidden}.header{position:fixed;top:0;left:0;right:0;z-index:200;display:flex;align-items:center;justify-content:space-between;gap:.75rem;padding:var(--space) calc(var(--space) * 1.5);padding-top:max(var(--space),env(safe-area-inset-top,0px));padding-left:max(calc(var(--space) * 1.5),env(safe-area-inset-left,0px));padding-right:max(calc(var(--space) * 1.5),env(safe-area-inset-right,0px));mix-blend-mode:normal;isolation:isolate;pointer-events:none}.header::before{content:"";position:absolute;inset:0;z-index:0;pointer-events:none;background:linear-gradient(to bottom,rgba(13,13,13,.96) 0,rgba(13,13,13,.82) 70%,rgba(13,13,13,.12) 100%)}.header>*{position:relative;z-index:1}.header *{pointer-events:auto}.logo{display:inline-flex;align-items:center;min-width:0;flex:1 1 auto;font-family:var(--font-body);font-weight:700;font-size:2.5rem;letter-spacing:.02em;color:var(--text);text-decoration:none}.logo__highlight{position:relative;display:inline-flex;align-items:center;height:calc(2em + 1.75px);color:#fff;font-size:2em;line-height:1}.logo__highlight::before{content:"";position:absolute;left:0;top:0;width:100%;height:100%;background:linear-gradient(to bottom,transparent 0,transparent calc(37.5% - 1px),var(--bg) calc(37.5% - 1px),var(--bg) 37.5%,transparent 37.5%,transparent calc(50% - 1px),var(--bg) calc(50% - 1px),var(--bg) 50%,transparent 50%,transparent calc(62.5% - 1px),var(--bg) calc(62.5% - 1px),var(--bg) 62.5%,transparent 62.5%);pointer-events:none;z-index:1}.logo-64-wrap{display:inline-block;position:relative;width:calc(2em + 1.75px);height:calc(2em + 1.75px);overflow:visible;vertical-align:middle;margin-left:.15em}.logo-64{position:absolute;left:0;top:0;display:inline-grid;grid-template-columns:repeat(8,1em);grid-template-rows:repeat(8,1em);gap:1px;width:calc(8 * 1em + 7 * 1px);height:calc(8 * 1em + 7 * 1px);background:var(--accent);transform:scale(.25);transform-origin:left top}.logo-64__cell{width:1em;height:1em;background:var(--bg);transition:background .25s}.logo-64__cell--hover,.logo-64__cell--on{background:#a8e6f5}.logo-64__cell--cursor{animation:2s ease-in-out infinite logo-64-cursor-blink}@keyframes logo-64-cursor-blink{0%,100%{background:var(--accent)}50%{background:var(--bg)}}.menu-toggle{flex-shrink:0;position:relative;z-index:1;width:40px;height:28px;display:flex;flex-direction:column;justify-content:space-between;background:0 0;border:none;cursor:pointer;padding:0;-webkit-tap-highlight-color:transparent}.menu-toggle__line{display:block;height:2px;background:#a8e6f5;transition:transform .3s,opacity .3s}.menu-toggle[aria-expanded=true] .menu-toggle__line:first-child{transform:translateY(13px) rotate(45deg)}.menu-toggle[aria-expanded=true] .menu-toggle__line:nth-child(2){opacity:0}.menu-toggle[aria-expanded=true] .menu-toggle__line:nth-child(3){transform:translateY(-13px) rotate(-45deg)}.nav{position:fixed;top:0;right:0;bottom:0;width:min(100%,380px);max-width:100vw;background:var(--bg);padding:calc(var(--space) * 2);padding-top:max(calc(var(--space) * 2),env(safe-area-inset-top,0px));padding-bottom:max(calc(var(--space) * 2),env(safe-area-inset-bottom,0px));padding-right:max(calc(var(--space) * 2),env(safe-area-inset-right,0px));display:flex;flex-direction:column;justify-content:center;transform:translateX(100%);transition:transform .4s cubic-bezier(.4, 0, .2, 1);z-index:250;border-left:1px solid var(--border);pointer-events:auto}.nav.is-open{transform:translateX(0)}.nav__list{list-style:none;position:relative;z-index:2}.nav__list li{margin-bottom:.5rem}.nav__list a{font-family:var(--font-display);font-weight:600;font-size:clamp(1.5rem, 4vw, 2.5rem);color:var(--text);text-decoration:none;display:inline-block;padding:.4rem .5rem;margin:0 -.5rem;transition:color .2s,transform .2s;cursor:pointer;pointer-events:auto}.nav__list a:hover{color:var(--accent);transform:translateX(8px)}.nav__footer{margin-top:auto;padding-top:var(--space);display:flex;gap:1.5rem;position:relative;z-index:1}.nav__footer a{font-size:.9rem;color:var(--text-muted);text-decoration:none;transition:color .2s}.nav__footer a:hover{color:var(--text)}@media (max-width:768px){.header{mix-blend-mode:normal}.logo{font-size:clamp(.95rem, 4.2vw, 1.45rem)}.menu-toggle__line{background:var(--accent);box-shadow:0 0 0 1px rgba(13,13,13,.35)}.menu-toggle{width:44px;height:32px;padding:8px;margin:-8px -8px -8px 0;box-sizing:content-box}.menu-toggle[aria-expanded=true] .menu-toggle__line:first-child{transform:translateY(15px) rotate(45deg)}.menu-toggle[aria-expanded=true] .menu-toggle__line:nth-child(3){transform:translateY(-15px) rotate(-45deg)}}@media (max-width:380px){.logo{font-size:clamp(.85rem, 3.9vw, 1.15rem)}.header{padding-left:max(.75rem,env(safe-area-inset-left,0px));padding-right:max(.75rem,env(safe-area-inset-right,0px))}}.hero{display:flex;flex-direction:column;justify-content:flex-start;padding:max(calc(var(--space) * 5),calc(var(--hero-header-clearance) + 2rem)) calc(var(--space) * 1.5) calc(var(--space) * .5);max-width:var(--container);margin:0 auto}.hero__label{font-size:1.7rem;text-transform:uppercase;letter-spacing:.2em;color:var(--text-muted);margin-bottom:1rem;hyphens:none;overflow-wrap:normal;word-break:normal}.hero__title{font-family:var(--font-body);font-weight:700;font-size:clamp(3rem, 8vw, 8rem);line-height:1.05;letter-spacing:.04em;margin-bottom:1.5rem;hyphens:none;overflow-wrap:normal;word-break:normal}.hero__title .line{display:block}.hero__title .hero__word-keep{white-space:nowrap}.hero__desc{font-family:var(--font-body);font-size:clamp(1rem, 2vw, 1.25rem);color:var(--text-muted);max-width:36ch}@keyframes hero-desc-snake-pulse{0%,49.999%{color:var(--accent)}100%,50%{color:var(--text-muted)}}.page-realisations .hero__desc.hero__desc--snake-revealed{animation:4s linear infinite hero-desc-snake-pulse}@media (prefers-reduced-motion:reduce){.page-realisations .hero__desc.hero__desc--snake-revealed{animation:none;color:var(--accent)}}.hero__desc-accent{color:var(--accent)}.hero__desc-nowrap{white-space:nowrap}@media (max-width:768px){.hero{padding-left:clamp(.9rem,4vw,1.25rem);padding-right:clamp(.9rem,4vw,1.25rem)}.hero__label{font-size:clamp(.78rem, 3vw, 1rem);letter-spacing:.12em}.hero__title{font-size:clamp(1.45rem, 7.4vw, 2.35rem);line-height:1.08;letter-spacing:.01em;overflow-wrap:normal;word-break:keep-all}.hero__title .line{max-width:100%}.hero__title .hero__word-keep{white-space:nowrap}.hero__desc{max-width:100%}.hero__desc-nowrap{white-space:normal}}@media (max-width:430px){.hero{padding-left:max(.85rem,env(safe-area-inset-left,0px));padding-right:max(.85rem,env(safe-area-inset-right,0px))}.hero__title{font-size:clamp(1.18rem, 6.1vw, 1.72rem);line-height:1.12;letter-spacing:0}}.page-contact main{padding-left:calc(var(--space) * 1.5);padding-right:calc(var(--space) * 1.5);padding-bottom:clamp(3rem,8vh,6rem)}.page-realisations main{padding-top:clamp(6.5rem,12vh,9rem)}.page-contact .hero{padding-top:max(clamp(7.5rem,16vh,12rem),calc(var(--hero-header-clearance) + 1.25rem));padding-bottom:clamp(1rem,3vh,2rem)}@media (min-width:769px){.page-contact .hero{padding-top:max(clamp(11rem,22vh,15rem),calc(var(--hero-header-clearance) + 2.5rem))}}@media (min-width:769px) and (max-height:900px){.page-contact .hero{padding-top:max(12rem,calc(var(--hero-header-clearance) + 3rem))}}.contact-form{position:relative}.contact-section{max-width:min(100%,32rem)}.contact-section__title{font-family:var(--font-display);font-size:clamp(1.25rem, 2.5vw, 1.5rem);font-weight:600;color:var(--text);margin-bottom:.75rem}.contact-section__intro{margin-bottom:1.75rem;max-width:42ch}.contact-section__intro code{font-size:.85em;color:var(--accent)}.contact-form__field{margin-bottom:1.25rem}.contact-form__field--honeypot{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden;margin:0}.contact-form__field--turnstile .contact-form__label{margin-bottom:.5rem}.contact-form__turnstile{min-height:4.5rem}.contact-form__label{display:block;font-size:.875rem;font-weight:500;color:var(--text-muted);margin-bottom:.35rem}.contact-form__label abbr{text-decoration:none;color:var(--accent)}.contact-form__input,.contact-form__textarea{width:100%;font-family:var(--font-body);font-size:1rem;color:var(--text);background:var(--bg-alt);border:1px solid var(--border);border-radius:4px;padding:.65rem .85rem;transition:border-color .2s,box-shadow .2s}.contact-form__textarea{resize:vertical;min-height:8rem;line-height:1.45}.contact-form__input::placeholder,.contact-form__textarea::placeholder{color:var(--text-muted);opacity:.75}.contact-form__input:hover,.contact-form__textarea:hover{border-color:rgba(232,197,71,.35)}.contact-form__input:focus,.contact-form__textarea:focus{outline:0;border-color:var(--accent);box-shadow:0 0 0 2px rgba(232,197,71,.2)}.contact-form__actions{margin-top:1.5rem;margin-bottom:0}.contact-form__submit{font-family:var(--font-body);font-size:1rem;font-weight:600;color:var(--bg);background:var(--accent);border:none;border-radius:4px;padding:.75rem 1.75rem;cursor:pointer;transition:filter .2s,transform .15s}.contact-form__submit:hover:not(:disabled){filter:brightness(1.08)}.contact-form__submit:active:not(:disabled){transform:scale(.98)}.contact-form__submit:disabled{opacity:.6;cursor:not-allowed}.contact-form__status{margin-top:1.25rem;font-size:.9375rem;line-height:1.4}.contact-form__status--ok{color:#7bc96f}.contact-form__status--err{color:#e57373}.contact-form__status--wait{color:var(--text-muted)}.page-realisations .hero{min-height:min(78vh,760px);padding-top:max(clamp(7.8rem,17vh,12.5rem),calc(var(--hero-header-clearance) + 1.75rem));padding-bottom:clamp(.5rem,2vh,1.5rem)}.page-realisations .hero__title{font-size:clamp(2.2rem, 6.2vw, 5.5rem)}@media (max-height:760px){.page-realisations .hero{min-height:auto;padding-top:max(clamp(6.2rem,14vh,9.5rem),calc(var(--hero-header-clearance) + .25rem));padding-bottom:.25rem}.page-realisations .hero__title{font-size:clamp(1.8rem, 5.2vw, 4rem);line-height:1}}@media (max-width:768px){:root{--hero-header-clearance:clamp(6.5rem, 11vh, 8.5rem)}.page-contact .hero{padding-top:max(clamp(6.2rem,12vh,8rem),calc(var(--hero-header-clearance) + .35rem))}.page-realisations .hero{padding-top:max(clamp(7rem,15vh,9rem),calc(var(--hero-header-clearance) + .75rem))}.page-realisations main{padding-top:clamp(5.2rem,9vh,6.8rem)}}@media (max-width:768px) and (max-height:760px){.page-realisations .hero{padding-top:max(clamp(6.5rem,14vh,8.5rem),calc(var(--hero-header-clearance) + .4rem))}}.hero .letters-tumble,.hero .letters-tumble .char{display:inline-block;cursor:default}.hero .letters-tumble .char--space{min-width:.25em;white-space:pre}#hero-letters-canvas{position:fixed;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:49}#logo-snake-line{position:fixed;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:0}#logo-snake-datavis-gap-mask{position:fixed;pointer-events:none;z-index:50;background:var(--bg);border-radius:1px}.line-mask-word{position:relative;z-index:2;background:var(--bg);box-decoration-break:clone;-webkit-box-decoration-break:clone}.video-background{position:fixed;top:0;left:0;width:100vw;height:100vh;z-index:-1;overflow:hidden}.video-background .hero-video{position:absolute;top:50%;left:50%;min-width:100%;min-height:100%;width:auto;height:auto;transform:translate(-50%,-50%);object-fit:cover;filter:blur(6px) contrast(1) grayscale(100%)}.video-background__blur-zone{position:absolute;top:0;left:0;right:0;height:45%;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);pointer-events:none;animation:10s ease-in-out infinite video-blur-pulse}@keyframes video-blur-pulse{0%,100%{opacity:1}50%{opacity:0}}.video-background__overlay{position:absolute;inset:0;background:linear-gradient(to bottom,rgba(13,13,13,.35) 0,rgba(13,13,13,.7) 100%);pointer-events:none}.video-background .video-fallback{display:none;position:absolute;inset:0;align-items:center;justify-content:center;padding:2rem;text-align:center;color:var(--text-muted);font-size:.9rem;background:var(--bg)}.video-background .video-fallback.is-visible{display:flex}.video-background .video-fallback code{background:rgba(255,255,255,.1);padding:.2em .5em;border-radius:4px}main{position:relative;z-index:1}.video-section[hidden]{display:none!important}.video-section{padding:0;margin:0 auto;max-width:100%}.video-section__inner{width:100%}.video-wrapper{position:relative;aspect-ratio:16/9;max-height:85vh;overflow:hidden;background:var(--bg-alt);filter:blur(6px) grayscale(100%)}.video-wrapper iframe,.video-wrapper video{width:100%;height:100%;object-fit:cover;transition:filter .4s,transform .4s}.video-wrapper:hover .hero-video{filter:none}.video-wrapper iframe{border:none}.video-fallback{display:none;position:absolute;inset:0;align-items:center;justify-content:center;padding:2rem;text-align:center;color:var(--text-muted);font-size:.9rem;background:var(--bg-alt)}.video-fallback.is-visible{display:flex}.video-fallback code{background:rgba(255,255,255,.1);padding:.2em .5em;border-radius:4px}.driven{display:flex;flex-direction:column;justify-content:center;padding:calc(var(--space) * .5) calc(var(--space) * 1.5);max-width:var(--container);margin:0 auto}.driven__label{font-size:.85rem;text-transform:uppercase;letter-spacing:.2em;color:var(--text-muted);margin-bottom:1rem}.driven__title{font-family:var(--font-display);font-weight:800;font-size:clamp(1.2rem, 4vw, 2.5rem);line-height:.98;letter-spacing:-.03em}.driven__title span{display:block}.work{padding:calc(var(--space) * .75) calc(var(--space) * 1.5);max-width:var(--container);margin:0 auto}.work__title{font-family:var(--font-display);font-weight:700;font-size:clamp(1.5rem, 3vw, 2rem);margin-bottom:var(--space);color:var(--text-muted)}.work__grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1px;background:var(--border)}.work__card{background:var(--bg);padding:var(--space);text-decoration:none;color:var(--text);display:flex;flex-direction:column;gap:.5rem;transition:background .3s,color .3s}.work__card:hover{background:var(--bg-alt);color:var(--accent)}.work__card-num{font-size:.8rem;color:var(--text-muted)}.work__card-name{font-family:var(--font-display);font-weight:600;font-size:1.5rem}.skills{padding:calc(var(--space) * 3) calc(var(--space) * 1.5);max-width:var(--container);margin:0 auto}.skills__title{font-family:var(--font-display);font-weight:700;font-size:clamp(1.5rem, 3vw, 2rem);margin-bottom:var(--space);color:var(--text-muted)}.skills__list{list-style:none;display:flex;flex-wrap:wrap;gap:.5rem 2rem}.skills__list li{font-family:var(--font-display);font-weight:600;font-size:clamp(1.25rem, 2.5vw, 2rem);padding:.5rem 0;border-bottom:2px solid transparent;transition:border-color .3s,color .3s}.skills__list li:hover{border-bottom-color:var(--accent);color:var(--accent)}.cta{padding:calc(var(--space) * 2) calc(var(--space) * 1.5);text-align:center;max-width:var(--container);margin:0 auto}.cta__title{font-family:var(--font-display);font-weight:800;font-size:clamp(2rem, 6vw, 4rem);letter-spacing:-.02em;margin-bottom:1.5rem}.cta__link{display:inline-block;font-family:var(--font-display);font-weight:600;font-size:1rem;text-transform:uppercase;letter-spacing:.15em;color:var(--accent);text-decoration:none;padding:1rem 2rem;border:2px solid var(--accent);transition:background .3s,color .3s}.cta__link:hover{background:var(--accent);color:var(--bg)}.footer{padding:calc(var(--space) * 2) calc(var(--space) * 1.5);border-top:1px solid var(--border)}.footer__inner{max-width:var(--container);margin:0 auto;display:flex;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem}.footer__tagline{font-size:.9rem;color:var(--text-muted)}.footer__legal a{color:var(--text-muted);text-decoration:none;font-size:.9rem}.footer__legal a:hover{color:var(--text)}[data-anim=card],[data-anim=desc],[data-anim=label],[data-anim=section],[data-anim=skill],[data-anim=title] .line{opacity:0;transform:translateY(24px)}.hero__title .line{transform:translateY(0);opacity:1}