* {
    margin:0 auto;
    padding:0;
    outline:none;
}

:root {
    --background-color:#1d1d1d;
    --light-color-100:#FFF;
    --dark-color-100:#000;
    --dark-color-300:#343434;
    --dark-color-500:#555;
    --accent-blue:#4db1e8;
    --component-shadow-100:0 0 10px 0 rgba(0,0,0,0.25);
    --component-shadow-200:0 0 30px 0 rgba(0,0,0,0.75);
}

body, html {
    margin:0 auto;
    font-family: 'Montserrat', 'Open Sans', sans-serif;
    background:var(--background-color);
    color:var(--light-color-100);
    overflow-x:hidden;
}

body.htmx-swapping {
    opacity:0.5;
}

#loader,
.intro {
    position:fixed;
    top:0;
    left:0;
    height:100%;
    width:100%;
    background:rgba(0,0,0,0.72);
    z-index:10000;
}

.intro {
    display:none;
    background:#111;
    z-index:10001;
}

.intro-bar {
    position:absolute;
    bottom:0;
    left:0;
    height:10px;
    background:var(--accent-blue);
    width:0%;
    z-index:199;
}

.close-intro {
    position:absolute;
    z-index:200;
    right:0;
    top:0;
    display:block;
}
.close-intro a {
    display:block;
    color:#FFF;
    padding:15px;
    text-decoration: none;
}

#loader {
    display:block;
    background:#000;
    z-index:10000;
}

#loader svg {
    position:absolute;
    left:50%;
    top:50%;
    margin:-36px 0 0 -36px;
}

.intro video {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;   
    height: 100%; 
    object-fit: cover; 
    object-position: center; 
    z-index:150; 
}

@media only screen and (max-width:1067px){
    .intro video {
        object-fit:unset;
        left:0;
        top:50%;
        width:100vw;
        height:auto;
        margin:calc(-25% - 35px) auto 0;
    }
}


.spinner {
    -webkit-animation: rotate 2s linear infinite;
    animation: rotate 2s linear infinite;
    z-index: 2;
    position: absolute;
    top: 50%;
    left: 50%;
    margin: -25px 0 0 -25px;
    width: 50px;
    height: 50px;
}
.spinner .path {
    stroke: var(--accent-blue);
    stroke-linecap: round;
    -webkit-animation: dash 1.5s ease-in-out infinite;
    animation: dash 1.5s ease-in-out infinite;
}

@-webkit-keyframes rotate {
    100% {
        transform: rotate(360deg);
    }
}

@keyframes rotate {
    100% {
        transform: rotate(360deg);
    }
}
@-webkit-keyframes dash {
    0% {
        stroke-dasharray: 1, 150;
        stroke-dashoffset: 0;
    }
    50% {
        stroke-dasharray: 90, 150;
        stroke-dashoffset: -35;
    }
    100% {
        stroke-dasharray: 90, 150;
        stroke-dashoffset: -124;
    }
}
@keyframes dash {
    0% {
        stroke-dasharray: 1, 150;
        stroke-dashoffset: 0;
    }
    50% {
        stroke-dasharray: 90, 150;
        stroke-dashoffset: -35;
    }
    100% {
        stroke-dasharray: 90, 150;
        stroke-dashoffset: -124;
    }
}

.htmx-indicator
{
    opacity:0;
    transition: opacity 500ms ease-in;
    display:none;
}

.htmx-request .htmx-indicator,
#loader.htmx-indicator {
    opacity:1;
    display:block;
}
.htmx-request.htmx-indicator{
    opacity:1;
    display:block;
}

header,
section,
footer,
main,
.splash-block {
    position:relative;
    width:100%;
}
main {
    padding-top:108px;
}

@media only screen and (max-width:967px){
    main {
        padding-top:87px;
    }
}
header {
    padding:25px 0;
    background:var(--dark-color-100);
    position:fixed;
    z-index:9999;
}

.view-container,
.view-box {
    position:relative;
    width:1600px;
    margin:0 auto;
}

@media only screen and (max-width:1667px){
    .view-container,
    .view-box {
        width:1400px;
    }
}

@media only screen and (max-width:1467px){
    .view-container,
    .view-box {
        width:1200px;
    }
}

