/*
Theme Name: Process
Author: Cubera Solutions AG
Author URI: https://cubera.ch/ 
Description: 
Version: 2.1.0
Text Domain: process
*/

@font-face {
    font-family: "Maison Extended Bold";
    src: url("fonts/MaisonNeueExtendedWEB-Bold.woff2") format("woff2"),
    url("fonts/MaisonNeueExtendedWEB-Bold.woff") format("woff");
    font-weight: 400;
    font-style: normal;
}

@font-face {
    font-family: "Maison Neue Bold";
    src: url("fonts/MaisonNeue-Bold.woff2") format("woff2"),
    url("fonts/MaisonNeue-Bold.woff") format("woff");
    font-weight: 600;
    font-style: normal;
}

@font-face {
    font-family: "Maison Neue Book";
    src: url("fonts/MaisonNeue-Book.woff2") format("woff2"),
    url("fonts/MaisonNeue-Book.woff") format("woff");
    font-weight: 600;
    font-style: normal;
}

* {
    margin: 0;
    padding: 0;
    font-family: "Maison Neue Book", Arial, Helvetica, sans-serif;
    -moz-box-sizing: border-box;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    -webkit-font-smoothing: antialiased;
}

html[lang="zh-tw"] * {
	font-family: "Maison Neue Book", 'Noto Sans TC', sans-serif;
}

html[lang="zh-cn"] * {
	font-family: "Maison Neue Book", 'Noto Sans SC', sans-serif;
}

*, body, button, input, textarea, select {
    text-rendering: optimizeLegibility;
    -moz-osx-font-smoothing: grayscale;
}

html,
body {
    height: 100%;
}

body {
    background: #FFFFFF;
    -webkit-text-stroke-width: 0 !important;
}

html.hide-overflow,
body.hide-overflow {
    position: fixed;
    width: 100%;
    height: 100%;
    overflow: hidden;
}

html.noscroll,
body.noscroll {
    position: relative;
    height: 100%;
    overflow: hidden;
}

body.noscroll {
    padding-right: 17px;
}

::-moz-selection {
    background: #666;
    color: #fff;
    text-shadow: none;
}

::selection {
    background: #666;
    color: #fff;
    text-shadow: none;
}

input,
textarea,
button,
select,
a {
    -webkit-tap-highlight-color: rgba(0,0,0,0);
}

a {
    position: relative;
    text-decoration: none;
    color: inherit;
}

:focus {
    outline: none;
}

b, strong {
    font-family: "Maison Neue Bold";
    font-weight: 600;
}

html[lang="zh-tw"] b,
html[lang="zh-tw"] strong {
	font-family: "Maison Neue Bold", 'Noto Sans TC', sans-serif;
}

html[lang="zh-cn"] b,
html[lang="zh-cn"] strong {
	font-family: 'Noto Sans SC', sans-serif;
}

html[lang="zh-tw"] b,
html[lang="zh-tw"] strong,
html[lang="zh-cn"] b,
html[lang="zh-cn"] strong {
	font-weight: 700;
}

/*** Typographie ***/
h1, h2, h3, h4 {
    font-family: "Maison Neue Bold";
    font-weight: 600;
}

html[lang="en-US"] h5 strong {
	font-family: "Maison Extended Bold";
}

html[lang="zh-tw"] h1,
html[lang="zh-tw"] h2,
html[lang="zh-tw"] h3,
html[lang="zh-tw"] h4 {
	font-family: "Maison Neue Bold", 'Noto Sans TC', sans-serif;
}

html[lang="zh-tw"] h1 .taxonomy-term,
html[lang="zh-cn"] h1 .taxonomy-term {
	font-family: "Maison Neue Bold", 'Noto Sans TC', sans-serif;
	display: inline-block;
  	margin-top: 30px;
  	line-height: 1.1;
}

html[lang="zh-cn"] h1,
html[lang="zh-cn"] h2,
html[lang="zh-cn"] h3,
html[lang="zh-cn"] h4 {
	font-family: 'Noto Sans SC', sans-serif;
}

html[lang="zh-tw"] h1,
html[lang="zh-tw"] h2,
html[lang="zh-tw"] h3,
html[lang="zh-tw"] h4,
html[lang="zh-cn"] h1,
html[lang="zh-cn"] h2,
html[lang="zh-cn"] h3,
html[lang="zh-cn"] h4 {
	font-weight: 700;
}

h1 a,
h2 a {
    font-family: "Maison Neue Bold";
    font-weight: 600;
}

html[lang="zh-tw"] h1 a,
html[lang="zh-tw"] h2 a {
	font-family: "Maison Neue Bold", 'Noto Sans TC', sans-serif;
}

html[lang="zh-cn"] h1 a,
html[lang="zh-cn"] h2 a {
	font-family: 'Noto Sans SC', sans-serif;
}

html[lang="zh-tw"] h1 a,
html[lang="zh-tw"] h2 a,
html[lang="zh-cn"] h1 a,
html[lang="zh-cn"] h2 a {
	font-weight: 700;
}

h1 {
    font-size: calc(56px + (124 - 56) * (100vw - 414px) / (1440 - 414));
    /*line-height: 0.92;*/
    line-height: 1.5;
    letter-spacing: -0.02em;
    margin-bottom: 0;
}

h1.h1-5 {
    font-size: calc(30px + (60 - 30) * (100vw - 414px) / (1440 - 414));
    /*line-height: 1.03;*/
    line-height: 1.5;
    margin-bottom: 0;
}

.projects-filter-title {
    font-size: calc(32px + (60 - 32) * (100vw - 414px) / (1440 - 414));
    line-height: 1.1;
}

.page-header .header-text,
.location-name,
.location-name-chinese {
    font-size: calc(60px + (80 - 60) * (100vw - 414px) / (1440 - 414));
}

.page-header .header-text {
    margin-top: calc(-1 * (30px + (40 - 30) * (100vw - 414px) / (1440 - 414)));
}

h2 {
    font-size: calc(48px + (124 - 48) * (100vw - 414px) / (1440 - 414));
    line-height: 1;
    margin-bottom: 0;
}

h3 {
    font-size: calc(36px + (48 - 36) * (100vw - 414px) / (1440 - 414));
    /*line-height: 1.08;*/
    line-height: 1.3;
    margin-bottom: 0;
}

h4 {
    font-size: calc(30px + (36 - 30) * (100vw - 414px) / (1440 - 414));
    /*line-height: 1.17;*/
    line-height: 1.3;
    margin-bottom: 0;
}

h5 {
    font-size: calc(26px + (32 - 26) * (100vw - 414px) / (1440 - 414));
    /*line-height: 1;*/
    line-height: 1.3;
    letter-spacing: -0.01em;
    margin-bottom: 0;
}

html[lang="en-US"] h5 {
	font-family: "Maison Extended Bold";
    font-weight: normal;
    line-height: 1.2;
}

.col-copy ul {
    padding-left: 20px;
}

.col-copy ol {
    padding-left: 30px;
}

.col-copy p + ul,
.col-copy p + ol {
    position: relative;
    top: -10px;
}

p,
.col-copy ul li,
.col-copy ol li,
.news-excerpt,
.project-teaser-excerpt,
div.wpcf7-response-output {
    /*font-size: calc(17px + (16 - 17) * (100vw - 414px) / (1440 - 414));
    line-height: 1.50;*/
    font-size: 1.3rem;
    line-height: 2.4rem;
}

p.byline {
    opacity: 0.45;
    font-size: calc(0.75 * (18px + (26 - 18) * (100vw - 414px) / (1440 - 414)));
    line-height: 1.33;
    letter-spacing: 1px;
}

.col-copy p,
.col-copy h4,
.col-copy-half p,
.col-copy-half h4 {
    margin-bottom: calc(1.45 * (16px + (17 - 16) * (100vw - 414px) / (1440 - 414)));
}

.project-lead .col-copy p,
.page-intro .col-copy p {
    /*font-size: 20px;*/
    font-size: 1.3rem;
    margin-bottom: 0;
}

.project-lead.small-lead-text .col-copy p,
.page-intro.small-lead-text .col-copy p {
    /*font-size: calc(17px + (16 - 17) * (100vw - 414px) / (1440 - 414));
    line-height: 1.50;*/
    font-size: 1.3rem;
    line-height: 2.4rem;
}

.project-lead .col-copy p + p,
.page-intro .col-copy p + p {
    margin-top: 14px;
}

.team-memeber-name {
    font-family: "Maison Neue Bold";
    font-size: calc(18px + (32 - 18) * (100vw - 414px) / (1440 - 414));
    line-height: 1.4;
    letter-spacing: 0.4px;
}

.col-copy .quote p {
    font-family: inherit;
    font-size: inherit;
    line-height:inherit;
}

.news-title,
.impulse-excerpt p {
    font-size: calc(30px + (40 - 30) * (100vw - 414px) / (1440 - 414));
    line-height: 1.17;
    letter-spacing: 0.8px;
}

.team-description {
    font-family: "Maison Neue Bold";
    font-size: calc(20px + (35 - 20) * (100vw - 414px) / (1440 - 414));
}

.locations-tabs {
    font-size: calc(18px + (32 - 18) * (100vw - 414px) / (1440 - 414));
    line-height: 1.2;
}

.col-copy a:after,
.col-copy-half a:after,
.project-contact-right a:after {
    content: "";
    position: absolute;
    width: 100%;
    height: 1px;
    bottom: -3px;
    left: 0;
    background: linear-gradient(90deg, currentColor calc(100% / 3), transparent 0 calc(200% / 3), currentColor 0) 100% 100%/300% 3px no-repeat;
    transition: background 0.6s;
}

.col-copy a:hover:after,
.col-copy-half a:hover:after,
.project-contact-right a:hover:after  {
    background: linear-gradient(90deg, currentColor calc(100% / 3), transparent 0 calc(200% / 3), currentColor 0) 0% 100%/300% 3px no-repeat;
}

a.cta-primary {
    display: inline-block;
    position: relative;
    margin-top: 37px;
    padding-left: 54px;
    font-family: "Maison Neue Bold";
}

a.cta-secondary {
    display: inline-block;
    position: relative;
    margin-top: 32px;
    padding-left: 44px;
    font-family: "Maison Neue Book";
}

a.cta-primary {
    color: #00AFFF;
    transition: color 0.3s;
    line-height: 1;
}

a.cta-primary:hover {
    color: #00E1D4;
}

a.cta-primary:after,
a.cta-secondary:after {
    content: none;
}

a.cta-primary:before {
    content: "";
    position: absolute;
    width: 44px;
    height: 44px;
    top: -11px;
    left: 0;
    border-radius: 100%;
}

a.cta-primary:before {
    background-color: #00AFFF;
    background-image: url(images/cta-arrow-white.svg);
    background-repeat: no-repeat;
    background-position: center;
    transition: background-color 0.3s;
}

a.cta-primary:hover:before {
    background-color: #00E1D4;
}

a.cta-secondary span {
    position: absolute;
    width: 34px;
    height: 34px;
    top: -6px;
    left: 0;
    border-radius: 100%;
    border: 1px solid #1C2229;
    transition: background-color 0.3s;
}

a.cta-secondary span svg {
    display: inline-block;
    width: 18px;
    height: 13px;
    margin: 10px 7px;
}

a.cta-secondary span svg path {
    transition: stroke 0.3s;
}

a.cta-secondary:hover span {
    background-color: #1C2229;
}

a.cta-secondary:hover span svg path {
    stroke: #FFFFFF;
}

/*a.cta-primary:before {
    content: "";
    position: absolute;
    width: 44px;
    height: 44px;
    top: -11px;
    left: 0;
    border-radius: 100%;
}

a.cta-secondary:before {
    content: "";
    position: absolute;
    width: 34px;
    height: 34px;
    top: -6px;
    left: 0;
    border-radius: 100%;
    transition: background-color 0.3s;
}

a.cta-primary:before {
    background-color: #00AFFF;
    background-image: url(images/cta-arrow-white.svg);
    background-repeat: no-repeat;
    background-position: center;
}

a.cta-secondary:before {
    border: 1px solid #1C2229;
    background-image: url(images/cta-arrow-black.svg);
    background-repeat: no-repeat;
    background-position: center;
}*/

