:root{--navy:#10185b;--red:#df2b31;--ink:#16181d;--muted:#6a6f79;--line:#e7e8ec;--soft:#f6f7f9;--white:#fff;--max:1200px;--shadow:0 14px 40px rgba(12,18,55,.12)}
*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;font-family:Inter,Arial,sans-serif;color:var(--ink);background:#fff;line-height:1.65}img{max-width:100%;display:block}a{text-decoration:none;color:inherit}.container{width:min(calc(100% - 40px),var(--max));margin:auto}.topbar{height:36px;background:var(--navy);color:#fff;font-size:12px}.topbar-inner,.topbar-left,.topbar-right{display:flex;align-items:center;justify-content:space-between;height:100%;gap:20px}.topbar-left{justify-content:flex-start}.site-header{height:84px;background:#fff;position:sticky;top:0;z-index:50;border-bottom:1px solid rgba(0,0,0,.06);transition:.3s}.header-inner{height:100%;display:flex;align-items:center;justify-content:space-between}.brand img{width:220px;max-height:58px;object-fit:contain}.main-nav{display:flex;align-items:center;gap:25px;font-size:13px;font-weight:500}.main-nav a{position:relative}.main-nav a:not(.nav-cta):after{content:"";position:absolute;left:0;bottom:-9px;width:0;height:2px;background:var(--red);transition:.25s}.main-nav a:hover:after,.main-nav a.active:after{width:100%}.nav-cta,.btn{background:var(--red);color:#fff;padding:12px 18px;border-radius:3px;font-weight:600;display:inline-flex;align-items:center;justify-content:center;border:1px solid var(--red);transition:.25s}.btn:hover,.nav-cta:hover{background:#bd2027;border-color:#bd2027}.btn.outline{background:transparent;border-color:#fff}.btn.dark-outline{background:transparent;color:var(--navy);border-color:var(--navy)}.menu-toggle{display:none;background:none;border:0}.hero{min-height:650px;display:flex;align-items:center;position:relative;color:#fff;background:center/cover no-repeat}.hero:before,.page-hero:before{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(7,11,38,.76),rgba(7,11,38,.28) 55%,rgba(7,11,38,.08))}.hero .container,.page-hero .container{position:relative;z-index:2}.hero-copy{max-width:590px}.eyebrow{font-size:12px;letter-spacing:.2em;text-transform:uppercase;font-weight:600;color:var(--red);margin-bottom:14px}.hero .eyebrow{color:#fff;opacity:.82}.hero h1{font-family:"Libre Franklin",sans-serif;font-size:clamp(38px,5vw,62px);line-height:1.12;letter-spacing:-.035em;font-weight:500;margin:0 0 20px}.hero p{font-size:17px;font-weight:300;max-width:580px;color:rgba(255,255,255,.9)}.hero-actions{display:flex;gap:12px;margin-top:30px}.anniversary{margin-top:40px;display:flex;align-items:center;gap:15px;font-size:13px}.anniversary strong{font-size:32px;font-weight:500}.section{padding:95px 0}.section.soft{background:var(--soft)}.section.dark{background:var(--navy);color:#fff}.section-head{max-width:690px;margin-bottom:42px}.section-head.center{text-align:center;margin-left:auto;margin-right:auto}.section h2,.page-hero h1{font-family:"Libre Franklin",sans-serif;font-size:clamp(30px,4vw,46px);line-height:1.2;letter-spacing:-.025em;font-weight:500;margin:0 0 18px}.section-head p{color:var(--muted)}.dark .section-head p{color:rgba(255,255,255,.72)}.split{display:grid;grid-template-columns:1.05fr .95fr;gap:70px;align-items:center}.split.reverse .media{order:2}.media img{width:100%;height:500px;object-fit:cover;border-radius:4px}.accent-line{width:55px;height:3px;background:var(--red);margin:22px 0}.stats{display:grid;grid-template-columns:repeat(4,1fr);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}.stat{padding:30px;border-right:1px solid var(--line)}.stat:last-child{border:0}.stat strong{display:block;font-size:30px;font-weight:500;color:var(--navy)}.stat span{font-size:13px;color:var(--muted)}.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}.card{background:#fff;border:1px solid var(--line);transition:.3s}.card:hover{transform:translateY(-6px);box-shadow:var(--shadow)}.card img{height:230px;width:100%;object-fit:cover}.card-body{padding:26px}.card h3{font-size:19px;font-weight:600;margin:0 0 10px}.card p{font-size:14px;color:var(--muted)}.text-link{font-size:13px;color:var(--red);font-weight:600}.project-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}.project{position:relative;overflow:hidden;min-height:380px}.project img{width:100%;height:100%;object-fit:cover;position:absolute;inset:0;transition:.5s}.project:after{content:"";position:absolute;inset:0;background:linear-gradient(0deg,rgba(5,8,28,.84),transparent 65%)}.project:hover img{transform:scale(1.04)}.project-info{position:absolute;left:28px;right:28px;bottom:24px;color:#fff;z-index:2}.project-info h3{margin:4px 0;font-size:21px;font-weight:500}.project-info span{font-size:11px;letter-spacing:.16em;text-transform:uppercase}.feature-list{display:grid;grid-template-columns:repeat(2,1fr);gap:15px}.feature-list div{padding:17px 18px;background:#fff;border-left:3px solid var(--red);color:var(--ink);font-size:14px}.cta{padding:65px;background:var(--red);color:#fff;display:flex;align-items:center;justify-content:space-between;gap:30px}.cta h2{margin:0;font-size:34px}.page-hero{height:360px;background:center/cover no-repeat;display:flex;align-items:flex-end;padding-bottom:65px;color:#fff;position:relative}.page-hero h1{margin-bottom:8px}.breadcrumbs{font-size:12px;opacity:.8}.content-grid{display:grid;grid-template-columns:2fr 1fr;gap:55px}.side-nav{border:1px solid var(--line);padding:25px;position:sticky;top:110px}.side-nav a{display:block;padding:10px 0;border-bottom:1px solid var(--line);font-size:14px}.service-block{padding:35px 0;border-bottom:1px solid var(--line);scroll-margin-top:120px}.service-block h3{font-size:25px;font-weight:500}.gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:15px}.gallery img{height:230px;width:100%;object-fit:cover}.logo-wall{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}.client-box{height:130px;border:1px solid var(--line);display:flex;align-items:center;justify-content:center;text-align:center;padding:20px;font-weight:600;color:var(--navy);background:#fff}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}.form-field{display:flex;flex-direction:column;gap:7px}.form-field.full{grid-column:1/-1}.form-field label{font-size:12px;font-weight:600}.form-field input,.form-field select,.form-field textarea{padding:14px;border:1px solid #d8dbe2;font:inherit;background:#fff}.form-field textarea{min-height:140px}.site-footer{background:#0c103a;color:rgba(255,255,255,.74);padding:70px 0 20px}.footer-grid{display:grid;grid-template-columns:1.5fr repeat(3,1fr);gap:50px}.footer-grid h4{color:#fff;font-size:14px}.footer-grid a{display:block;margin:8px 0;font-size:13px}.footer-logo{width:220px;background:#fff;padding:8px;margin-bottom:20px}.footer-bottom{border-top:1px solid rgba(255,255,255,.12);margin-top:45px;padding-top:20px;display:flex;justify-content:space-between;font-size:12px}.whatsapp,.backtop{position:fixed;right:20px;width:46px;height:46px;border-radius:50%;display:grid;place-items:center;z-index:40;border:0;color:#fff;font-weight:700}.whatsapp{bottom:74px;background:#20b55a}.backtop{bottom:20px;background:var(--navy);cursor:pointer}.reveal{opacity:0;transform:translateY(25px);transition:.7s}.reveal.visible{opacity:1;transform:none}.preloader{position:fixed;inset:0;background:#fff;z-index:1000;display:flex;align-items:center;justify-content:center;gap:13px;transition:.5s}.preloader span{width:28px;height:28px;border:3px solid #ddd;border-top-color:var(--red);border-radius:50%;animation:spin .8s linear infinite}.preloader b{font-size:13px;letter-spacing:.18em}.preloader.done{opacity:0;visibility:hidden}@keyframes spin{to{transform:rotate(360deg)}}
@media(max-width:980px){.topbar-left span{display:none}.menu-toggle{display:block;width:40px}.menu-toggle span{display:block;height:2px;background:var(--navy);margin:6px}.main-nav{position:absolute;top:84px;left:0;right:0;background:#fff;display:none;flex-direction:column;align-items:stretch;padding:25px 30px;box-shadow:var(--shadow)}.main-nav.open{display:flex}.main-nav a{padding:7px 0}.split,.content-grid{grid-template-columns:1fr}.split.reverse .media{order:0}.cards{grid-template-columns:repeat(2,1fr)}.footer-grid{grid-template-columns:repeat(2,1fr)}.side-nav{position:static}.hero{min-height:590px}.hero h1{font-size:46px}.stats{grid-template-columns:repeat(2,1fr)}.stat:nth-child(2){border-right:0}}
@media(max-width:650px){.container{width:min(calc(100% - 28px),var(--max))}.topbar{display:none}.site-header{height:72px}.brand img{width:185px}.main-nav{top:72px}.hero{min-height:600px;align-items:flex-end;padding:100px 0 70px;background-position:62% center}.hero:before{background:linear-gradient(0deg,rgba(7,11,38,.9),rgba(7,11,38,.15) 75%)}.hero h1{font-size:34px;line-height:1.16;max-width:360px}.hero p{font-size:15px}.hero-actions{flex-wrap:wrap}.section{padding:70px 0}.section h2{font-size:31px}.media img{height:340px}.cards,.project-grid,.gallery,.logo-wall,.form-grid{grid-template-columns:1fr}.project{min-height:300px}.stats{grid-template-columns:1fr 1fr}.stat{padding:22px 15px}.stat strong{font-size:24px}.feature-list{grid-template-columns:1fr}.cta{padding:38px 25px;display:block}.cta h2{font-size:28px;margin-bottom:22px}.footer-grid{grid-template-columns:1fr}.footer-bottom{display:block}.page-hero{height:300px;padding-bottom:45px}}

/* Modern motion, transparent header and language controls */
body{padding-top:0}.topbar{position:relative;z-index:90}.site-header{position:absolute;top:36px;left:0;right:0;background:transparent;border-bottom:1px solid rgba(255,255,255,.18);color:#fff;z-index:80;box-shadow:none}.site-header.scrolled{position:fixed;top:0;background:rgba(255,255,255,.97);color:var(--ink);border-bottom-color:rgba(0,0,0,.06);box-shadow:0 8px 28px rgba(10,16,55,.09);backdrop-filter:blur(12px)}
.brand{position:relative;display:block;width:220px;height:58px}.brand img{position:absolute;inset:0;width:220px;height:58px;object-fit:contain;transition:opacity .3s ease}.brand .logo-normal{opacity:0}.brand .logo-white{opacity:1}.site-header.scrolled .logo-normal,.site-header.menu-open .logo-normal{opacity:1}.site-header.scrolled .logo-white,.site-header.menu-open .logo-white{opacity:0}.site-header:not(.scrolled) .main-nav a{color:#fff}.site-header.scrolled .main-nav a,.site-header.menu-open .main-nav a{color:var(--ink)}.site-header:not(.scrolled) .menu-toggle span{background:#fff}.site-header.scrolled .menu-toggle span,.site-header.menu-open .menu-toggle span{background:var(--navy)}
.hero,.page-hero{overflow:hidden;background-image:none!important}.hero::after,.page-hero::after{content:"";position:absolute;inset:-4%;background-image:var(--hero-image);background-position:center;background-size:cover;z-index:0;animation:heroBreath 18s ease-in-out infinite alternate;will-change:transform}.hero:before,.page-hero:before{z-index:1}.hero .container,.page-hero .container{z-index:3}.hero-light-wave{position:absolute;z-index:2;inset:-40% auto -40% -55%;width:34%;transform:skewX(-16deg);background:linear-gradient(90deg,transparent,rgba(255,255,255,.03),rgba(255,255,255,.14),rgba(255,255,255,.025),transparent);filter:blur(9px);animation:lightSweep 9s ease-in-out infinite;pointer-events:none;mix-blend-mode:screen}.hero h1{font-size:clamp(32px,4vw,50px);font-weight:400;line-height:1.16;letter-spacing:-.025em;max-width:520px}.hero p{font-size:16px;max-width:540px}.page-hero h1{font-weight:400;font-size:clamp(30px,3.5vw,43px)}
@keyframes heroBreath{0%{transform:scale(1.035) translate3d(-.4%,0,0)}50%{transform:scale(1.075) translate3d(.5%,-.3%,0)}100%{transform:scale(1.045) translate3d(0,.4%,0)}}
@keyframes lightSweep{0%,15%{left:-55%;opacity:0}30%{opacity:.85}55%{left:122%;opacity:.25}70%,100%{left:122%;opacity:0}}
.language-wrap{position:relative;height:100%;display:flex;align-items:center}.language-toggle{height:100%;border:0;background:transparent;color:#fff;display:flex;align-items:center;gap:8px;font:inherit;cursor:pointer;padding:0}.language-toggle b{font-size:10px;padding:2px 6px;border:1px solid rgba(255,255,255,.35);border-radius:2px}.language-toggle i{width:6px;height:6px;border-right:1px solid #fff;border-bottom:1px solid #fff;transform:rotate(45deg) translateY(-2px)}.language-menu{position:absolute;right:0;top:calc(100% + 8px);width:245px;background:#fff;color:var(--ink);padding:10px;box-shadow:0 18px 45px rgba(7,11,38,.22);border:1px solid var(--line);opacity:0;visibility:hidden;transform:translateY(-6px);transition:.22s;z-index:120}.language-wrap.open .language-menu{opacity:1;visibility:visible;transform:none}.language-menu button{display:block;width:100%;text-align:left;border:0;background:transparent;padding:10px 11px;font:inherit;font-size:13px;cursor:pointer}.language-menu button:hover{background:var(--soft);color:var(--red)}.language-divider{height:1px;background:var(--line);margin:6px 0}.language-menu .stop-translate{font-size:11px;color:var(--muted)}.language-menu small{display:block;padding:8px 11px 4px;font-size:9px;color:#999}.goog-te-banner-frame,.skiptranslate iframe{display:none!important}body{top:0!important}#google_translate_element{position:absolute;width:1px;height:1px;overflow:hidden;opacity:0;pointer-events:none}
.site-footer{position:relative;overflow:hidden;padding-top:82px;background:radial-gradient(circle at 90% 18%,rgba(223,43,49,.12),transparent 27%),linear-gradient(145deg,#090d31,#0c103a 58%,#11195a)}.footer-grid,.footer-bottom{position:relative;z-index:3}.footer-logo{background:transparent;padding:0}.footer-art{position:absolute;inset:0;pointer-events:none;overflow:hidden}.footer-square{position:absolute;border:1px solid rgba(255,255,255,.09);display:block;animation:footerSpin 28s linear infinite}.square-one{width:130px;height:130px;right:8%;top:15%;transform:rotate(15deg)}.square-two{width:72px;height:72px;right:28%;bottom:12%;animation-duration:20s;animation-direction:reverse}.square-three{width:190px;height:190px;left:-70px;bottom:-85px;animation-duration:38s}.footer-watermark{position:absolute;right:5%;top:28%;display:flex;align-items:center;gap:12px;color:rgba(255,255,255,.045);transform:rotate(-4deg);animation:footerFloat 8s ease-in-out infinite}.footer-watermark strong{font-size:130px;line-height:.8;font-weight:500}.footer-watermark span{font-size:22px;line-height:1.15;font-weight:600;letter-spacing:.08em}.footer-bottom a{color:#fff;font-weight:600}.footer-bottom a:hover{color:#ef565b}
@keyframes footerSpin{to{transform:rotate(375deg)}}@keyframes footerFloat{50%{transform:translateY(-12px) rotate(-2deg)}}
.preloader{transition:opacity .55s ease,visibility .55s ease}.preloader.done{pointer-events:none}
@media(max-width:980px){.site-header{top:36px}.site-header.menu-open{background:#fff;color:var(--ink);box-shadow:var(--shadow)}.main-nav{top:84px}.site-header:not(.scrolled) .main-nav{background:#fff}.footer-watermark{right:-5%;opacity:.7}.hero h1{font-size:42px}}
@media(max-width:650px){.topbar{display:block;height:34px}.topbar-left a:not(:first-child),.topbar-left span{display:none}.topbar-inner{gap:10px}.language-toggle span{display:none}.site-header{top:34px;height:72px}.site-header.scrolled{top:0}.main-nav{top:72px}.brand,.brand img{width:185px;height:50px}.hero{padding-top:135px}.hero h1{font-size:31px;max-width:330px}.hero p{font-size:14px}.footer-watermark{right:-25%;top:38%}.footer-watermark strong{font-size:100px}.footer-watermark span{font-size:17px}.square-one{right:-45px}}
@media(prefers-reduced-motion:reduce){.hero::after,.page-hero::after,.hero-light-wave,.footer-square,.footer-watermark{animation:none!important}}


/* Requested fly-in motion, premium preloader, social icons and compact page galleries */
.hero-copy,.page-hero .container{opacity:0;filter:blur(4px);transform:translate3d(-72px,30px,0);will-change:opacity,transform,filter}
body.motion-ready .hero-copy,body.motion-ready .page-hero .container{animation:heroContentFly 1.12s cubic-bezier(.16,.84,.24,1) .08s both}
@keyframes heroContentFly{
  0%{opacity:0;filter:blur(4px);transform:translate3d(-72px,30px,0) scale(.975)}
  72%{opacity:1;filter:blur(0);transform:translate3d(7px,-2px,0) scale(1.004)}
  100%{opacity:1;filter:none;transform:none}
}
.fly-in{opacity:0;filter:blur(4px);transition:opacity .92s ease,transform 1.05s cubic-bezier(.16,.84,.24,1),filter .88s ease;transition-delay:var(--fly-delay,0ms);will-change:opacity,transform,filter}
.fly-in.fly-left{transform:translate3d(-86px,32px,0) scale(.97)}
.fly-in.fly-right{transform:translate3d(86px,32px,0) scale(.97)}
.fly-in.visible{opacity:1;filter:none;transform:none}

.nav-socials{display:flex;align-items:center;gap:9px;margin-left:-5px}
.nav-socials a,.footer-socials a{display:grid;place-items:center;width:34px;height:34px;border:1px solid currentColor;border-radius:50%;transition:transform .25s ease,background .25s ease,color .25s ease,border-color .25s ease}
.nav-socials a:after{display:none!important}
.nav-socials svg,.footer-socials svg{width:15px;height:15px;fill:currentColor}
.site-header:not(.scrolled):not(.menu-open) .nav-socials a{color:#fff;border-color:rgba(255,255,255,.48)}
.site-header.scrolled .nav-socials a,.site-header.menu-open .nav-socials a{color:var(--navy);border-color:rgba(16,24,91,.25)}
.nav-socials a:hover{transform:translateY(-2px);background:var(--red);border-color:var(--red);color:#fff!important}
.footer-socials{display:flex;align-items:center;gap:10px;margin-top:20px}
.footer-grid .footer-socials a{margin:0;color:#fff;border-color:rgba(255,255,255,.3)}
.footer-socials a:hover{transform:translateY(-2px);background:var(--red);border-color:var(--red)}

.page-gallery-section{padding-top:0}
.page-gallery{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.page-gallery.page-gallery-three{grid-template-columns:repeat(3,1fr)}
.page-gallery figure{position:relative;overflow:hidden;margin:0;min-height:250px;background:var(--soft)}
.page-gallery figure:after{content:"";position:absolute;inset:0;border:1px solid rgba(255,255,255,.26);pointer-events:none}
.page-gallery img{width:100%;height:100%;min-height:250px;object-fit:cover;transition:transform .7s cubic-bezier(.2,.75,.25,1)}
.page-gallery figure:hover img{transform:scale(1.045)}
.project-grid-six{grid-template-columns:repeat(3,1fr)}
.project-grid-six .project{min-height:320px}

.preloader{
  background:transparent;
  gap:0;
  overflow:hidden;
  isolation:isolate;
  transition:visibility 0s linear 1.08s;
}

.preloader:before{
  content:"";
  position:absolute;
  inset:0;
  z-index:-2;
  background:
    radial-gradient(circle at 20% 20%,rgba(255,255,255,.12),transparent 32%),
    radial-gradient(circle at 85% 72%,rgba(77,0,6,.2),transparent 38%),
    linear-gradient(135deg,#ef343c,#d9212a 52%,#bd151e);
  background-size:170% 170%;
  animation:preloaderRedMotion 5.5s ease-in-out infinite alternate;
  transform:translateY(0);
  transition:transform .92s cubic-bezier(.76,0,.24,1) .12s;
  will-change:transform;
}

.preloader:after{
  content:"";
  position:absolute;
  inset:0;
  z-index:-1;
  background:
    linear-gradient(
      115deg,
      transparent 18%,
      rgba(255,255,255,.045) 34%,
      rgba(255,255,255,.13) 48%,
      rgba(255,255,255,.04) 62%,
      transparent 78%
    );
  background-size:220% 100%;
  animation:preloaderLightMotion 4.8s ease-in-out infinite;
  transform:translateY(0);
  transition:transform .92s cubic-bezier(.76,0,.24,1) .12s;
  will-change:transform;
}

.preloader-inner{
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:22px;
  color:#fff;
  position:relative;
  z-index:2;
  transition:opacity .26s ease,transform .72s cubic-bezier(.76,0,.24,1);
}

/* Only the progress circle, GULLIFFORD and CONTRACTORS */
.preloader-inner:before{
  display:none;
  content:none;
}

.preloader .progress-ring{
  width:56px;
  height:56px;
  border:4px solid rgba(255,255,255,.26);
  border-top-color:#fff;
  border-right-color:#fff;
  border-radius:50%;
  animation:spin .82s linear infinite;
  box-shadow:0 0 35px rgba(255,255,255,.12);
}

.preloader-brand{
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  width:max-content;
  text-align:center;
}

.preloader .preloader-word{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:.13em;
  color:#fff;
  font-family:"Libre Franklin",sans-serif;
  font-size:26px;
  font-weight:700;
  line-height:1;
  letter-spacing:.17em;
  text-shadow:0 7px 25px rgba(83,0,5,.22);
}

/*
  Each letter element is the fixed white outline.
  Only its ::after face spins, so the outline remains stationary.
*/
.preloader-word i{
  position:relative;
  display:inline-block;
  font-style:normal;
  color:transparent;
  font:inherit;
  line-height:inherit;
  letter-spacing:inherit;
  -webkit-text-stroke:1px rgba(255,255,255,.88);
  text-stroke:1px rgba(255,255,255,.88);
  text-shadow:none;
  transform:none!important;
  animation:none!important;
}

.preloader-word i::after{
  content:attr(data-letter);
  position:absolute;
  inset:0;
  display:grid;
  place-items:center;
  color:#fff;
  font:inherit;
  line-height:inherit;
  letter-spacing:inherit;
  -webkit-text-stroke:0 transparent;
  text-stroke:0 transparent;
  text-shadow:0 7px 25px rgba(83,0,5,.22);
  transform-origin:center center;
  transform-style:preserve-3d;
  backface-visibility:visible;
  animation:preloaderLetterSpinPause 2.1s cubic-bezier(.45,0,.2,1) infinite;
  animation-delay:calc(var(--i) * 70ms);
}

.preloader-subtitle{
  display:block!important;
  width:auto!important;
  height:auto!important;
  margin:11px 0 0!important;
  padding:0!important;
  border:0!important;
  border-radius:0!important;
  background:none!important;
  color:rgba(255,255,255,.94)!important;
  font-family:"Libre Franklin",sans-serif!important;
  font-size:11px!important;
  font-weight:500!important;
  line-height:1!important;
  letter-spacing:.34em!important;
  text-align:center!important;
  text-indent:.34em!important;
  box-shadow:none!important;
  transform:none!important;
  animation:preloaderContractorsGlow 1.8s ease-in-out infinite!important;
}

@keyframes preloaderLetterSpinPause{
  0%{transform:rotateY(0deg)}
  38%{transform:rotateY(180deg)}
  76.2%{transform:rotateY(360deg)}
  100%{transform:rotateY(360deg)}
}

@keyframes preloaderContractorsGlow{
  0%,100%{
    opacity:.42;
    text-shadow:0 0 0 rgba(255,255,255,0);
  }
  50%{
    opacity:1;
    text-shadow:
      0 0 8px rgba(255,255,255,.52),
      0 0 18px rgba(255,255,255,.26);
  }
}

@keyframes preloaderRedMotion{
  0%{background-position:0% 20%}
  100%{background-position:100% 80%}
}

@keyframes preloaderLightMotion{
  0%,100%{background-position:130% 0}
  50%{background-position:-40% 0}
}

@media(max-width:1100px){.project-grid-six{grid-template-columns:repeat(2,1fr)}.page-gallery{grid-template-columns:repeat(2,1fr)}}
@media(max-width:980px){.nav-socials{margin:5px 0 0}.nav-socials a{width:38px;height:38px}.main-nav .nav-socials{flex-direction:row}.site-header:not(.scrolled) .main-nav .nav-socials a{color:var(--navy);border-color:rgba(16,24,91,.25)}}
@media(max-width:650px){.project-grid-six,.page-gallery,.page-gallery.page-gallery-three{grid-template-columns:1fr}.page-gallery figure,.page-gallery img{min-height:290px}.preloader-inner:before{width:210px;height:210px}.preloader .preloader-word{font-size:21px}.preloader-subtitle{font-size:9px;letter-spacing:.3em;text-indent:.3em;margin-top:9px}.hero-copy,.page-hero .container{transform:translate3d(-48px,34px,0)}.fly-in{transition-duration:.9s,1s,.85s}.fly-in.fly-left{transform:translate3d(-52px,34px,0) scale(.965)}.fly-in.fly-right{transform:translate3d(52px,34px,0) scale(.965)}}
@media(prefers-reduced-motion:reduce){.hero-copy,.page-hero .container,.fly-in,.preloader:before,.preloader:after,.preloader-word i,.preloader-subtitle{animation:none!important;transition:none!important}.hero-copy,.page-hero .container,.fly-in{opacity:1;filter:none;transform:none}.preloader-word i{transform:none}}


/* Final specificity guard against the original generic .preloader span rule */
.preloader .preloader-subtitle{
  width:auto!important;
  height:auto!important;
  border:0!important;
  border-radius:0!important;
  background:none!important;
}


/* Subtle 10% black overlay for hero and page hero images */
.hero:before,
.page-hero:before{
  background:
    linear-gradient(rgba(0,0,0,.25),rgba(0,0,0,.25)),
    linear-gradient(
      90deg,
      rgba(7,11,38,.76),
      rgba(7,11,38,.28) 55%,
      rgba(7,11,38,.08)
    );
}


/* Mobile fly-in correction: keep the stronger phone start position,
   but always release it when IntersectionObserver adds .visible. */
@media(max-width:650px){
  .fly-in{
    transition-property:opacity,transform,filter;
    transition-duration:.88s,1.08s,.82s;
    transition-timing-function:ease,cubic-bezier(.16,.84,.24,1),ease;
  }
  .fly-in.fly-left{transform:translate3d(-72px,26px,0) scale(.965)}
  .fly-in.fly-right{transform:translate3d(72px,26px,0) scale(.965)}
  .fly-in.visible,
  .fly-in.fly-left.visible,
  .fly-in.fly-right.visible{
    opacity:1;
    filter:none;
    transform:translate3d(0,0,0) scale(1);
  }
  body.motion-ready .hero-copy,
  body.motion-ready .page-hero .container{
    animation-name:mobileHeroContentFly;
    animation-duration:1.05s;
    animation-timing-function:cubic-bezier(.16,.84,.24,1);
    animation-delay:.08s;
    animation-fill-mode:both;
  }
}
@keyframes mobileHeroContentFly{
  0%{opacity:0;filter:blur(4px);transform:translate3d(-64px,28px,0) scale(.97)}
  72%{opacity:1;filter:blur(0);transform:translate3d(6px,-2px,0) scale(1.004)}
  100%{opacity:1;filter:none;transform:translate3d(0,0,0) scale(1)}
}

/* Prevent the off-screen fly-in starting positions from widening mobile pages. */
html,
body{
  width:100%;
  max-width:100%;
  overflow-x:hidden;
}

@supports (overflow-x:clip){
  html,
  body{
    overflow-x:clip;
  }
}
