/* ===================================================================
 *  08. common and reusable styles 
 *
 * ------------------------------------------------------------------- */
.skip-link {
    width: 0px;
    display: block;
    height: 0px;
}
html {
    overflow-x: hidden;
}
em {
    font-style: italic !important;
}
.section-intro {
  text-align: center;
  position: relative;
  margin-bottom: 1.5rem;
}
.section-intro h1 {
  font-family: "georgia", serif;
  font-size: 56px;
  line-height: 1.1;
 margin-bottom: 40px;
}
.section-intro h3 {
  font-family: "FuturaMedium", sans-serif;
  font-size: 21px !important;
  line-height: 1.667;
  color:white;
  text-transform: uppercase;
  letter-spacing: .3rem;
  margin-bottom: 1.2rem;
}
.section-intro .lead {
  font-family: "FuturaMedium", sans-serif;
  font-size: 1.8;
  line-height: 1.833;
}
.section-intro.with-bottom-sep {
  padding-bottom: 4.2rem;
  position: relative;
}
.section-intro.with-bottom-sep::after {
  display: inline-block;
  height: 1px;
  width: 200px;
  background-color: rgba(242, 242, 242, 0.1);
  text-align: center;
}


.datasetrenderer {
    height: 100vh;
}

.animated.fast {
  -webkit-animation-duration: 800ms;
  animation-duration: 800ms;
}

.animated.faster {
  -webkit-animation-duration: 500ms;
  animation-duration: 500ms;
}

.animated.slow {
  -webkit-animation-duration: 2s;
  animation-duration: 2s;
}

.animated.slower {
  -webkit-animation-duration: 3s;
  animation-duration: 3s;
}


.container {
    position: relative;
    max-width: 40000px;
}



/* turn off parallax sections on touch devices */
.touch section {
    background-attachment: scroll !important;
}


/* cute little divider */
.icon {
    padding: 50px 0 37px 0;
    display: block;
}
.icon--divider {
    height: 27px !important;
    display: block;
    margin: 0 auto;
    width: 100%;
    fill: #2babe2;
}


/* ===================================================================
 *  MENU
==================================================================*/
header {
    z-index: 10000000;
}
.header-menu-text {
    width: 92px !important;
    left: -84px !important;
    font-size: 15px;
    padding: 0;
    font-family: FuturaMedium;
}
#header-menu-trigger {
    right: 10px;
    top: 10px;
}
#header-menu-trigger.opaque {
    background-color: #2babe2;
}
#header-menu-trigger.opaque::before {
    width: 100vw;
    height: 62px;
    content: "";
    position: absolute;
    right: -10px;
    top: -10px;
    XXbackground: #2babe2;
}
#header-menu-trigger.opaque .header-menu-text {
    background-color: #2babe2;
}
.nav-list {
    margin-top: 15px !important;
}
nav img {
    width: 55px;
}
#menu-nav-wrap .header-social-list li a {
    color: white;
}
#menu-nav-wrap .nav-list li {
    padding: 15px 0 15px 0px;
    border-bottom: 1px solid rgb(68, 68, 68);
}
#menu-nav-wrap .nav-list li a {
    color: white;
    font-family: FuturaLight;
    line-height: 1;
}


/* ===================================================================
 *  HOME
==================================================================*/

.print {
    display: inline-block;
    background: rgba(0,0,0,0.3);
    width: auto;
    padding: 12px;
    font-family: FuturaMedium;
    z-index: 10000;
    position: absolute;
}
.print a {
    color: white;
    background: none;
}