@media only screen and (min-width: 1440px) {
	
	h1 {
      font-size: 124px;
	}
	
	h1.h1-5 {
		font-size: 60px;
	}
	
	.projects-filter-title {
		font-size: 60px;
	}
	
	.page-header .header-text,
	.location-name,
	.location-name-chinese {
		font-size: 80px;
	}
	
	.page-header .header-text {
		margin-top: -40px;
	}
	
	.location-name {
		bottom: 200px;
	}	
	
	.fp-slide.fs_text .quote {
		margin-top: -60px;
		font-size: 120px;
	}
	
	.fp-slide.reference-item.fs_text .quote {
		margin-top: -40px;
		font-size: 80px;
	}
	
	h2 {
      font-size: 124px;
	}
	
	h3 {
      font-size: 48px;
	}
  
  h5 {
    font-size: 32px;
  }
	
	p,
	.col-copy ul li,
	.col-copy ol li,
	.news-excerpt,
  .project-teaser-excerpt,
	div.wpcf7-response-output {
		/*font-size: 16px;*/
    font-size: 1.3rem;
	}
  
  .project-lead.small-lead-text .col-copy p,
  .page-intro.small-lead-text .col-copy p {
      /*font-size: 16px;*/
      font-size: 1.3rem;
  }
	
	.col-copy p + ul,
	.col-copy p + ol {
		top: -22px;
	}
	
	.col-copy .quote p {
		font-size: inherit;
	}
	
	p.byline {
		font-size: 19px;
	}
	
	.col-copy p {
		  /*font-size: 16px;*/
      margin-bottom: 24px;
	}
	
	.col-copy p:last-child {
		margin-bottom: 0;
	}		

	.team-memeber-name {
		font-size: 32px;
		line-height: 40px;
	}
	
	.news-title,
	.impulse-excerpt p {
		font-size: 40px;
	}
	
	.team-description {
		font-size: 35px;
	}
	
	.locations-tabs {
		font-size: 32px;
	}
	
}

@media only screen and (max-width: 430px) {
	
	h1 {
      font-size: 56px;
	}
	
	h1.h1-5 {
		font-size: 30px;
	}
	
	.projects-filter-title {
		font-size: 32px;
	}
	
	.col-copy ul {
		padding-left: 16px;
	}

	.col-copy ol {
		padding-left: 23px;
	}
	
	.page-header .header-text,
	.location-name,
	.location-name-chinese {
		font-size: 60px;
	}
	
	.page-header .header-text {
		margin-top: -30px;
	}
	
	.location-name {
		bottom: 180px;
	}
	
	.fp-slide.fs_text .quote {
		margin-top: -20px;
		font-size: 40px;
	}
	
	.fp-slide.reference-item.fs_text .quote {
		margin-top: -22px;
		font-size: 36px;
		padding: 0 10px;
	}	
		
	.single-impulse-entry .page-header .header-text {
		font-size: 50px;
		padding: 0 20px;
	}	
	
	h2 {
      font-size: 48px;
	}
	
	h3 {
      font-size: 36px;
	}
  
  h5 {
    font-size: 26px;
  }
	
	p,
	.col-copy ul li,
	.col-copy ol li,
	.news-excerpt,
  .project-teaser-excerpt,
	div.wpcf7-response-output {
		font-size: 17px;
	}
  
  .project-lead.small-lead-text .col-copy p,
  .page-intro.small-lead-text .col-copy p {
      font-size: 17px;
  }
	
	.team-description {
		font-size: 20px;
	}
	
	p.byline {
		font-size: 14px;
	}
	
	.col-copy p {
		margin-bottom: 26px;
	}
	
	.project-lead p,
	.page-intro p,
	.team-memeber-name {
		font-size: 18px;
	}
	
	.col-copy .quote p {
		font-size: 26px;
		line-height: 1.25;
	}
	
	.news-title,
	.impulse-excerpt p {
		font-size: 26px;
	}
	
	.locations-tabs {
		font-size: 18px;
	}
	
}

@media only screen and (max-width: 320px) {
	
	.page-header .header-text,
	.location-name,
	.location-name-chinese {
		font-size: 50px;
	}
	
	.page-header .header-text {
		margin-top: -25px;
	}
	
}

.col-full picture {
    display: block;
    text-align: center;
}

img {
    max-width: 100%;
    height: auto;
    vertical-align: middle;
}

#mobileDetector,
#landscape,
#portrait {
    display: none;
}

@media (max-width: 736px) and (orientation: landscape), (max-width: 430px) and (orientation: portrait) {
	
    #mobileDetector {
        display: block;
    }
	
}

@media only screen and (orientation: landscape) {

    #landscape {
        display: block;
    }
	
}

@media only screen and (orientation: portrait) {

    #portrait {
        display: block;
    }
	
}

/*** Header ***/
header {
    position: fixed;
    width: 100%;
    height: 100px;
    z-index: 99;
    -webkit-transition: height .3s,background .3s,-webkit-transform .3s;
    transition: height .3s,background .3s,transform .3s;
    -webkit-backface-visibility: hidden;
    backface-visibility: hidden;
    mix-blend-mode: difference;
}

header.nav-down {
    transform: translateY(0);
}

header.hasBG.nav-down {
    transform: translateY(-12px);
}

header.nav-up {
    transform: translateY(-100%);
}

.page-template-team header {
    height: 76px;
}

.page-template-team header.nav-down {
    background: #FFFFFF;
}

.page-template-team header.nav-down.disable-bg {
    background: none;
}

.logo {
    position: absolute;
    z-index: 1;
    width: 168px;
    height: 36px;
    margin: 32px 0 0 84px;
    transition: margin 0.3s;
}

.logo a {
    position: absolute;
    display: block;
    width: 100%;
    height: 100%;
    z-index: 1;
}

.logo.logo-white svg,
.logo.logo-black svg {
    width: 168px;
    height: 36px;
	margin-left: -22px;
}

.logo.logo-white svg g,
.logo.logo-black svg g,
.logo.logo-white svg path,
.logo.logo-black svg path {
    fill: #FFFFFF;
}

.static-main-menu-wrapper {
    position: absolute;
    top: 36px;
    right: 84px;
    transition: right 0.3s;
}

.static-main-menu {
    display: flex;
    flex-wrap: nowrap;
    align-items: center;
}

.static-menu {
    list-style: none;
}

.static-menu li {
    float: left;
}

.static-menu li a {
    color: #FFFFFF;
    font-family: "Maison Neue Book";
    font-size: 16px;
    line-height: 24px;
    padding: 4px 0;
    margin-right: 40px;
    transition: color 0.3s;
}

.static-menu li.current-menu-item a {
    font-family: "Maison Neue Bold";
}

html[lang="zh-tw"] li.current-menu-item a {
	font-family: "Maison Neue Bold", 'Noto Sans TC', sans-serif;
}

html[lang="zh-tw"] .static-menu li.current-menu-item a {
	font-weight: 700;
}

html[lang="zh-cn"] .static-menu li.current-menu-item a {
	font-family: 'Noto Sans SC', sans-serif;
	font-weight: 700;
}

.menu-black .static-menu li a {
    color: #FFFFFF;
}

.hasBG.menu-black .static-menu li a,
.hasBG.menu-white .static-menu li a {
    color: #FFFFFF;
}

.static-menu li a:after {
    content: "";
    position: absolute;
    opacity: 0;
    width: 100%;
    height: 1px;
    bottom: 0px;
    left: 0;
    background: linear-gradient(90deg, currentColor calc(100% / 3), transparent 0 calc(200% / 3), currentColor 0) 0% 100%/300% 3px no-repeat;
    transition: background 0.6s ease-in-out, opacity 0.3s;
}

.static-menu li.current_page_item a:after,
.static-menu li.current-menu-item a:after,
.static-menu li a:hover:after {
    opacity: 1;
    background: linear-gradient(90deg, currentColor calc(100% / 3), transparent 0 calc(200% / 3), currentColor 0) 100% 100%/300% 3px no-repeat;
}

.menu-primary-container {
    opacity: 1;
    transition: opacity 0.3s;
}

.contact-cto {
    margin-right: 8px;
    opacity: 1;
    transition: opacity 0.3s;
}

.hide-menu .menu-primary-container,
.hide-menu .menu-primary-german-container,
.hide-menu .menu-primary-chinese-simplified-container,
.hide-menu .menu-primary-chinese-traditional-container,
.hide-menu .contact-cto {
    opacity: 0;
}

.contact-cto a {
    color: #FFFFFF;
    font-family: "Maison Neue Book";
    font-size: 16px;
    line-height: 24px;
    padding: 5.5px 17px;
    border: 1px solid #FFFFFF;
    border-radius: 17px;
    transition: color 0.3s, border-color 0.3s, background 0.3s;
}

html[lang="zh-tw"] .contact-cto a {
	font-family: "Maison Neue Book", 'Noto Sans TC', sans-serif;
}

.menu-black .contact-cto a,
.hasBG.menu-black .contact-cto a,
.hasBG.menu-white .contact-cto a {
    color: #FFFFFF;
    border-color: #FFFFFF;
}

.contact-cto a:hover {
    background: #FFFFFF;
    color: #1C2229;
    /*border-color: #1C2229;*/
}

.menu-black .contact-cto a:hover,
.hasBG.menu-black .contact-cto a:hover,
.hasBG.menu-white .contact-cto a:hover {
    background: #FFFFFF;
    color: #1C2229;
    /*border-color: #1C2229;*/
}

.overlay-menu {
    position: fixed;
    opacity: 0;
    width: 100vw;
    top: -100vh;
    left: 0;
    height: 0;
    background: #1C2229;
    z-index: 100;
    transition: opacity 0.3s;
    overflow: hidden;
}

.overlay-menu.show {
    opacity: 1;
    top: 0;
    height: calc(var(--vh, 1vh) * 100);
}

.overlay-main-menu {
    position: relative;
    padding: 86px 24px 160px 24px;
    display: flex;
    height: calc(var(--vh, 1vh) * 100);
}

.overlay-main-menu > div {
    width: 100%;
    align-self: center;
}

.overlay-secondary-menu {
    list-style: none;
    color: #FFFFFF;
}

.overlay-secondary-menu li {
    padding: 12px 0;
}

.overlay-secondary-menu li a {
    display: inline-block;
    font-family: 'Maison Neue Bold';
    font-size: 36px;
    line-height: 42px;
}

.overlay-menu-footer {
    position: absolute;
    width: 100%;
    bottom: 0;
    padding: 0 24px 36px 24px;
    display: flex;
    justify-content: space-between;
}

.overlay-menu-adress {
    color: #FFFFFF;
}

.overlay-menu-adress a {
    display: inline-block;
    position: relative;
    padding: 4px 0;
}

.overlay-menu-adress a:after {
    content: "";
    position: absolute;
    width: 100%;
    height: 1px;
    bottom: 0px;
    left: 0;
    background: linear-gradient(90deg, currentColor calc(100% / 3), transparent 0 calc(200% / 3), currentColor 0) 0% 100%/300% 3px no-repeat;
    transition: background 0.6s ease-in-out, opacity 0.3s;
}

.overlay-menu-adress a:hover:after {
    background: linear-gradient(90deg, currentColor calc(100% / 3), transparent 0 calc(200% / 3), currentColor 0) 100% 100%/300% 3px no-repeat;
}

.overlay-menu-adress p:last-child {
    display: none;
}

.overlay-menu-language-wrapper {
    align-self: end;
    display: flex;
    gap: 12px;
}

.overlay-menu-language-wrapper .language.inactive {
    cursor: default;
}