@media only screen and (max-width:1267px){
    .view-container,
    .view-box {
        width:1024px;
    }
}

@media only screen and (max-width:1067px){
    .view-container,
    .view-box {
        width:96%;
    }
}

.logo,
.contact,
.contact-obj,
.contact-obj-icon,
.contact-obj-text,
.menu-icon,
.triangle,
.link-text,
.icon-text-block,
.ib-text-block,
.arrow-left,
.arrow-right,
.work-block,
.work-label span,
.work-label div,
.sb-left,
.sb-right,
.client-logo,
.footer-left,
.footer-right,
.footer-disc,
.disc-footer-col,
.disc-footer-col.right span,
.disc-footer-col.right a,
.image-text-block {
    display:inline-block;
    vertical-align: middle;
    box-sizing: border-box;
}
.contact-obj-text {
    box-sizing: initial;
}
.contact-obj {
    margin-right:35px;
}

.logo {
    width:275px;
}
.logo.footer {
    width:150px;
}

@media only screen and (max-width: 967px){
    .logo {
        width:175px;
    }
}
.logo img {
    width:100%;
}
.logo:hover,
.logo img:hover,
.logo a:hover {
    cursor:pointer;
}

.contact-obj-icon {
    width:15px;
}

.contact-obj-icon.email {
    width:18px;
}

.contact-obj-icon span {
    font-size:8px;
    display:none;
}

@media only screen and (max-width:667px) {
    .contact-obj-icon.email {
        width: 19px;
        margin-right:15px;
    }
    .contact-obj-icon {
        text-align:center;
        width:36px;
    }
    .contact-obj-icon img {
        width:15px;
    }
    .contact-obj-icon span {
        display:block;
        margin:5px auto 0;
    }
}
.contact-obj-text {
    width:calc(100% - 25px);
    padding-left:10px;
    font-size:11px;
    font-weight:300;
    color:var(--accent-blue);
}

.contact-obj-text span {
    color:#FFF;
}

@media only screen and (max-width:667px){
    .contact-obj {
        margin-right:10px;
    }
    .contact-obj-text {
        display:none;
    }
}

.contact {
    width:calc(100% - 275px);
    text-align:right;
}

@media only screen and (max-width:967px){
    .contact {
        width:calc(100% - 175px);
    }
}

.menu-icon {
    width:30px;
}

.menu-icon span {
    display:block;
    text-align:left;
}
.menu-icon span div {
    width:100%;
    height:3px;
    background:var(--light-color-100);
    margin-bottom:2px;
    border-radius:2px;
    margin-left:0;
    margin-right:0;
}
.menu-icon span div:first-child,
.menu-icon span div:last-child {
    width:70%;
}
.menu-icon span div:last-child {
    background:var(--accent-blue);
}

.splash-block {
    background-size:cover!important;
    view-transition-name: slide-it;
}
.splash-block,
.splash-filter {
    min-height:75vh;
}
.splash-filter {
    display:table;
    position:relative;
    width:100%;
    background: rgb(34,34,34);
    background: linear-gradient(198deg, rgba(34,34,34,0) 0%, rgba(34,34,34,0) 22%, rgba(0,0,0,0.6573004201680672) 57%);
    z-index:10;
}
.splash-filter .view-container {
    display:table-cell;
    position:relative;
    width:100%;
    vertical-align:middle;
    text-align:center;
}
.splash-filter .view-container .view-box {
    text-align:left;
}

.splash-block .video-frame {
    position:absolute;
    top:0;
    left:0;
    width:100%;
    height:100%;
    z-index:0;
}

.splash-block .video-frame video {
    position:relative;
    width:100%;
    height:100%;
    z-index:0;
}

.splash-navigator {
    position:absolute;
    width:100%;
    bottom:25px;
    left:0;
    text-align:right;
    z-index:10;
}
.splash-navigator .view-box {
    margin:0 auto;
}
.splash-block h1,
.interim-block h1,
.interim-block h3 {
    font-weight:900;
    text-transform:uppercase;
    text-shadow:0 0 10px var(--dark-color-100);
    font-size:63px;
    line-height:52px;
    width:50%;
    margin:0 0 15px;
}

.interim-block h3 {
    font-size:43px;
    text-transform: none;
    font-weight:500;
    width:100%;
    text-align:center;
}