#home::before {
    content: '';
    position: absolute;
    bottom: -1px;
    left: 0;
    right: 0;
    z-index: 3;
    height: 8vw;
    pointer-events: none;
    background: url(https://svgshare.com/i/9kZ.svg) center top no-repeat;
    background-size: 100% 100%;
}
#home::after {
    background-image: url('https://i.imgur.com/Y93aD12.png');
    width: 100%;
    height: 100%;
    background-repeat: repeat;
    content: "";
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    background-size: 50px;
    opacity: 0.2;
}
#home {
  width: 100%;
  height: calc(100vh + 8vw);
  XXbackground-color: #151515;
  XXbackground-image: url("https://i.imgur.com/cMJEFOT.jpg");
  XXbackground-repeat: no-repeat;
  XXbackground-position: center 30%;
  XX-webkit-background-size: cover;
  XX-moz-background-size: cover;
  XXbackground-size: cover;
  XXbackground-attachment: fixed;
  min-height: 804px;
  position: relative;
}
#myVideo {
    position: fixed;
    left: 0;
    bottom: 0;
    min-width: 100vw;
    min-height: 100vh;
    max-width: 1000vw;
    z-index: -1;
}




#home {
    height: 100vh;
}
#home::after {
    background: black;
    width: 100%;
    height: 100%;
    background-repeat: repeat;
    content: "";
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    background-size: 50px;
    opacity: 0.3;
}
#home > img {
    position: fixed;
    left: 0;
    bottom: 0;
    min-width: 100vw;
    min-height: 100vh;
    max-width: 1000vw;
    z-index: -1;
}
#home {
    background: rgba(0, 0, 0, 0) url("/~/media/7155E71A6A1B4C5C9573C57CDFC89072.ashx?la=en") no-repeat scroll center 0 / auto 100%;
    background-attachment: fixed;
    background-position: center;
    background-repeat: no-repeat;
    background-size: cover;
}





.home-content-table {
    z-index:100;
}
.home-social-list::before {
    display: none;
}


.home-social-list {
    z-index: 10000;
    bottom: 117px;
    left: 0;
    width: 100vw;
    padding-left: 5%;
}
.home-social-list li {
    float: left;
    width: 18%;
}
.home-social-list img {
    width: 41px;
    margin: 9px -16px 9px 0px;
}
.home-social-list li a:hover, .home-social-list li a:focus, .home-social-list li a:active {
    color: white;
}

.home-content-table h3 {
    font-family: "futuramedium",sans-serif;
    font-size: 23px !important;
    letter-spacing: 2px;
    text-align: center;
    text-shadow: 1px 1px 4px black;
}
.home-content-tablecell h1 {
    font-family: "futurabold",serif;
    text-shadow: 1px 1px 4px black;
}
.home-content-tablecell .more .button {
    font-size: 16px;
    height: 50px;
    line-height: 50px;
    text-shadow: 1px 1px 4px black;
}



/* move home stuff on on short devices (i.e., mobile) */
@media (max-height: 800px){
.home-content-tablecell .row {
    margin-top: -150px;
}
.home-social-list {
    bottom: 26vh;
}
}

.playpause {
    top: 95vh;
    position: absolute;
    z-index: 10000000;
    width: 100vw;
    text-align: center;
}
.fa-pause-circle {
    color: white;
    font-size: 27px;
    cursor: pointer;
}
.playpause.toggle {
    border: none;
    height: auto;
    line-height: 1;
    margin: 0;
}
.playpause.toggle .fa-pause-circle::before {
    content: "\f144";
}

/* ===================================================================
 *  MESSAGE
==================================================================*/
#message {
  position: relative;
  padding: 30px 0;
  background-color: #FFFFFF;
  min-height: 696px;
  text-align: center;
    padding: 30px 0 106px 0;
}
#message span {
  color: #2babe2;
}
#message .animate-this {
animation-duration: 5s;
}

#message h3 {
  font-family: "FuturaMedium", sans-serif;
  font-size: 1.8rem;
  line-height: 1.667;
  color: #252525;
  text-transform: uppercase;
  letter-spacing: .3rem;
  position: relative;
    padding: 35px 0;
}
#message p {
    font-family: "georgia", serif;
    font-size: 17px;
    line-height: 1.8;
    color: #2e383f;
    margin: 22px auto;
    text-align: left;
}
#sig {
    width: 200px;
    display: block;
    margin-bottom: -13px;
}
.toggle {
    font-size: 16px;
    height: 50px;
    line-height: 46px;
    font-family: FuturaMedium;
    text-transform: uppercase;
    letter-spacing: 4px;
    border: 3px solid #2babe2;
    padding: 0px 40px 0px 40px;
    color: #2babe2 !important;
    display: inline-block;
    margin-top: 27px;
}