.overlay-menu-language-wrapper .language.inactive,
.overlay-menu-language-wrapper .language:hover {
    border-radius: 100%;
    background: #FFFFFF;
    color: #1C2229;
}

#hamburger {
    display: none;
    position: absolute;
    top: -11px;
    right: -11px;
    padding: 10px;
    cursor: pointer;
    width: 52px;
    height: 52px;
    z-index: 1;
}

#hamburger-copy {
    position: absolute;
    top: 24px;
    right: 13px;
    padding: 10px;
    cursor: pointer;
    width: 52px;
    height: 52px;
    z-index: 1;
    transition: top 0.3s;
}

.nav-up + nav #hamburger-copy {
    top: -100px;
}

#hamburger .lines-button,
#hamburger-copy .lines-button {
    -webkit-transition: 0.3s;
    transition: 0.3s;
    cursor: pointer;
    user-select: none;
    opacity: 1;
}

#hamburger .lines,
#hamburger-copy .lines {
    display: inline-block;
    width: 32px;
    height: 0;
    border-radius: 0;
    background: #000;
    -webkit-transition: 0.3s;
    transition: 0.3s;
    position: relative;
}

#hamburger.expanded .lines,
#hamburger-copy.expanded .lines {
    background: transparent;
}

#hamburger .lines:before,
#hamburger .lines:after,
#hamburger-copy .lines:before,
#hamburger-copy .lines:after {
    display: inline-block;
    width: 32px;
    height: 1.5px;
    background: #FFF;
    -webkit-transition: 0.3s;
    transition: 0.3s;
    position: absolute;
    left: 0;
    content: '';
    -webkit-transform-origin: 3.14286px center;
    -moz-transform-origin: 3.14286px center;
    -ms-transform-origin: 3.14286px center;
    transform-origin: 3.14286px center;
}

.menu-black #hamburger .lines:before,
.menu-black #hamburger .lines:after,
.menu-black + nav #hamburger-copy .lines:before,
.menu-black + nav #hamburger-copy .lines:after,
#close .lines:before,
#close .lines:after {
    background: #000;
}

.hasBG.menu-black #hamburger .lines:before,
.hasBG.menu-black #hamburger .lines:after,
.hasBG.menu-black + nav #hamburger-copy .lines:before,
.hasBG.menu-black + nav #hamburger-copy .lines:after {
    background: #FFF;
}

.show-menu #hamburger-copy .lines:before,
.show-menu #hamburger-copy .lines:after {
    background: #FFF !important;
}

@media (max-width: 960px) {

  .static-main-menu {
      display: none;
  }
  
  #hamburger {
      display: block;
  }
	
}

#hamburger .lines:before,
#hamburger-copy .lines:before {
    top: 4px;
}

#hamburger .lines:after,
#hamburger-copy .lines:after {
    top: -6px;
}

#hamburger.expanded .lines:before,
#hamburger.expanded .lines:after,
#hamburger-copy.expanded .lines:before,
#hamburger-copy.expanded .lines:after {
    background: #FFF;
    -webkit-transform-origin: 50% 50%;
    -moz-transform-origin: 50% 50%;
    -ms-transform-origin: 50% 50%;
    transform-origin: 50% 50%;
    top: -1px;
    width: 32px;
}

#hamburger.expanded .lines:before,
#hamburger-copy.expanded .lines:before {
    transform: rotate3d(0, 0, 1, 45deg);
    -webkit-transform: rotate3d(0, 0, 1, 45deg);
    -moz-transform: rotate3d(0, 0, 1, 45deg);
    -ms-transform: rotate3d(0, 0, 1, 45deg);
}

#hamburger.expanded .lines:after,
#hamburger-copy.expanded .lines:after {
    transform: rotate3d(0, 0, 1, -45deg);
    -webkit-transform: rotate3d(0, 0, 1, -45deg);
    -moz-transform: rotate3d(0, 0, 1, -45deg);
    -ms-transform: rotate3d(0, 0, 1, -45deg);
}

@media only screen and (max-width: 1200px) {
  
  .logo {
      margin: 32px 0 0 24px;
  }
  
  .static-main-menu-wrapper {
      right: 24px;
  }
  
}

@media only screen and (max-width: 736px) {
  
  .logo {
      margin: 24px 0 0 24px;
      width: 45px;
      height: 40px;
      overflow: hidden;
  }
  
  .logo.logo-white svg,
  .logo.logo-black svg {
      width: 175px;
      height: 40px;
  }
  
  .overlay-secondary-menu li {
      padding: 8px 0;
  }
	
	#hamburger {
      top: -18px;
      right: 7px;
      width: 36px;
      height: 36px;
	}
	
	#hamburger-copy {
      top: 18px;
      right: 30px;
      width: 36px;
      height: 36px;
	}
	
}

/*** Navigation ***/
.language-dropwdown {
    display: flex;
    opacity: 0;
    position: absolute;
    top: 0;
    right: 34px;
    pointer-events: none;
    transition: opacity 0.3s;
}

.show-langs .language-dropwdown {
    opacity: 1;
    pointer-events: all;
}

.language-dropwdown > div {
    margin-right: 8px;
}

.language {
    text-align: center;
    font-family: "Maison Neue Book";
    font-size: 16px;
}

.language.inactive {
    width: 34px;
    height: 34px;
    line-height: 33px;
    color: #FFFFFF;
    border: 1px solid #FFFFFF;
    border-radius: 17px;
    cursor: pointer;
    transition: color 0.3s, border-color 0.3s;
}

html[lang="zh-tw"] .language.inactive,
html[lang="zh-cn"] .language.inactive {
	line-height: 34px;
}

.show-langs .language.inactive,
.language.inactive:hover {
    background: #FFFFFF;
    color: #1C2229;
    /*border-color: #1C2229;*/
}

.menu-black .language.inactive,
.hasBG.menu-black .language.inactive,
.hasBG.menu-white .language.inactive {
    color: #FFFFFF;
    border-color: #FFFFFF;
}

.menu-black .show-langs .language.inactive,
.hasBG.menu-black .show-langs .language.inactive,
.hasBG.menu-white .show-langs .language.inactive,
.menu-black .language.inactive:hover,
.hasBG.menu-black .language.inactive:hover,
.hasBG.menu-white .language.inactive:hover {
    background: #FFFFFF;
    color: #1C2229;
    border-color: #1C2229;
}

.language a {
    display: block;
    width: 34px;
    height: 34px;
    line-height: 33px;
    color: #FFFFFF;
    border: 1px solid #FFFFFF;
    border-radius: 17px;
    text-decoration: none;
    transition: color 0.3s, border-color 0.3s, background 0.3s;
}

html[lang="zh-tw"] .language a,
html[lang="zh-cn"] .language a {
	line-height: 34px;
}

.language a:hover {
    background: #FFFFFF;
    color: #1C2229;
    border-color: #1C2229;
}

.menu-black .language a,
.hasBG.menu-black .language a,
.hasBG.menu-white .language a {
    color: #FFFFFF;
    border-color: #FFFFFF;
}

.menu-black .language a:hover,
.hasBG.menu-black .language a:hover,
.hasBG.menu-white .language a:hover {
    background: #FFFFFF;
    color: #1C2229;
    border-color: #1C2229;
}

/*** General ***/
.page-content-wrapper {
    overflow: hidden;
}

.page-wrapper {
    background: #FFFFFF;
}

.page-content-wrapper.simple {
    background: #FFFFFF;
    padding-top: 120px;
}

.page-content-wrapper.simple h1 {
    margin-bottom: 40px;
}

.page-content-wrapper.simple h2 {
    margin-bottom: 20px;
}

.content-wrapper-row {
    width: 100%;
    padding: 0;
}

.content-wrapper-row.module {
    padding: 100px 0;
}

.page-content-wrapper.project .content-wrapper-row,
.content-wrapper-row.module.project-lead,
.content-wrapper-row.module.page-intro {
    padding: 120px 0;
}

.page-content-wrapper.project .content-wrapper-row.reduced-padding-bottom,
.content-wrapper-row.module.project-lead.reduced-padding-bottom,
.content-wrapper-row.module.page-intro.reduced-padding-bottom,
.content-wrapper-row.module.project-lead.extra-padding-bottom,
.page-content-wrapper.project .content-wrapper-row.extra-padding-bottom {
    padding-bottom: 80px;
}

.content-wrapper-row.module.project-lead.minimal-padding-bottom {
    padding-bottom: 20px;
}

.content-wrapper-row.module.module-projects.reduced-padding-top,
.content-wrapper-row.module.module-grid-full {
    padding-top: 0;
}

.content-wrapper-row.image-gallery-teaser-wrapper {
    padding-top: 100px;
}

.content-wrapper-row.module.project-lead h5.quote {
    margin-top: 80px;
}

.content-wrapper-row.module.project-lead p.quote-author {
    margin-top: 16px;
    font-size: 16px;
    line-height: 24px;
}

.content-wrapper-row.module.no-padding-top {
    padding-top: 0 !important;
}

.content-wrapper-row.module.reduced-padding-top {
    padding-top: 40px;
}

.content-wrapper-row.module.reduced-padding-bottom {
    padding-bottom: 40px;
}

.content-wrapper-row.module.reduced-padding-top.module-3col {
    padding-top: 0;
}

.grid-wrapper {
    width: 100%;
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 32px;
}

.tax-industry section.first,
.post-type-archive-project section.first,
.page-template-projects-list section.first {
    padding-top: 120px;
}

.project-lead .grid-wrapper .row,
.page-intro .grid-wrapper .row,
.module-projects .row {
    display: flex;
}

.module-projects .row {
    flex-wrap: wrap;
    gap: 116px 96px;
}

.tax-industry .module-projects .row,
.post-type-archive-project .module-projects .row,
.page-template-news .module-projects .row {
    gap: 96px 48px;
}

.project-lead.lead-align-right .grid-wrapper .row,
.page-intro.lead-align-right .grid-wrapper .row {
    justify-content: flex-end;
}

.project-lead.lead-align-left .grid-wrapper .row,
.page-intro.lead-align-left .grid-wrapper .row {
    justify-content: flex-start;
}

.project-lead .grid-wrapper .col-copy,
.page-intro .grid-wrapper .col-copy {
    width: calc(66.66% - 16px / 3);
    margin: 0;
}

.tax-industry .project-lead .grid-wrapper .col-copy {
	width: calc(75% - 16px / 3);
}

.module-projects .project-teaser {
    position: relative;
    display: flex;
    gap: 16px;    
    align-items: center;
    width: 100%;
}

.module-projects .project-teaser .element-link {
    position: absolute;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    z-index: 1;
}

.module-projects .project-teaser .element-link:hover ~ .project-teaser-text a span {
    background-color: #1C2229;
}

.module-projects .project-teaser .element-link:hover ~ .project-teaser-text a span svg path {
    stroke: #FFFFFF;
}

.module-projects .project-teaser.format-normal {
    width: calc(50% - 48px);
    flex-direction: column;
}

.tax-industry .project-teaser.format-normal,
.post-type-archive-project .project-teaser.format-normal,
.page-template-news .project-teaser.format-normal {
    width: calc(25% - 36px);
}

.module-projects .project-teaser-category {
    font-family: "Maison Neue Bold", 'Noto Sans TC', sans-serif;
	font-weight: bold;
    margin-bottom: 8px;
}

.module-projects .format-normal .project-teaser-category {
    margin-bottom: 16px;
}

.module-projects .project-teaser-image-wrapper {
    width: 66.66%;
    padding-right: 64px;
}

.module-projects .format-normal .project-teaser-image-wrapper {
    width: 100%;
    padding: 0;
}

.module-projects .format-hero-left .project-teaser-image-wrapper > p,
.module-projects .format-hero-right .project-teaser-image-wrapper > p {
    display: none;
}

.module-projects .format-normal .project-teaser-image-wrapper > p {
    display: block;
}

.module-projects .format-normal .project-teaser-text .project-teaser-category {
    display: none;
}