.interim-block.new h1, 
.interim-block.new p {
    width:100%;
}

.splash-block h1 span,
.interim-block h1 span {
    color:var(--accent-blue);
}

.splash-block p,
.interim-block p {
    padding-top:15px;
    font-size:27px;
    line-height:27px;
    width:50%;
    margin:15px 0 0;
}

.interim-block p span {
    color:var(--accent-blue);
    padding-bottom:0;
    display:block;
}

.interim-block p.smaller {
    font-size:21px;
    padding-top:0;
}

.view-box {
    display:table;
    width:100%;
    height:100%;
}
.view-frame {
    display:table-cell;
    vertical-align: middle;
}

.interim-block h1,
.interim-block p {
    width:70%;
    margin-left:auto;
    margin-right:auto;
    text-align:center;
}
.interim-block p {
    line-height:36px;
}
@media only screen and (max-width:1667px){
    .splash-block h1,
    .interim-block h1,
    .interim-block p {
        width:70%;
    }
    .splash-block p {
        width:65%;
    }
}

@media only screen and (max-width:1267px){
    .splash-block h1,
    .interim-block h1,
    .interim-block p {
        width:85%;
    }
    .splash-block p {
        width:75%;
    }
}

@media only screen and (max-width:967px){
    .interim-block {
        height:70vh!important;
    }
    .splash-block h1,
    .interim-block h1,
    .interim-block p {
        width:100%;
        font-size:52px;
    }
    .interim-block h3 {
        font-size:23px;
        line-height:23px;
        margin-top:-10px;
    }

    .interim-block p {
        font-size:27px;
    }
    .splash-block p {
        width:90%;
    }
}

@media only screen and (max-width:867px){
    .splash-block h1,
    .interim-block h1,
    .interim-block p
    {
        width:100%;
        font-size:32px;
        line-height:34px;
    }
    .splash-block p,
    .interim-block p {
        width:90%;
        font-size:16px;
        line-height:20px;
    }
    .splash-block,
    .splash-filter {
        min-height:65vh;
    }
    .interim-block p.smaller {
        font-size:16px;
    }
}

.splash-navigator a {
    font-size:13px;
    text-decoration:none;
}
.splash-navigator a:hover span {
    text-decoration:underline;
    cursor:pointer;
}

.splash-navigator a:first-child {
    margin-right:35px;
}

footer {
    padding:75px 0 50px;
    background:var(--dark-color-100);
}

.triangle,
.arrow-left,
.arrow-right {
    width: 0;
    height: 0;
    border-top: 4px solid transparent;
    border-bottom: 4px solid transparent;
    border-right: 4px solid var(--light-color-100);
}

.arrow-left {
    width: 0;
    height: 0;
    border-top: 10px solid transparent;
    border-bottom: 10px solid transparent;
    border-right: 10px solid var(--light-color-100);
}

.triangle.right
{
    border-right:none;
    border-left: 4px solid var(--light-color-100);
}

.arrow-right
{
    border-right:none;
    border-top: 10px solid transparent;
    border-bottom: 10px solid transparent;
    border-left: 10px solid var(--light-color-100);
}

.link-text {
    padding-left:15px;
    padding-right:15px;
}

.title-block {
    padding:100px 0;
    margin:0 auto;
}

.title-block h2,
.title-block p {
    margin:0 auto;
    text-align:center;
}


.title-block h2 {
    font-size:27px;
    font-weight:300;
    margin-bottom:15px;
}
.title-block h2 span {
    color:var(--accent-blue);
}
.title-block p {
    width:40%;
    line-height:32px;
    font-weight:300;
    margin-bottom:25px;
}

.title-block p.wide {
    width:67%;
}

.title-block.left-align h2,
.title-block.right-align h2 {
    margin:0 0 15px;
}

.title-block.left-align h2,
.title-block.left-align p,
.title-block.left-align p.wide {
    text-align:left;
    width:50%;
}

.title-block.left-align p,
.title-block.left-align p.wide,
.title-block.right-align p,
.title-block.right-align p.wide {
    margin:0 0 7px;
}

.title-block.right-align h2,
.title-block.right-align p,
.title-block.right-align p.wide {
    text-align:right;
    width:50%;
}

.title-block.border-bottom {
    border-bottom: 1px var(--dark-color-300) solid;
}