#head {
    max-width: 204px;
}

.quote p {
    display: block;
    font-style: italic !important;
    font-size: 26px !important;
    text-align: center !important;
    font-weight: bold !important;
    width: 70%;
}
.quote p::before, .quote p::after {
    content: '“';
    font-style: italic;
    color: #2babe2;
    font-size: 69px;
    line-height: 0;
    vertical-align: -19px;
    margin-right: 6px;
}
.quote p::after {
    content: '”';
    margin-left: 6px;
    vertical-align: -22px;
}

/* ===================================================================
 *  timeline
==================================================================*/
#timeline {
    XXbackground: url("https://www.transparenttextures.com/patterns/maze-black.png"), linear-gradient(#191919, #191919);
    background: url("https://i.imgur.com/IVu1hQ9.png"), linear-gradient(#191919, #191919);
  min-height: 800px;
  position: relative;
  padding: 100px 0 0px;
  color: rgba(255, 255, 255, 0.3);
    overflow: hidden;
}
#timeline::before {
    content: "";
    background: url("https://i.imgur.com/bcKsJuC.png");
    width: 100%;
    height: 61vw;
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    transform: rotate(180deg);
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center center;
    opacity: 0.3;
}
#how-it-works {
    padding-bottom: 0;
    padding-top: 50px;
}
#timeline h3 {
    font-family: FuturaMedium;
    color: white;
}
#timeline h1 {
  color: #FFFFFF;
}
#timeline .col-6{
  text-align: center;
  max-width: 1040px;
  margin-bottom: 3rem;
  padding: 0 50px;
}

#timeline p {
    color: #dedede;
    font-family: futuralight;
    font-size: 19px;
    line-height: 1.2;
}


.timeline__text li {
    background: #2babe2;
    padding-top: 0px;
}
.timeline__text a:hover h3, .timeline__text a:hover p {
    color: #2babe2 !important;
}
.timeline__text li::after {
    content: '';
    position: absolute;
    left: 50%;
    bottom: 54%;
    transform: translateX(-50%);
    width: 12px;
    height: 12px;
    border-radius: 50%;
    background: inherit;
}
.timeline__text li div {
    width: 153px;
}

.timeline__text li:last-of-type {
    padding-bottom: 100px;
    margin-top: -100px;
}
.timeline__text li:last-of-type div {
    padding-top: 93px;
}

.last-bullet {
    display: none;
}
.col-sm-8.col-sm-offset-2 {
    margin-left: auto;
    margin-right: auto !important;
    float: none;
    margin-bottom: 20px;
}

/* ====================== FACTS ====================== */

#facts h1 {
    color: white;
}
#facts .intro {
    background: url("https://i.imgur.com/IVu1hQ9.png"), linear-gradient(#191919, #191919);
    text-align: center;
    padding-bottom: 50px;
}
#facts {
    background: url(~/media/B022436D3BA641B5BB0B06EEC81AFA0E) top, center #fff;
    background-position: center bottom;
    background-size: cover;
    margin-top: -1px;
}
.brick {
    background: white;
    width: 90%;
    margin: 27px auto;
}
.bricks-wrapper {
    margin-top: -116px;
    padding-bottom: 50px;
}
#facts h2 {
    font-family: "FuturaMedium", sans-serif;
    letter-spacing: 1px;
    margin-bottom: 1.2rem;
    text-align: center;
    z-index: 100000;
    position: relative;
    font-size: 19px;
    padding: 15px;
    line-height: 1.2;
    color: #262626;
    word-wrap: normal;
}
#facts h2 span {
    display: block;
    font-size: 74px;
    font-family: Georgia;
    letter-spacing: 0;
    margin-bottom: 20px;
}
#facts .brick-3 h2 span::after {
    content: "%";
}
XX#facts h2::after {
    XXbackground: url("https://i.imgur.com/OVZOSla.png");
    XXbackground-position-x: 0%;
    XXbackground-position-y: 0%;
    XXbackground-repeat: repeat;
    XXheight: 20px;
    content: "";
    position: relative;
    display: block;
    XXbackground-repeat: no-repeat;
    XXbackground-position: center center;
   XXmargin: 22px 0 29px 0;
    height: 1px;
    background: #c6c6c6;
    width: 100px;
    margin: 33px auto 6px auto;
}