.module-projects .format-hero-right .project-teaser-image-wrapper {
    order: 2;
    padding-right: 0;
    padding-left: 64px;
}

.module-projects .project-teaser-image {
    padding-bottom: 72.82%;
    background-position: center;
    background-size: cover;
}

.page-template-news .module-projects .project-teaser-image {
    padding-bottom: 60%;
}

.module-projects .project-teaser-video {
    position: relative;
    width: 100%;
    height: 0;
    padding-bottom: 72.5%;
    overflow: hidden;
}

.module-projects .project-teaser-video video { 
    position: absolute;
    height: 100%;
    left: 50%;
    transform: translateX(-50%);
}

.module-projects .project-teaser-text {
    width: 33.33%;
}

.module-projects .format-normal .project-teaser-text {
    width: 100%;
	padding-bottom: 8px;
}

.module-projects .projects-page-wrapper,
.module-team .team-page-wrapper {
    margin-top: 80px;
    justify-content: center;
}

.page-template-news .projects-page-wrapper {
    margin-top: 0;
}

.module-projects .project-teaser-text h3 {
    margin-bottom: 24px;
}

.tax-industry .module-projects .project-teaser-text h3,
.post-type-archive-project .module-projects .project-teaser-text h3,
.page-template-news .module-projects .format-normal .project-teaser-text h3 {
	margin-bottom: 0;
	font-size: 20px;	
}

.page-template-news .format-normal .project-teaser-excerpt {
	display: none;
}

.module-projects .projects-page-wrapper a,
.module-team .team-page-wrapper a {
    display: inline-block;
    padding: 4px 0;
}

.module-projects .projects-page-wrapper a:after,
.module-team .team-page-wrapper a:after {
    content: "";
    position: absolute;
    width: 100%;
    height: 1px;
    bottom: 0px;
    left: 0;
    background: linear-gradient(90deg, currentColor calc(100% / 3), transparent 0 calc(200% / 3), currentColor 0) 0% 100%/300% 3px no-repeat;
    transition: background 0.6s ease-in-out, opacity 0.3s;
}

.module-projects .projects-page-wrapper a:hover:after,
.module-team .team-page-wrapper a:hover:after {
    background: linear-gradient(90deg, currentColor calc(100% / 3), transparent 0 calc(200% / 3), currentColor 0) 100% 100%/300% 3px no-repeat;
}

.text-align-right {
    text-align: right;
}

.col {
    float: left;
}

.col.float-right {
    float: right;
}

.col-full {
    width: calc(100% - 0px);
    margin: 0 auto;
}

.col-full.is-video-wrapper {
    position: relative;
    width: 100%;
    height: 0;
    padding-bottom: 56.25%;
}

.col-copy,
.col-quote,
.wpcf7-response-output {
    width: calc(66.66% - 16px / 3);
    margin: 0 auto;
}

.col-copy > *:last-child,
.col-copy-half > *:last-child {
    margin-bottom: 0;
}

.col-copy p img {
    margin-top: 6%;
}

.col-copy-half-2col {
    margin-bottom: 32px;
}

.col-copy-half-wrapper,
.col-full .col-copy-half-wrapper {
    display: flex;
    gap: 16px;
    width: 100%;
    margin: 0 auto;
}

.col-copy-half-wrapper > div {
    width: 50%;
}

.col-full .col-copy-half-wrapper > div:first-child {
    padding-right: 48px;
}

.col-full .col-copy-half-wrapper > div:last-child {
    padding-left: 48px;
}

.col-full .col-copy-half-wrapper > div > div > img {
    max-width: 50%;
}

.col-copy-half-wrapper > div.is-video-wrapper {
    position: relative;
    height: 0;
    padding-bottom: 28.125%;
}

.col-full-half-wrapper > div:last-child {
    float: right;
}

.col-full-half-wrapper > div {
    width: calc(50% - 15px);
}

.col-copy-quarter-left {
    width: calc(25% - 15px);
}

.col-copy-quarter-right {
    width: calc(75% - 15px);
}

.col-copy-3col-wrapper {
    display: flex;
    gap: 16px;
}

.col-copy-3col-wrapper .col-copy-3col {
    width: calc(33.33%);
}

.col-copy-3col-wrapper h5 {
    margin-bottom: 16px;
}

.col-copy ul,
.col-copy-3col-wrapper .col-copy-3col ul {
    padding-left: 20px;
    list-style: none;
}

.col-copy ul li,
.col-copy-3col-wrapper .col-copy-3col ul li {
    position: relative;
    font-size: 16px;
    line-height: 24px;
    margin-bottom: 16px;
}

.col-copy ul li:after,
.col-copy-3col-wrapper .col-copy-3col ul li:after {
    content: "";
    position: absolute;
    top: 11px;
    left: -20px;
    width: 12px;
    height: 0;
    border-bottom: 1px solid #1C2229;
}

.col-copy ul lI:last-child,
.col-copy-3col-wrapper .col-copy-3col ul li:last-child {
    margin-bottom: 0;
}

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

  .grid-wrapper {
      padding: 0 24px;
  }
  
}

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

	.tax-industry .module-projects .row,
	.post-type-archive-project .module-projects .row,
	.page-template-news .module-projects .row {
		gap: 72px 36px;
	}
	
	.tax-industry .project-teaser.format-normal,
	.post-type-archive-project .project-teaser.format-normal,
	.page-template-news .project-teaser.format-normal {
		width: calc(33.33% - 24px);
	}
	
}

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

  .content-wrapper-row.module,
  .page-content-wrapper.project .content-wrapper-row,
  .content-wrapper-row.module.project-lead,
  .content-wrapper-row.module.page-intro {
      padding: 60px 0;
  }
  
  .page-content-wrapper > section:first-child > .project-lead {
      padding: 80px 0 120px 0 !important;
  }
  
  .page-content-wrapper.project .content-wrapper-row.reduced-padding-bottom,
  .content-wrapper-row.module.project-lead.reduced-padding-bottom,
  .content-wrapper-row.module.page-intro.reduced-padding-bottom,
  .content-wrapper-row.module.project-lead.extra-padding-bottom,
  .page-content-wrapper.project .content-wrapper-row.extra-padding-bottom {
      padding-bottom: 40px;
  }
  
  .page-template-projects-list section.first {
      padding-top: 90px;
  }
  
  .project-lead .grid-wrapper .col-copy,
  .page-intro .grid-wrapper .col-copy {
      width: 100%;
  }
  
  .col-copy-3col-wrapper {
      display: flex;
      gap: 60px;
      flex-direction: column;
  }
  
  .col-copy-3col-wrapper .col-copy-3col {
      width: 100%;
  }
  
  .col-copy-half-wrapper,
  .col-full .col-copy-half-wrapper {
      flex-direction: column;
      gap: 36px;
  }
  
  .col-full .col-copy-half-wrapper > div:first-child {
      padding-right: 0;
  }
  
  .col-full .col-copy-half-wrapper > div:last-child {
      padding-left: 0;
  }
	
	.col-copy-quarter-right {
      width: 100%;
	}
	
	.col-copy-quarter-left {
      width: 60%;
      margin-bottom: 30px;
	}
  
  .module-projects .row {
      gap: 56px;
  }
  
  .module-projects .project-teaser.format-hero-left,
  .module-projects .project-teaser.format-hero-right,
  .module-projects .project-teaser.format-normal {
      flex-direction: column;
      width: 100%;
  }
  
  .module-projects .project-teaser-image-wrapper {
      width: 100%;
      padding: 0;
  }
  
  .module-projects .format-hero-left .project-teaser-image-wrapper > p,
  .module-projects .format-hero-right .project-teaser-image-wrapper > p {
      display: block;
  }
  
  .module-projects .project-teaser-text {
      width: 100%;
  } 
  
  .module-projects .project-teaser-text .project-teaser-category {
      display: none;
  }
  
  .module-projects .format-hero-right .project-teaser-image-wrapper {
      order: 0;
      padding-right: 0;
      padding-left: 0;
  }
	
	.tax-industry .module-projects .row,
	.post-type-archive-project .module-projects .row,
	.page-template-news .module-projects .row {
		gap: 48px 24px;
	}
	
	.tax-industry .project-teaser.format-normal,
	.post-type-archive-project .project-teaser.format-normal,
	.page-template-news .project-teaser.format-normal {
		width: calc(50% - 12px);
	}
	
}

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

	
	.col-full,
	.col-copy,
	.copy-half {
		width: 100%;
	}
	
	.col-copy-half-wrapper > div,
	.col-full-half-wrapper > div {
		width: 100%;
		float: none;
	}
	
	.tax-industry .module-projects .row,
	.post-type-archive-project .module-projects .row,
	.page-template-news .module-projects .row {
		gap: 48px;
	}
	
	.tax-industry .project-teaser.format-normal,
	.post-type-archive-project  .project-teaser.format-normal,
	.page-template-news .project-teaser.format-normal {
		width: 100%;
	}
	
}

@media only screen and (min-width: 1440px) {
	
	.col-full {
		width: calc(100% - 0px);
	}
	
	.col-copy-half-wrapper > div {
		width: calc(50% - 20px);
	}
	
}

.video-fallback {
    display: none;
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    overflow: hidden;
}

.video-fallback picture,
.video-fallback img {
    position: absolute;
    object-fit: cover;
    width: 100%;
    max-width: none !important;
    height: 100% !important;
}

#loader {
    position: absolute;
    top: 0;
    left: 0;
    margin-left: 0;
    margin-top: 0;
    width: 100%;
    height: 100%;
    background: #000000;
    opacity: 0;
    z-index: 50;
    transition: opacity 0.3s;
    pointer-events: none;
}

#loader.show {
    opacity: 1;
}

#loader img {
    position: absolute;
    top: 50%;
    left: 50%;
    margin-left: -100px;
    margin-top: -50px;
    width: 200px;
    height: 100px;
}

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

  #loader img {
      position: absolute;
      top: 50%;
      left: 50%;
      margin-left: calc(-200px / 3);
      margin-top: calc(-100px / 3);
      width: calc(400px / 3);
      height: calc(200px / 3);
  }
  
}

/*** Home ***/
.page-content-wrapper.home {
    opacity: 0;
    -webkit-transition: opacity 0.2s;
    transition: opacity 0.2s;
}

.page-content-wrapper.home.visible {
    opacity: 1;
}

/*** Fullscreen Media Tiles ***/
.video-wrapper {
    position: absolute;
    width: 100%;
    height: 100%;
    overflow: hidden;
    z-index: 1;
}

.single-news-entry .project-header .video-wrapper {
	left: 50%;
    max-width: 1136px;
    transform: translateX(-50%);
}

.video-wrapper-overlay {
    position: absolute;
    height: 100%;
    width: 100%;
    z-index: 10;
}

.video-wrapper-overlay .grid-wrapper {
    height: 100%;
}

.video-wrapper-overlay .grid-wrapper .row {
    display: flex;
    flex-direction: column;
    justify-content: center;
    height: 100%;
}

.video-wrapper video {
    object-fit: cover;
    font-family: 'object-fit: cover;';
    width: 100%;
    height: 100%;
}

/*** Projects Navigation ***/
.page-content-wrapper.projects {
    opacity: 0;
    -webkit-transition: opacity 0.2s;
    transition: opacity 0.2s;
}

.page-content-wrapper.projects.visible {
    opacity: 1;
}

/*** Newsletter ***/
.content-newsletter-wrapper {
    padding: 0 0 100px 0;
}

.content-newsletter-wrapper .row {
    display: flex;
    gap: 16px;
    align-items: flex-start;
    width: 100%;   
}

.content-newsletter-left {
    width: 66.66%;
    padding-right: 64px;
}

.content-newsletter-right {
    width: 33.33%;
}

.content-newsletter-text {
    color: #00AFFF;
}

.content-newsletter-right .form-row {
    display: flex;
    gap: 16px;
    flex-wrap: nowrap;
    width: 100%;
    margin-bottom: 32px;
}

