@import "./fonts.css";

*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
:root{--black:#000;--white:#fff;--gray-light:#a0a0a0;--gray-mid:#666;--gray-dark:#1a1a1a;--ts:cubic-bezier(.25,.46,.45,.94);--tp:cubic-bezier(.16,1,.3,1)}
html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}
body{font-family:'Futura Bk Book','Futura','Century Gothic',sans-serif;background:var(--black);color:var(--white);overflow-x:hidden;line-height:1.5;animation:page-in .35s ease both}
@keyframes page-in{from{opacity:0}to{opacity:1}}
body.page-out{opacity:0;transition:opacity .2s ease;pointer-events:none}
a{text-decoration:none;color:inherit;transition:opacity .3s var(--ts)}a:hover{opacity:.7}
img{display:block;max-width:100%;content-visibility:auto}

.nav{position:fixed;top:0;left:0;width:100%;z-index:1000;padding:20px 32px;display:flex;align-items:center;justify-content:space-between;background:transparent;transition:background .4s var(--ts)}
.nav.scrolled{background:rgba(0,0,0,.85);backdrop-filter:blur(12px)}
.nav__left{font-size:11px;font-weight:400;letter-spacing:2.5px;text-transform:uppercase;opacity:.9}
.nav__center{position:absolute;left:50%;transform:translateX(-50%)}
.nav__logo{font-family:'Futura Bk Book','Futura','Century Gothic',sans-serif;font-size:28px;font-weight:400;font-style:italic;letter-spacing:6px;text-transform:uppercase;display:flex;align-items:center;justify-content:center;line-height:1}
.nav__logo .dot{font-style:normal}
.nav__logo-img{height:28px;width:auto;display:block}
.nav__right{display:flex;align-items:center;gap:32px}
.nav__link{font-size:11px;font-weight:400;letter-spacing:2.5px;text-transform:uppercase;cursor:pointer;position:relative}
.nav__link::after{content:'';position:absolute;bottom:-2px;left:0;width:0;height:1px;background:var(--white);transition:width .4s var(--tp)}
.nav__link:hover::after{width:100%}.nav__link:hover{opacity:1}

.menu-overlay{position:fixed;top:0;left:0;width:100%;height:100%;z-index:2000;display:flex;pointer-events:none;opacity:0}
.menu-overlay.active{pointer-events:all;opacity:1}
.menu-overlay__bg{position:absolute;inset:0;background:var(--black);opacity:0;transition:opacity .6s var(--ts)}
.menu-overlay.active .menu-overlay__bg{opacity:1}
.menu-overlay__left{width:50%;height:100%;position:relative;z-index:1;overflow:hidden;transform:translateX(-100%);transition:transform .8s var(--tp)}
.menu-overlay.active .menu-overlay__left{transform:translateX(0)}
.menu-overlay__image-bg{width:100%;height:100%;object-fit:cover}
.menu-overlay__brand{position:absolute;bottom:60px;left:40px;z-index:2}
.menu-overlay__brand-name{font-family:'Futura Bk Book','Futura','Century Gothic',sans-serif;font-size:72px;font-style:italic;letter-spacing:12px;text-transform:uppercase;line-height:1;text-shadow:0 4px 30px rgba(0,0,0,.6);display:flex;align-items:flex-end}
.menu-overlay__brand-name-img{height:72px;width:auto;display:block}
.menu-overlay__brand-sub{font-size:18px;letter-spacing:4px;margin-top:4px;font-weight:300}
.menu-overlay__right{width:50%;height:100%;position:relative;z-index:1;display:flex;flex-direction:column;justify-content:center;padding:60px 80px;transform:translateX(100%);transition:transform .8s var(--tp);transition-delay:.1s}
.menu-overlay.active .menu-overlay__right{transform:translateX(0)}
.menu-overlay__close{position:absolute;top:20px;right:32px;font-size:11px;letter-spacing:2.5px;text-transform:uppercase;cursor:pointer;z-index:3;transition:opacity .3s}
.menu-overlay__close:hover{opacity:.6}
.menu-overlay__media-label{position:absolute;top:20px;left:40px;font-size:11px;letter-spacing:2.5px;text-transform:uppercase;opacity:.9}
.menu-overlay__nav{display:flex;flex-direction:column}
.menu-overlay__nav-item{font-size:56px;font-weight:400;letter-spacing:3px;text-transform:uppercase;padding:24px 0;border-bottom:1px solid rgba(255,255,255,.15);cursor:pointer;transition:opacity .4s var(--ts),transform .4s var(--ts);opacity:0;transform:translateY(30px)}
.menu-overlay.active .menu-overlay__nav-item{opacity:1;transform:translateY(0)}
.menu-overlay.active .menu-overlay__nav-item:nth-child(1){transition-delay:.3s}
.menu-overlay.active .menu-overlay__nav-item:nth-child(2){transition-delay:.4s}
.menu-overlay.active .menu-overlay__nav-item:nth-child(3){transition-delay:.5s}
.menu-overlay.active .menu-overlay__nav-item:nth-child(4){transition-delay:.6s}
.menu-overlay__nav-item:hover{opacity:.5}
.menu-overlay__cta{position:absolute;bottom:60px;right:80px;font-size:12px;letter-spacing:2px;text-transform:uppercase;text-decoration:underline;text-underline-offset:4px;cursor:pointer}