@media only screen and (max-width:1067px){
    .title-block {
        padding:50px 0;
    }
    .title-block h2,
    .title-block.right-align h2,
    .title-block.left-align h2 {
        font-size:18px;
    }
    .title-block p,
    .title-block.right-align p,
    .title-block.right-align p.wide,
    .title-block.left-align p,
    .title-block.left-align p.wide,
    .title-block.right-align h2,
    .title-block.left-align h2 {
        width:100%;
    }
}


.col2 .icon-text-block,
.col2 .ib-text-block {
    width:calc(50% - 20px);
    margin-bottom:20px;
}
.col2 .ib-text-block {
    width:calc(50% - 50px);
}
.col2 .icon-text-block:nth-child(even)
{
    margin-left:10px;
}

.col2 .icon-text-block:nth-child(odd)
{
    margin-right:10px;
}

.col2 .ib-text-block:nth-child(odd) {
    margin-right:25px;
}
.col2 .ib-text-block:nth-child(even) {
    margin-left:25px;
}

.icon-text-block,
.ib-text-block {
    background:var(--dark-color-300);
    box-shadow:var(--component-shadow-100);
    vertical-align:top;
    padding:70px 100px;
    min-height:310px;
    transition:400ms;
}

.icon-text-block:hover,
.ib-text-block:hover {
    transform:scale(1.025);
}

.ib-text-block.black {
    background:var(--dark-color-100);
}

.itb-icon {
    position:relative;
    margin:0 0 15px 0;
    max-width:50px;
    height:45px;
}
.itb-icon img {
    width:100%;
    height:100%;
}

.itb-title h3 {
    font-weight:300;
    font-size:22px;
    padding-bottom:15px;
}

.itb-title h3 span {
    color:var(--accent-blue);
}

.itb-text {
    margin:0;
    width:80%;
}
.itb-text p {
    font-size:14px;
    line-height:22px;
}

.full-image-block {
    margin:100px 0;
    width:100%;
    background-size:cover!important;
    background-attachment:fixed!important;
    height:550px;
}

.full-image-block span,
.section-block .filter,
.image-text-block span {
    display:block;
    position:absolute;
    width:100%;
    height:100%;
    background: rgb(34,34,34);
    background: linear-gradient(180deg, rgba(34,34,34,0) 0%, rgba(34,34,34,0) 32%, rgba(0,0,0,0.7077205882352942) 88%);
}
.full-image-block span .view-container {
    height:100%;
}
.image-label {
    position:absolute;
    width:100%;
    padding-bottom:15px;
    left:0;
    bottom:0;
    text-align:right;
    font-size:12px;
}


.arrow-left {
    margin:0 150px 0 -150px;
}

.arrow-right {
    margin:0 0 0 150px;
}

.work-scroller {
    padding-bottom:75px;
}

.work-scroller.htmx-swapping {
    opacity:0.27;
}


.work-block {
    padding:100px 100px 50px;
    text-align:center;
    background:var(--dark-color-300);
    box-shadow: var(--component-shadow-100);
    min-height:550px;
    overflow:hidden;
    position:relative;
    transition:400ms;
    margin:0 15px 25px;
}
.work-block:nth-child(1){
    margin-left:0;
}

.work-scroller .view-container {
    overflow:visible;
}
.work-slider {
    width:3000px;
}

.work-scroller.right .work-slider {
    margin-left:-150px;
}

.work-slider .arrow-left:hover,
.work-slider .arrow-right:hover
{
    cursor:pointer;
}

.work-video {
    position:relative;
    width:300px;
    height:550px;
    margin:0 auto 25px;
    background:var(--dark-color-100);
    box-shadow:var(--component-shadow-200);
    z-index:10;
    transition:400ms;
    overflow:hidden;
}

.wv-filter {
    position:absolute;
    width:100%;
    height:100%;
    top:0;
    left:0;
    background:rgba(0,0,0,0.5);
    z-index:100;
    transition:400ms;
}

.work-label {
    transition:400ms;
}
.work-label span {
    font-size:14px;
}
.work-label div {
    margin-left:15px;
}