.content-newsletter-right .form-row input {
    appearance: none;
    border: 0;
    font-size: 16px;
    line-height: 24px;
    padding-bottom: 8px;
    border-bottom: 1px solid #1C2229;
}

.content-newsletter-right .form-row input[type="text"] {
    width: 50%;
}

.content-newsletter-right .form-row input[type="email"] {
    width: 100%;
}

.content-newsletter-right .form-title {
    margin-bottom: 32px;
}

.content-newsletter-right .form-submit-wrapper {
    position: relative
}

.content-newsletter-right .form-submit-wrapper input {
    padding-left: 54px;
    font-family: "Maison Neue Bold";
    color: #00AFFF;
    font-size: 16px;
    line-height: 44px;
    appearance: none;
    border: 0;
    background-color: unset;
    background-image: url(images/cta-arrow-submit.svg);
    background-repeat: no-repeat;
    background-position: left;
    background-size: 44px 44px;
    cursor: pointer;
}

.content-newsletter-legal {
    display: none;
    margin-top: 56px;
    text-align: center;
}

.content-newsletter-legal a {
    display: inline-block;
    padding: 4px 0;
}

.content-newsletter-legal a:after {
    content: "";
    position: absolute;
    width: 100%;
    height: 1px;
    bottom: 0px;
    left: 0;
    background: linear-gradient(90deg, currentColor calc(100% / 3), transparent 0 calc(200% / 3), currentColor 0) 0% 100%/300% 3px no-repeat;
    transition: background 0.6s ease-in-out, opacity 0.3s;
}

.content-newsletter-legal a:hover:after {
    background: linear-gradient(90deg, currentColor calc(100% / 3), transparent 0 calc(200% / 3), currentColor 0) 100% 100%/300% 3px no-repeat;
}

@-webkit-keyframes autofill {
    to {
        color: #000;
        background: transparent;
    }
}

.content-newsletter-right input[name='email']:-webkit-autofill,
.content-newsletter-right input[name='EMAIL']:-webkit-autofill {
    -webkit-animation-name: autofill;
    -webkit-animation-fill-mode: both;
}

.mc4wp-response {
    margin-top: 40px;
    text-align: center;
}

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

  .content-newsletter-wrapper {
      padding: 0 0 60px 0;
  }
  
  .content-newsletter-wrapper .row {
      gap: 56px;
      flex-direction: column;
  }
  
  .content-newsletter-left {
      width: 100%;
      padding-right: 0;
  }
  
  .content-newsletter-right {
      width: 100%;
  }
  
  .content-newsletter-legal {
      display: block;
  }
  
  .content-newsletter-right .form-title {
      margin-bottom: 28px;
  }
  
  .content-newsletter-right .form-row {
      gap: 28px;
      flex-direction: column;
  }
  
  .content-newsletter-right .form-row input[type="text"] {
      width: 100%;
  }
  
}

/*** Projects Page ***/
.single-news-entry .content-wrapper-row.module.project-pre-header,
.single-project .content-wrapper-row.module.project-pre-header {
    padding-top: 220px;
    padding-bottom: 60px;
}

.single-news-entry .module-project-entry-category,
.single-project .module-project-entry-category {
    font-family: "Maison Neue Book";
    font-size: 20px;
    line-height: 27px;
    margin-bottom: 16px;
}

html[lang="zh-tw"] .single-news-entry .module-project-entry-category,
html[lang="zh-tw"] .single-project .module-project-entry-category {
	font-family: "Maison Neue Book", 'Noto Sans TC', sans-serif;
}

html[lang="zh-cn"] .single-news-entry .module-project-entry-category,
html[lang="zh-cn"] .single-project .module-project-entry-category {
	font-family: 'Noto Sans SC', sans-serif;
}

.single-news-entry .project-pre-header h1,
.single-project .project-pre-header h1 {
    font-size: calc(36px + (48 - 36) * (100vw - 414px) / (1440 - 414));
    /*line-height: 1.08;*/
    line-height: 1.5;
}

.single-news-entry .content-wrapper-row.module.module-grid-copy.reduced-padding-bottom,
.single-project .content-wrapper-row.module.module-grid-copy.reduced-padding-bottom {
    padding-bottom: 0;
}

.project-header {
    position: relative;
    height: 0;
    padding-bottom: 50%;
}

.project-header img {
    position: absolute;
    object-fit: cover;
    width: 100%;
    height: 100%;
}

.single-news-entry .project-header img {
    left: 50%;
    max-width: 1136px;
    transform: translateX(-50%);
}

.page-content-wrapper.project .content-wrapper-row.image-gallery-teaser-wrapper {
    padding: 0;
}

.page-content-wrapper.project .content-wrapper-row.image-gallery-teaser-wrapper + .content-wrapper-row.module-divider.images-gallery {
    padding-top: 28px;
}

.content-wrapper-row.module-divider.images-gallery.no-padding-bottom {
    padding-bottom: 0;
}

.content-wrapper-row.module-divider.images-gallery .c-slider {
    position: relative;
}

.content-wrapper-row.module-divider.images-gallery .c-slider__container {
    display: flex;
}

.project-contact-wrapper {
    padding-bottom: 120px;
}

.page-header {
    position: relative;
    height: 90vh;
}

.isMobile .page-header {
    -webkit-transition: height 0.3s;
    transition: height 0.3s;
}

.page-header.hasHypeContent .hype-wrapper {
    width: 80%;
    height: 80%;
    margin: 0 10%;
    padding-top: 10%;
}

/*.page-header.hasGradient:before {
	content: "";
	position: absolute;
	opacity: 0.8;
	width: 100%;
	height: 100%;
	background: -moz-linear-gradient(top, rgba(0,0,0,0.6) 0%, rgba(0,0,0,0) 130px, rgba(0,0,0,0) 100%);
	background: -webkit-linear-gradient(top, rgba(0,0,0,0.6) 0%,rgba(0,0,0,0) 130px,rgba(0,0,0,0) 100%);
	background: linear-gradient(to bottom, rgba(0,0,0,0.6) 0%,rgba(0,0,0,0) 130px,rgba(0,0,0,0) 100%);
	filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#99000000', endColorstr='#00000000',GradientType=0 );
	transform: translateZ(0);
	z-index: 5;
}*/

.page-header.scroll-white .scroll-indicator,
.page-header.scroll-black .scroll-indicator {
    display: none;
    content: "";
    position: absolute;
    bottom: 40px;
    margin-bottom: -21px;
    margin-left: -21px;
    left: 50%;
    width: 43px;
    height: 43px;
    opacity: 0;
    background: url(images/scroll-arrow-white@2x.png);
    background-size: 43px 43px;
    z-index: 1;
    animation-name: pointy-down, disappear;
    animation-duration: 1.5s, 4.5s;
    animation-iteration-count: 3, 1;
}

.page-header.scroll-black .scroll-indicator {
    background: url(images/scroll-arrow-black@2x.png);
}

@keyframes pointy-down {
	0%, 20%, 50%, 80%, 100% {
		bottom: 40px;
	}
	40% {
		bottom: 50px;
	}
	60% {
		bottom: 45px;
	}
}

.page-header picture,
.page-header img {
    position: absolute;
    object-fit: cover;
    width: 100%;
    height: 100%;
}

.page-header .header-text {
    position: absolute;
    padding: 0 32px;
    width: 100%;
    max-width: 1200px;
    bottom: 120px;
    left: 50%;
    transform: translateX(-50%);
    font-family: "Maison Neue Bold";
    z-index: 10;
}

.page-header .header-text.vertical-align {
    bottom: 50%;
    transform: translateX(-50%) translateY(50%);
}

.project-lead h2 {
    margin-bottom: 50px;
}

.module-grid-copy img {
    width: 100%;
    max-width: 100%;
    height: auto;
}

.col-copy-half-wrapper img {
    margin: 0;
}

.divider-wrapper {
    position: relative;
    width: 100%;
    height: 0;
    padding-bottom: 56.25%;
    max-width: 1440px;
    margin: 0 auto;
}

.divider-wrapper picture,
.divider-wrapper img {
    position: absolute;
    object-fit: cover;
    width: 100%;
    height: 100%;
}

@media only screen and (min-width: 1px) and (max-width: 767px) {
  
  .divider-wrapper {
    height: 90vh;
    padding-bottom: 0;
  }
  
  .page-header .header-text {
      padding: 0 24px;
      bottom: 80px;
  }
  
  .single-project .content-wrapper-row.module.project-pre-header {
      padding-top: 150px;
      padding-bottom: 20px;
  }
  
  .project-header {
      padding-bottom: 75%;
  }
  
  .single-project section:first-child .content-wrapper-row {
      padding: 80px 0 40px 0;
  }
  
}

.hype-wrapper {
	position: relative;
	width: 100%;
	height: 0;
}

.hype-height-wrapper {
	position: absolute;
	width: 100%;
	height: 100%;
}

.quote-author-wrapper {
    margin-top: 20px;
}

.quote-author-wrapper span:first-child {
    display: block;
    font-family: 'Maison Neue Bold';
	font-weight: bold;
}

.project-contact-wrapper .row {
    display: flex;
}

.project-social-wrapper {
	background: #FFF;
	border-top: 2px solid rgba(151, 151, 151, 0.5);
	position: relative;
    width: 100%;
    height: 252px;
}

.project-competences-wrapper {
	background: #FFF;
	border-top: 2px solid rgba(151, 151, 151, 0.5);
	position: relative;
    width: 100%;
	padding-bottom: 8%;
}

.project-competences-wrapper .project-competences-left,
.project-competences-wrapper .project-competences-right {
	font-size: 22px;
	line-height: 1.27;
	letter-spacing: 0.4px;
	color: rgba(0, 0, 0, 0.5);
}

.project-social-wrapper .social-wrapper {
	height: 70px;
    width: 100%;
    text-align: center;
    margin: 0 auto;
}

.project-social-wrapper .social-wrapper .social {
	top: 15px;
}

.project-social-title,
.project-competences-title,
.impulse-download-title,
.faq-title {
	position: absolute;
	left: 0;
	width: 100%;
	font-family: "Maison Neue Bold";
	font-size: 20px;
    line-height: 1.1;
    padding: 35px 0;
    text-align: center;
	color: #979797;
}

.project-social-title,
.project-competences-title,
.impulse-download-title,
.faq-title {
    position: relative;
}

.project-contact-left {
    align-self: center;
    width: 50%;
    padding-right: 96px;
}

.project-contact-right {
    width: 50%;
    padding-left: 48px;
}

.project-contact-text h4 {
    margin-bottom: 24px;
}

.project-contact-name {
    font-family: "Maison Neue Bold", 'Noto Sans TC', sans-serif !important;
    font-size: 20px;
    margin-top: 24px;
}

html[lang="zh-tw"] .project-contact-name,
html[lang="zh-cn"] .project-contact-name {
	font-weight: 700;
}

.project-contact-phone {
    margin-top: 24px;
}

.project-contact-linkedin {
    margin-top: 24px;
}

.project-contact-linkedin a {
    display: inline-block;
    padding: 4px 0;
}

.project-contact-linkedin a:after {
    content: "";
    position: absolute;
    width: 100%;
    height: 1px;
    bottom: 0px;
    left: 0;
    background: linear-gradient(90deg, currentColor calc(100% / 3), transparent 0 calc(200% / 3), currentColor 0) 0% 100%/300% 3px no-repeat;
    transition: background 0.6s ease-in-out, opacity 0.3s;
}

.project-contact-linkedin a:hover:after {
  background: linear-gradient(90deg, currentColor calc(100% / 3), transparent 0 calc(200% / 3), currentColor 0) 100% 100%/300% 3px no-repeat;
}

.project-references-wrapper,
.content-wrapper-row.module-divider.project-references-wrapper {
    position: relative;
    border-top: 2px solid #979797;
    width: 100%;
    height: 0;
    padding-bottom: calc(56.8% + 73px);
    overflow: hidden;
}