.contact-overlay{position:fixed;top:0;left:0;width:100%;height:100%;z-index:3000;display:flex;pointer-events:none;opacity:0;transition:opacity .5s var(--ts)}
.contact-overlay.active{pointer-events:all;opacity:1}
.contact-overlay__bg{position:absolute;inset:0;background:var(--black);opacity:0;transition:opacity .6s var(--ts)}
.contact-overlay.active .contact-overlay__bg{opacity:1}
.contact-overlay__left{width:42%;height:100%;position:relative;z-index:1;display:flex;flex-direction:column;justify-content:center;padding:60px 56px;transform:translateX(-100%);transition:transform .7s var(--tp)}
.contact-overlay.active .contact-overlay__left{transform:translateX(0)}
.contact-overlay__headline{font-family:'Futura Bk Book','Futura','Century Gothic',sans-serif;font-size:44px;font-weight:400;font-style:italic;line-height:1.15;margin-bottom:24px}
.contact-overlay__subtitle{font-size:17px;font-weight:300;color:var(--gray-light);margin-bottom:56px}
.contact-overlay__region{margin-bottom:32px}
.contact-overlay__region-name{font-size:20px;font-weight:400;margin-bottom:8px}
.contact-overlay__region-address{font-size:17px;font-weight:300;color:var(--gray-light);line-height:1.6}
.contact-overlay__region-email{font-size:17px;font-weight:300;color:var(--gray-light)}
.contact-overlay__right{width:58%;height:100%;position:relative;z-index:1;display:flex;flex-direction:column;transform:translateX(100%);transition:transform .7s var(--tp);transition-delay:.08s}
.contact-overlay.active .contact-overlay__right{transform:translateX(0)}
.contact-overlay__close{position:absolute;top:20px;right:32px;font-size:11px;letter-spacing:2.5px;text-transform:uppercase;cursor:pointer;z-index:3;transition:opacity .3s}
.contact-overlay__close:hover{opacity:.6}
.cf__progress{padding:48px 56px 0}
.cf__bar{width:100%;height:2px;background:rgba(255,255,255,.12);margin-bottom:12px}
.cf__fill{height:100%;background:var(--white);transition:width .5s var(--tp);width:33.33%}
.cf__ind{font-size:16px;font-weight:300;color:var(--gray-light)}
.cf__header{padding:28px 56px 0}
.cf__title{font-size:17px;letter-spacing:2px;text-transform:uppercase;text-decoration:underline;text-underline-offset:4px;margin-bottom:10px}
.cf__desc{font-size:17px;font-weight:300;color:var(--gray-light)}
.cf__body{flex:1;display:flex;flex-direction:column;justify-content:center;padding:0 56px}
.cf__step{display:none;opacity:0;transform:translateX(30px);transition:opacity .4s var(--tp),transform .4s var(--tp)}
.cf__step.active{display:block}.cf__step.visible{opacity:1;transform:translateX(0)}
.fr{display:grid;grid-template-columns:1fr 1fr;gap:0 32px;margin-bottom:28px}
.fr--full{grid-template-columns:1fr}
.ff{display:flex;flex-direction:column;margin-bottom:8px}
.ff__l{font-size:16px;font-weight:300;color:var(--gray-light);margin-bottom:10px}
.ff__i{background:transparent;border:none;border-bottom:1px solid rgba(255,255,255,.2);color:var(--white);font-family:inherit;font-size:18px;font-weight:300;padding:8px 0;outline:none;transition:border-color .3s}
.ff__i:focus{border-color:rgba(255,255,255,.6)}
.ff__i.field-error{border-color:#e55;animation:shake .4s ease}
.st.field-error{outline:1px solid #e55;outline-offset:8px;border-radius:4px;animation:shake .4s ease}
.fcb__i.field-error{outline:2px solid #e55;outline-offset:2px;animation:shake .4s ease}
@keyframes shake{0%,100%{transform:translateX(0)}20%,60%{transform:translateX(-6px)}40%,80%{transform:translateX(6px)}}
.ff__i::placeholder{color:rgba(255,255,255,.2)}
.ff__i[type="date"]{cursor:pointer}
.ff__i[type="date"]::-webkit-calendar-picker-indicator{filter:invert(1);cursor:pointer;opacity:.6;transition:opacity .3s}
.ff__i[type="date"]::-webkit-calendar-picker-indicator:hover{opacity:1}
.sl{font-size:17px;font-weight:300;color:var(--gray-light);margin-bottom:20px}
.st{display:flex;flex-wrap:wrap;gap:10px;margin-top:8px}
.st__t{padding:10px 18px;border:1px solid rgba(255,255,255,.25);background:transparent;color:var(--white);font-family:inherit;font-size:11px;letter-spacing:1.5px;text-transform:uppercase;cursor:pointer;transition:background .3s,border-color .3s;user-select:none}
.st__t:hover{border-color:rgba(255,255,255,.5)}
.st__t.selected{background:var(--white);color:var(--black);border-color:var(--white)}
.fcb{display:flex;align-items:center;gap:12px;margin-top:24px;cursor:pointer}
.fcb__i{width:16px;height:16px;border:1px solid rgba(255,255,255,.3);background:transparent;appearance:none;cursor:pointer;position:relative;flex-shrink:0;transition:background .2s}
.fcb__i:checked{background:var(--white);border-color:var(--white)}
.fcb__i:checked::after{content:'✓';position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:11px;color:var(--black);font-weight:600}
.fcb__l{font-size:15px;letter-spacing:1.5px;text-transform:uppercase;color:var(--gray-light)}
.cf__nav{display:flex;justify-content:space-between;align-items:center;padding:0 56px 40px}
.cf__btn{font-size:12px;letter-spacing:2px;text-transform:uppercase;cursor:pointer;background:none;border:none;color:var(--white);font-family:inherit;transition:opacity .3s;padding:0}
.cf__btn:hover{opacity:.6}
.cf__btn--next,.cf__btn--submit{text-decoration:underline;text-underline-offset:4px}
.cf__btn--back{opacity:.6}.cf__btn--back:hover{opacity:1}

.showcase-hero{padding:90px 60px 0;display:flex;align-items:stretch;gap:56px;contain:layout style}
.showcase-hero__media{flex:0 0 52%;position:relative;overflow:hidden;aspect-ratio:1/1.15;background:#222}
.showcase-hero__image{width:100%;height:100%;object-fit:cover}
.showcase-hero__play-btn{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:64px;height:64px;border-radius:50%;background:rgba(255,255,255,.15);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:1;transition:background .4s,transform .3s}
.showcase-hero__play-btn:hover{background:rgba(255,255,255,.25);transform:translate(-50%,-50%) scale(1.05)}
.showcase-hero__play-btn svg{width:18px;height:18px;margin-left:3px;fill:var(--white)}
.showcase-hero__content{flex:0 0 40%;padding-top:16px;display:flex;flex-direction:column;justify-content:center}
.showcase-hero__title{font-size:40px;font-weight:300;letter-spacing:2px;text-transform:uppercase;line-height:1.1;margin-bottom:28px}
.showcase-hero__text{font-size:18px;font-weight:300;line-height:1.75;color:var(--gray-light);max-width:380px}
.latest-projects{padding:80px 60px 0}
.latest-projects__title{font-size:36px;font-weight:300;letter-spacing:1px;text-transform:uppercase;margin-bottom:40px}
.projects-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.project-card{cursor:pointer;position:relative;display:block}
.project-card__image-wrapper{width:100%;aspect-ratio:3/2;overflow:hidden}
.project-card__image{width:100%;height:100%;object-fit:cover;transition:transform .8s var(--tp);filter:brightness(.9)}
.project-card:hover .project-card__image{transform:scale(1.04);filter:brightness(1)}
.project-card__info{display:flex;align-items:baseline;justify-content:space-between;margin-top:16px}
.project-card__service{font-size:17px;font-weight:400;letter-spacing:1px;text-transform:uppercase}
.project-card__client{font-size:17px;font-weight:300;color:var(--gray-light)}

.page-header{padding:100px 60px 0}
.page-header__client{font-size:17px;font-weight:300;opacity:.6;margin-bottom:6px}
.page-header__title{font-size:42px;font-weight:300;letter-spacing:2px;text-transform:uppercase;line-height:1.1}
.service-hero{padding:40px 60px 0;display:flex;align-items:stretch;gap:48px}
.service-hero__media{flex:0 0 55%;aspect-ratio:16/10;position:relative;overflow:hidden;background:#222}
.service-hero__image{width:100%;height:100%;object-fit:cover}
.service-hero__desc{flex:1;display:flex;flex-direction:column;justify-content:center;padding:20px 0}
.service-hero__desc-text{font-size:19px;font-weight:300;line-height:1.8;color:var(--gray-light);letter-spacing:.3px}
.service-hero__desc-text p{margin-bottom:16px}
.service-hero__desc-text p:last-child{margin-bottom:0}
.service-detail{padding:56px 60px 0;display:flex;align-items:flex-start;justify-content:space-between;gap:80px}
.service-detail__left{flex:0 0 55%}
.service-detail__label{font-family:'Futura Bk Book','Futura','Century Gothic',sans-serif;font-size:30px;font-weight:400;margin-bottom:20px}
.service-detail__text{font-size:18px;font-weight:300;line-height:1.75;color:var(--gray-light);max-width:420px}
.service-detail__right{flex:0 0 35%;padding-top:4px}
.service-detail__meta-group{margin-bottom:28px}
.service-detail__meta-title{font-size:20px;font-weight:400;margin-bottom:6px}
.service-detail__meta-value{font-size:18px;font-weight:300;color:var(--gray-light);line-height:1.6}

.work-section{padding:64px 0 0}
.work-section__label{text-align:center;font-size:19px;font-weight:300;margin-bottom:32px}
.work-gallery{position:relative;height:580px;width:100%;overflow:hidden;cursor:grab}
.work-gallery.grabbing{cursor:grabbing}
.work-gallery__item,.work-gallery__item--center{position:absolute;top:50%;left:50%;width:740px;height:500px;overflow:hidden;border-radius:16px;border:1.5px solid rgba(255,255,255,.25);box-shadow:0 8px 40px rgba(0,0,0,.4);transition:transform .6s var(--tp),opacity .6s var(--tp);transform:translate(-50%,-50%) scale(.75);opacity:.5;z-index:1;will-change:transform,opacity}
.work-gallery__item.carousel-active,.work-gallery__item--center.carousel-active{transform:translate(-50%,-50%) scale(1);opacity:1;z-index:3}
.work-gallery__item.carousel-prev,.work-gallery__item--center.carousel-prev{transform:translate(-115%,-50%) scale(.85);opacity:.6;z-index:2}
.work-gallery__item.carousel-next,.work-gallery__item--center.carousel-next{transform:translate(15%,-50%) scale(.85);opacity:.6;z-index:2}
.work-gallery__image{width:100%;height:100%;object-fit:cover;pointer-events:none}

.footer{padding:80px 60px 48px;background:var(--black);margin-top:80px;border-top:1px solid rgba(255,255,255,.08);content-visibility:auto;contain-intrinsic-size:0 300px}
.footer__logo-area{display:flex;justify-content:center;align-items:center;flex-direction:column;margin-bottom:64px}
.footer__logo{font-family:'Futura Bk Book','Futura','Century Gothic',sans-serif;font-size:64px;font-style:italic;letter-spacing:14px;text-transform:uppercase;line-height:1;display:flex;align-items:flex-end;justify-content:center}
.footer__logo-img{height:64px;width:auto;display:block}
.footer__logo-sub{font-size:12px;letter-spacing:6px;text-transform:uppercase;margin-top:8px;font-weight:300}
.footer__divider{width:100%;height:1px;background:rgba(255,255,255,.12);margin-bottom:40px}
.footer__columns{display:flex;justify-content:space-between;align-items:flex-start}
.footer__col{display:flex;flex-direction:column;gap:8px}
.footer__col-title{font-size:18px;font-weight:400;margin-bottom:4px}
.footer__col-link{font-size:16px;font-weight:300;color:var(--gray-light);cursor:pointer;transition:color .3s}
.footer__col-link:hover{color:var(--white);opacity:1}
.footer__col-email{font-size:16px;font-weight:300;color:var(--gray-light);text-decoration:underline;text-underline-offset:3px}
.footer__lets-talk{font-size:17px;letter-spacing:2px;text-transform:uppercase;text-decoration:underline;text-underline-offset:4px;cursor:pointer}

.reveal{opacity:0;transform:translateY(24px);transition:opacity .8s var(--tp),transform .8s var(--tp);will-change:opacity,transform}
.reveal.visible{opacity:1;transform:translateY(0);will-change:auto}
.reveal-delay-1{transition-delay:.1s}.reveal-delay-2{transition-delay:.2s}.reveal-delay-3{transition-delay:.3s}

@media(max-width:1024px){.showcase-hero{flex-direction:column;gap:40px;padding:84px 40px 0}.showcase-hero__media{flex:0 0 auto;width:100%;max-width:560px;aspect-ratio:1}.showcase-hero__content{flex:0 0 auto;padding-top:0}.latest-projects{padding:60px 40px 0}.service-detail{flex-direction:column;gap:40px;padding:40px 40px 0}.service-detail__left,.service-detail__right{flex:0 0 100%}.service-hero{padding:32px 40px 0;gap:32px}.service-hero__media{flex:0 0 50%}.page-header{padding-left:40px;padding-right:40px}.work-section{padding:48px 0 0}.work-gallery{height:500px}.work-gallery__item,.work-gallery__item--center{width:620px;height:420px}.menu-overlay__nav-item{font-size:40px}.menu-overlay__right{padding:60px 48px}.contact-overlay__left{width:38%;padding:48px 36px}.contact-overlay__right{width:62%}.contact-overlay__headline{font-size:36px}}
@media(max-width:768px){.nav{padding:16px 20px}.nav__logo{font-size:22px;letter-spacing:4px}.nav__logo-img{height:22px}.nav__left{display:none}.nav__right{gap:20px}.showcase-hero{padding:80px 24px 0}.showcase-hero__media{aspect-ratio:4/3;max-width:100%}.showcase-hero__title{font-size:26px}.showcase-hero__text{font-size:16px;max-width:100%}.latest-projects{padding:48px 24px 0}.latest-projects__title{font-size:24px}.projects-grid{grid-template-columns:1fr;gap:24px}.project-card__image-wrapper{aspect-ratio:4/3}.project-card__service{font-size:14px}.project-card__client{font-size:14px}.page-header{padding:84px 24px 0}.page-header__title{font-size:28px}.service-hero{padding:28px 24px 0;flex-direction:column;gap:20px}.service-hero__media{flex:none;width:100%}.service-hero__desc-text{font-size:16px}.service-detail{padding:36px 24px 0}.service-detail__label{font-size:24px}.work-section{padding:40px 0 0}.work-section__label{font-size:16px}.work-gallery{height:400px}.work-gallery__item,.work-gallery__item--center{width:85vw;max-width:480px;height:320px}.footer{padding:60px 24px 36px}.footer__columns{flex-wrap:wrap;gap:32px}.footer__col-title{font-size:16px}.footer__col-email,.footer__col-link{font-size:14px}.footer__logo-img{height:44px}.menu-overlay__left{display:none}.menu-overlay__right{width:100%;padding:80px 32px 60px}.menu-overlay__nav-item{font-size:32px;padding:20px 0}.contact-overlay__left{display:none}.contact-overlay__right{width:100%}.cf__progress,.cf__header{padding-left:28px;padding-right:28px}.cf__body{padding:0 28px}.cf__nav{padding:0 28px 32px}.cf__title{font-size:15px}.cf__desc{font-size:15px}.ff__l{font-size:14px}.ff__i{font-size:16px}.sl{font-size:15px}.st__t{font-size:10px;padding:8px 14px}.contact-overlay__headline{font-size:28px}}
@media(max-width:480px){.fr{grid-template-columns:1fr}.showcase-hero__title{font-size:22px}.work-gallery{height:280px}.work-gallery__item,.work-gallery__item--center{width:88vw;max-width:360px;height:220px}.footer__logo-img{height:32px}.footer__columns{gap:24px}.menu-overlay__nav-item{font-size:26px;padding:16px 0}.st{gap:8px}.st__t{font-size:9px;padding:7px 10px}}

/* PAGE LOADER */
#aster-loader{position:fixed;inset:0;z-index:9999998;background:#000;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:28px;transition:opacity .8s ease,visibility .8s ease}
#aster-loader.out{opacity:0;visibility:hidden;pointer-events:none}
.aster-loader__img{height:32px;width:auto;filter:brightness(0) invert(1);animation:loader-pulse 1.6s ease-in-out infinite}
.aster-loader__bar{width:120px;height:1px;background:rgba(255,255,255,.15);overflow:hidden;position:relative}
.aster-loader__bar::after{content:'';position:absolute;left:-100%;top:0;height:100%;width:100%;background:rgba(255,255,255,.7);animation:loader-bar 1.6s ease-in-out infinite}
@keyframes loader-pulse{0%,100%{opacity:1}50%{opacity:.2}}
@keyframes loader-bar{0%{left:-100%}100%{left:100%}}

/* CURSOR */
@media(min-width:1024px){
  *{cursor:none!important}
  .cursor{position:fixed;top:0;left:0;width:12px;height:12px;border-radius:50%;background:var(--white);pointer-events:none;z-index:99999;transform:translate(-50%,-50%);transition:width .35s var(--tp),height .35s var(--tp),background .35s var(--tp),opacity .2s;will-change:transform}
  body:not(:hover) .cursor{opacity:0}
  body:has(:is(a,button,input,select,textarea,[role=button]):hover) .cursor{width:40px;height:40px;background:rgba(255,255,255,.15);border:1px solid rgba(255,255,255,.6)}
  .cursor-dot{position:fixed;top:0;left:0;width:4px;height:4px;border-radius:50%;background:var(--white);pointer-events:none;z-index:100000;transform:translate(-50%,-50%);will-change:transform}
}
@media(max-width:1023px){.cursor,.cursor-dot{display:none!important}}

.confirm-overlay{position:fixed;inset:0;z-index:10000;background:rgba(0,0,0,.95);display:flex;align-items:center;justify-content:center;text-align:center;opacity:0;pointer-events:none;transition:opacity .6s ease;cursor:pointer}
.confirm-overlay.active{opacity:1;pointer-events:all}
.confirm-overlay__inner{padding:40px;max-width:620px}
.confirm-overlay__title{font-family:'Futura Bk Book','Futura','Century Gothic',sans-serif;font-size:clamp(28px,5vw,52px);font-style:italic;letter-spacing:4px;text-transform:uppercase;margin-bottom:28px;line-height:1.15}
.confirm-overlay__sub{font-size:clamp(18px,2.5vw,22px);font-weight:300;line-height:1.7;color:rgba(255,255,255,.8);letter-spacing:.4px}