/* ======================SECTION INTROS====================== */
.intro-panel {
    width: 100%;
    XXXheight: 112vw;
    position: relative;
    overflow: visible;
    background: white;
    z-index: 0;
}
.intro-panel .container {
    width: 100%;
    height: 100%;
    XXXdisplay: table;
    display: block;
    position: relative;
    text-align: center;
}
.intro-panel .container .row {
    XXXdisplay: table-cell;
    z-index: 500;
}
.intro-panel .col-12.animate-this {
    margin: 48px auto 70px auto;
    width: 100%;
}
.intro-panel h1 {
    font-family: FuturaMedium;
    color: #151515;
    line-height: 1.667;
    letter-spacing: .3rem;
    text-transform: uppercase;
}
.intro-panel h1 span {
    color: #151515;
    font-family: "georgia", serif;
    font-size: 4.8rem;
    line-height: 1.1;
    margin-bottom: 40px;
    text-transform: none;
    letter-spacing: 0;
    display: block;
    font-size: 51px;
}
.intro-panel p {
    color: white;
    font-family: futura;
    font-size: 16px;
    line-height: 1.5;
    letter-spacing: 2px;
    margin-top: 100px;
    font-weight: bold;
}

.intro-panel img {
    bottom: 0;
    left: 0;
    width: 100%;
    z-index: 1000;
}