.content-wrapper-row.module-divider.project-references-wrapper {
	border: 0;
}

.project-references-title {
	position: absolute;
    width: 100%;
	font-family: "Maison Neue Bold";
	font-size: 20px;
    line-height: 1.1;
    padding: 33px 15px;
    text-align: center;
}

.c-slider.references-slider {
	height: 100%;
	width: calc(50% - 60px);
}

.reference-item {
	position: relative;
	padding: 0 30px;
    height: 100%;
	overflow: hidden;
	transform: translateZ(0);
	transform-style: preserve-3d;
	will-change: auto;	
}

.reference-item > div {
	position: relative;
    width: 100%;
    height: 100%;
    overflow: hidden;
	transform: translateZ(0);
	transform-style: preserve-3d;
	will-change: auto;
}

.projects-grid .team-member picture img {
	width: 100%;
    height: 100%;
    object-fit: cover;
}

/*.projects-customer-list {
	background: #FFF;
}

.projects-customer-list p,
.projects-customer-list a {
	color: rgba(0, 0, 0, 0.5);
}

.projects-customer-list a {
	transition: color 0.3s;
}

.projects-customer-list a:hover {
	color: #000;
}*/

.projects-filter-title {
	font-family: "Maison Neue Bold";
	color: #FFF;
    padding: 136px 0;   
}

.projects-filter-title.no-filter {
	padding-bottom: 72px;
}

.projects-filter {
	position: relative;
}

#projectsFilter {
	max-width: 100%;
	font-family: 'Maison Neue Bold';
	font-size: 32px;
    line-height: 36px;
    background: transparent;
    color: #FFF;
    border: 0;
    border-bottom: 4px solid #FFF;
}

#projectsFilter option {
	color: #000;
}

.projects-cat-scroll-wrapper {
	overflow: auto;
    padding: 15px 0;
}

.projects-filter-item {
	margin-bottom: 15px;
}

.projects-list-wrapper {
	width: calc(100% - 10px);
	padding: 32px 0;
}

.projects-list-item {
	position: relative;
	float: left;
	width: calc(33.333% - 15px);
	padding: 32px 15px;
}

.projects-list-item a {
	position: absolute;
	width: 100%;
	height: 100%;
	left: 0;
	top: 0;
  z-index: 1;
}

.projects-list-image {
	float: left;
    width: 150px;
    height: 150px;
}

.projects-list-image picture {
	width: 100%;
    height: 100%;
}

.projects-list-image picture img {
	width: 100%;
    height: 100%;
    object-fit: cover;
}

.projects-list-name {
	position: absolute;
    top: 50%;
    margin-left: 170px;
    font-family: 'Maison Neue Bold';
    font-size: 32px;
    line-height: 36px;
    color: #FFF;
    transform: translateY(-50%);
}

@media only screen and (min-width: 768px) and (max-width: 1439px) {
	
	.projects-list-item {
		width: calc(50% - 15px);
		padding: 24px 15px;
	}
	
	.projects-list-image {
		width: calc(96px + (150 - 96) * (100vw - 768px) / (1440 - 768));
		height: calc(96px + (150 - 96) * (100vw - 768px) / (1440 - 768));
	}
	
	.projects-list-name {
		margin-left: calc(116px + (170 - 116) * (100vw - 768px) / (1440 - 768));
		font-size: calc(18px + (32 - 18) * (100vw - 768px) / (1440 - 768));
		line-height: 1.1;
	}
		
}

@media only screen and (min-width: 1px) and (max-width: 767px) {
  
  .project-contact-wrapper {
      padding-bottom: 60px;
  }
  
  .project-contact-wrapper .row {
      flex-direction: column;
      gap: 56px;
  }
  
  .project-contact-left {
      width: 100%;
      padding-right: 0;
  }
  
  .project-contact-right {
      width: 100%;
      padding-left: 0;
  }
	
	#projectsFilter {
		width: 100%;
		font-size: 24px;
		line-height: 26px;
	}
	
	/*.projects-filter-item {
		margin-bottom: 0;
	}*/
	
	.projects-list-item {
		width: 100%;
		padding: 12px 0px;
	}
	
	.projects-list-image {
		width: 96px;
		height: 96px;
	}
	
	.projects-list-name {
		margin-left: 116px;
		font-size: 18px;
		line-height: 22px;
	}
	
}

@media only screen and (min-width: 1px) and (max-width: 600px) {
	
	.project-social-wrapper .social-wrapper {
		height: auto;
	}
	
	.project-social-wrapper .grid-wrapper {
		position: relative;
	}
	
	.project-social-title,
	.project-competences-title {
		position: relative;
		font-size: 18px;
	}
	
	.project-references-title {
		font-size: 18px;
	}
	
	.project-competences-wrapper .col-copy-half-wrapper > div:first-child {
		margin: 0;
	}
	
	.project-competences-wrapper {
		padding-bottom: 15%;
	}
	
	.project-competences-wrapper .text-align-right {
		text-align: left;
	}
	
	.project-competences-wrapper p {
		font-size: 14px;
	}
	
	.project-social-wrapper {
		height: auto;
		padding-bottom: 15%;
	}
	
	.projects-cat-scroll-wrapper {
		margin-bottom: 0;
		white-space: nowrap;
	}
	
}

@media only screen and (min-width: 1440px) {
  
  .project-header {
    position: relative;
    height: 720px;
    padding-bottom: 0;
  }
	
	.divider-wrapper {
		height: 880px;
		padding-bottom: 0;
	}
	
	.project-social-title,
	.project-competences-title,
	.impulse-download-title,
	.faq-title {
		font-size: 21px;
	}
	
	.project-references-wrapper,
	.content-wrapper-row.module-divider.project-references-wrapper {
		height: 883px;
		padding-bottom: 0;
	}
	
	.project-references-title {
		font-size: 22px;
	}
	
}

@media only screen and (min-width: 1664px) {

	.project-social-wrapper .grid-wrapper {
		margin: 0 calc(50% - 832px);
	}
	
}

@media only screen and (min-width: 1920px) {
	
	.project-social-title,
	.project-competences-title,
	.impulse-download-title,
	.faq-title {
		font-size: 22px;
	}
	
}

@media only screen and (max-width: 768px) {
	
	.project-references-wrapper,
	.content-wrapper-row.module-divider.project-references-wrapper {
		height: 502px;
		padding-bottom: 0;
	}
	
	.projects-filter-title {
		padding: 40px 0;
	}
	
	.projects-filter-title.no-filter {
		padding-bottom: 0;
	}
	
}

@media only screen and (max-width: 430px) {
	
	.project-references-wrapper,
	.content-wrapper-row.module-divider.project-references-wrapper {
		height: 0;
		padding-bottom: calc(123.4% + 120px);
	}
	
	.reference-item {
		padding: 0 16px;
	}
	
	.c-slider.references-slider {
		width: calc(100% - 48px);
		left: 24px;
	}
	
}

.fp-slide.reference-item.fs_media > div:after {
	content: "";
	position: absolute;
	bottom: 0;
	opacity: 0.8;
	width: 100%;
	height: 100%;
	background: -moz-linear-gradient(top, rgba(0,0,0,0) 0%, rgba(0,0,0,0) 50%, rgba(0,0,0,0.6) 100%);
	background: -webkit-linear-gradient(top, rgba(0,0,0,0) 0%,rgba(0,0,0,0) 50%,rgba(0,0,0,0.6) 100%);
	background: linear-gradient(to bottom, rgba(0,0,0,0) 0%,rgba(0,0,0,0) 50%,rgba(0,0,0,0.6) 100%);
	filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#00000000', endColorstr='#99000000',GradientType=0 );
	transform: translateZ(0);
	z-index: 1;
}

.fp-slide.reference-item.fs_media.hasHype > div:after {
	content: none;
}

.reference-item .left,
.reference-item .right {
	overflow: hidden;
}

.fp-slide.reference-item.hs_media_text .video-wrapper {
	width: 100%;
    height: 50% !important;
}

.fp-slide.reference-item .left {
	float: none;
	width: 100%;
	height: 50.6%;
	top: 0;
}

.fp-slide.reference-item .right {
	float: none;
	width: 100%;
	height: 50%;
	bottom: 0;
}

.fp-slide.reference-item.fs_media .right,
.fp-slide.reference-item.fs_media.hasVideo .right{
	top: 50%;
}

.fp-slide.reference-item .copy-wrapper {
	width: 100%;
	top: 20px;
	left: 0;
	text-align: center;
}

.fp-slide.reference-item .copy-wrapper .customer {
    font-size: 18px;
    height: 60px;
}

.fp-slide.reference-item .copy-wrapper .title {
    font-size: 30px;
    line-height: 1.17;
	letter-spacing: 0.8px;
    height: 120px;
}

.fp-slide.reference-item .button {
	margin: 0 auto;
}

.fp-slide.reference-item.fs_text .button {
    top: calc(50% + 200px);
    bottom: auto;
    margin-left: -100px;
}

@media only screen and (max-width: 1023px) {
	
	.fp-slide.reference-item .copy-wrapper {
		top: 10px;
	}
	
	.fp-slide.reference-item .copy-wrapper .customer {
		font-size: 14px;
		height: 42px;
	}
	
	.fp-slide.reference-item .copy-wrapper .title {
		font-size: 22px;
		line-height: 1.17;
		letter-spacing: 0.8px;
		height: 88px;
	}
	
	.fp-slide.reference-item .button {
		font-size: 16px;
		width: 180px;
	}
	
	.fp-slide.reference-item .button a {
		padding: 8px 0;
	}
	
	.fp-slide.reference-item.fs_text .button {
		top: calc(50% + 140px);
		margin-left: -90px;
	}
	
}

@media only screen and (max-width: 430px) {
	
	.fp-slide.reference-item .copy-wrapper {
		top: 15px;
	}
	
	.fp-slide.reference-item .copy-wrapper .customer {
		font-size: 16px;
		height: 45px;
	}
	
	.fp-slide.reference-item .copy-wrapper .title {
		height: 90px;
	}
	
}

/*** Kompetenzen ***/
.content-wrapper-row.page-intro {
	padding: 10vh 0;
}

.page-intro {
	font-size: 32px;
	line-height: 1.25;
	letter-spacing: 1px;
	color: #FFF;
	background-color: #000;
}

.page-intro p,
.project-lead p {
	margin-bottom: 40px;
}

.page-intro p:last-child,
.project-lead p:last-child {
	margin-bottom: 0;
}

/*** Impulse & Agentur > News ***/
.impulse-wrapper,
.news-wrapper {
	position: relative;
	padding: 40px 0 45px 0;
	border-bottom: 2px solid rgba(255, 255, 255, 0.45);
}

.sticky-wrapper {
	z-index: 1;
}

.news-wrapper {
	color: #FFF;
}

.news-wrapper > a,
.impulse-wrapper > a {
	position: absolute;
    top: 0;
    width: 100%;
    height: 100%;
}

#news-categories {
	display: none;
	margin-bottom: 72px;
}

#news-categories.rendered {
	display: block;
}

.news-categories .grid-wrapper {
	padding-right: 0;
	opacity: 0;
	transition: opacity 0.3s;
}

.news-categories.rendered .grid-wrapper {
	opacity: 1;
}

.news-cat-inner-wrapper {
	min-height: 82px;
	padding: 5px 0;
}

.news-cat-scroll-wrapper {
	overflow: auto;
    padding: 15px 0;
    white-space: nowrap;
}

.news-cat-mask-wrapper {
	position: relative;
}

.simplebar-content > div {
	display: inline-block;
  margin-right: 10px;
  border: 1px solid #000;
  border-radius: 20px;
  line-height: 40px;
  padding: 0px 20px;
	transition: background 0.3s, color 0.3s;
	cursor: pointer;
}

