@font-face { font-family: 'icons'; src: url(../assets/iconfont/font/icons.woff2) format('woff2'), url(../assets/iconfont/font/icons.woff) format('woff'), url(../assets/iconfont/font/icons.ttf) format('truetype'); font-weight: normal; font-style: normal }
* { -moz-box-sizing: border-box; -webkit-box-sizing: border-box; box-sizing: border-box; }

/* = Reset
----------------------------------------------------------------------------------------------------------------- */
html, body, div, span, h1, h2, h3, h4, h5, h6, p, hr, a, a img, font, img, dd, dl, dt, li, ol, ul, blockquote, fieldset, form, label, legend, table, caption, tr, th, td { margin: 0; padding: 0; border: 0; font-size: 100%; }

/* = HTML5 Elements
----------------------------------------------------------------------------------------------------------------- */
article, aside, details, figcaption, figure, footer, header, hgroup, menu, nav, section { display: block; }
audio, canvas, video { display: inline-block; }
html { -webkit-text-size-adjust: 100%; -ms-text-size-adjust: 100%; }

/* = Body
----------------------------------------------------------------------------------------------------------------- */
body { color: #3F2A56; font-size: 1em; text-align: left; font-family: myriad-pro, Arial, Helvetica, sans-serif; font-weight: 400; text-rendering: optimizeLegibility; -moz-osx-font-smoothing: grayscale; -webkit-font-smoothing: antialiased; background: #fff; }

/* = ICONS (font based - paste assets/iconfont/config.json file into fontello.com to add-to/edit these icons)
----------------------------------------------------------------------------------------------------------------- */
.icon:before,
.icon:after,
.btn--chevron:after,
.tick-list li:before,
.accordion > dt:after,
.slider-controls span:before,
.lSAction > .lSPrev:after,
.lSAction > .lSNext:after,
.kedq-sub:after,
.tab-accordion:after { font-family: "icons"; font-style: normal; font-weight: normal; speak: none; display: inline-block; text-decoration: inherit; width: auto; text-align: center; font-variant: normal; text-transform: none; text-decoration: none; line-height: 1em }

.icon--before { margin-right: 5px; }
.icon--after { margin-left: 5px; }
.icon--pdf:after { content: '\f1c1'; }
.icon--ext:after { content: '\e80b'; }
.icon--twitter:after { content: '\f099'; }
.icon--linkedin:after { content: '\f0e1'; }
.icon--prev:after { content: '\e815'; }
.icon--next:after { content: '\e816'; }
.icon--anchor:after { content: '\e802'; font-size: .6em; vertical-align: middle; }
.tick-list li:before { content: '\e813'; }
.icon--network:after { content: '\e810'; }
.icon--handshake:after { content: '\e81a'; }
.icon--magnet:after { content: '\e81b'; }
.icon--puzzle:after { content: '\e817'; }
.icon--medal:after { content: '\e819'; }
.icon--growthbar:after { content: '\e818'; }
.icon--video:before { content: '\e82f'; }
.icon--clusters:before { content: '\e889'; }
.icon--calc:before { content: '\e82c'; }
.icon--group:before { content: '\e82a'; }
.icon--input:before { content: '\e826'; }
.icon--skills:before { content: '\e825'; }
.icon--scientists:before { content: '\e822'; }
.icon--3people:before { content: '\e82d'; }
.icon--maze:before { content: '\e821'; }
.icon--enlarge:after { content: '\e80a'; }
.icon--organisers:before { content: '\e823'; }
.icon--scientist:before { content: '\e812'; }
.icon--key:before { content: '\e827'; }
.icon--single-cluster:before { content: '\e808'; }
.icon--growth:before { content: '\e824'; }
.icon--graph:before { content: '\e82e'; }
.icon--cloud:before { content: '\e829'; }
.icon--training-skills:before { content: '\e85d'; }
.icon--moniter:before { content: '\e85e'; }
.icon--bulb-cog:before { content: '\e85c'; }
.icon--person-link:before { content: '\e85f'; }
.icon--close:before { content: '\e807'; }
.icon--info:before { content: '\f086'; }
.slide-prev:before,
.lSAction > .lSPrev:after { content: '\e801'; }
.slide-next:before,
.lSAction > .lSNext:after { content: '\e803'; }

/* = Typography
----------------------------------------------------------------------------------------------------------------- */
h1, h2, h3, h4, h5, h6,
.h1, .h2, .h3, .h4, .h5, .h6 { margin: 0 0 20px; color: #3F2A56; line-height: normal; font-weight: 600; }
h1, .h1 { font-size: 42px; margin-bottom: 35px; font-weight: 300; }
h2, .h2 { font-size: 38px; margin-bottom: 30px; font-weight: 300; }
.h3-large { font-size: 30px; margin-bottom: 25px; font-weight: 300; }
h3, .h3 { font-size: 24px; }
h4, .h4 { font-size: 22px; }
h5, .h5 { font-size: 20px; }
h6, .h6 { font-size: 18px; }

p { margin: 0 0 25px; line-height: 1.65em; }
p:last-child { margin-bottom: 4px; }

.leader { font-size: 21px; font-weight: 300; }
.leader strong { font-weight: 400; }
.lead-italic { font-size: 22px; font-weight: 300; font-style: italic; }

.text-red { color: #D50032; }
.text-white { color: #fff; }
.text-white:hover { color: #fff; }
a.text-white:hover { text-decoration: underline; }
.text-300 { font-weight: 300; }
.text-400 { font-weight: 400; }
.text-600 { font-weight: 600; }
.text-italic { font-style: italic; }
.page-number { margin: 0; font-weight: 300; }
.page-title { margin-bottom: 15px; }
.page-title:last-child { margin-bottom: 0; }

blockquote { margin: 40px 0; border-left: 6px solid #c7c7c7; padding-left: 35px; }
blockquote p { margin: 0; font-size: 1.4em; line-height: 1.65em; font-family: myriad-pro, Arial, Helvetica, sans-serif; }
blockquote cite { font-size: 1em; font-style: normal; margin-top: 15px; display: block; }
blockquote p cite { font-size: 0.75em; }

a { color: #3F2A56; text-decoration: none; }
a:hover { color: #3F2A56; text-decoration: none; }

.anchor-link { display: block; margin-top: 40px; }
.anchor-link:last-child { margin-bottom: 0; }
.anchor-link .icon { display: inline-block; margin-right: 12px; width: 36px; height: 36px; line-height: 36px; border-radius: 50%; text-align: center; color: #fff; background: #3F2A56; }

img { max-width: 100%; vertical-align: bottom; height: auto; -ms-interpolation-mode: bicubic; }

hr { margin: 40px 0; height: 1px; border: 0; border-top: 1px solid #ccc; }
small { font-size: 0.8em; }
address { margin: 0 0 20px; line-height: 1.65em; font-style: normal; }
sub, sup { line-height: 0; position: relative; vertical-align: baseline; }
sup { top: -0.5em; }
sub { bottom: -0.25em; }
pre { margin: 0; }
pre code { font-size: 1.5em; white-space: pre-wrap; }
.clr { clear: both; }
.textCenter { text-align: center; }

@media screen and (min-width: 981px) {
    .bubble-below { margin-bottom: 5px; }
}

@media screen and (max-width: 1024px) {
    h1, .h1 { font-size: 40px; }
    h2, .h2 { font-size: 36px; }
}

@media screen and (max-width: 650px) {
    h1, .h1 { font-size: 38px; }
    h2, .h2 { font-size: 34px; }
    .h3-large { font-size: 28px; }
}

@media screen and (max-width: 480px) {
    h1, .h1 { font-size: 36px; }
    h2, .h2 { font-size: 32px; }
}

@media screen and (max-width: 400px) {
    h1, .h1 { font-size: 34px; }
    h2, .h2 { font-size: 30px; }
    .h3-large { font-size: 26px; }

    .leader { font-size: 20px; }

    .anchor-link { margin-top: 35px; }
}

@media screen and (max-width: 360px) {
    .h3-large { font-size: 25px; }
}

@media screen and (max-width: 340px) {
    h1, .h1 { font-size: 32px; }
}

/* = Round number
----------------------------------------------------------------------------------------------------------------- */
.round-number { margin: 20px auto; width: 50px; height: 50px; line-height: 49px; font-size: 24px; text-align: center; border-radius: 50%; color: #fff; background: #D50032; }

@media screen and (max-width: 400px) {
    .round-number { margin: 15px auto; width: 46px; height: 46px; line-height: 45px; font-size: 22px; }
    .ws-title { margin-bottom: 16px; }
}

/* = Shared margins
----------------------------------------------------------------------------------------------------------------- */
.margin-bottom--medium { margin-bottom: 40px; }
.margin-bottom--large { margin-bottom: 60px; }

@media screen and (max-width: 1024px) {
    .margin-bottom--large { margin-bottom: 55px; }
}

@media screen and (max-width: 750px) {
    .margin-bottom--large { margin-bottom: 50px; }
}

@media screen and (max-width: 400px) {
    .margin-bottom--large { margin-bottom: 45px; }
}

/* = Buttons
----------------------------------------------------------------------------------------------------------------- */
.btn { display: inline-block; vertical-align: top; padding: 13px 20px; margin: 0; color: #fff; font-weight: 400; font-family: myriad-pro, Arial, Helvetica, sans-serif; outline: none; cursor: pointer; border: 1px solid #3F2A56; background: #3F2A56; -webkit-border-radius: 24px; border-radius: 24px; }
.btn:hover { color: #fff; }

.btn--bold { font-weight: 600; }
.btn--medium { padding: 16px 24px; -webkit-border-radius: 30px; border-radius: 30px; }
.btn--outline { color: #3F2A56; padding: 13px 20px; background-color: rgba(255, 255, 255, 0.7); border-color: #8EAF9B; transition: .3s ease; }
.btn--outline:hover { color: #3F2A56; }
.btn--red { border-color: #D50032; background: #D50032; }
.btn--chevron:after { padding-left: 16px; content: '\e805'; }
.btn--footer { background: rgba(255, 255, 255, 0.1); }

p + p .btn { margin-top: 25px; }
p + p .btn:last-child { margin-bottom: 4px; }


@media screen and (min-width: 1201px) {
    .btn {    position: relative; -webkit-transform: perspective(1px) translateZ(0); transform: perspective(1px) translateZ(0);  -webkit-transition-property: color;  transition-property: color;  -webkit-transition-duration: 0.3s; transition-duration: 0.3s;  cursor: pointer;  -webkit-tap-highlight-color: rgba(0,0,0,0);  }
    .btn:before { content: "";  position: absolute;   z-index: -1;    top: 0;   left: 0;    right: 0;   bottom: 0;   background: #D50032;   -webkit-border-radius: 24px; border-radius: 24px;    -webkit-transform: scale(0);  transform: scale(0);  -webkit-transition: transform .25s linear;  transition: transform .25s linear; }
    .btn--medium:before {-webkit-border-radius: 30px; border-radius: 30px; }  

    .btn:hover, 
    .btn:focus, 
    .btn:active {  color: #fff;   border-color: #D50032;  -webkit-transition: all 0.06s linear, color 0.25s linear; transition: all 0.06s linear, color 0.25s linear; -webkit-transition-delay: 0.25s, 0.04s;  transition-delay: 0.25s, 0.04s;  }
    
    .btn--outline:before { background: #8EAF9B;   }
    .btn--outline:hover, 
    .btn--outline:focus, 
    .btn--outline:active  {border-color: #8EAF9B;   }

    .btn--red:before { background: #e91e63;   }
    .btn--red:hover, 
    .btn--red:focus, 
    .btn--red:active  {border-color: #e91e63;   }

    .btn:hover:before, 
    .btn:focus:before, 
    .btn:active:before {  -webkit-transform: scaleX(1);  transform: scaleX(1);  }

    input.btn {-webkit-transition-delay: 0s; transition-delay: 0s; -webkit-transition:all .3s ease; transition:all .3s ease; }
    input.btn:hover, 
    input.btn:focus, 
    input.btn:active { border-color:#D50032 ; background: #D50032; -webkit-transition-delay: 0s; transition-delay: 0s;  -webkit-transition:all .3s ease; transition:all .3s ease; }
}


@media screen and (max-width: 480px) {
    .btn--outline { background-color: rgba(255, 255, 255, 0.95); }
}

@media screen and (max-width: 400px) {
    p + p .btn { margin-top: 20px; }
}

/* = Lists
----------------------------------------------------------------------------------------------------------------- */
ul { margin: 0 0 25px; padding-left: 22px; line-height: 1.65em; }
ul li { margin: 0 0 12px; }
ul li:last-child { margin-bottom: 0; }
ul li ul { margin-top: 20px; margin-left: 30px; list-style-type: circle; }

ol { margin: 0 0 25px; padding-left: 25px; line-height: 1.65em; }
ol li { margin: 0 0 12px; }
ol li ol { margin-top: 20px; margin-left: 30px; list-style-type: lower-latin; }

dl { margin: 0 0 25px; line-height: 1.65em; }
dt { color: #111; font-weight: 600; }
dd { margin: 0 0 20px; }

ul:last-child,
ol:last-child,
dl:last-child { margin-bottom: 4px; }

.tick-list { list-style: none; margin: 35px 0; padding: 0; position: relative; }
.tick-list:first-child { margin-top: 0; }
.tick-list:last-child { margin-bottom: 0; }
.tick-list:before { content: ''; position: absolute; top: 20px; left: 19px; width: 2px; height: calc(100% - 40px); background: #3C2C53; opacity: 0.2; }
.tick-list li { position: relative; padding-left: 60px; margin-bottom: 18px; }
.tick-list li:before { position: absolute; top: calc(50% - 20px); left: 0; width: 40px; height: 40px; line-height: 43px; text-align: center; border-radius: 40px; color: #fff; background: #3F2A56; box-shadow: 0 0 0 5px #fff; }

.row--lgrey .tick-list li:before { box-shadow: 0 0 0 5px #F5F5F6; }

.plain-list { list-style: none; margin: 0; padding: 0; }
.plain-list li { line-height: 1.5em; }

.number-list { margin: 0; padding: 0; list-style-type: none; }
.number-list li { counter-increment: step-counter; padding-left: 60px; margin-bottom: 18px; position: relative; }
.number-list li:before { content: counter(step-counter); display: block; position: absolute; top: 5px; left: 0; width: 40px; height: 40px; text-align: center; line-height: 40px; font-size: 1.25em; font-weight: 600; border-radius: 50%; background-color: #D50032; color: #fff; }

.lp-item { margin: 50px 0 0; }
.lp-item .h3 { float: left; line-height: 1.45em; width: calc(100% - 150px); max-width: 230px; margin: 0; padding: 0 0 30px; border-bottom: 2px solid rgba(255, 255, 255, 0.3); }
.lp-icon { float: left; width: 120px; height: 120px; margin: 7px 30px 0 0; border-radius: 50% 0 50% 50%; color: #fff; background: #85B09A; position: relative; }
.lp-icon:before { position: absolute; font-size: 3.2em; top: 50%; left: 50%; transform: translate(-50%, -50%); }
.lp-icon.icon--clusters:before { font-size: 3.8em; }
.lp-icon span { position: absolute; top: 0; left: 0; width: 100%; margin: 0; text-align: center; line-height: 114px; display: block; }

.list-pills--white * { color: #fff; }

.list-circles { margin: 50px 0; }
.list-circles:first-child { margin-top: 5px; }
.list-circles:last-child { margin-bottom: 5px; }

.lc-item { margin: 50px 0 0; position: relative; display: table; }
.lc-item:first-child { margin-top: 0; }

.lc-text { padding-left: 25px; display: table-cell; vertical-align: middle; position: relative; }
.lc-text p { position: relative; }
.lc-text p:last-child { padding-bottom: 24px; }
.lc-text p:last-child:before { content: ''; position: absolute; left: 0; bottom: 0; width: 10px; height: 10px; border-radius: 50%; background: #D50032; }
.lc-text p:last-child:after { content: ''; position: absolute; left: 22px; bottom: 3px; width: calc(100% - 20px); height: 2px; background: #D50032; }

.lc-iconwrap { width: 110px; display: table-cell; vertical-align: middle; }
.lc-icon { width: 110px; height: 0; padding-top: 110px; border-radius: 50%; color: #D50032; background: #f2dfe5; position: relative; }
.lc-icon:before { position: absolute; font-size: 3.4em; top: 50%; left: 50%; transform: translate(-50%, -50%); }
.lc-icon.icon--scientists:before { transform: translate(-50%, -50%) scale(0.9); }

@media screen and (min-width:601px) {
    .plain-list--5050 { -webkit-column-count: 2; column-count: 2; -webkit-column-gap: 50px; column-gap: 50px; }
}

@media screen and (min-width: 981px) and (max-width: 1200px) {
    .lp-icon { width: 25%; height: 0; padding-top: 25%;; margin: 7px 20px 0 0; }
    .lp-item .h3 { width: calc(75% - 20px); font-size: 2vw; max-width: 250px; }
    .lp-icon:before { font-size: 3.2vw; }
    .lp-icon.icon--clusters:before { font-size: 4vw; }
    .lp-icon span { font-size: 2.3vw; line-height: 1; top: 50%; left: 50%; transform: translate(-50%, -52%); }
}

@media screen and (min-width: 981px) {
    .lc-item { float: left; width: calc(50% - 25px); margin: 50px 50px 0 0; }
    .lc-item:nth-child(-n+2) { margin-top: 0; }
    .lc-item:nth-child(even) { margin-right: 0; }
}

@media screen and (min-width: 1201px) {
    .list-circles { margin: 60px 0; }
    .lc-item { width: calc(50% - 30px); margin: 50px 60px 0 0; }
}

@media screen and (min-width: 1401px) {
    .lc-item { width: calc(50% - 40px); margin: 50px 80px 0 0; }
    .lc-text { padding-left: 30px; }
}

@media screen and (max-width: 980px) {
    .lp-item { margin: 40px 0 0; }
    .lp-item:first-child { margin: 0; }
    .lp-item .h3 { max-width: 100%; }

    .list-circles { margin: 45px 0; }
}

@media screen and (max-width: 650px) {
    .tick-list { margin: 30px 0; }

    .list-circles { margin: 40px 0; }
    .lc-item { margin: 45px 0 0; }
}

@media screen and (max-width: 480px) {
    .tick-list { margin: 25px 0; }

    .list-pills { margin-bottom: 10px; }
    .lp-item { margin: 35px 0 0; }

    .lp-icon { width: 25%; height: 0; padding-top: 25%;; margin: 5px 25px 0 0; }
    .lp-item .h3 { width: calc(75% - 25px); font-size: 5vw; padding: 0 0 6vw; }
    .lp-icon:before { font-size: 8.1vw; }
    .lp-icon.icon--clusters:before { font-size: 12vw; }
    .lp-icon span { font-size: 6vw; line-height: 1; top: 50%; left: 50%; transform: translate(-50%, -52%); }

    .lc-item { margin: 40px 0 0; }
    .lc-iconwrap { width: 25%; vertical-align: top; padding-top: 10px; }
    .lc-icon { width: 100%; padding-top: 100%; }

    .lc-icon:before { font-size: 10.5vw; }
    .lc-text p:last-child:before { width: 8px; height: 8px; }
    .lc-text p:last-child:after { left: 20px; }
}

@media screen and (max-width: 400px) {
    .tick-list { margin: 20px 0; }
    .lp-item { margin: 30px 0 0; }

    .list-circles { margin: 35px 0; }
    .lc-iconwrap { padding-top: 8px; }
    .lc-item { margin: 35px 0 0; }
    .lc-text { padding-left: 22px; }
}

@media screen and (max-width: 350px) {
    .tick-list li,
    .number-list li { padding-left: 55px; }
    .tick-list li:before { font-size: .9em; top: calc(50% - 18px); width: 36px; height: 36px; line-height: 38px; border-radius: 36px; }

    .number-list li:before { font-size: .9em; width: 36px; height: 36px; line-height: 36px; border-radius: 36px; }

    .lp-item { margin: 25px 0 0; }
    .list-circles { margin: 30px 0; }
    .lc-item { margin: 30px 0 0; }
}

/* = Tables
----------------------------------------------------------------------------------------------------------------- */
.tableWrap { margin: 40px 0; overflow: auto; }
.tableWrap:first-child { margin-top: 5px; }
.tableWrap:last-child { margin-bottom: 5px; }
table { width: 100%; margin: 0 0 20px; border-spacing: 0; border-collapse: collapse; }

.tableWrap table { margin: 0; }

th { padding: 15px 10px; color: #fff; border: 1px solid #333; background: #333; }
tr:nth-child(even) td { background: #f6f6f6; }
td { padding: 10px; border: 1px solid #e5e5e5; background: #fff; }
.rowItemStandout td { color: #fff; background: #a1c897; }

.table-plain th,
.table-plain td { padding: 5px 10px; color: #3F2A56; background: #fff; border: none; }
.table-plain tr:nth-child(even) td { background: #fff; }

.table-challenges { font-weight: 600; }
.table-challenges td:first-child { padding-left: 0; width: 100px; }
.table-challenges td:nth-child(2) { width: 50px; text-align: center; }
.table-challenges .chart-bar { transform:scaleX(0); display: block; height: 30px; border-radius: 0 30px 30px 0; -webkit-transform-origin: left; transform-origin: left; transition-delay: 0.5s; transition:1.5s ease; }
.pageLoaded .table-challenges .chart-bar,
.no-js .table-challenges .chart-bar  { transform:scaleX(1); } 
html.is-animating .table-challenges .chart-bar  { transform:scaleX(0); } 

.table-caption { margin: 20px 0; font-size: .9em; }

.chart-bar { background-color: #555; }
.cb-purple { background: #3F2A56; opacity: 0.9; }
.cb-purple-60 { background: #3F2A56; opacity: 0.6; }
.cb-purple-30 { background: #3F2A56; opacity: 0.3; }
.cb-green { background: #85B09A; opacity: 0.9; }
.cb-green-60 { background: #85B09A; opacity: 0.6; }
.cb-green-30 { background: #85B09A; opacity: 0.3; }

@media screen and (min-width: 601px) {
    .table-challenges { font-size: 18px; font-weight: 600; }
    .table-challenges td:first-child { width: 110px; }
    .table-challenges td:nth-child(2) { width: 60px; }
    .table-plain th,
    .table-plain td { padding: 6px 10px; }
    .table-caption { margin: 25px 0; font-size: 1em; }
}

@media screen and (max-width: 400px) {
    .tableWrap { margin: 35px 0; }
    .table-caption { margin: 20px 0; }

    .table-challenges .chart-bar { height: 26px; border-radius: 0 26px 26px 0; }
}

@media screen and (max-width: 350px) {
    .table-challenges { font-size: 15px; }
    .table-challenges td:first-child { width: 90px; }
    .table-challenges td:nth-child(2) { width: 40px; }
}

/* = Flex
----------------------------------------------------------------------------------------------------------------- */
.flx { display: -ms-flexbox; display: -webkit-flex; display: flex; }
.flx-inl { display: -ms-inline-flexbox; display: -webkit-inline-flex; display: inline-flex; }
.flx--col { -webkit-flex-direction: column; -ms-flex-direction: column; flex-direction: column; }
.flx--jc { -webkit-justify-content: center; -ms-flex-pack: center; justify-content: center; }
.flx--ac { -webkit-align-content: center; -ms-flex-line-pack: center; align-content: center; }
.flx--ai { -webkit-align-items: center; -ms-flex-align: center; align-items: center; }
.flx--wr { -webkit-flex-wrap: wrap; -ms-flex-wrap: wrap; flex-wrap: wrap; }
.flx--noSh { -webkit-flex: 0 0 auto; -ms-flex: 0 0 auto; flex: 0 0 auto; }

/* = Columns & cards
----------------------------------------------------------------------------------------------------------------- */
.cols { margin: 40px 0; }
.cols:first-child { margin-top: 0; }
.cols:last-child { margin-bottom: 5px; }
.cols .col { margin: 0 0 45px; width: 100%; }
.cols .col:last-child { margin-bottom: 0; }

.cols--benefits .col { padding-top: 40px; }
.cols--bullets:last-child { margin-bottom: 0; }

.cols--key-enablers { margin: 0; }

.card { color: #3F2A56; background: #fff; }
.card--radius { border-radius: 18px; }
.card--shadow { box-shadow: 0px 15px 30px rgba(0, 0, 0, 0.1); }
.card--greyred { background: #e3e1e7; }

.cols .card { padding: 50px; }
.card--challenge p { margin-bottom: 16px; }
.card--challenge p:last-child { margin: 0; }

.cols.cols--bullets .col { margin: 0 0 12px; }
.cols.cols--bullets .col:last-child { margin: 0; }

.cols.slider--cols-3 .col { margin: 0; border-radius: 18px; background: #fff; }
.cols.slider--cols-3 .card { padding: 75px 35px 35px; height: auto; box-shadow: none; position: relative; }

.no-js .slider--cols-3 .col {margin-bottom: 60px;}
.no-js .slider--cols-3 .col:last-child {margin-bottom: 0;}

.challenge-no { top: -30px; left: calc(50% - 38px); width: 78px; height: 78px; text-align: center; border-radius: 50%; position: absolute; background: #fff; }
.challenge-no div { font-weight: 600; }
.challenge-no .h3-large { margin: 0; line-height: 75px; color: #D50032; }
.challenge-no .caps { margin-top: -15px; width: 110px; left: 50%; transform: translateX(-50%); letter-spacing: 1.1px; text-transform: uppercase; color: #D50032; position: relative; }
.challenge-pill { color: #fff; font-size: 11px; margin: 4px; padding: 5px 12px; border-radius: 28px; line-height: 1; letter-spacing: 0.8px; text-transform: uppercase; display: inline-block; background: #8EAF9B; }

.card--benefit { position: relative; border-radius: 20px 20px 0 20px; }
.card--benefit p { font-size: 17px; }

.cols .card.card--benefit { padding-top: 60px; }
.card-icon { top: -40px; left: calc(50% - 40px); width: 80px; height: 80px; text-align: center; border-radius: 50%; position: absolute; background: #D50032; }
.card-icon:before { position: absolute; color: #fff; font-size: 2.5em; top: 50%; left: 50%; -webkit-transform: translate(-50%, -50%); transform: translate(-50%, -50%); }
.card-icon.icon--organisers:before,
.card-icon.icon--scientist:before { transform: translate(-50%, -50%) scale(0.95) }
.card-icon.icon--scientists:before { transform: translate(-50%, -50%) scale(0.85) }

@media screen and (min-width: 981px) {
    .cols.cols--half .col { float: left; width: calc(50% - 20px); margin: 0 30px 0 0; }
    .cols.cols--half .col:last-child { margin-right: 0; }

    .card--shadow { box-shadow: 0px 18px 30px rgba(0, 0, 0, 0.14); }
    .cols--3 .col { float: left; width: calc(33.333% - 20px); margin: 30px 30px 0 0; }

    .cols--benefits .col { width: calc(33.333% - 13.333px); margin: 20px 20px 0 0; }

    .cols--3 .col:nth-child(-n+3) { margin-top: 0; }
    .cols--3 .col:nth-child(3n+3) { margin-right: 0; }
    .cols--3 .card { padding: 30px 25px; }
    .cols .card { height: 100%; }
}

@media screen and (min-width: 1201px) {
    .cols--3 .col { float: left; width: calc(33.333% - 33.333px); margin: 50px 50px 0 0; }
    .cols--3 .card { padding: 35px; }

    .card--benefit p { font-size: 18px; }
    .cols--benefits .col { width: calc(33.333% - 16.666px); margin: 25px 25px 0 0; }

    .cols--key-enablers .col { float: left; width: calc(100% - 435px); margin: 0; }
    .cols--key-enablers .col:last-child { float: left; width: 400px; margin-left: 35px; }
}

@media screen and (max-width: 980px) {
    .col-title--max-600,
    .cols--bullets { max-width: 650px; margin-left: auto; margin-right: auto; }
}

@media screen and (max-width: 980px) and (min-width: 651px) {
    .cols--benefits .col { float: left; width: calc(50% - 15px); margin: 30px 30px 0 0; }
    .cols--benefits .col:nth-child(odd) { clear: left; }
    .cols--benefits .col:nth-child(even) { margin-right: 0; clear: right; }
    .cols--benefits .col:nth-child(-n+2) { margin-top: 0; }

    .cols .card.card--benefit { padding: 60px 30px 30px; }
}

@media screen and (max-width: 750px) and (min-width: 651px) {
    .card--benefit p { font-size: 16px; }
    .cols--benefits .col { width: calc(50% - 11px); margin: 25px 22px 0 0; }
}

@media screen and (max-width: 650px) {
    .cols .col { margin: 0 0 40px; }
    .cols .card { padding: 40px; }

    .card--benefit p { font-size: 18px; }

    .cols--benefits .col { float: none; width: 100%; margin: 0 0 30px; }
    .cols--benefits .col:last-child { margin: 0 0 5px; }
}

@media screen and (max-width: 480px) {
    .card--shadow { box-shadow: 0px 10px 30px rgba(0, 0, 0, 0.1); }
    .cols .card { padding: 35px; }

    .cols.slider--cols-3 .card { padding: 70px 30px 30px; }
    .card--challenge > h3 { margin-bottom: 15px; }
}

@media screen and (max-width: 400px) {
    .cols { margin: 35px 0; }
    .cols .col { margin: 0 0 35px; }
    .cols .card { padding: 30px; }
    .cols.slider--cols-3 .card { padding: 70px 25px 25px; }

    .challenge-pill { font-size: 10px; margin: 1px; letter-spacing: 0.4px; }

    .card--benefit p { font-size: 17px; }
    .cols--benefits .col { margin: 0 0 28px; }
    .cols .card.card--benefit { padding-top: 55px; }

    .card-icon { top: -37px; left: calc(50% - 37px); width: 74px; height: 74px; }
    .card-icon:before { font-size: 2.4em; }
}

@media screen and (max-width: 350px) {
    .cols .card { padding: 25px; }
    .card--challenge p { font-size: 15px; }
}

/* = Slider
----------------------------------------------------------------------------------------------------------------- */
.top-5-challenges { margin: 60px 0 5px; padding: 30px 38px 0; position: relative; overflow: hidden; }

.lSSlideOuter { /*overflow: hidden;*/ -webkit-touch-callout: none; -webkit-user-select: none; -khtml-user-select: none; -moz-user-select: none; -ms-user-select: none; user-select: none }
.lightSlider:before, .lightSlider:after { content: " "; display: table; }
.lightSlider { /*overflow: hidden;*/ margin: 0; }
.lSSlideWrapper { max-width: 100%; /*overflow: hidden;*/ position: relative; }
.lSSlideWrapper > .lightSlider:after { clear: both; }
.lSSlideWrapper .lSSlide { -webkit-transform: translate(0px, 0px); -ms-transform: translate(0px, 0px); transform: translate(0px, 0px); -webkit-transition: all 1s; -webkit-transition-property: -webkit-transform,height; -moz-transition-property: -moz-transform,height; transition-property: transform,height; -webkit-transition-duration: inherit !important; transition-duration: inherit !important; -webkit-transition-timing-function: inherit !important; transition-timing-function: inherit !important; }
.lSSlideWrapper .lSFade { position: relative; }
.lSSlideWrapper .lSFade > * { position: absolute !important; top: 0; left: 0; z-index: 0; margin-right: 0; width: 100%; }
.lSSlideWrapper.usingCss .lSFade > * { opacity: 0; -webkit-transition-delay: 0s; transition-delay: 0s; -webkit-transition-duration: inherit !important; transition-duration: inherit !important; -webkit-transition-property: opacity; transition-property: opacity; -webkit-transition-timing-function: inherit !important; transition-timing-function: inherit !important; }
.lSSlideWrapper .lSFade > *.active { z-index: 1; }
.lSSlideWrapper.usingCss .lSFade > *.active { opacity: 1; }

/* Pager */
.lSPager { list-style: none; margin: 0; padding: 0; line-height: 1; }
.lSSlideOuter .lSPager.lSpg { margin: 10px 0 0; padding: 0; text-align: center; }
.lSSlideOuter .lSPager.lSpg > li { cursor: pointer; display: inline-block; padding: 0 5px; margin: 0 3px; line-height: 1; }
.lSSlideOuter .lSPager.lSpg > li a { background-color: rgba(255, 255, 255, 0.1); display: inline-block; height: 13px; width: 13px; border: 1px solid rgba(255, 255, 255, 0.1); border-radius: 50%; overflow: hidden; text-indent: -999em; position: relative; -webkit-transition: all 0.4s linear 0s; transition: all 0.4s linear 0s; z-index: 1; }
.lSSlideOuter .lSPager.lSpg > li.active a { background-color: #fff; border-color: #fff; }

/* slider actions */
.slider-controls span,
.lSAction > a { position: absolute; width: 25px; height: 50px; line-height: 50px; font-size: 50px; margin-top: 15px; top: calc(50% - 25px); display: block; cursor: pointer; color: #fff; z-index: 2; }

.slider-controls span:before,
.lSAction > a:before { width: auto; vertical-align: top; }

.lSAction > .lSPrev { left: 0; }
.lSAction > .lSNext { right: 0; text-align: right; }

.slide-prev { left: -15px; }
.slide-next { right: -15px; text-align: right; }

.no-js .slider-controls {display: none;}

/* Rtl */
.lSSlideOuter.lSrtl { direction: rtl; }
.lSSlideOuter .lightSlider, .lSSlideOuter .lSPager { padding-left: 0; list-style: none outside none; }
.lSSlideOuter.lSrtl .lightSlider, .lSSlideOuter.lSrtl .lSPager { padding-right: 0; }
.lSSlideOuter .lightSlider > *, .lSSlideOuter .lSGallery li { float: left; }
.lSSlideOuter.lSrtl .lightSlider > *, .lSSlideOuter.lSrtl .lSGallery li { float: right !important; }

@-webkit-keyframes rightEnd {
    0% { left: 0; }
    50% { left: -15px; }
    100% { left: 0; }
}

@keyframes rightEnd {
    0% { left: 0; }
    50% { left: -15px; }
    100% { left: 0; }
}

@-webkit-keyframes leftEnd {
    0% { left: 0; }
    50% { left: 15px; }
    100% { left: 0; }
}

@keyframes leftEnd {
    0% { left: 0; }
    50% { left: 15px; }
    100% { left: 0; }
}

.lSSlideOuter .rightEnd { -webkit-animation: rightEnd 0.3s; animation: rightEnd 0.3s; position: relative; }
.lSSlideOuter .leftEnd { -webkit-animation: leftEnd 0.3s; animation: leftEnd 0.3s; position: relative; }
.lSSlideOuter.lSrtl .rightEnd { -webkit-animation: leftEnd 0.3s; animation: leftEnd 0.3s; position: relative; }
.lSSlideOuter.lSrtl .leftEnd { -webkit-animation: rightEnd 0.3s; animation: rightEnd 0.3s; position: relative; }

@media screen and (min-width: 1601px) {
    .slide-prev { left: -20px; }
    .slide-next { right: -20px; }
}

@media screen and (min-width: 1701px) {
    .slide-prev { left: -25px; }
    .slide-next { right: -25px; }
}

@media screen and (max-width: 1024px) {
    .lSSlideOuter .lSPager.lSpg > li a { height: 12px; width: 12px; }
}

@media screen and (max-width: 940px) {
    .top-5-challenges { padding: 30px 34px 0; }
}

@media screen and (max-width: 940px) {
    .top-5-challenges { padding: 30px 34px 0; }
}

@media screen and (max-width: 850px) {
    .top-5-challenges { padding: 30px 45px 0; }
    .slider-controls span,
    .lSAction > a { margin-top: 0; top: calc(50% - 32px); }
}

@media screen and (max-width: 600px) {
    .top-5-challenges { padding: 30px 35px 0; }
    .slider-controls span,
    .lSAction > a { width: 25px; height: 44px; line-height: 44px; font-size: 44px; top: calc(50% - 26px); }
}

@media screen and (max-width: 480px) {
    .top-5-challenges { margin: 50px 0; padding: 30px 30px 0; }
    .slider-controls span,
    .lSAction > a { width: 25px; height: 42px; line-height: 42px; font-size: 42px; top: calc(50% - 25px); }
}

@media screen and (max-width: 440px) {
    .top-5-challenges { margin: 45px 0; padding: 30px 25px 0; }
    .slider-controls span,
    .lSAction > a { width: 22px; height: 36px; line-height: 36px; font-size: 36px; }
}

@media screen and (max-width: 400px) {
    .top-5-challenges { margin: 40px 0; padding: 30px 20px 0; }
}

@media screen and (max-width: 360px) {
    .top-5-challenges { padding: 30px 15px 0; }
    .slider-controls span,
    .lSAction > a { width: 20px; height: 30px; line-height: 30px; font-size: 30px; }
}

@media screen and (max-width: 350px) {
    .top-5-challenges { padding: 30px 0 0; }
    .top-5-challenges + .slider-controls { display: none; }
}

/* = Tabs
----------------------------------------------------------------------------------------------------------------- */
.tabs { margin: 40px 0; }
.tabs:last-child { margin-bottom: 0; }
.tab-links { margin: 0; padding: 0; list-style: none; border-bottom: 1px solid #DFDCE3; }
.tab-links--flex { display: flex; justify-content: space-between; }

.tab-links li { display: inline-block; margin: 0 20px 0 0; }
.tab-links li:last-child { margin-right: 0;; }
.tab-links li a { padding: 20px; font-size: 18px; font-weight: 600; display: inline-block; color: #b2aabb; position: relative; }
.tab-links li a:hover { color: #3F2A56; opacity: 0.8; }
.tab-links li a.on { color: #3F2A56; }
.tab-links li a.on:after { content: ''; position: absolute; bottom: -1px; left: 0; width: 100%; height: 10px; background: #3F2A56; }
.tabs .panel { padding: 25px 0 0; }

.tab-accordion { display: none; position: relative; }
.tab-accordion:after { content: '\f196'; position: absolute; top: 19px; right: 20px; }
.tab-accordion.on:after { content: '\f147'; }

.no-js .tab-links {display: none;}

@media screen and (min-width: 1241px) {
    .tab-stage { margin-top: 20px; }
}

@media screen and (max-width: 1240px) {
    .tabs--key-enablers .tab-links { float: left; width: 300px; border: 1px solid #DFDCE3; border-width: 0 1px 0 0; }
    .tabs--key-enablers .tab-stage { float: left; width: calc(100% - 300px); }
    .tabs--key-enablers .tab-links li { display: block; margin: 0; }
    .tabs--key-enablers .tab-links li a { display: block; padding: 16px 20px; }
    .tabs--key-enablers .tab-links li a:hover { opacity: 1; }
    .tabs--key-enablers .tab-links li a.on { background: #e2e0e6; }
    .tabs--key-enablers .tab-links li a.on:after { content: none; }
    .tabs--key-enablers .panel { padding: 0 45px 0 30px; }
    .tabs--key-enablers .tab-links li a.on:before { content: ""; position: absolute; top: calc(50% - 18px); right: -15px; border-top: 18px solid transparent; border-bottom: 18px solid transparent; border-left: 15px solid #e2e0e6; display: block; width: 0; z-index: 1; }
}

@media screen and (max-width: 980px) {
    .tabs--key-enablers .tab-links { width: 270px; }
    .tabs--key-enablers .tab-stage { width: calc(100% - 270px); }
    .tabs--key-enablers .tab-links li a { font-size: 17px; }
    .tabs--key-enablers .panel { padding: 0 15px 0 30px; }
}

@media screen and (max-width:800px) {
    .tabs--key-enablers .tab-links { display: none; }
    .tabs--key-enablers .tab-stage { width: 100%; }
    .tabs--key-enablers .panel { padding: 0; margin: 40px 0; }
    .tabs--key-enablers .panel:last-child {margin-bottom: 0;}
    .tabs--key-enablers .tab-accordion { display: block; margin: 0 0 15px; padding: 16px 20px; background: #e2e0e6; }
}

@media screen and (max-width:400px) {
    .tabs--key-enablers .panel { margin: 35px 0; }
}

/* = Accordions
----------------------------------------------------------------------------------------------------------------- */
.accordion { margin: 30px 0; padding: 0; list-style: none; }
.accordion:first-child { margin-top: 0; }
.accordion:last-child { margin-bottom: 5px; }

.accordion > dt { display: block; margin: 0 0 20px; padding: 15px 55px 15px 20px; font-size: 18px; font-weight: 600; line-height: 1.4em; background: #F5F5F6; color: #3F2A56; cursor: pointer; position: relative; -webkit-transition: background-color 300ms; transition: background-color 300ms; }
.accordion > dt:after { content: '\e814'; font-size: 9px; top: calc(50% - 13px); right: 15px; width: 26px; height: 26px; line-height: 28px; border-radius: 50%; position: absolute; color: #fff; background: #D50032; }
.accordion > dt.active { margin: 0; background-color: #F5F5F6; }
.accordion > dt.active:after { -webkit-transform: rotate(180deg); transform: rotate(180deg); background: #3F2A56; }
.accordion > dt:last-of-type { margin: 0; }

.accordion dd { display: none; padding: 25px 15px; }
.accordion dd.active:last-child { padding-bottom: 5px; }
.accordion dd.active { display: block; margin: 0; }

.accordion--boxed dd { padding: 5px 20px 20px 20px; background: #F5F5F6; }
.accordion--boxed dd.active { margin-bottom: 20px; }
.accordion--boxed dd.active:last-child { padding-bottom: 20px; margin-bottom: 0; }

.no-js .accordion dd {display: block;}

@media screen and (max-width: 480px) {
    .accordion > dt { margin: 0 0 15px; }
    .accordion dd { padding: 25px 5px; }
    .accordion--boxed dd { padding: 5px 20px 20px 20px; }
}

/* = Forms
----------------------------------------------------------------------------------------------------------------- */
input.text, textarea, select { padding: 10px 12px; margin: 0; font-size: 1em; font-family: myriad-pro, Arial, Helvetica, sans-serif; border: 1px solid #e5e5e5; background: transparent; -moz-border-radius: 0; -webkit-border-radius: 0; border-radius: 0; }
input.text:focus, textarea:focus, select:focus { outline: none; border-color: #ccc; }
input.file { margin: 8px 0; }

/*Cross browser form reset*/
textarea,
input.text,
input[type="text"],
input[type="button"],
input[type="submit"],
.input-checkbox { -webkit-appearance: none; border-radius: 0; }

textarea { min-height: 150px; min-width: 75%; max-width: 75%; }

::-webkit-input-placeholder { color: #3F2A56; opacity: 0.6; }
::-moz-placeholder { color: #3F2A56; opacity: 0.6; }
:-ms-input-placeholder { color: #3F2A56; opacity: 0.6; }
:-moz-placeholder { color: #3F2A56; opacity: 0.6; }

/* = Clearing
----------------------------------------------------------------------------------------------------------------- */
.clearFix:after, .cols:after, .home-images:after, .inner-cols:after, .gs-item:after, .lp-item:after, .lc-item:after { content: ""; display: table; clear: both; }

/* = Framework and containers
----------------------------------------------------------------------------------------------------------------- */
.container { width: 1200px; margin: 0 auto; position: relative; }
.container--slider { width: 1280px; }
.container--header { position: relative; }

.z-1 { z-index: 1; }
.z-2 { z-index: 2; }
.z-3 { z-index: 3; }

.row { position: relative; }
.row--static { position: static; }
.row--home { position: relative; overflow: hidden; }
.row--about { position: relative; overflow: hidden; }
.row--white { background-color: #ffffff; }
.row--lgrey { background-color: #F5F5F6; }
.row--lgreen { background-color: #d5e5dd; }
.row--purple { color: #fff; background-color: #3F2A56; }

.row--overlap-third { overflow: hidden; }
.row--overlap-third:before { content: ''; position: absolute; top: -2px; width: 100vw; height: 240px; background: #F5F5F6; }

.row--pad { padding: 80px 0; }
.row--pad + .row--pad { padding-top: 0; }
.row--radius-bl { border-radius: 0 0 0 200px; }
.row--radius-br { border-radius: 0 0 200px 0; }

.row:not(.row--home):first-child { box-shadow: inset 0 1px #e2e0e5; }

main { padding-top: 100px; }

.page-info--margin { margin-bottom: 25px; }

.inner { max-width: 625px; margin-left: auto; margin-right: auto; }
.inner--750 { max-width: 750px; }
.inner--900 { max-width: 900px; }
.inner--950 { max-width: 950px; }
.inner--1160 { max-width: 1160px; }
.inner--left { margin-left: 0; }
.inner--right { margin-right: 0; }
.inner--home { padding: 5.5em 0 5em; }
.inner--margintop { margin-top: 60px; }

.inner-cols { max-width: 1160px; margin-left: auto; margin-right: auto; }
.ic-left { width: calc(100% - 680px); margin-right: 55px; float: left; }
.ic-right { width: 625px; float: left; }

.inner-cols--rightfirst { position: relative; }
.inner-cols--rightfirst .page-info { position: absolute; width: calc(100% - 680px); margin-right: 55px; }

.single-col { padding: 65px 60px; border-radius: 25px; background: #fff; }
.single-col--600 { max-width: 600px; }
.single-col--overlap { margin-top: -20%; }

.boxed-white { margin: 35px 0; padding: 35px; border-radius: 20px; background: #fff; }
.boxed-white:first-child { margin-top: 0; }
.boxed-white:last-child { margin-bottom: 0; }
.boxed-white hr { margin: 30px 0; border-top: 1px solid #e6e6e6; }

.boxed-white.boxed-white--nopad-bottom { padding-bottom: 0; }

.boxed-lgrey { padding: 20px; line-height: 1.65em; background: #F5F5F6; }

@media screen and (min-width: 751px) {
    .row { z-index: 1; }

    .boxed-white--large-pad { padding: 70px 50px; }
    .boxed-white--nopad-bottom-dt { padding-bottom: 0; }
}

@media screen and (min-width: 981px) {
    .page-info { margin-top: -25px; }
    .ic-left--margintop { margin-top: 100px; }
}

@media screen and (min-width: 1441px) {
    .single-col--overlap { margin-top: -280px; }
}

@media screen and (min-width: 1601px) {
    .row--pad { padding: 90px 0; }

    .ic-left,
    .inner-cols--rightfirst .page-info { width: calc(100% - 685px); margin-right: 60px; }
    .ic-right { width: 625px; }
}

@media screen and (max-width: 1440px) and (min-width: 981px) {
    .row.row--offsetnav { padding-right: 65px; }
}

@media screen and (max-width: 1345px) and (min-width: 981px) {
    .row.row--offsetnav .container { width: auto; margin-left: 40px; margin-right: 40px; }
}

@media screen and (max-width: 1360px) {
    .container { width: auto; margin-left: 40px; margin-right: 40px; }
}

@media screen and (max-width: 1320px) {
    .row--home { margin-top: -30px; }
    .row--pad { padding: 75px 0; }
    .inner--home { padding: 5em 0; }

    .single-col--overlap { margin-top: -15%; }
}

@media screen and (max-width: 1280px) {
    .container { width: auto; margin-left: 40px; margin-right: 40px; }
    .inner--home { padding: 4.5em 0; }

    .row--pad { padding: 70px 0; }
    .single-col--overlap { margin-top: -12.5%; }
}

@media screen and (max-width: 1200px) {
    .ic-left,
    .inner-cols--rightfirst .page-info { width: calc(100% - 650px); margin-right: 50px; }
    .ic-right { width: 600px; }
}

@media screen and (max-width: 1080px) {
    .ic-left,
    .inner-cols--rightfirst .page-info { width: calc(100% - 605px); margin-right: 45px; }
    .ic-right { width: 560px; }

    .row--pad { padding: 65px 0; }
    .row--radius-bl { border-radius: 0 0 0 150px; }
    .row--radius-br { border-radius: 0 0 150px 0; }

    .single-col--overlap { margin-top: -10%; }
}

@media screen and (max-width: 1024px) {
    .row--home { margin-top: -40px; }
    .inner--home { padding: 4em 0; }

    .ic-left,
    .inner-cols--rightfirst .page-info { width: calc(100% - 580px); margin-right: 40px; }
    .ic-right { width: 540px; }
}

@media screen and (max-width: 980px) {
    .row--radius-bl { border-radius: 0 0 0 75px; }
    .row--radius-br { border-radius: 0 0 75px 0; }

    .inner-cols,
    .inner--main { max-width: 750px; }
    .ic-left,
    .inner-cols--rightfirst .page-info { float: none; width: 100%; margin: 0 0 40px; }
    .ic-right { float: none; width: 100%; }

    .inner-cols--rightfirst .ic-right { order: 1; }
    .inner-cols--rightfirst .ic-left { order: 2; margin: 40px 0 0; }
    .inner-cols--rightfirst .page-info { position: relative; }

    .inner--margintop { margin-top: 50px; }

    .page-info--hasProfile { float: left; width: auto; }

    .single-col { padding: 60px 50px; background: linear-gradient(180deg, rgba(255,255,255,1) 0%, rgba(255,255,255,1) 16%, rgba(255,255,255,0) 100%); }
    .single-col--600 { margin-left: auto; margin-right: auto; max-width: 700px; }
    .single-col--overlap { margin-top: -70px; }
}

@media screen and (max-width: 850px) {
    .single-col { padding: 65px 0; }
    .single-col--overlap { margin-top: 0; }
}

@media screen and (max-width: 750px) {
    .row--home { margin-top: -50px; }
    .row--pad { padding: 60px 0; }
    .single-col { padding: 60px 0; background: transparent; }
    .row--radius-bl,
    .row--radius-br { border-radius: 0; }

    .row--pad + .row--overlap-third { padding-top: 60px; }

    .row--overlap-third:before { content: none; }
    .inner--home { padding: 3.5em 0 4em; }

    .inner--margintop { margin-top: 45px; }

    .boxed-white.boxed-white--notmob { padding: 0; background: transparent; }
}

@media screen and (max-width: 480px) {
    .container { margin-left: 30px; margin-right: 30px; }
    .row--home { margin-top: -60px; }
    .row--pad,
    .single-col { padding: 50px 0; }

    .row--pad + .row--overlap-third { padding-top: 50px; }

    .inner--margintop { margin-top: 40px; }
}

@media screen and (max-width: 400px) {
    .container { margin-left: 25px; margin-right: 25px; }
    .inner--home { padding: 3.5em 0; }

    .row--pad,
    .single-col { padding: 40px 0; }

    .row--pad + .row--overlap-third { padding-top: 40px; }

    .inner--margintop { margin-top: 35px; }

    .boxed-white { margin: 30px 0; padding: 30px; }
    .boxed-white hr { margin: 25px 0; }
}

@media screen and (max-width: 380px) {
    .page-info--hasProfile { float: none; width: 100%; }

    .boxed-white { padding: 30px 25px; }
}

@media screen and (max-width: 350px) {
    main { padding-top: 90px; }
    .container { margin-left: 20px; margin-right: 20px; }
    .row--home { margin-top: -55px; }
}

/* = Row background images 
----------------------------------------------------------------------------------------------------------------- */
.row--bg-book:before { content: ''; position: absolute; top: 0; left: 0; width: 100%; height: 100%; background-image: url(../assets/images/backgrounds/bg-book.svg); background-position: 0 75%; background-repeat: no-repeat; z-index: 0; }
.row--bg-megaphone:before { content: ''; position: absolute; top: 0; left: 0; width: 100%; height: 100%; background-image: url(../assets/images/backgrounds/bg-megaphone.svg); background-position: 0 45%; background-repeat: no-repeat; z-index: 0; }
.row--bg-rocket:before { content: ''; position: absolute; top: 0; left: 0; width: 100%; height: 100%; background-image: url(../assets/images/backgrounds/bg-rocket.svg); background-position: 0 30%; background-repeat: no-repeat; z-index: -1; }
.row--bg-cogs:before { content: ''; opacity: 0.75; position: absolute; top: 0; left: 0; width: 100%; height: 100%; background-image: url(../assets/images/backgrounds/bg-cogs-purple.svg); background-position: 8% 25%; background-repeat: no-repeat; z-index: 0; }
.row--bg-people:before { content: ''; position: absolute; top: 0; left: 0; width: 100%; height: 100%; background-image: url(../assets/images/backgrounds/bg-people.svg); background-position: left bottom 90px; background-repeat: no-repeat; z-index: 0; }
.row--bg-map:before { content: ''; position: absolute; top: 0; left: 0; width: 100%; height: 100%; background-image: url(../assets/images/backgrounds/bg-map.svg); background-position: 0 68%; background-repeat: no-repeat; z-index: 0; }
.row--bg-challenges { background: #3F2A56 url(../assets/images/backgrounds/bg-challenges.jpg) center no-repeat; background-size: cover; }
.row--bg-solve-challenges:before { opacity: 0.7; content: ''; position: absolute; top: 0; left: 0; width: 100%; height: 100%; background-image: url(../assets/images/backgrounds/bg-target.svg); background-position: 0 25%; background-repeat: no-repeat; z-index: 0; }
.row--bg-solutions { background: #85B09A url(../assets/images/backgrounds/bg-solutions.jpg) center no-repeat; background-size: cover; }

@media screen and (min-width: 1601px) {
    .row--bg-book:before,
    .row--bg-megaphone:before { background-size: 28% auto; }
    .row--bg-cogs:before { background-position: 12% 25%; background-size: 22% auto; }
    .row--bg-people:before { background-size: 32% auto; }
    .row--bg-solve-challenges:before { background-size: 32% auto; background-position: 0 25%; }
}

@media screen and (max-width: 1440px) {
    .row--bg-rocket:before { background-size: 40% auto; background-position: -10% 30%; }
}

@media screen and (max-width: 1320px) {
    .row--bg-people:before { background-size: 38% auto; background-position: left bottom 100px; }
    .row--bg-map:before { background-size: 36% auto; }
    .row--bg-solve-challenges:before { background-size: 35% auto; }

    .row--bg-rocket:before { background-position: -10% 28%; background-size: 42% auto; }
}

@media screen and (max-width: 1200px) {
    .row--bg-book:before { background-size: 36% auto; }
    .row--bg-megaphone:before { background-size: 32% auto; }
    .row--bg-rocket:before { background-position: -15% 30%; }
    .row--bg-cogs:before { background-size: 28% auto; background-position: 6% 25%; }
    .row--bg-people:before { background-size: 35% auto; background-position: 0 90%; }
    .row--bg-map:before { background-size: 34% auto; }
    .row--bg-solve-challenges:before { background-size: 33% auto; }
}

@media screen and (max-width: 1080px) {
    .row--bg-rocket:before { background-size: 42% auto; }
    .row--bg-cogs:before { background-size: 26% auto; background-position: 6% 25%; }
    .row--bg-people:before { background-size: 32% auto; background-position: 0 80%; }
    .row--bg-map:before { background-size: 32% auto; }

    .row--bg-solve-challenges:before { background-position: -4% 30%; }
}

@media screen and (max-width: 980px) {
    .row--bg-book:before { max-width: 850px; background-position: 0 70%; background-size: 70% auto; opacity: 0.2; }
    .row--bg-megaphone:before { max-width: 850px; background-position: 0 60%; background-size: 70% auto; opacity: 0.4; }
    .row--bg-rocket:before { background-position: 0 50%; background-size: 75% auto; opacity: 0.2; }
    .row--bg-cogs:before { max-width: 850px; background-position: 8% 55%; background-size: 70% auto; opacity: 0.15; }
    .row--bg-people:before { max-width: 1200px; background-position: 0 54%; background-size: 85% auto; opacity: 0.15; }
    .row--bg-map:before { max-width: 950px; background-position: 0 95%; background-size: 70% auto; opacity: 0.1; }

    .row--bg-solve-challenges:before { max-width: 850px; background-position: 0 15%; background-size: 60% auto; opacity: 0.125; }
}

@media screen and (max-width: 750px) {
    .row--bg-book:before,
    .row--bg-megaphone:before { position: fixed; top: 0; bottom: 0; min-height: 700px; height: 100vh; background-size: 75% auto; background-position: 0 90%; }
    .row--bg-rocket:before { opacity: 0.15; position: fixed; top: 0; bottom: 0; min-height: 700px; height: 100vh; background-size: 75% auto; background-position: 0 60%; z-index: 0; }
    .row--bg-cogs:before { opacity: 0.1; position: fixed; top: 0; bottom: 0; min-height: 700px; height: 100vh; background-size: 70% auto; background-position: 16% 90%; }
    .row--bg-people:before { opacity: 0.125; position: fixed; top: 0; bottom: 0; min-height: 700px; height: 100vh; background-size: 88% auto; background-position: 0 85%; }
    .row--bg-map:before { position: fixed; top: 0; bottom: 0; min-height: 700px; height: 100vh; background-size: 80% auto; background-position: 0 85%; }
    .row--bg-solve-challenges:before { position: fixed; top: 0; bottom: 0; min-height: 700px; height: 100vh; background-size: 70% auto; background-position: -10% 50%; }
}

@media screen and (max-width: 600px) {
    .row--bg-book:before,
    .row--bg-megaphone:before,
    .row--bg-map:before { background-position: 0 75%; background-size: 85% auto; }
    .row--bg-rocket:before { background-position: 0 55%; background-size: 91% auto; }
    .row--bg-cogs:before { background-position: 28% 80%; background-size: 74% auto; }
    .row--bg-people:before { background-position: 0 75%; background-size: 95% auto; }
    .row--bg-solve-challenges:before { background-size: 78% auto; background-position: -10% 65%; }
}

@media screen and (max-width: 480px) {
    .row--bg-book:before { min-height: 660px; background-size: 115% auto; }
    .row--bg-megaphone:before { min-height: 660px; background-size: 95% auto; }
    .row--bg-rocket:before { min-height: 660px; background-size: 94% auto; }
    .row--bg-cogs:before { min-height: 660px; background-size: 76% auto; background-position: 50% 80%; }
    .row--bg-people:before { min-height: 660px; background-size: 110% auto; background-position: 50% 85%; }
    .row--bg-map:before { min-height: 660px; background-size: 95% auto; }
    .row--bg-solve-challenges:before { min-height: 660px; background-size: 82% auto; }
}

@media screen and (max-width: 400px) {
    .row--bg-book:before,
    .row--bg-megaphone:before,
    .row--bg-map:before { min-height: 580px; background-position: 0 70%; }
    .row--bg-rocket:before { min-height: 580px; background-size: 97% auto; }
    .row--bg-cogs:before { min-height: 580px; background-size: 78% auto; background-position: 60% 80%; }
    .row--bg-people:before { min-height: 580px; background-size: 128% auto; background-position: 50% 75%; }
    .row--bg-solve-challenges:before { min-height: 580px; background-size: 90% auto; }
}

/* = Diagrams
----------------------------------------------------------------------------------------------------------------- */
.diagram { margin: 50px 0; }
.diagram img { display: block; margin: 0 auto; width: 100%; }
.diagram:first-child, h2 + .diagram, h3 + .diagram, h4 + .diagram { margin-top: 5px; }
.diagram:last-child { margin-bottom: 5px; }
.diag-caption { text-align: center; margin: 30px 0 0; }
.diag-enlarge { text-align: right; font-size: 14px; }
.diag-enlarge--top { margin-bottom: 10px; }
.diag-enlarge--margin-top { margin-top: 40px; }
.diag-enlarge span { padding-left: 3px; color: #D50032; }
.diag-enlarge--mobile { display: none; font-size: 12px; }

@media screen and (max-width: 750px) {
    .diagram { margin: 40px 0; }
    .diag-caption { margin: 25px 0 0; }

    .diag-enlarge--mobile { display: block; }
}

@media screen and (max-width: 400px) {
    .diagram { margin: 35px 0; }
    .diag-caption { margin: 20px 0 0; }

    .diag-enlarge--mobile { font-size: 11px; }
}

/* = Banners
----------------------------------------------------------------------------------------------------------------- */
.banner { height: 0; padding-top: 41.67%; background: #333; position: relative; z-index: 1; }
.banner--675 { padding-top: 46.88% }

.banner--bottom { margin-top: -200px; z-index: 0; }
.banner-image { position: absolute; top: 0; left: 0; width: 100%; height: 100%; background-position: center; background-size: cover; background-repeat: no-repeat; }

.banner--green:before { content: ''; opacity: 0.7; position: absolute; top: 0; left: 0; width: 100%; height: 100%; background: #85B09A; mix-blend-mode: multiply; z-index: 1; }
.banner--purple:before { content: ''; opacity: 0.5; position: absolute; top: 0; left: 0; width: 100%; height: 100%; background: #3F2A56; mix-blend-mode: multiply; z-index: 1; }
.banner--texture:after { content: ''; position: absolute; bottom: 0; left: 0; width: 100%; height: 34%; background: url(../assets/images/textures/test.svg); background-size: 6vw auto; z-index: 1; }

.banner--opacity-9:before { opacity: 0.9; }
.banner--opacity-10:before { opacity: 1; }

@media screen and (min-width: 1441px) {
    .banner { height: 600px; padding: 0; }
    .banner--675 { height: 675px; }
}

@media screen and (max-width: 1080px) {
    .banner--bottom { margin-top: -150px; }
}

@media screen and (max-width: 980px) {
    .banner--bottom { margin-top: -75px; }
}

@media screen and (max-width:750px) {
    .banner--bottom { margin-top: 0; z-index: 1; }
}

/* = Header 
----------------------------------------------------------------------------------------------------------------- */
header { position: fixed; top: 0; left: 0; width: 100%; padding: 25px 30px; background: transparent; -webkit-transition: background .3s ease; transition: background .3s ease; z-index: 10; }

.hdr-home { background: transparent; }
.hdr-actions { float: right; }
.hdr-actions .btn--connect { position: absolute; top: 0; left: 0; visibility: hidden; opacity: 0; transition: .3s ease; }

.no-js .hdr-actions *,
.no-js header { transition: none;}

.navOn header { background: #231534; }
.navOn .hdr-actions .btn { color: #fff; background-color: transparent; }
.navOn .hdr-actions .btn--connect { opacity: 1; visibility: visible; }

@media screen and (max-width: 600px) {
    .hdr-actions .btn--connect { display: none; }
}

@media screen and (max-width: 440px) {
    .hdr-actions .btn { font-size: 15px; padding: 12px 16px; vertical-align: middle; }
}

@media screen and (max-width: 400px) {
    header { padding: 25px; }
    .hdr-actions .btn { font-size: 14px; padding: 10px 14px; }
}

@media screen and (max-width: 350px) {
    header { padding: 20px; }

    .hdr-actions .btn { font-size: 13px; padding: 8px 12px; }
}

/* = Header > Logos
----------------------------------------------------------------------------------------------------------------- */
.hdr-logo-small { border-radius: 20%; display: inline-block; transition: .3s ease; background: rgba(255, 255, 255, 0.85); box-shadow: 0 0 0px 14px rgba(255, 255, 255, 0.85); }
.navOn .hdr-logo-small { opacity: 0; }
.hdr-home .hdr-logo-small { opacity: 0; visibility: hidden; }

.logo-main { position: relative; display: inline-block; width: 156px; transition: .3s ease; }

@media screen and (max-width: 600px) {
    .container--header:before { opacity: 0; visibility: hidden; content: ''; position: absolute; width: 49px; height: 50px; background: url(../assets/images/logos/logo_cht_white.svg) top left no-repeat; background-size: 49px auto; transition: .3s ease; }
    .navOn .container--header:before { opacity: 1; visibility: visible; }
}

@media screen and (max-width: 480px) {
    .hdr-logo-small { background: rgba(255, 255, 255, 0.95); box-shadow: 0 0 0px 14px rgba(255, 255, 255, 0.95); }
    .logo-main { width: 140px; }
}

@media screen and (max-width: 440px) {
    .logo-main { width: 130px; }
}

@media screen and (max-width: 400px) {
    .logo-main { width: 34.5%; }
}

@media screen and (max-width: 350px) {
    .logo-main { width: 33%; }
}

/* = Navigation Burger
----------------------------------------------------------------------------------------------------------------- */
.burger { position: relative; margin-left: 20px; padding: 14px; outline: none; display: inline-block; vertical-align: top; background: #F0F0F0; border: 1px solid #F0F0F0; -webkit-border-radius: 50%; border-radius: 50%; overflow: hidden; cursor: pointer; z-index: 10; -webkit-transition: background .3s ease, border-color .2s ease; transition: background .3s ease, border-color .2s ease; -webkit-tap-highlight-color: transparent; }
.burger > div { float: left; }
.hamburger { position: relative; margin: 0; padding: 0; width: 18px; height: 18px; cursor: pointer; outline: none; -webkit-transition: background 0.3s ease; transition: background 0.3s ease; overflow: hidden; }
.hamburger:focus { outline: none; }
.hamburger span { display: block; position: absolute; top: 50%; margin-top: -1px; left: 0; right: 0; height: 2px; background: #3C2C53; -webkit-transition: background 0.3s ease; transition: background 0.3s ease; }
.hamburger span::before,
.hamburger span::after { position: absolute; display: block; left: 0; width: 100%; height: 2px; background-color: #3C2C53; content: ""; -webkit-transition: 0.3s ease; transition: 0.3s ease; }
.hamburger span::before { top: -6px; }
.hamburger span::after { bottom: -6px; }

.navOn .burger { background-color: transparent; border-color: #5c5269; border-color: rgba(255, 255, 255, 0.4); }
.navOn .hamburger span { background: none; }
.navOn .hamburger span::before { top: 0; background-color: #fff; -webkit-transform: rotate(45deg); transform: rotate(45deg); }
.navOn .hamburger span::after { bottom: 0; background-color: #fff; -webkit-transform: rotate(-45deg); transform: rotate(-45deg); }

.no-js  .burger {display: none;}

@media screen and (max-width: 440px) {
    .burger { margin-left: 16px; vertical-align: middle; }
}

@media screen and (max-width: 350px) {
    .burger { margin-left: 15px; }
}

/* = Navigation - Menu
----------------------------------------------------------------------------------------------------------------- */
.navigation { display: flex; flex-direction: column; justify-content: center; visibility: hidden; opacity: 0; position: fixed; top: 100px; left: 0; width: 100%; padding: 40px 0; height: calc(100% - 100px); background: #231534; border-top: 1px solid #3C2C53; transition: .3s ease; z-index: 10; }
.navOn .navigation { visibility: visible; opacity: 1; }

.no-js .navigation {transition:none;}

.nav-inner { overflow: auto; max-height: 100%; }
.nav-list { list-style: none; counter-reset: nav-counter; margin: 0; padding: 0; column-count: 3; column-gap: 80px; }
.nav-item { margin: 16px 0; padding-left: 50px; font-size: 22px; line-height: 1.4em; display: inline-block; vertical-align: top; width: 100%; counter-increment: nav-counter; position: relative; }

.nav-item::before { position: absolute; content: counter(nav-counter, decimal-leading-zero) ""; left: 0; top: 0; color: #fff; font-size: 16px; line-height: 32px; font-weight: 300; opacity: 0.7; }
.nav-item::after { position: absolute; content: ""; width: 15px; height: 30px; left: 9px; top: 0; border-top-right-radius: 30px; border-bottom-right-radius: 30px; border: 1px solid #fff; border-left: 0; opacity: 0.5; }

.nav-item-link { color: #fff; font-weight: 600; transition:color .3s ease; }
.nav-item-link:hover { color: #fff; }
.nav-item-link.on { color: #8EAF9B; }

@media screen and (min-width: 1201px) {
    .nav-item-link:hover { color: #DFDCE3; }
}

@media screen and (max-width: 1200px), screen and (max-height: 650px) {
    .navigation { padding: 35px 0; }
    .nav-list { column-gap: 70px; }
    .nav-item { margin: 14px 0; font-size: 21px; }
    .nav-item::before { line-height: 30px; }
    .nav-item::after { width: 14px; height: 28px; border-top-right-radius: 28px; border-bottom-right-radius: 28px; }
}

@media screen and (max-width: 1060px) {
    .navigation { padding: 30px 0; }
    .nav-list { column-count: 2; }
}

@media screen and (max-width: 750px), screen and (max-height: 600px) {
    .nav-list { column-gap: 50px; }
    .nav-item { margin: 12px 0; font-size: 20px; padding-left: 45px; }
    .nav-item::before { font-size: 15px; line-height: 28px; }
    .nav-item::after { width: 13px; height: 26px; border-top-right-radius: 26px; border-bottom-right-radius: 26px; }
}

@media screen and (max-width: 650px) {
    .navigation { padding: 25px 0; }
    .nav-list { column-count: 1; column-gap: 0; }
}

@media screen and (max-width: 360px) {
    .nav-item { margin: 10px 0; font-size: 19px; padding-left: 40px; }
    .nav-item::before { font-size: 14px; line-height: 26px; }
    .nav-item::after { width: 12px; height: 24px; border-top-right-radius: 24px; border-bottom-right-radius: 24px; }
}

@media screen and (max-width: 350px) {
    .navigation { top: 90px; height: calc(100% - 90px); }
}

/* = Navigation - Page prev next
----------------------------------------------------------------------------------------------------------------- */
.page-nav { position: fixed; right: 40px; top: calc(50% - 45px); z-index: 3; }
.pn-btn { float: right; clear: both; margin: 7px 0; font-size: 15px; height: 36px; width: 36px; color: #fff; background: #b7cbbf; border-radius: 18px; overflow: hidden; position: relative; transition: .3s ease; }
.pn-btn span { position: absolute; right: 36px; line-height: 36px; padding-left: 18px; color: #fff; opacity: 0; transition: .4s ease; }
.pn-btn:after { float: right; width: 36px; line-height: 36px; vertical-align: middle; }
.pn-btn:hover span { opacity: 1; }

@media screen and (min-width: 1025px) {
    .pn-btn:hover,
    .pn-btn:focus { width: 84px; color: #fff; }
}

@media screen and (min-width: 751px) and (max-height: 650px) {
    .page-nav { top: calc(55% - 45px); }
}

@media screen and (max-width: 980px) {
    .page-nav { top: auto; bottom: 40px; }
}

@media screen and (max-width: 480px) {
    .page-nav { right: 30px; }
}

/* = Image arrays
----------------------------------------------------------------------------------------------------------------- */
.home-images { position: absolute; bottom: -10%; right: -5%; width: calc(100% - 550px); max-width: 900px; max-height: 107%; background: url(../assets/images/textures/texture-hp-lines-m.svg) 100% 100% no-repeat; }
.hi-tleft { float: left; width: calc(50% - 12px); margin-right: 24px; }
.hi-tright { float: right; width: calc(50% - 12px); }
.hi-bleft { float: left; width: calc(50% - 12px); margin-top: 24px; }
.hi-tleft .hi-img { transform: scale(0.6); transform-origin: 100% 100%; width: 100%; height: 0; padding-bottom: 100%; border-radius: 50% 50% 14% 50%; background: url(../assets/images/homepage/homegrid-topleft.jpg) no-repeat; }
.hi-tright .hi-img { width: 100%; height: 0; padding-bottom: 100%; border-radius: 50% 50% 50% 14%; background: url(../assets/images/homepage/homegrid-topright.jpg) no-repeat; }
.hi-bleft .hi-img { width: 100%; height: 0; padding-bottom: 100%; border-radius: 50% 14% 50% 50%; background: url(../assets/images/homepage/homegrid-bottom.jpg) no-repeat; }
.hi .hi-img { background-size: cover; }

.image-drop { position: relative; }
.image-drop .id-img { display: block; width: 100%; height: 0; padding-bottom: 100%; border-radius: 50% 50% 10% 50%; background: #ccc; }
.image-drop .id-img--tl { border-radius: 10% 50% 50% 50%; }
.image-drop .id-img--tr { border-radius: 50% 10% 50% 50%; }
.image-drop .icon { top: 50%; left: 50%; position: absolute; transform: translate(-50%, -50%); }
.image-drop .icon--video:before { display: block; margin: 0 auto; width: 56px; height: 56px; line-height: 56px; color: #fff; font-size: 1.4em; text-align: center; border-radius: 50%; border: 2px solid #fff; }

.about-images { margin: 10em 0 0; background: url(../assets/images/textures/texture-hp-lines-m.svg) 150% 60% no-repeat; position: relative; }
.about-images .image-drop--top { width: 67%; float: right; min-width: 280px; }
.about-images .image-drop--bottom { margin-top: -25px; left: -26%; width: 56%; float: left; min-width: 200px; }
.about-images .id-img--tl { background: url(../assets/images/pills/about-pill-top.jpg) no-repeat; }
.about-images .id-img--br { background: url(../assets/images/pills/about-pill-bottom.jpg) no-repeat; }

.challenges-group { margin: 22em 0 0 -115px; padding: 0 0 80px 75px; background: url(../assets/images/textures/texture-hp-lines-m.svg) -55px bottom no-repeat; background-size: 104% auto; }
.challenges-group .image-drop--bottom,
.challenges-group .bubble-wrap { width: 67%; min-width: 320px; margin: 0 auto 0 0; }
.challenges-group .bubble-wrap .bubble-text { margin: 0 0 35px auto; }
.challenges-group .id-img { background: url(../assets/images/pills/challenges-pill.jpg) no-repeat; }

.acknowledgement-group { margin: 12em 0 0 -115px; padding: 0 0 80px 75px; background: url(../assets/images/textures/texture-hp-lines-m.svg) -25px bottom no-repeat; background-size: 104% auto; }
.acknowledgement-group .bubble-text { margin: 0 auto; }

.lookingahead-group { margin: 34em 0 0 -115px; padding: 0 0 80px 75px; background: url(../assets/images/textures/texture-hp-lines-m.svg) -25px bottom no-repeat; background-size: 100% auto; }
.lookingahead-group .bubble-text { margin: 0 40px 0 auto; }

.recommendations-group { margin: 38em 0 0 0; }
.recommendations-group .bubble-text { margin: 0 40px 0 auto; }

.image-drop--ke { max-width: 400px; margin: 50px auto; }
.image-drop--ke-people .id-img { background: url(../assets/images/pills/microscope-pill.jpg) center no-repeat; }
.image-drop--ke-collab .id-img { background: url(../assets/images/pills/women-laptop-pill.jpg) center no-repeat; }
.image-drop .id-img { background-size: cover; }

.id-vidcaption { color: #fff; text-align: center; }
.id-vidcaption span { margin-top: 10px; display: inline-block; }
.id--lensblue:before { content: ''; opacity: 0.375; position: absolute; top: 0; left: 0; width: 100%; height: 100%; background: #3F2A56; border-radius: 10% 50% 50% 50%; }

@media screen and (min-width: 1601px) {
    .home-images { right: 50%; margin-right: -900px; }
    .about-images { right: 20px; }

    .lookingahead-group .bubble-text { margin: 0 60px 0 auto; }
}

@media screen and (max-width: 1440px) {
    .challenges-group,
    .acknowledgement-group,
    .lookingahead-group { margin-left: -75px; padding: 0 0 75px 75px; background-size: 570px auto; }
}

@media screen and (max-width: 1400px) {
    .home-images { margin-left: 600px; width: 850px; left: 0; right: auto; }
    .challenges-group,
    .acknowledgement-group,
    .lookingahead-group { margin-left: 0; padding: 0 0 90px 0; background-size: 540px auto; }
}

@media screen and (max-width: 1320px) {
    .home-images { margin-left: 560px; max-height: 104%; }
    .about-images { background-position: 120% 50%; }
    .about-images .image-drop--bottom { margin-top: 20px; }
}

@media screen and (max-width: 1200px) {
    .challenges-group .image-drop--bottom,
    .challenges-group .bubble-wrap { width: 100%; max-width: 320px; min-width: 0; }

    .image-drop--ke { margin: 40px auto 0; }
}

@media screen and (max-width: 1100px) {
    .about-images { background-position: 90% 50%; }
    .about-images .image-drop--top { min-width: 100%; }
    .about-images .image-drop--bottom { margin-top: 40px; }
}

@media screen and (max-width: 1024px) {
    .home-images { margin-left: 530px; }
    .recommendations-group .bubble-text { margin: 0 20px 0 auto; }
}

@media screen and (max-width: 980px) {
    .about-images { margin: 20px auto 0; max-width: 460px; background-position: 65% 65%; }

    .challenges-group { margin: 10px auto 0; background-size: 90% auto; background-position: 25% 100%; }
    .challenges-group .bubble-wrap .bubble-text { margin: 0 auto 35px 0; }
    .challenges-group .image-drop--bottom,
    .challenges-group .bubble-wrap { width: 100%; max-width: 50%; float: left; }

    .acknowledgement-group,
    .lookingahead-group { margin: 10px auto 0; background-size: 80% auto; background-position: 25% 100%; }

    .recommendations-group { margin: 10px auto 0; }

    .lookingahead-group .bubble-text,
    .recommendations-group .bubble-text { margin: 0 auto; }
}

@media screen and (max-width: 850px) {
    .home-images { position: fixed; max-height: 95%; margin: 0; margin: 0; top: 135px; bottom: auto; left: auto; right: -14%; width: 630px; opacity: 0.175; z-index: 0; }
}

@media screen and (max-width: 800px) {
    .image-drop--ke { margin: 30px auto 20px; }
}

@media screen and (max-width: 750px) {
    .challenges-group,
    .acknowledgement-group { background-position: 50% 100%; background-size: 580px auto; }
    .challenges-group .image-drop--bottom { float: none; max-width: 400px; margin: 50px auto 0; }
    .challenges-group .bubble-wrap { float: none; max-width: 100%; }
    .challenges-group .bubble-wrap .bubble-text { margin: 0 auto 30px; }
}

@media screen and (max-width: 650px) {
    .home-images { width: 600px; right: -120px; }
}

@media screen and (max-width: 600px) {
    .home-images { top: 120px; width: 560px; right: -150px; opacity: 0.125; }
}

@media screen and (max-width: 480px) {
    .home-images { top: 40px; width: 540px; right: -260px; }
    .about-images { margin: 0; background-size: 480px auto; background-position: 80% 65%; }
    .about-images .image-drop--bottom { margin-top: 30px; }

    .challenges-group,
    .acknowledgement-group,
    .lookingahead-group { background: none; padding: 0; margin: 0; }
    .challenges-group .image-drop--bottom { margin-top: 40px; }

    .image-drop--ke { margin: 30px auto 10px; }
}

@media screen and (max-width: 400px) {
    .about-images .image-drop--bottom { margin-top: 20px; }
}

/* = Image zoom
----------------------------------------------------------------------------------------------------------------- */
.imageZoom { overflow: hidden; position: relative; }
.imageZoom .iz-overlay { display: none; position: absolute; top: 0; left: 0; width: 100%; height: 100%; overflow: auto; background: #fff; }
.imageZoom .iz-overlay .iz-zoom { width: 250%; max-width: 250%; }
.imageZoom--150 .iz-overlay .iz-zoom { width: 150%; max-width: 150%; }
.imageZoom--200 .iz-overlay .iz-zoom { width: 200%; max-width: 200%; }

@media screen and (max-width: 750px) {
    .imageZoom.zoomed .iz-overlay { display: block; }
}

@media screen and (max-width: 480px) {
    .imageZoom .iz-overlay .iz-zoom { width: 300%; max-width: 300%; }
    .imageZoom--150 .iz-overlay .iz-zoom { width: 175%; max-width: 175%; }
    .imageZoom--200 .iz-overlay .iz-zoom { width: 250%; max-width: 250%; }
}

/* = Image Profile card
----------------------------------------------------------------------------------------------------------------- */
.profile-card { margin: 45px 0 45px auto; position: relative; max-width: 250px; text-align: right; }
.profile-card:last-child { margin-bottom: 0; }
.pc-image { width: 170px; height: 170px; margin: 0 0 25px auto; border-radius: 50% 50% 10% 50%; position: relative; background: #8eaf9b; overflow: hidden; }
.pc-image img { position: absolute; left: 50%; top: 50%; transform: translate(-50%, -50%); border-radius: 50% 50% 10% 50%; border: 8px solid #8EAF9B; }
.pc-caption { font-size: 14px; line-height: 1.5em; }

@media screen and (max-width: 980px) {
    .profile-card { margin: 0; float: right; }
}

@media screen and (max-width: 600px) {
    .profile-card { max-width: 220px; }
    .pc-image { width: 130px; height: 130px; margin: 0 0 20px auto; }
    .pc-image img { border-width: 6px; }
    .pc-caption { font-size: 12px; }
}

@media screen and (max-width: 480px) {
    .profile-card { max-width: 200px; }
    .pc-image { width: 120px; height: 120px; }
    .pc-caption { font-size: 11px; }
}

@media screen and (max-width: 400px) {
    .profile-card { max-width: 190px; }
    .pc-image { width: 110px; height: 110px; margin: 0 0 16px auto; }
    .pc-image img { border-width: 5px; }
}

@media screen and (max-width: 380px) {
    .profile-card { max-width: 100%; margin: 25px 0 0; float: none; text-align: left; display: flex; align-items: center; }
    .pc-image { width: 120px; height: 120px; margin: 0; }
    .pc-caption { font-size: 12px; width: calc(100% - 140px); margin-left: 20px; }
}

/* = Bubble text
----------------------------------------------------------------------------------------------------------------- */
.bubble-text { width: 250px; height: 250px; background: #fff; border-radius: 50% 0 50% 50%; font-size: 22px; position: relative; }
.bubble-text--point-left { border-radius: 0 50% 50% 50%; }
.bubble-text--point-br { border-radius: 50% 50% 0 50%; }
.bubble-text--red { color: #FBFBFC; background: #D50032; }
.bubble-text--purple { color: #FBFBFC; background: #3F2A56; }
.bubble-text p { line-height: 1.45em; }
.bubble-text p:not(:last-child) { margin-bottom: 10px; }

.bt-inner { position: absolute; min-width: 160px; top: 50%; left: 50%; transform: translate(-50%, -50%); }
.bt-inner--min140 { min-width: 140px; }
.bt-inner--l5 { margin-left: 5px; }
.bt-inner--l10 { margin-left: 10px; }
.bt-inner--l15 { margin-left: 15px; }
.bt-inner--l20 { margin-left: 20px; }

.bubble-text--l-overlap { position: absolute; bottom: -160px; right: 735px; }
.bubble-text--tr-overlap { position: absolute; top: -180px; right: 40px; }
.single-col--overlap .bubble-text--tr-overlap { top: 80px; }

.bubble-wrap--solving-challenges { margin: 50em 0 0; }
.bubble-wrap--solutions-practice { margin: 17em 0 0; }

.bubble-wrap--solving-challenges .bubble-text,
.bubble-wrap--solutions-practice .bubble-text { margin: 0 auto; }

@media screen and (min-width: 1441px) {
    .single-col--overlap .bubble-text--tr-overlap { top: 160px; }
}

@media screen and (max-width: 1400px) {
    .bubble-text--tr-overlap { right: 80px; }
}

@media screen and (max-width: 1280px) {
    .bubble-text--l-overlap { right: 700px; bottom: -140px; }
}

@media screen and (max-width: 1200px) {
    .bubble-text { width: 230px; height: 230px; }
    .bubble-text--l-overlap { right: 680px; bottom: -130px; }
}

@media screen and (max-width: 1080px) {
    .bubble-text--l-overlap { right: 630px; bottom: -125px; }
    .bubble-text--tr-overlap { right: 60px; }
    .single-col--overlap .bubble-text--tr-overlap { top: 40px; }
}

@media screen and (max-width: 1024px) {
    .bubble-text--l-overlap { right: 580px; }
    .bubble-text--tr-overlap { right: 50px; }
}

@media screen and (max-width: 980px) {
    .bubble-text--l-overlap { right: auto; left: 0; bottom: -250px; }
    .single-col--overlap .bubble-text--tr-overlap { top: 0; }

    .bubble-wrap--solving-challenges,
    .bubble-wrap--solutions-practice { margin: 0; }
}

@media screen and (max-width: 980px) and (min-width: 751px) {
    .bubble-text--950 { margin: 45px auto; padding: 40px 50px; position: relative; top: 0; left: 0; right: 0; bottom: 0; width: 100%; max-width: 600px; height: auto; border-radius: 80px 0 80px 80px; }
    .bubble-text--950:last-child { margin-bottom: 2px; }
    .bubble-text--950 .bt-inner { position: relative; transform: none; top: 0; left: 0; }
    .bubble-text--point-left { border-radius: 0 80px 80px 80px; }
}

@media screen and (max-width: 750px) {
    .bubble-text { margin: 45px auto; position: relative; top: 0; left: 0; right: 0; bottom: 0; }
    .bubble-text:last-child { margin-bottom: 10px; }
}

@media screen and (max-width: 750px) and (min-width: 481px) {
    .bubble-text { width: 100%; height: auto; padding: 40px 50px; border-radius: 80px 0 80px 80px; }
    .bubble-text .bt-inner { position: relative; transform: none; top: 0; left: 0; }
    .bubble-text--point-left { border-radius: 0 80px 80px 80px; }
}

@media screen and (max-width: 480px) {
    .bubble-text { margin: 40px auto; }
}

@media screen and (max-width: 400px) {
    .bubble-text { margin: 35px auto; }
}

/* = CTA blocks
----------------------------------------------------------------------------------------------------------------- */
.cta-block { margin: 50px 0; padding: 60px; color: #fff; background: #3F2A56; }
.cta-block:first-child { margin-top: 2px; }
.cta-block:last-child { margin-bottom: 5px; }
.cta-block--bg { background: #3F2A56 url(../assets/images/backgrounds/bg-video-cta.svg) right -150px center no-repeat; background-size: 75% auto; }
.cta-block *:not(.btn) { color: #fff; }

@media screen and (max-width: 980px) {
    .cta-block--bg { background-size: auto 80%; }
}

@media screen and (max-width: 650px) {
    .cta-block { margin: 50px 0; padding: 50px; }
}

@media screen and (max-width: 480px) {
    .cta-block { margin: 40px 0; padding: 40px; }
}

@media screen and (max-width: 400px) {
    .cta-block { margin: 35px 0; padding: 35px; }
}

@media screen and (max-width: 360px) {
    .cta-block { margin: 30px 0; padding: 30px; }
}

/* = Growth module
----------------------------------------------------------------------------------------------------------------- */
.growth-module { padding: 60px; background: #F0F0F0; border-radius: 26px; position: relative; box-shadow: 0px 16px 32px rgba(0, 0, 0, 0.125); }
.gm-title span { display: inline-block; padding: 12px 30px 14px; border: 1px solid #3F2A56; border-radius: 14px; }

.gs-item { width: 120px; margin-right: 20px; float: left; }
.gs-item:last-child { margin-right: 0; }
.gs-item.on { width: calc(100% - 560px); }

.gsi-count { margin-bottom: 15px; padding-left: 54px; font-size: 32px; font-weight: 600; color: #D50032 }
.gsi-icon { float: left; width: 120px; height: 120px; line-height: 120px; text-align: center; margin-right: 20px; border-radius: 50% 50% 0 50%; background: #3F2A56; position: relative; -webkit-transition:.3s ease; transition:.3s ease; }
.gsi-icon:after { font-size: 4em; color: #fff; position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%);  }
.gsi-icon.icon--handshake:after { font-size: 2.7em; top: calc(50% + 3px); }
.gsi-icon.icon--magnet:after { font-size: 3.1em; top: calc(50% + 1px); }
.gsi-text { float: left; width: 0; height: 120px; overflow: hidden; }
.gsi-text p:last-child { margin-bottom: 0; }

.on .gsi-icon { background: #D50032; }
.on .gsi-text { width: calc(100% - 140px); height: auto; }

.growth-bar { margin: 55px 0 0; position: relative; }
.growth-bar .gb-text { border-radius: 28px; margin: 0; padding: 12px 12px 12px 80px; font-weight: 400; text-align: center; color: #fff; background: #85B09A; }
.growth-bar .gb-icon { position: absolute; top: calc(50% - 42px); font-size: 2.25em; width: 84px; height: 84px; line-height: 84px; text-align: center; border-radius: 50%; color: #fff; background: #85B09A; z-index: 1; }

@media screen and (min-width: 981px) {
    .gs-item { cursor: pointer; }
    .gs-item:hover:not(.on) .gsi-icon { background: #5c5269; }
}

@media screen and (max-width: 1200px) {
    .growth-module { padding: 50px; }
    .gs-item { width: 100px; }
    .gsi-icon { width: 100px; height: 100px; line-height: 100px; }
    .gsi-icon:after { transform: translate(-50%, -50%) scale(0.8); }
    .gsi-count { margin-bottom: 12px; padding-left: 40px; font-size: 30px; }

    .gs-item.on { width: calc(100% - 480px); }
    .on .gsi-text { width: calc(100% - 120px); }
}

@media screen and (max-width: 980px) {
    .growth-inner { position: relative; }
    .growth-steps { width: calc(100% - 80px); }

    .growth-bar { margin: 40px 0 0; position: static; }
    .growth-bar:after { content: ''; position: absolute; top: 5px; right: 27px; width: 10px; height: calc(100% - 10px); background: #85B09A; }
    .growth-bar .gb-icon { top: 0; right: 0; font-size: 2em; width: 60px; height: 60px; line-height: 62px; }
    .growth-bar .gb-text { padding: 12px; position: relative; z-index: 1; }

    .on .gsi-icon { background: #3F2A56; }
    .gs-item { float: none; width: 100%; margin: 35px 0; padding: 30px; border-radius: 28px; background: #fff; }
    .gs-item.on { width: 100%; }
    .gs-item:last-child { margin-bottom: 0; }

    .gsi-text { width: calc(100% - 120px); height: auto; }
    .gsi-count { line-height: 1; padding-left: 0; text-align: center; }
}

@media screen and (max-width: 750px) {
    .growth-module { padding: 0; box-shadow: none; background: none; }
    .gs-item { margin: 30px 0; background: #F0F0F0; }
    .growth-bar { margin: 35px 0 0; }
    .gm-title span { display: block; }
}

@media screen and (max-width: 600px) {
    .growth-steps { width: calc(100% - 65px); }
    .gs-item { margin: 25px 0; border-radius: 14px; }
    .gsi-icon { width: 80px; height: 80px; line-height: 80px; }
    .gsi-icon:after { transform: translate(-50%, -50%) scale(0.7); }
    .gsi-count { font-size: 28px; }

    .gsi-text,
    .on .gsi-text { width: calc(100% - 100px); }

    .growth-bar { margin: 30px 0 0; }
    .growth-bar:after { right: 22px; }
    .growth-bar .gb-text { border-radius: 14px; text-align: left; padding: 18px 22px; }
    .growth-bar .gb-icon { font-size: 1.75em; width: 50px; height: 50px; line-height: 52px; }
}

@media screen and (max-width: 480px) {
    .growth-steps { width: calc(100% - 45px); }
    .gs-item { padding: 25px; border-radius: 12px; }
    .gsi-count { font-size: 26px; }
    .gsi-icon { width: 60px; height: 60px; line-height: 60px; margin-right: 15px; }
    .gsi-icon:after { transform: translate(-50%, -50%) scale(0.6); }

    .gsi-text,
    .on .gsi-text { width: calc(100% - 75px); }

    .gsi-text .h3 { font-size: 22px; margin-bottom: 15px; }

    .growth-bar { margin: 25px 0 0; }
    .growth-bar:after { right: 10px; width: 8px; }
    .growth-bar .gb-text { border-radius: 12px; font-size: 20px; }
    .growth-bar .gb-icon { right: -7px; font-size: 1.5em; width: 40px; height: 40px; line-height: 42px; }
}

@media screen and (max-width: 440px) {
    .growth-steps { width: calc(100% - 40px); }
    .gs-item { margin: 22px 0; }
    .gsi-icon { width: 54px; height: 54px; line-height: 54px; }
    .gsi-icon:after { transform: translate(-50%, -50%) scale(0.5); }
    .gsi-count { font-size: 24px; }
    .gsi-text, .on .gsi-text { width: calc(100% - 69px); }
    .gsi-text .h3 { font-size: 20px; margin-bottom: 12px; }

    .growth-bar:after { right: 8px; }
    .growth-bar .gb-icon { font-size: 1.25em; width: 35px; height: 35px; line-height: 37px; }
}

@media screen and (max-width: 400px) {
    .gsi-icon { width: 45px; height: 45px; line-height: 47px; }
    .gsi-icon:after { transform: translate(-50%, -50%) scale(0.4); }
    .gsi-count { font-size: 22px; }
    .gsi-text, .on .gsi-text { width: calc(100% - 60px); }
    .gsi-text .h3 { font-size: 19px; margin-bottom: 10px; }
    .gsi-text p { font-size: 15px; }
    .growth-bar .gb-text { font-size: 19px; }
}

/* = Key enablers
----------------------------------------------------------------------------------------------------------------- */
.ked-key { font-size: 12px; line-height: 1.25em; position: absolute; top: 20px; right: 25px; padding: 10px 10px 10px 26px; color: #777; border: 1px solid #e2e0e5; }
.ked-key .icon { padding-right: 4px; position: absolute; top: 10px; left: 10px; }

@media screen and (min-width: 481px) {
    .ked-wrap { padding: 15px 0; position: relative; }
    .key-enablers-diagram { margin: 0 auto; max-width: 425px; position: relative; }
    .ked-title { margin-bottom: 40px; }
    .ked-quarter { float: left; width: 50%; height: 0; padding-top: 50%; position: relative; }
    .ked-bulb { position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); width: 100px; height: 100px; border-radius: 50%; color: #fff; background: #D50032 url(../assets/images/diagrams/key-enablers/bulb.svg) center no-repeat; background-size: auto 50%; }
    .ked-tagline { position: absolute; bottom: 25px; left: calc(50% - 100px); width: 200px; text-align: center; line-height: 1.25em; font-weight: 600; }

    .kedq-sub { position: absolute; top: 0; left: 0; width: 100%; height: 100%; -webkit-transition: .3s ease; transition: .3s ease; }
    .kedq-sub--collab { background: url(../assets/images/diagrams/key-enablers/seg-tl-a.svg) 0 0 no-repeat; background-size: 100% auto; }
    .kedq-sub--training { background: url(../assets/images/diagrams/key-enablers/seg-tl-b.svg) 0 0 no-repeat; background-size: 100% auto; }
    .kedq-sub--tech { background: url(../assets/images/diagrams/key-enablers/seg-tr-a.svg) 0 0 no-repeat; background-size: 100% auto; }
    .kedq-sub--impl { background: url(../assets/images/diagrams/key-enablers/seg-tr-b.svg) 0 0 no-repeat; background-size: 100% auto; }

    .ked-label { position: absolute; margin: 0; font-size: 12px; font-weight: 600; width: 90px; text-align: center; }
    .kedq-sub--collab .ked-label { bottom: 94%; right: 55%; }
    .kedq-sub--training .ked-label { bottom: 34%; right: 100%; }
    .kedq-sub--tech .ked-label { bottom: 98%; left: 55%; }
    .kedq-sub--impl .ked-label { bottom: 36%; right: -48%; }
    .kedq-sub--linking .ked-label { top: 36%; right: -42%; }
    .kedq-sub--people .ked-label { top: 34%; left: -40%; }

    .kedq-sub--people { background: url(../assets/images/diagrams/key-enablers/seg-bl.svg) 0 0 no-repeat; background-size: 100% auto; }
    .kedq-sub--linking { background: url(../assets/images/diagrams/key-enablers/seg-br.svg) 100% 0 no-repeat; background-size: 100% auto; }

    .ked-quarter .icon { position: absolute; font-size: 2.6em; }
    .kedq-sub--collab .icon { top: 19%; right: 20%; font-size: 2.1em; }
    .kedq-sub--training .icon { bottom: 18%; left: 16%; font-size: 2.8em; }
    .kedq-sub--tech .icon { top: 14%; left: 20%; }
    .kedq-sub--impl .icon { color: #fff; bottom: 18%; right: 16%; }

    .ked-quarter .trigger { position: absolute; width: 50%; height: 50%; z-index: 1; cursor: pointer; }
    .ked-quarter .trigger--tl { top: 0; right: 0; width: 60%; }
    .ked-quarter .trigger--bl { bottom: 0; left: 0; height: 60%; }
    .ked-quarter .trigger--tr { top: 0; left: 0; width: 60%; }
    .ked-quarter .trigger--br { bottom: 0; right: 0; height: 60%; }

    .trigger--tl:hover + .kedq-sub--collab { transform: translate(-6px, -16px); }
    .trigger--bl:hover + .kedq-sub--training { transform: translate(-16px, -6px); }
    .trigger--tr:hover + .kedq-sub--tech { transform: translate(6px, -16px); }
    .trigger--br:hover + .kedq-sub--impl { transform: translate(16px, -6px); }
    .trigger--tlb:hover + .kedq-sub--people { transform: translate(-16px, 6px); }
    .trigger--trb:hover + .kedq-sub--linking { transform: translate(16px, 6px); }

    .ked-quarter .trigger--tlb { top: 0; left: 0; height: 60%; }
    .ked-quarter .trigger--trb { top: 0; right: 0; height: 60%; }
    .ked-quarter--bl .icon { position: absolute; font-size: 2.85em; top: 18%; left: 16%; }
    .ked-quarter--br .icon { position: absolute; font-size: 2.7em; color: #fff; top: 18%; right: 16%; }

    .ked-modal-outer { visibility: hidden; position: fixed; top: 0; left: 0; width: 100%; height: 100%; z-index: 15; }
    .ked-modal-outer.on { visibility: visible; }
    .ked-modal { opacity: 0; border-radius: 16px; padding: 30px; position: absolute; top: 50%; left: 50%; width: 425px; font-size: 15px; background-color: #F0F0F0; box-shadow: 0px 4px 30px rgba(0, 0, 0, 0.225); visibility: hidden; -webkit-transform: scale(0) translate(-50%, -50%); transform: scale(0) translate(-50%, -50%); -webkit-transform-origin: left; transform-origin: left; -webkit-transition: .3s ease; transition: .3s ease; z-index: 2; }
    .ked-modal-outer.on .ked-modal { -webkit-transform: scale(1) translate(-50%, -50%); transform: scale(1) translate(-50%, -50%); visibility: visible; opacity: 1; }
    .ked-quarter .ked-modal .ked-modal-close { color: #3F2A56; cursor: pointer; width: 50px; height: 50px; line-height: 50px; text-align: center; font-size: 1em; top: 0; left: auto; bottom: auto; right: 0; z-index: 1; }
}

@media screen and (max-width: 980px) {
    .ked-key { font-size: 10px; top: 15px; padding: 8px 8px 8px 25px; max-width: 100px; }
    .ked-key .icon { top: 9px; left: 10px; }
}

@media screen and (min-width: 481px) and (max-width: 700px) {
    .ked-wrap { padding: 0; }
    .key-enablers-diagram { max-width: 350px; }
    .ked-tagline { bottom: 20px; }

    .ked-bulb { width: 80px; height: 80px; }

    .ked-quarter .icon { font-size: 2.1em; }
    .kedq-sub--collab .icon { font-size: 1.7em; }
    .kedq-sub--training .icon { font-size: 2.2em; }
    .kedq-sub--linking .ked-label { right: -50%; }
    .kedq-sub--impl .ked-label { right: -52%; }
}

@media screen and (min-width: 481px) and (max-width: 600px) {
    .key-enablers-diagram { max-width: 290px; }
    .ked-bulb { width: 65px; height: 65px; }
    .ked-tagline { bottom: 15px; left: calc(50% - 80px); font-size: 15px; width: 160px; }

    .ked-quarter .icon { font-size: 2em; }
    .kedq-sub--collab .icon { font-size: 1.6em; }
    .kedq-sub--training .icon { font-size: 2.1em; }
    .kedq-sub--impl .ked-label,
    .kedq-sub--linking .ked-label { right: -62%; }
    .kedq-sub--people .ked-label { left: -50%; }
}

@media screen and (max-width: 700px) {
    .ked-key { top: -5px; }
}

@media screen and (max-width: 600px) {
    .ked-key { top: -10px; right: -15px; transform: scale(0.9); transform-origin: top right; }
}

@media screen and (max-width: 480px) {
    .key-enablers-diagram { display: flex; flex-direction: column; }
    .ked-bulb { order: 0; position: relative; margin: 0 auto 10px; width: 60px; height: 60px; border-radius: 50%; color: #fff; background: #D50032 url(../assets/images/diagrams/key-enablers/bulb.svg) center no-repeat; background-size: auto 50%; }
    .key-enablers-diagram .ked-tagline { margin: 0 0 15px; font-size: 4.25vw; text-align: center; }
    .ked-label { margin: 0; font-weight: 600; }
    .ked-quarter { display: flex; flex-direction: column; order: 2; }
    .ked-quarter--bl { order: 1; }

    .ked-title,
    .ked-modal-close,
    .ked-quarter .trigger,
    .ked-modal-outer,
    .ked-modal > h4,
    .ked-key { display: none; }

    .mob-on.ked-modal-outer { display: block; }
    .ked-modal { padding: 25px; margin: 5px 0; background: #f3f3f3; }

    .kedq-sub { margin: 4px 0; padding: 12px 30px 12px 64px; position: relative; color: #fff; background: #333; }
    .kedq-sub:after { content: '\f107'; position: absolute; right: 15px; top: 16px; font-size: 1.2em; }

    .kedq-sub.on:after { -webkit-transform: rotate(180deg); transform: rotate(180deg); }

    .kedq-sub > .icon,
    .kedq-sub .icon--handshake { position: absolute; left: 0; top: 0; height: 100%; width: 50px; text-align: center; font-size: 1.75em; background: rgba(0, 0, 0, 0.08); }
    .kedq-sub > .icon:before,
    .kedq-sub .icon--handshake:after { position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); }

    .kedq-sub .icon--handshake { font-size: 1.4em; }
    .kedq-sub > .icon--person-link { background: rgba(0, 0, 0, 0.15); }

    .kedq-sub--training { order: 2; color: #3F2A56; background: #b6d0c2; }
    .kedq-sub--training + .ked-modal-outer { order: 3; }
    .kedq-sub--collab { order: 4; background: #92b9a5; }
    .kedq-sub--collab + .ked-modal-outer { order: 4; }

    .kedq-sub--people { color: #3F2A56; background: #dce8e2; }
    .kedq-sub--tech { color: #3F2A56; background: #e2e0e6; }
    .kedq-sub--impl { background: #75669d; }
    .kedq-sub--linking { background: #3f2a56; }
}

@media screen and (max-width: 400px) {
    .key-enablers-diagram .ked-tagline { font-size: 4.7vw; }
}

@media screen and (max-width: 380px) {
    .ked-label { font-size: 15px; }
    .kedq-sub:after { right: 14px; top: 15px; }
    .ked-modal { font-size: 15px; padding: 22px; }
}

@media screen and (max-width: 360px) {
    .ked-label { font-size: 14px; }
    .kedq-sub:after { top: 14px; }
}

@media screen and (max-width: 340px) {
    .kedq-sub { padding: 10px 28px 10px 60px; }
    .kedq-sub:after { top: 12px; }
}

/* = Challenges graph
----------------------------------------------------------------------------------------------------------------- */
.pg-wrap { margin: 50px auto 65px; position: relative; }
.pg-caption { margin-bottom: 10px; }
.plotted-graph { position: relative; }
.pg-key { text-align: right; margin: 0 0 12px; font-size: .9em; }
.pg-key span { padding-right: 5px; color: #D50032; font-weight: 300; }
.pg-image img { width: 100%; }
.pg-stage { position: absolute; top: 0; left: 0; width: 100%; height: 100%; }
.pg-point { position: absolute; border-radius: 50%; }
.pg-mobile-modal { font-size: .9em; display: none; position: absolute; top: 0; left: 0; width: 91%; height: 92%; margin: 0 0 8% 9%; padding: 40px 35px 35px; color: #fff; background: #D50032; }
.pg-mobile-modal--purple { background: #3F2A56; }
.pg-mobile-modal span { cursor: pointer; position: absolute; top: 15px; right: 15px; }
.pgm-content { overflow: auto; height: 100%; }
.pgm-content p:not(:last-child) { margin-bottom: 20px; }

.pg-modal { opacity: 0; visibility: hidden; padding: 15px 20px; min-width: 350px; top: calc(100% + 20px); left: 50%; position: relative; -webkit-transform: translateX(-50%); transform: translateX(-50%); background: #D50032; border-radius: 10px; color: #fff; font-size: .95em; transition: .3s ease; }
.pg-modal:before { content: ''; position: absolute; top: -13px; left: calc(50% - 10px); width: 0; height: 0; border: 0 solid transparent; border-right-width: 10px; border-left-width: 10px; border-bottom: 14px solid #D50032; }
.pg-modal--purple { background: #3F2A56; }
.pg-modal--purple:before { border-bottom: 14px solid #3F2A56; }

.pg-point { width: 4%; height: 4%; cursor: pointer; }
.pg-point:hover .pg-modal { opacity: 1; visibility: visible; }

.pg-point--1 { top: 35%; right: 33.6%; }
.pg-point--2 { top: 22.7%; right: 32%; }
.pg-point--3 { top: 22.5%; right: 13.8%; }
.pg-modal--3 { transform: translateX(-76%); }
.pg-modal--3:before { left: calc(76% - 10px); }
.pg-point--4 { top: 15.5%; right: 24%; }
.pg-point--5 { top: 4.5%; right: 5.5%; }
.pg-modal--5 { left: auto; right: 0; -webkit-transform: translateX(calc(-100% + 70px)); transform: translateX(calc(-100% + 70px)); }
.pg-modal--5:before { left: calc(83% - 10px); }

@media screen and (max-width: 980px) {
    .pg-wrap { max-width: 600px; }
}

@media screen and (max-width: 750px) {
    .pg-modal { font-size: .9em; }
    .pg-modal--11 { -webkit-transform: translateX(-60%); transform: translateX(-60%); }
    .pg-modal--11:before { left: calc(60% - 10px); }
}

@media screen and (max-width: 600px) {
    .pg-key { font-size: .8em; }
    .pg-modal { min-width: 300px; }
    .pg-modal p { line-height: 1.55em; }
    .pg-modal--12 { -webkit-transform: translateX(calc(-100% + 60px)); transform: translateX(calc(-100% + 60px)); }
}

@media screen and (max-width:480px) {
    .pg-wrap { margin: 40px auto 50px; }
    .pg-modal { display: none; }
    .pg-key { font-size: .75em; }
    .pg-mobile-modal { display: block; opacity: 0; visibility: hidden; transition: .3s ease; }
    .pg-mobile-modal.on { opacity: 1; visibility: visible; }
}

@media screen and (max-width:400px) {
    .pg-mobile-modal { padding: 40px 30px 30px; }
}

/* = Modal
----------------------------------------------------------------------------------------------------------------- */
.modal { display: none; background: rgba(0, 0, 0, 0.5); position: fixed; top: 0; left: 0; height: 100%; width: 100%; z-index: 9999; }
.modal.on { display: block; }
.modal .modal-inner { max-width: 840px; width: 90%; max-height: 90%; left: 50%; top: 45%; padding: 45px 40px 40px; margin: 0 auto; background: #fff; display: block; float: none; position: absolute; -ms-transform: translate(-50%, -50%); -webkit-transform: translate(-50%, -50%); transform: translate(-50%, -50%); overflow: auto; -webkit-transition: top .3s ease-in-out; transition: top .3s ease-in-out; }
.modal.on .modal-inner { top: 50%; }
.modalClose { cursor: pointer; text-decoration: none; top: 0; right: 0; width: 36px; height: 36px; line-height: 36px; color: #fff; background: #8EAF9B; overflow: hidden; position: absolute; text-align: center; z-index: 1; }
.modalClose:after { line-height: 40px; font-size: 20px; text-align: center; }
.modal-content p:last-child { margin-bottom: 5px; }
.modal-content video { width: 100%; display: block; }
.modal .youtube-container { margin: 0; }
.modal--video .modal-inner { padding: 15px; }

.video-container { position: relative; margin: 30px 0; padding-bottom: 56.25%; height: 0; overflow: hidden; max-width: 100%; }
.video-container iframe, .video-container object, .video-container embed { position: absolute; top: 0; left: 0; width: 100%; height: 100%; }
.video-container:first-child { margin-top: 0; }
.video-container:last-child { margin-bottom: 15px; }
.modal .video-container:last-child { margin-bottom: 0; }

@media screen and (max-width: 600px) {
    .modal--video .modal-inner { padding: 10px; overflow: visible; }

    .modalClose { width: 30px; height: 30px; line-height: 30px; top: -30px; }
    .modalClose:before { font-size: 16px; }
}

@media screen and (max-width: 480px) {
    .modal--video .modal-inner { padding: 6px; overflow: visible; width: 94%; }
    .modalClose { width: 28px; height: 28px; line-height: 28px; top: -28px; }
    .modalClose:before { font-size: 14px; }
}

/* = Footer
----------------------------------------------------------------------------------------------------------------- */
footer { padding: 85px 0 60px; color: #fff; background: #3F2A56; position: relative; z-index: 5; }
footer a { color: #fff; }
footer .icon--social { display: inline-block; vertical-align: middle; margin-right: 18px; text-align: center; width: 40px; height: 40px; line-height: 40px; border-radius: 50%; background: #D50032; }
footer a:not([class]):hover { color: #fff; text-decoration: underline; }

.btn--footer { margin-left: 20px; padding: 10px 18px; vertical-align: middle; }
.btn--footer:first-child { margin-left: 0; }

.ftr-connect { float: left; }
.ftr-logos { margin-top: -22px; float: right; text-align: right; }
.ftr-logos img { margin-left: 35px; display: inline-block; vertical-align: middle; }
.ftr-logos img:first-child { margin-left: 0; }
.ftr-text { padding-top: 30px; margin-top: 50px; font-size: 14px; border-top: 1px solid #645477; }
.ftr-text a { text-decoration: underline; }
.ftr-links { margin-right: 80px; }
.ftr-links a:not(:last-child) { padding-right: 12px; margin-right: 8px; border-right: 1px solid #eee; }

.nojavascript {position: fixed; bottom:0; left: 0; width: 100%; padding:12px; text-align: center; color:#fff; background: #d50032; z-index: 20;}

@media screen and (min-width: 1201px) {
    .ftr-text { margin-top: 80px; }
    .ftr-logos { margin: 0; }
    .ftr-logos img { margin: 0; }
    .ftr-logo-cht { position: absolute; top: -20px; margin: 0; left: calc(50% - 45px); }
}

@media screen and (max-width: 850px) {
    footer { padding: 60px 0; }

    .ftr-connect { float: none; }
    .ftr-logos { float: none; margin: 40px 0; text-align: center; }
    .ftr-text { margin: 0; }

    .btn--footer { float: right; margin: 0; }
}

@media screen and (max-width: 600px) {
    .ftr-logos { display: flex; justify-content: space-between; }
    .ftr-links { margin-right: 20px; }
}

@media screen and (max-width: 480px) {
    .ftr-text { font-size: 13px; }
    .ftr-logo-uoc { width: 200px; }
}

@media screen and (max-width: 400px) {
    footer { padding: 50px 0; }
    .ftr-text { font-size: 12px; }
    .ftr-logos { margin: 35px 0; }
    .ftr-logo-cht { width: 80px; }
    .ftr-logo-uoc { width: 170px; }
    footer .icon--social { margin-right: 16px; width: 38px; height: 38px; line-height: 38px; }
    .btn--footer { font-size: 14px; padding: 10px 16px; }
    .btn--footer .icon { vertical-align: top; font-size: .85em; }
}

@media screen and (max-width: 360px) {
    .ftr-text { font-size: 11px; }
    .ftr-logo-cht { width: 70px; }
    .ftr-logo-uoc { width: 160px; }
}

@media screen and (max-width: 340px) {
    footer { padding: 45px 0; }
    footer .icon--social { margin-right: 14px; width: 36px; height: 36px; line-height: 36px; }
    .btn--footer { font-size: 13px; padding: 9px 14px; }
    .ftr-links { margin-right: 10px; }
    .ftr-links a:not(:last-child) { padding-right: 9px; margin-right: 6px; }
}

/* = Page loader and animations
----------------------------------------------------------------------------------------------------------------- */
.content-wrap { background: #fff; }
.page-loader { width: 60px; height: 60px; display: inline-block; position: fixed; left: calc(50% - 30px); top: calc(50% - 30px); z-index: -1; }

.transition-fade { transition: opacity 0.3s; opacity: 1; }
html.is-animating .transition-fade { opacity: 0; }

.transition-intop { transition: opacity 0.5s, transform 0.6s; opacity: 1; transform: translateY(0); }
html.is-animating .transition-intop { opacity: 0; transform: translateY(-50px); }
html.is-leaving .transition-intop { opacity: 0; }

.transition-inbottom { transition: opacity 0.5s, transform 0.6s; opacity: 1; transform: translateY(0); }
html.is-animating .transition-inbottom { opacity: 0; transform: translateY(50px); }
html.is-leaving .transition-inbottom { opacity: 0; }

.transition-left { transition: opacity 0.5s, transform 0.6s; opacity: 1; transform: translateX(0); }
html.is-animating .transition-left { opacity: 0; transform: translateX(-50px); }
html.is-leaving .transition-left { opacity: 0; transform: translateX(0); }

.transition-right { transition: opacity 0.5s, transform 0.6s; opacity: 1; transform: translateX(0); }
html.is-animating .transition-right { opacity: 0; transform: translateX(50px); }
html.is-leaving .transition-right { opacity: 0; transform: translateX(0); }

.transition-zoomin { transition: opacity 0.5s, transform 0.6s; opacity: 1; transform: scale(1); }
html.is-animating .transition-zoomin { opacity: 0; transform: scale(0.7); }
html.is-leaving .transition-zoomin { opacity: 0; transform: scale(0.7); }

.transition-zoomin-small { transition: opacity 0.5s, transform 0.6s; opacity: 1; transform: scale(1); }
html.is-animating .transition-zoomin-small { opacity: 0; transform: scale(0.9); }
html.is-leaving .transition-zoomin-small { opacity: 0; transform: scale(0.9); }

@media screen and (min-width: 981px) {
    html.is-changing .delay-1 { transition-delay: 0.25s; }
    html.is-changing .delay-2 { transition-delay: 0.5s; }
    html.is-changing .delay-3 { transition-delay: 0.75s; }
    html.is-changing .delay-4 { transition-delay: 1s; }
    html.is-changing .delay-5 { transition-delay: 1.25s; }

    html.is-changing .delay-small-1 { transition-delay: 0.15s; }
    html.is-changing .delay-small-2 { transition-delay: 0.3s; }
    html.is-changing .delay-small-3 { transition-delay: 0.45s; }
    html.is-changing .delay-small-4 { transition-delay: 0.6s; }
}

@media screen and (min-width: 1401px) {
    .page-loader { width: 70px; height: 70px; left: calc(50% - 35px); top: calc(50% - 35px); }
}

@media screen and (min-width: 1601px) {
    .page-loader { width: 80px; height: 80px; left: calc(50% - 40px); top: calc(50% - 40px); }
}

@media screen and (max-width: 980px) {
    html.is-animating .transition-intop-mobile { transform: translateY(-50px); }
}