/* ======================STORIES====================== */
.stories .container {
    z-index: 10;
}
.desc {
    background: white;
    margin-top: -50px !important;
    position: relative;
    display: block;
    font-style: italic;
    font-size: 23px;
    text-align: center;
    line-height: 1.5;
    padding: 51px 30px 30px;
    color: black;
    max-width: 400px;
    margin-left: auto !important;
    margin-right: auto !important;
    float: none !important;
}
.desc::before {
    height: 19px;
    width: 100%;
    top: 0px;
    content: "";
    position: absolute;
    display: block;
    left: 0;
    background: #2babe2;
    left: 0;

}
.stories {
    XXz-index: 10000000;
    position: relative;
    background: white;
}
.container.other {
    background: rgba(0, 0, 0, 0) linear-gradient(to top left, rgb(0, 0, 70), rgb(43,171,226)) repeat scroll 0% 0%;
    margin: 0;
    width: 100vw;
    padding: 40px 15px 0 15px;
}
.container.other::before {
    content: '';
    position: absolute;
    top: -1px;
    left: 0;
    right: 0;
    z-index: 3;
    height: 8vw;
    pointer-events: none;
    XXXbackground: url(https://svgshare.com/i/9kZ.svg) center top no-repeat;
    background-size: 100% 100%;
    transform: rotate(180deg);
}
.row.one {
    padding: 0px 0 50px 0;
}
.story {
    z-index: 10000;
}
.story h2 {
    font-family: FuturaMedium;
    font-size: 22px;
    text-align: center;
    color: white;
    margin: 0px 0 0 0;
    position: relative;
    letter-spacing: 0;
    line-height: 1.3;
    transition: all .2s;
}
.story::after {
    XXbackground: url("/~/media/images/eng-V3/img/brush-stroke.png");
    XXheight: 20px;
    content: "";
    position: relative;
    display: block;
    XXbackground-repeat: no-repeat;
    XXbackground-position: center center;
    XXmargin: 22px 0 29px 0;
    height: 1px;
    background: rgba(255,255,255,0.5);
    width: 100px;
    margin: 40px auto 6px auto;
}
.story h2:hover {
    transform: translateY(-2px);
}
.dots {
    background: url("https://i.imgur.com/hW2LVGv.png");
    width: 100%;
    height: 400px !important;
    position: absolute;
    bottom: 0;
    left: 0;
    mix-blend-mode: overlay;
    z-index: -1;
    background-size: cover;
    background-repeat: no-repeat;
}
.turn-word {
    display: none;
}


/* ======================FEATURED STORIES BLOCK====================== */
.feature {
    overflow: hidden;
}
.feature .grid {
    overflow: hidden;
}
/* Common style */
.grid figure {
    position: relative;
    overflow: hidden;
    width: 100%;
    background: #3085a3;
    text-align: center;
    cursor: pointer;
    margin: 25px 0;
}
.grid figure img {
	position: relative;
	display: block;
	min-height: 100%;
	max-width: 100%;
	opacity: 1;
       min-width: 100%;
}
.grid figure figcaption {
	padding: 0;
	color: #fff;
	text-transform: uppercase;
	font-size: 1.25em;
	-webkit-backface-visibility: hidden;
	backface-visibility: hidden;
}
.grid figure figcaption::before,
.grid figure figcaption::after {
	pointer-events: none;
}
.grid figure figcaption,
.grid figure figcaption > a {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
}
/* Anchor will cover the whole item by default */
/* For some effects it will show as a button */
.grid figure figcaption > a {
	z-index: 1000;
	text-indent: 200%;
	white-space: nowrap;
	font-size: 0;
	opacity: 0;
}
figure.effect-zoe figcaption {
	top: auto;
	bottom: 0;
	height: 96px;
	background: #2babe2;
	color: #3c4a50;
	-webkit-transition: -webkit-transform 0.35s;
	transition: transform 0.35s;
	XX-webkit-transform: translate3d(0,100%,0);
	XXtransform: translate3d(0,100%,0);
           background-image: url(https://i.imgur.com/b06XIGo.png);
        background-size: cover;
       display: table;
}
figure.effect-zoe h2 {
    font-family: FuturaMedium;
    color: white;
    text-transform: none;
    font-size: 22px;
    letter-spacing: 0px;
    padding: 5px;
    display: table-cell !important;
    vertical-align: middle;
}
figure.effect-zoe p.icon-links a {
	float: right;
	color: #3c4a50;
	font-size: 1.4em;
}

figure.effect-zoe:hover p.icon-links a:hover,
figure.effect-zoe:hover p.icon-links a:focus {
	color: #252d31;
}
figure.effect-zoe h2,
figure.effect-zoe p.icon-links a {
	-webkit-transition: -webkit-transform 0.35s;
	transition: transform 0.35s;
	XX-webkit-transform: translate3d(0,200%,0);
	XXtransform: translate3d(0,200%,0);
}
figure.effect-zoe p.icon-links a span::before {
	display: inline-block;
	padding: 8px 10px;
	font-family: 'feathericons';
	speak: none;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}




/* ======================learning====================== */
#learning-stories .container.other {
    background: rgba(0, 0, 0, 0) linear-gradient(to top left, rgb(192, 61, 171), rgb(56, 65, 171)) repeat scroll 0% 0%;
}
#learning-stories .desc::before, #learning-stories figure.effect-zoe figcaption {
    background-color: rgb(113, 89, 195);
}


/* ======================research====================== */
#research-stories .container.other {
    background: rgba(0, 0, 0, 0) linear-gradient(to top left, rgb(0, 171, 244), rgb(9, 66, 219)) repeat scroll 0% 0%;
}
#research-stories .desc::before, #research-stories figure.effect-zoe figcaption {
    background-color: rgb(0, 172, 245);
}