.simplebar-content > div p {
	font-family: 'Maison Neue Book';
  /*font-size: 20px;
  line-height: 1;*/
  font-size: 1.3rem;
  line-height: 40px;
}

.simplebar-content > div.active {
	cursor: default;
}

.simplebar-content > div.active,
.simplebar-content > div:hover {
	background: #000;
    color: #FFF;
}

.news-more {
	width: 100%;
  	padding: 40px 0;
  	text-align: center;
}

.news-more-button {
  display: inline-block;
  background-color: #55C8FF;
  color: #000;
  border: 0;
  padding: 11px 20px;
  font-family: "Maison Neue Bold";
  text-decoration: none;
  text-align: center;
  font-size: 18px;
  border-radius: 2px;
  transition: background 0.6s;
  cursor: pointer;
}

.news-more-button:hover {
  background-color: #FFFFFF;
}

@media only screen and (min-width: 1440px) {
	
	.news-categories .col-full {
		width: 100%;
	}
	
}

@media only screen and (max-width: 430px) {
	
	#news-categories {
		max-height: 57px;
	}
  
  .nav-down .news-categories {
    top: 55px !important;
  }
	
	.news-cat-inner-wrapper {
		padding: 0;
		padding-top: 1px;
	}
	
	.news-categories .grid-wrapper {
		padding: 0;
	}
	
	.news-categories .col-full {
		width: 100%;
		margin: 0 auto;
	}
	
	.news-cat-scroll-wrapper {
		padding: 15px 0 15px 15px;
	}
	
	.news-cat-mask-wrapper:before {
		width: 15px;
	}

	.news-cat-mask-wrapper:after {
		width: 15px;
	}
	
}

.impulse-spacer,
.news-spacer {
	height: 102px;
}

@media (max-width: 736px) and (orientation: landscape), (max-width: 430px) and (orientation: portrait) {
	
	.impulse-spacer,
	.news-spacer {
		height: 57px;
	}
	
}

.impulse-title p,
.news-category p {
	font-family: "Maison Neue Bold";
	margin-bottom: 25px;
}

html[lang="zh-tw"] .impulse-title p,
html[lang="zh-tw"] .news-category p {
	font-family: "Maison Neue Book", 'Noto Sans TC', sans-serif;
}

html[lang="zh-cn"] .impulse-title p,
html[lang="zh-cn"] .news-category p {
	font-family: 'Noto Sans SC', sans-serif;
}

html[lang="zh-tw"] .impulse-title p,
html[lang="zh-tw"] .news-category p,
html[lang="zh-cn"] .impulse-title p,
html[lang="zh-cn"] .news-category p {
	font-weight: 700;
}

.impulse-excerpt {
	margin-bottom: 34px;
}

.news-title {
	font-family: "Maison Neue Bold";
	margin-bottom: 25px;
}

html[lang="zh-tw"] .news-title {
	font-family: "Maison Neue Book", 'Noto Sans TC', sans-serif;
}

html[lang="zh-cn"] .news-title {
	font-family: 'Noto Sans SC', sans-serif;
}

html[lang="zh-tw"] .news-title,
html[lang="zh-cn"] .news-title {
	font-weight: 700;
}

.impulse-teaser-image,
.news-teaser-image {
	width: calc(66.66% + 30px);
    margin-left: calc(33.33% - 30px);
}

.impulse-teaser-image.compact,
.news-teaser-image.compact {
	width: calc(50% - 15px);
    margin-left: calc(50% + 15px);
}

.impulse-wrapper .button,
.impulse-download-wrapper .button {
	border: 0;
    width: 200px;
    text-align: center;
    font-size: 18px;
    border-radius: 2px;
}

.impulse-download-wrapper .button {
	margin: 0 auto;
}

.impulse-wrapper .button a,
.impulse-download-wrapper .button a {
	display: block;
	font-family: "Maison Neue Bold";
    text-decoration: none;
    padding: 11px 0;
}

.impulse-download-wrapper,
.impulse-list-wrapper {
	background: #FFF;
	padding-bottom: 8%;
}

.impulse-list-wrapper {
	border-top: 2px solid rgba(151, 151, 151, 0.5);
}

.faq-wrapper {
	color: #FFF;
	padding-bottom: 8%;
}

.impulse-download-wrapper .col-copy {
	padding: 2% 0;
}

.impulse-download-wrapper .legal {
	font-size: 15px;
    line-height: 1.33;
    letter-spacing: 1px;
    text-align: center;
	color: rgba(0, 0, 0, 0.5);
}

.impulse-list-wrapper ul {
	list-style-type: none;
}

.impulse-list-wrapper ul li {
	position: relative;
	padding-left: 44px;
}

.impulse-list-wrapper ul li svg {
	position: absolute;
    left: 0;
    width: 38px;
    height: 32px;
}

.impulse-list-wrapper ul li svg g g {
	stroke-width: 2px;
}

.impulse-btn {
	position: absolute;
    bottom: 10%;
    left: 50%;
    border: 0;
    width: 260px;
	margin-left: -130px;
    text-align: center;
    font-size: 18px;
    border-radius: 2px;
	z-index: 1;
}

.impulse-btn a {
	display: block;
    font-family: "Maison Neue Bold";
    text-decoration: none;
    padding: 11px 0;
}

.whitepaper-download {
	background: #FFF;
	padding-top: 140px;
	min-height: 50vw;
}

.whitepaper-download p {
	text-align: center;
}

.whitepaper-download .impulse-btn {
	position: relative;
	margin-bottom: 140px;
	background: #ffed00;
	transition: background 0.3s;
}

.whitepaper-download .impulse-btn:hover {
	background: #000;
}

.whitepaper-download .impulse-btn a {
	color: #000;
	border: 0;
	transition: color 0.3s;
}

.whitepaper-download .impulse-btn a:hover {
	color: #ffed00;
}

@media only screen and (max-width: 430px) {
	
	.impulse-wrapper,
	.news-wrapper {
		padding: 45px 0 37px 0;
	}
	
	.impulse-download-wrapper {
		padding-bottom: 15%;
	}
	
	.impulse-teaser-image,
	.impulse-teaser-image.compact,
	.news-teaser-image,
	.news-teaser-image.compact {
		width: 100%;
		margin-left: 0;
		margin-bottom: 20px;
	}
	
	.impulse-title,
	.news-title {
		font-size: 28px;
		margin: 25px 0 15px 0;
	}
  
  .news-category {
    margin-top: 20px;
  }

}

/*** Agentur > Team ***/
.module-team .grid-wrapper.is-slider {
    max-width: unset;
    padding: 0;
}

.module-team .row {
  position: relative;
}

.module-team-grid {
    display: flex;
    flex-wrap: wrap;
    gap: 80px 16px;
}

.infiniteslide {
    align-items: flex-start !important;
}

.module-team-member {
    width: calc(33.33% - 32px / 3);
    max-width: 384px;
}

.module-team-member.half-width {
    width: calc(50% - 8px);
    max-width: unset;
}

.module-team-member.half-width:nth-child(odd) {
    padding-right: 40px;
}

.module-team-member.half-width:nth-child(even) {
    padding-left: 40px;
}

.module-team-member-label {
    font-family: 'Maison Neue Bold';
    font-size: 16px;
    line-height: 24px;
    margin-bottom: 16px;
}

.module-team-member-image-wrapper {
    width: 100%;
    height: 0;
    padding-bottom: 100%;
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
}

.module-team-member-content {
    margin-top: 16px;
    /*font-size: 16px;
    line-height: 24px;*/
    font-size: 1.3rem;
    line-height: 2.4rem;
}

.module-team-member-name {
    font-family: "Maison Neue Bold";
}

html[lang="zh-tw"] .module-team-member-name {
  font-family: "Maison Neue Bold", 'Noto Sans TC', sans-serif;
	font-weight: 700;
}

html[lang="zh-cn"] .module-team-member-name {
	font-family: 'Noto Sans SC', sans-serif;
	font-weight: 700;
}

.module-team-slider .module-team-member {
    padding-right: 16px;
}

.team-page-wrapper {
    display: flex;
}

.team-filter {
    margin-bottom: 72px;
}

.team-filter-wrapper {
    overflow: auto;
    white-space: nowrap;
}

.team-filter-item {
    display: inline-block;
    margin-right: 10px;
    border: 1px solid #000;
    border-radius: 21px;
    padding: 10px 20px;
    transition: background 0.3s, color 0.3s;
    cursor: pointer;
}

@media only screen and (min-width: 1px) and (max-width: 767px) {
  
  .module-team-member {
      width: calc(100% - 32px / 3);
      max-width: 296px;
  }
  
  .module-team-grid {
      gap: 40px 20px;
  }
  
  .module-team-grid .module-team-member {
      width: calc(50% - 10px);
  }
  
  .page-template-contact .module-team .module-team-grid .module-team-member {
      width: 100%;
  }
  
  .page-template-contact .module-team .module-team-member.half-width:nth-child(odd) {
      padding-right: 0;
  }
  
  .page-template-contact .module-team .module-team-member.half-width:nth-child(even) {
      padding-left: 0;
  }
	
}

/*** Agentur > Jobs ***/
.module-jobs-grid {
    display: flex;
	flex-wrap: wrap;
    gap: 80px 16px;
}

.module-job-entry {
    position: relative;
    width: calc(50% - 8px);
}

.module-job-entry .element-link {
    position: absolute;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    z-index: 1;
}

.module-job-entry .element-link:hover ~ .module-job-entry-link a span {
    background-color: #1C2229;
}

.module-job-entry .element-link:hover ~ .module-job-entry-link a span svg path {
    stroke: #FFFFFF;
}

.module-job-entry-category {
    font-family: "Maison Neue Bold";
    font-size: 16px;
    line-height: 24px;
    margin-bottom: 14px;
}

.single-job-entry .content-wrapper-row.module.job-header {
    padding-top: 220px;
}

.single-job-entry section + section .content-wrapper-row.module.reduced-padding-top {
    padding-top: 0;
}

.single-job-entry .module-job-entry-category {
    font-family: "Maison Neue Book";
    font-size: 20px;
    line-height: 27px;
    margin-bottom: 16px;
}

.single-job-entry .job-header h1 {
    font-size: calc(36px + (48 - 36) * (100vw - 414px) / (1440 - 414));
    line-height: 1.08;
}

.jobs .page-intro,
.job-wrapper {
	border-bottom: solid 2px rgba(255, 255, 255, 0.45);
}

.job-wrapper {
	position: relative;
	padding-top: 4%;
}

.job-wrapper a {
	position: absolute;
	display: block;
	top: 0;
	width: 100%;
	height: 100%;
}

.job {
	color: #FFF;
	font-family: "Maison Neue Bold";
}

.job-location {
	font-size: 20px;
	line-height: 1.25;
	letter-spacing: 0.5px;
}

.job-title {
	font-family: "Maison Neue Bold";
	font-size: 40px;
	line-height: 1.13;
	letter-spacing: 0.2px;
	margin-top: 4%;
}

.job-excerpt {
	font-size: 20px;
	line-height: 1.25;
	letter-spacing: 0.5px;
	margin-top: 8%;
	margin-bottom: 16%;
}

.job-excerpt p {
	margin-bottom: 25px;
}

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

  .single-job-entry .content-wrapper-row.module.job-header {
      padding-top: 150px;
  }
  
}

@media only screen and (max-width: 430px) {
	
	.page-content-wrapper.jobs {
		padding-top: 55px;
	}
	
	.job-location {
		font-size: 14px;
		text-align: center;
		margin: 4% 0 6%;
	}
	
	.job-title {
		font-size: 35px;
		text-align: center;
	}
	
	.job-excerpt {
		margin-top: 16%;
	}
	
}

/*** Standorte ***/
.module-locations-tabs {
	border-top: 1px solid #EBEBEB;
}

.locations-tabs {
	margin: 60px 0;
}

.locations-tab {
	float: left;
	margin-right: 60px;
    border-bottom: 3px solid rgba(255, 255, 255, 0);
	transition: border-color 0.3s;
    cursor: pointer;
}