video.full
{
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.case-title {

    position:absolute;
    left:0;
    top:0;
    margin-top:-25px;
    z-index:0;

    opacity:0.18;

    width:150%;
    text-align:left;

    font-size:250px;
    text-transform: uppercase;
    font-weight:900;

    -moz-transform: translateX(100%);
    -webkit-transform: translateX(100%);
    transform: translateX(100%);

    -moz-animation: text-slide-left 15s linear infinite;
    -webkit-animation: text-slide-left 15s linear infinite;
    animation: text-slide-left 15s linear infinite;

    animation-play-state: paused;

}

.work-block:hover {
    transform:scale(1.01);
    cursor:pointer;
}

.work-block:hover .work-video {
    transform:scale(1.1);
    margin-bottom:25px;
}

.work-block:hover .case-title {
    animation-play-state: running;
}

.work-block:hover .work-label {
    opacity:0;
}



.work-block:hover .wv-filter {
    opacity:0;
}

.section-block {
    width:100%;
    height:550px;
    background-size:cover!important;
}

.section-block .view-container {
    height:100%;
}

.section-body {
    position:absolute;
    width:100%;
    bottom:25px;
}

.sb-left {
    width:65%;
}

.sb-right {
    width:35%;
}
.sb-left {
    text-align:left;
}
.sb-left h4,
.staff-title {
    font-size:12px;
    font-weight:300;
}
.sb-left p,
.staff-name {
    text-transform:uppercase;
    font-weight:700;
    font-size:43px;
}
.staff-name {
    font-size:36px;
}
.sb-right {
    text-align:right;
}
.sb-right span {
    padding-right:40px;
    font-size:13px;
}
.sb-right a {
    padding:7px 15px 7px 35px;
    border:1px var(--light-color-100) solid;
    border-radius:20px;
    transition:400ms;
}
.sb-right a:hover {
    cursor:pointer;
    background:var(--light-color-100);
    color:var(--dark-color-100);
}

.sb-right a:hover .triangle.right {
    border-left: 4px solid var(--dark-color-100);
}

.contact-cta-block {
    padding:150px 0;
}

.tb-title,
.fl-title {
    font-size:12px;
    margin-bottom:50px;
}

.tb-text p,
.fl-content p,
.fr-menu ul li {
    font-size:20px;
    line-height:27px;
    margin-bottom:25px;
}
.tb-text p strong,
.fl-content p strong {
    color:var(--accent-blue);
    font-weight:300;
}

.tb-cta,
.fl-cta {
    margin-top:50px;
    font-size:12px;
}
.tb-cta:hover,
.fl-cta:hover {
    cursor:pointer;
}
.tb-cta span,
.fl-cta span {
    margin-left:35px;
}

.fl-social {
    position:relative;
    margin:0 0 15px;
    text-align:left;
}
.social-icon {
    display:inline-block;
    vertical-align: middle;
    box-sizing: border-box;
    width:20px;
}
.social-icon img {
    width:100%;
}

.section-title-block {
    text-align:center;
    padding-bottom:100px;
}
.st-title {
    font-size:12px;
    font-weight:300;
    padding-bottom:50px;
}
.st-text {
    position:relative;
    width:450px;
    font-size:20px;
    line-height:30px;
}

.client-logos {
    background:var(--light-color-100);
    padding:50px 0;
}

.client-logos .view-container {
    text-align:center;
}

.client-logo {
    width:85px;
    margin:15px;
}




@media only screen and (max-width:1467px){
    .client-logo {
        width:120px;
        margin:15px 45px;
    }
}

@media only screen and (max-width:1267px){
    .client-logo {
        width:100px;
        margin:15px 45px;
    }
}

.client-logo img {
    width:100%;
}

.footer-left,
.footer-right {
    padding-right:100px;
    vertical-align: top;
}

.footer-left {
    width:55%;
}
.footer-right {
    width:45%;
}

.fl-content p {
    width:72%;
    margin-left:0;
}

.fl-address {
    position:relative;
    width:200px;
    color:var(--dark-color-500);
    font-size:12px;
    margin:0;
    padding:0px 0 50px;
}



.fr-contact {
    opacity:0.3;
}
.fr-contact .contact-obj-text {
    color:#FFF;
}

.fr-menu {
    padding-bottom:50px;
}
.fr-menu ul li {
    list-style: none;
    list-style-type: none;
    margin-bottom:5px;
}
.fr-menu ul li a:hover {
    cursor:pointer;
}

.infocomm {
    position:relative;
    width:100px;
    margin:0 0 50px;
}
.infocomm img {
    width:100%;
}

@media only screen and (max-width:767px){
    .fl-address {
        width:50%;
        margin:0 auto;
        text-align:center;
    }
    .fl-social {
        text-align:center;
        margin:0 auto 15px;
    }
    .infocomm {
        width:96%;
        text-align:center;
        margin:0 auto 50px;
    }
    .infocomm img {
        width:100px;
    }
    .fr-contact {
        text-align:center;
    }
}

.disc-footer {
    margin-top:50px;
    border-top:1px rgba(255,255,255,0.1) solid;
    padding:50px 0 0;
}

.footer-disc,
.disc-footer-col.right span {
    font-size: 12px;
    color:var(--dark-color-500);
    padding-left:50px;
}

.disc-footer-col {
    width:50%;
}

.disc-footer-col.right span {
    padding-left:0;
    padding-right:12px;
}
.disc-footer-col.right {
    text-align:right;
}

.footer-disc a {
    color:var(--accent-blue);
}
.footer-disc a:hover {
    text-decoration:underline;
    cursor:pointer;
}

.disc-footer-col.right a {
    width:35px;
}

.image-text-block {
    position:relative;
    width:32%;
    margin:0 1% 15px 0;
    height:500px;
    background-size:cover!important;
}
.image-text-block:hover {
    cursor:pointer;
}

.imtb-title {
    position:absolute;
    bottom:0;
    padding:0 15px 10px;
    opacity:0.1;
    transform:scale(0.95);
    transition:400ms;
}
.image-text-block:hover .imtb-title {
    transform:scale(1);
    opacity:1;
}
.imtbt-title {}
.imtbt-contact {
    transform:scale(0.85);
    padding:10px 0 25px;
    margin-left:-23px;
}

/**
 @ Slider Transitions :::
 */
@keyframes fade-in {
    from { opacity: 0; }
}

@keyframes fade-out {
    to { opacity: 0; }
}

@keyframes slide-from-right {
    from { transform: translateX(90px); }
}

@keyframes slide-to-left {
    to { transform: translateX(-90px); }
}

/* define animations for the old and new content */
::view-transition-old(slide-it) {
    animation: 180ms cubic-bezier(0.4, 0, 1, 1) both fade-out,
    600ms cubic-bezier(0.4, 0, 0.2, 1) both slide-to-left;
}
::view-transition-new(slide-it) {
    animation: 420ms cubic-bezier(0, 0, 0.2, 1) 90ms both fade-in,
    600ms cubic-bezier(0.4, 0, 0.2, 1) both slide-from-right;
}


/**
 @ Text Scroller
*/

/* for Firefox */
@-moz-keyframes text-slide-left {
    from { -moz-transform: translateX(100%); opacity:1; }
    to { -moz-transform: translateX(-100%); opacity:0; }
}

/* for Chrome */
@-webkit-keyframes text-slide-left {
    from { -webkit-transform: translateX(100%); opacity:1; }
    to { -webkit-transform: translateX(-100%); opacity:0; }
}

@keyframes text-slide-left {
    from {
        -moz-transform: translateX(100%);
        -webkit-transform: translateX(100%);
        transform: translateX(100%);
        opacity:1;
    }
    to {
        -moz-transform: translateX(-100%);
        -webkit-transform: translateX(-100%);
        transform: translateX(-100%);
        opacity:0;
    }
}

.work-block.mobile {
    display:none;
}


.ss-block {
    position:relative;
    width:100%;
    border-bottom:1px var(--dark-color-300) solid;
}
.ssb-left,
.ssb-right {
    display:inline-block;
    vertical-align:top;
    width:50%;
}
.ssb-left,
.ssb-right,
.ssb-block {
    height:500px;
}


.ssb-left.image,
.ssb-right.image {
    background-size:cover!important;
}

.ssb-table {
    display:table;
    table-layout: fixed;
    width:100%;
}

.ssb-block {
    display: table-cell;
    position:relative;
    width: 100%;
    vertical-align: middle;
    text-align: center;
}

.ssbb-inner {
    display: inline-block;
    width:60%;
    margin:0 auto;
}

.ssbb-inner .itb-text {
    width:100%;
}

.product-block {
    display:inline-block;
    vertical-align: top;
    box-sizing: border-box;
    padding:15px;
    border:1px var(--dark-color-300) solid;
    width:24.5%;
    margin:0 0 25px;
}

.pb-image {
    position:relative;
    margin:0 auto 5px;
    background:#FFF;
    box-sizing: border-box;
    padding:35px;
    text-align:center;
}
.pb-image img {
    position:relative;
    width:60%;
    margin:0 auto;
}

.pb-text {
    font-size:14px;
    line-height:22px;
}
.pb-cta {
    box-sizing: border-box;
    padding:25px 0 5px;
}
.pb-cta.contact-obj a {
    position:relative;
    margin:15px 0;
    color:#FFF;
}
.contact-obj a {
    color:#FFF;
}

.menu-icon span div {
    transition:400ms;
}

span.opened div:nth-child(3) {
    display:none;
}

span.opened div:nth-child(1) {
    transform:rotate(45deg);
    width:100%;
}
span.opened div:nth-child(2) {
    transform:rotate(-45deg);
    margin-top:-5px;
}

.menu-component {
    position:fixed;
    height:calc(100% - 108px);
    width:500px;
    top:108px;
    right:0;
    background:var(--dark-color-100);
    overflow-y:auto;
    z-index:99;
    right:-500px;
}
.menu-component.opened {
    right:0;
}

.menu-component .view-container {
    position:relative;
    width:80%;
    margin:0 auto;
    padding:25px 0;
}

.menu-component .fr-menu ul li {
    margin-bottom:25px;
    font-size:32px;
    font-weight:100;
    padding-bottom:5px;
    border-bottom:2px transparent solid;
    transition:400ms;
}

.menu-component .fr-menu ul li:hover {
    border-bottom:2px var(--accent-blue) solid;
}

.interim-block {
    position:relative;
    background:#000;
    height:85vh;
}

.interim-block a {
    color:var(--accent-blue);
}


footer {
    border-top:1px rgba(255,255,255,0.09) solid;
}


.services {
    position:relative;
    width:60%;
    text-align:center;
    padding:50px 0;
}

@media only screen and (max-width:1667px){
    .services {
        width:80%;
    }
}
@media only screen and (max-width:1267px){
    .services {
        width:100%;
    }
}

@media only screen and (max-width:867px){
    .services {
        padding:20px 0;
    }
}

.service-block {
    position:relative;
    width:100%;
    margin:7px auto;
}

.service,
.service span,
.service img {
    display:inline-block;
    vertical-align: middle;
    box-sizing: border-box;
}

.service {
    margin-right:10px;
}

.service span {
    font-size:27px;
    padding-right:10px;
}

.service img {
    width:32px;
}

@media only screen and (max-width:867px){
    .service-block {
        margin:4px auto;
    }
    .service span {
        font-size:12px;
        padding-right:2px;
    }
    .service-block {
        margin:2px auto;
    }
    .service {
        margin-right:7px;
    }
    .service img {
        width:15px;
    }
}


@media only screen and (max-width: 2167px){
    .arrow-right {
        margin: 0 0 0 50px;
    }
    .work-scroller.right .work-slider {
        margin-left: -400px;
    }
}


@media only screen and (max-width:1996px){
    .arrow-left {
        margin: 0 50px 0 -5px;
    }
    .arrow-right {
        margin: 0 0 0 50px;
    }
    .work-scroller.right .work-slider {
        margin-left: -400px;
    }
}

@media only screen and (max-width:1867px){
    .work-scroller.right .work-slider {
        margin-left: -450px;
    }
}

@media only screen and (max-width:1777px){
    .work-scroller.right .work-slider {
        margin-left: -550px;
    }
}

@media only screen and (max-width:1677px){
    .work-block {
        padding:75px 75px 50px;
    }
    .work-scroller.right .work-slider {
        margin-left: -500px;
    }

    .icon-text-block, .ib-text-block {
        padding:70px 50px;
        min-height:330px;
    }
}

@media only screen and (max-width:1550px){
    .work-block {
        padding:50px;
    }
    .work-scroller.right .work-slider {
        margin-left: -450px;
    }
    .work-block {
        padding:50px;
        min-height:0;
    }
    .work-scroller.right .work-slider {
        margin-left: -450px;
    }
    .product-block {
        width:32%;
    }
}

@media only screen and (max-width:1387px){
    .work-scroller.right .work-slider {
        margin-left: -300px;
    }
    .work-video {
        width:250px;
        height:400px;
    }
    .ssbb-inner {
        width:90%;
    }

}

@media only screen and (max-width: 1297px){
    .work-scroller.right .work-slider {
        margin-left: -350px;
    }
    .work-video {
        width:200px;
        height:350px;
    }
    .icon-text-block, .ib-text-block {
        padding:50px 30px;
        min-height:330px;
    }
    .disc-footer-col {
        width:60%;
    }
    .disc-footer-col.right {
        width:40%;
    }
    .image-text-block {
        width:calc(50% - 11px);
    }
    .product-block {
        width:45%;
    }
}

@media only screen and (max-width: 1067px){
    .work-scroller.right .work-slider {
        margin-left: -350px;
    }
    .work-video {
        width:175px;
        height:300px;
    }
    .full-image-block {
        margin:25px 0;
        height: 350px;
        background-attachment: scroll!important;
    }
    .disc-footer-col {
        width:65%;
    }
    .disc-footer-col.right {
        width:35%;
    }
    .title-block p.wide {
        width:100%;
    }
    .ssb-left,
    .ssb-right {
        display:block;
        width:100%;
    }
    .ssb-left.text,
    .ssb-right.text,
    .ssb-block {
        height:auto;
        min-height:0;
    }
    .ssb-block {
        padding:50px 0;
    }
}

@media only screen and (max-width: 967px){

    .menu-component {
        top:86px;
        height:calc(100% - 86px);
        width:320px;
    }

    .menu-component .fr-menu ul li {
        font-size:18px;
        margin-bottom:10px;
    }

    .arrow-left,
    .arrow-right {
        display:none;
    }
    .work-slider {
        width:100%;
    }
    .work-block {
        padding:20px;
        margin:0 0 25px;
    }

    .work-block.mobile {
        width:calc(50% - 3px);
    }
    .work-video {
        width:100%;
        height:auto;
        max-height:250px;
    }
    .case-title {
        font-size:200px;
        animation-play-state: running;
    }
    .work-block.mobile {
        display:inline-block;
    }
    .work-block.original {
        display:none;
    }
    .icon-text-block, .ib-text-block,
    .col2 .icon-text-block, .col2 .ib-text-block {
        width:100%;
        display:block;
        min-height:0;
        height:auto;
    }
    .col2 .icon-text-block:nth-child(odd),
    .col2 .icon-text-block:nth-child(even),
    .col2 .ib-text-block:nth-child(odd),
    .col2 .ib-text-block:nth-child(even)
    {
        margin-right:auto;
        margin-left:auto;
    }
    .footer-left,
    .footer-right {
        width:100%;
        padding-right:0;
    }
    .disc-footer-col,
    .disc-footer-col.right {
        width:100%;
        padding:0 0 35px;
        text-align:center;
    }
    .logo.footer {
        padding-bottom:25px;
    }
    .footer-disc {
        padding-left:0;
        width:100%;
    }
    .product-block {
        display:block;
        position:relative;
        margin:0 auto 15px;
        width:96%;
    }
}

@media only screen and (max-width: 867px){
    .image-text-block {
        width:100%;
    }
    .imtb-title {
        opacity:1;
    }
}

@media only screen and (max-width:776px){
    .section-block {
        height:300px;
    }
    .sb-left p, .staff-name {
        font-size:27px;
    }
    .sb-right a {
        padding:3px 10px 4px 15px;
    }
    .sb-right span {
        font-size:10px;
    }
    .contact-cta-block {
        padding:25px 0;
    }
}

@media only screen and (max-width: 667px){
    .work-label span {
        font-size:9px;
    }
    .work-scroller {
        padding-bottom:15px;
    }
    .st-text {
        width:90%;
        font-size:16px;
        line-height:22px;
    }
    .client-logos {
        padding: 15px 0;
    }
}














.interim-block.new {
    margin:0 auto;
}

.interim-block.new h1, 
.interim-block.new p {
    width:80%;
}