/* ======================experience====================== */
#experience-stories .container.other {
    background: rgba(0, 0, 0, 0) linear-gradient(to top left, rgb(255, 187, 0), rgb(246, 129, 14)) repeat scroll 0% 0%;
}
#experience-stories .desc::before, #experience-stories figure.effect-zoe figcaption {
    background-color: rgb(242, 145, 20);
}



/* ======================engagement====================== */
#engagement-stories .container.other {
    background:rgba(0, 0, 0, 0) linear-gradient(to top left, rgb(128, 0, 86), rgb(192, 62, 62)) repeat scroll 0% 0%;
}
#engagement-stories .desc::before, #engagement-stories figure.effect-zoe figcaption {
    background-color: rgb(216, 61, 86);
}





/* ======================FINANCES====================== */
.finances {
    position: relative;
}
.finances .container.other  {
    padding-top: 51px !important;
    background: white;
    margin-top: 0px;
    padding-bottom: 100px;
}
#finances-stories::before {
    content: '';
    position: absolute;
    bottom: -8vw;
    left: 0;
    right: 0;
    z-index: 3;
    height: 8vw;
    pointer-events: none;
    background: url(https://svgshare.com/i/9kZ.svg) center top no-repeat;
    background-size: auto;
    background-size: 100% 100%;
    transform: rotate(180deg);
}
.finances h3 {
    font-family: "FuturaMedium", sans-serif;
    font-size: 1.8rem;
    line-height: 1.667;
    color: #252525;
    text-transform: uppercase;
    letter-spacing: .3rem;
    position: relative;
    padding: 35px 0;
}
.finances p {
    font-family: "georgia", serif;
    font-size: 17px;
    line-height: 1.8;
    margin: 22px auto;
    text-align: left;
}
.finances .col-12 {
    z-index: 1000000;
    position: relative;
}
.phil-toggle, .btn {
    font-size: 16px;
    height: 50px;
    line-height: 46px;
    font-family: FuturaMedium;
    text-transform: uppercase;
    letter-spacing: 4px;
    border: 3px solid #2babe2;
    padding: 0px 40px 0px 40px;
    color: #2babe2 !important;
    display: block;
    text-align: center;
    width: 210px;
    margin-left: auto;
    margin-right: auto;
}
.btn {
    width: auto;
    height: auto;
    line-height: 28px;
    padding-top: 10px;
    padding-bottom: 10px;
}


/*---------------------- FOOTER----------------------*/
#footer {
    background: url("https://i.imgur.com/IVu1hQ9.png"), linear-gradient(#191919, #191919);
    min-height: 800px;
    position: relative;
    padding: 130px 0 100px;
    color: white;
    overflow: hidden;
   
}
#footer::before {
    content: "";
    background: url("https://i.imgur.com/bcKsJuC.png");
    width: 100%;
    height: 61vw;
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    transform: rotate(180deg);
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center center;
    opacity: 0.3;
}
#footer h2 {
    font-family: FuturaMedium;
    color: white;
    text-align: center;
    letter-spacing: .3rem;
    text-transform: uppercase;
    margin: 20px 0;
    font-size: 27px;
}
#footer p {
    font-family: "georgia", serif;
    font-size: 17px;
    line-height: 1.8;
    margin: 22px auto;
    text-align: left;
}
#footer strong {
    font-family: FuturaMedium;
    font-size: 23px;
    display: block;
    line-height: 1;
}
#footer a {
    font-weight: bold;
    color: #2babe2;
}
.trustees {
    font-size: 16px;
    line-height: 32px;
    font-family: FuturaMedium;
    text-transform: uppercase;
    letter-spacing: 4px;
    border: 3px solid white;
    padding: 10px 40px 10px 40px;
    color: white !important;
    display: block;
    text-align: center;
    margin-left: auto;
    margin-right: auto;
    font-weight: normal !important;
}