.locations-tab:last-child {
	margin: 0;
}

html[lang="zh-tw"] .locations-tab {
	font-family: "Maison Neue Book", 'Noto Sans TC', sans-serif;
}

html[lang="zh-cn"] .locations-tab {
	font-family: 'Noto Sans SC', sans-serif;
}

.locations-tab.active {
	font-family: "Maison Neue Bold";
}

.locations-tab.active,
.locations-tab:hover {
	border-color: #FFF;
}

html[lang="zh-tw"] .locations-tab.active {
	font-family: "Maison Neue Book", 'Noto Sans TC', sans-serif;
}

html[lang="zh-cn"] .locations-tab.active {
	font-family: 'Noto Sans SC', sans-serif;
}

html[lang="zh-tw"] .locations-tab.active,
html[lang="zh-tw"] .locations-tab.active {
	font-weight: 700;
}

.locations-tab-content {
	display: none;
}

.locations-tab-content.active {
	display: block;
}

.locations-tab-content picture {
	position: relative;
    display: block;
    width: 100%;
    height: 0;
    padding-bottom: 56.25%;
}

.locations-tab-content picture img {
	position: absolute;
    object-fit: cover;
    width: 100%;
    height: 100%;
}

.locations-tab-text {
	margin-top: 60px;
}

.locations-tab-ctos {
	margin-top: 60px;
}

.locations-tab-ctos > div {
	float: left;
	margin-right: 20px;
	font-family: "Maison Neue Bold";
	cursor: pointer;
}

.locations-tab-cto-contact {
	background: #FF5050;
	color: #FFF;
	line-height: 20px;
	transition: background 0.3s, color 0.3s;
}

.locations-tab-cto-contact a {
	display: block;
	border: 0;
	padding: 14px 20px;
	font-family: "Maison Neue Bold";
}

.locations-tab-cto-contact a:after {
	content: none;
}

.locations-tab-cto-contact:hover {
	background: #FFF;
	color: #FF5050;
}

.locations-tab-cto-team {
	background: #000;
	color: #FFF;
	border: 1px solid #FFF;
	line-height: 20px;
    padding: 14px 20px;
	transition: background 0.3s, color 0.3s;
}

.locations-tab-cto-team:hover {
	background: #FFF;
	color: #000;
}

.location-name {
	position: absolute;
    width: 100%;
	font-family: "Maison Neue Bold";
    line-height: 1;
    letter-spacing: -0.4px;
    text-align: center;
    z-index: 3;
	transform: translateZ(10px);
}

.location-name-chinese {
	position: absolute;
    bottom: 100px;
    width: 100%;
	font-family: "Maison Neue Bold";
    line-height: 1;
    letter-spacing: -0.4px;
    text-align: center;
    z-index: 3;
	transform: translateZ(10px);
}

.standorte .button {
	position: absolute;
	bottom: 37px;
	left: 50%;
	margin-left: -100px;
	background-color: #000;
    border: 0;
    width: 200px;
    text-align: center;
    font-size: 18px;
    border-radius: 2px;
	z-index: 3;
	transform: translateZ(10px);
}

.standorte .button a {
    display: block;
    font-family: "Maison Neue Bold";
    text-decoration: none;
    padding: 11px 0;
}

.standorte-map {
    position: relative;
    width: 100%;
    height: 0;
    padding-bottom: 56.25%;
}

.module-contact-wrapper {
    padding-bottom: 100px;
}

.module-contact-wrapper .standorte-map {
    padding-bottom: 50%;
}

#map-canvas {
    position: absolute;
    width: 100%;
    height: 100%;
}

.images-gallery,
.content-wrapper-row.module-divider.images-gallery {
    position: relative;
    width: 100%;
    overflow: hidden;
}

.images-gallery .image-gallery {
    width: 100%;
    height: 100%;
    max-width: 1200px;
    left: 50px;
    padding-top: 0;
    padding-bottom: 0;
}

.images-gallery .c-slider__slide {
	padding: 0 34px;
}

.images-gallery .c-slider__slide__description {
    margin-top: 8px;
    font-size: 16px;
    line-height: 24px;
}

.images-gallery .c-slider-nav {
    margin-top: -20px;
}

.images-gallery .c-slider-nav.c-slider-prev,
.images-gallery.nav-arrow-white .c-slider-nav.c-slider-prev {
    right: calc(100% - 20px);
}

@media only screen and (max-width: 1359px) {
	
	.images-gallery .image-gallery {	
		max-width: calc(100vw - 3 * 34px - 20px);
	}
	
}

@media only screen and (max-width: 767px) {
  
  .module-contact-wrapper {
      padding-bottom: 60px;
  }
    
  .module-contact-wrapper .standorte-map {
      width: calc(100% + 48px);
      margin-left: -24px;
      padding-bottom: calc(100% + 48px);
  }
	
	.images-gallery .image-gallery {
		max-width: calc(100vw - 48px);
      	left: 18px;
      	padding-top: 0;
      	padding-bottom: 0;
	}
  
  	.images-gallery .c-slider__slide {
      	padding: 0 6px;
  	}

}

@media only screen and (min-width: 1360px) {

	.images-gallery .image-gallery {
		left: calc(50% - 600px);
	}
	
	.standorte-map {
		height: 839px;
		padding-bottom: 0;
	}
  
  .module-contact-wrapper .standorte-map {
    height: 0;
    padding-bottom: 50%;
  }
	
}

/*** Contact Form 7 ***/
div.wpcf7-mail-sent-ok {
    border: 0 !important;
    margin: 0 auto 20px auto !important;
    text-align: center;
    background: #000;
    color: #FFF;
    padding: 20px 0;
}

/*** Overlay ***/
.overlay-wrapper {
    position: fixed;
    top: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.5);
    z-index: 1000;
}

.overlay-scroll-wrapper {
    position: absolute;
    width: 90%;
    height: 90%;
    top: 5%;
    left: 5%;
    padding: 5%;
    background: #FFF;
    overflow-y: scroll;
    -webkit-overflow-scrolling: touch;
}

.overlay-wrapper h2,
.overlay-wrapper h3,
.overlay-wrapper p {
    margin-bottom: 3%;
}

@media only screen and (max-width: 430px) {
	
	#close {
		top: 5%;
		right: 5%;
	}
	
	.overlay-scroll-wrapper {
		padding: 5% 10% 5% 5%;
	}
	
}

/*** 404 ***/
.page404 {
    background: #FFFFFF;
}

.page404 h1 {
    font-size: calc(15vh + 15vw);
    text-align: center;
    margin: 10vh 0;
}

/*** Footer ***/
footer {
    background: #1C2229;
    margin-top: 120px;
}

footer .footer-wrapper {
    padding: 140px 0 40px 0;
}

footer .footer-wrapper .col-full {
    display: flex;
    flex-wrap: nowrap;
    gap: 16px;
}

footer .lsa-wrapper {
    width: calc(33.33% - 16px / 3);
}

footer .footer-menu-wrapper {
    width: calc(66.66% + 16px / 3);
    display: flex;
    flex-wrap: wrap;
    gap: 80px 16px;
}

footer .footer-menu-wrapper > div {
    width: calc(33.33% - 32px / 3);
}

footer .footer-menu-wrapper > div.legal-wrapper {
    width: 100%;
}

footer .footer-menu-title {
    font-family: "Maison Neue Bold";
    font-weight: bold;
    font-size: 1.3rem;
    line-height: 2.4rem;
    color: #FFFFFF;
    margin-bottom: 5px;
}

footer .process-logo-reduced {
    width: 55px;
    height: 48px;
    background-image: url(images/process-logo-reduced.svg);
    margin-bottom: 50px;
}

footer .adress-wrapper p {
    font-size: 16px;
    line-height: 28px;
    color: #FFFFFF;
}

footer .adress-wrapper a {
    display: inline-block;
    padding-bottom: 4px;
    margin: 5px 0;
    line-height: 24px;
}

footer .footer-menu {
    list-style: none;
}

footer .footer-menu li {
    margin-bottom: 10px;
}

footer .footer-menu li a,
footer .legal-wrapper a {
    display: inline-block;
    font-size: 16px;
    line-height: 24px;
    padding-bottom: 4px;
    color: #FFFFFF;
}

footer .adress-wrapper a:after,
footer .social-link a:after,
footer .footer-menu li a:after,
footer .legal-wrapper a:after {
    content: "";
    position: absolute;
    width: 100%;
    height: 1px;
    bottom: 0px;
    left: 0;
    background: linear-gradient(90deg, currentColor calc(100% / 3), transparent 0 calc(200% / 3), currentColor 0) 100% 100%/300% 3px no-repeat;
    transition: background 0.6s;
}

footer .adress-wrapper a:hover:after,
footer .social-link a:hover:after,
footer .footer-menu li a:hover:after,
footer .legal-wrapper a:hover:after {
    background: linear-gradient(90deg, currentColor calc(100% / 3), transparent 0 calc(200% / 3), currentColor 0) 0% 100%/300% 3px no-repeat;
}

footer .social-link a {
    color: #FFFFFF;
    font-size: 16px;
    line-height: 24px;
    display: inline-block;
    padding-bottom: 4px;
    margin-bottom: 10px;
}

footer .data-protection-wrapper {
    margin-top: 20px;
}

footer .data-protection-wrapper a {
    font-family: "Maison Neue Bold";
    font-size: 18px;
    line-height: 28px;
    letter-spacing: 1px;	
}

footer .data-protection-wrapper a:after {
    content: "";
    position: absolute;
    width: 100%;
    height: 3px;
    bottom: -3px;
    left: 0;
    background: linear-gradient(90deg, currentColor calc(100% / 3), transparent 0 calc(200% / 3), currentColor 0) 100% 100%/300% 3px no-repeat;
    transition: background 0.6s;
}

footer .data-protection-wrapper a:hover:after {
    background: linear-gradient(90deg, currentColor calc(100% / 3), transparent 0 calc(200% / 3), currentColor 0) 0% 100%/300% 3px no-repeat;
}

footer .lsa-wrapper a {
    display: inline-block;
    max-width: 345px;
    padding-left: 11px;
    font-family: "Maison Neue Bold";
    font-weight: bold;
    font-size: 1.3rem;
    line-height: 2.4rem;
    color: #FFFFFF;
    text-decoration: none;
}

footer .lsa-wrapper a:after {
    content: none;
}

footer .locations-wrapper > div a:after {
    content: "";
    position: absolute;
    width: 100%;
    height: 3px;
    bottom: -3px;
    left: 0;
    background: linear-gradient(90deg, currentColor calc(100% / 3), transparent 0 calc(200% / 3), currentColor 0) 100% 100%/300% 3px no-repeat;
    transition: background 0.6s;
}

footer .locations-wrapper > div a:hover:after {
    background: linear-gradient(90deg, currentColor calc(100% / 3), transparent 0 calc(200% / 3), currentColor 0) 0% 100%/300% 3px no-repeat;
}

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

  footer {
      background: #1C2229;
      margin-top: 60px;
  }
  
  footer .footer-wrapper {
      padding: 80px 0;
  }
  
  footer .footer-wrapper .col-full {
      flex-direction: column;
      gap: 38px;
  }
  
  footer .lsa-wrapper {
      width: 100%;
  }
  
  footer .process-logo-reduced {
      width: 44px;
      height: 38px;
      background-size: 44px 38px;
      margin-bottom: 34px;
      margin-left: -10px;
  }
  
  footer .lsa-wrapper a {
      padding-left: 0;
  }
  
  footer .footer-menu-wrapper {
      width: 100%;
      flex-direction: column;
      gap: 56px;
  }
  
  footer .footer-menu-wrapper > div {
      width: 100%;
  }
  
}

/* =================== Helper =================== */
.clearfix:after {
    content:"";
    display:block;
    clear:both;
}

.hidden,
.hp-message {
	display: none !important;
}
