*{
  margin: 0;
  padding: 0;
  box-sizing:border-box;
}

body{
  font-family: sofia-pro, sans-serif;
  font-weight: 300; /* 300,400,500,700 */
  font-size: 18px;
  line-height: 30px;
  color:#0F3B47;
}

img{
  border: 0;
  max-width:100%;
}

a{
  color:#0F3B47;
  text-decoration: none;
  cursor:pointer;
  transition:.7s color, .7s background-color;
}
a:focus{
  outline: none;
}
a:hover{
  transition:.3s color, .3s background-color;
}

h2,h3{
  color:#EDBFCF;
  font-weight: 700;
  font-size: 30px;
  line-height: 35px;
  margin-bottom: 30px;
}
h3{
  margin-top: 60px;
}

body.insights h2, body.insights h3{
  color:#00B79E;
}
body.services h2, body.services h3{
  color:#F2594D;
}
body.how-it-works h2, body.how-it-works h3{
  color:#294094;
}
body.contact h2, body.contact h3{
  color:#F2D112;
}


p{
  margin-bottom: 30px;
}

ul, ol{
  margin: 0 0 15px 30px;
}


.nav{
  display:inline;
  list-style-type:none;
  margin:0;
  position:absolute;
  top:0;
  right:0;
}
.nav li{
  display:block;
  float:left;
  width:10vw;
  position:relative;
}
.nav a{
  display:block;
  width:100%;
  height:10vw;
  background-color:#0F3B47;
  text-align:center;
  font-weight: 500;
  color:#FFF;
  text-transform:uppercase;
  font-size: 20px;
  line-height: 25px;
  position:relative;
  z-index:3;
}
.nav a span{
  display:block;
  position: relative;
  top: 50%;
  transform: translateY(-50%);
}

.nav li.about a:hover, .nav li.about a.current{
  background-color:#EDBFCF;
}
.nav li.insights a:hover, .nav li.insights a.current{
  background-color:#00B79E;
}
.nav li.services a:hover, .nav li.services a.current{
  background-color:#F2594D;
}
.nav li.services:hover a{
  background-color:#F2594D;
}
.nav li.works a:hover, .nav li.works a.current{
  background-color:#294094;
}
.nav li.contact a:hover, .nav li.contact a.current{
  background-color:#F2D112;
}

.nav li ul{
  position:absolute;
  left:0;
  margin:0;
  top: -500px;
  z-index: 1;
  transition:1s top;
}
.nav li:hover ul{
  top: 10vw;
  transition:.3s top;
}

.nav li ul a{
  display:block;
  width:100%;
  height:auto;
  font-size: 20px;
  line-height: 25px;
  text-transform:none;
  padding: 20px 0;
  border-top: 1px solid #FFF;
  background-color:#F2594D;
  font-weight:400;
}
.nav li ul a.current{
  font-weight:700;
}


.navspace{
  height: 10vw;
}


.home-logo{
  position:absolute;
  width: 17vw;
  left: 3vw;
  top: 3vw;
  z-index: 5;
}

.home-kate{
  position:absolute;
  z-index: 4;
  width: calc(60vw - 17px);
  top: 10vw;
  left:0;
  padding-left: 12.6vw;
}
.home-kate img{
  width:100%;
}

.home{
  margin-left: 50vw;
  background-color:#0F3B47;
  color:#FFF;
  font-size: 1.5vw;
  line-height: 2vw;
  font-weight: 700;
  height: calc(100vh - 12vw);
  padding: 0 10vw 0 15vw;
}
.home .home-content{
  position: relative;
  top: 50%;
  transform: translateY(-50%);
  margin: 0 auto;
}

.home-main{
  max-width: 900px;
  margin: 0 auto;
  padding: 80px 0;
  position:relative;
}
.home-main.short{
  padding-bottom:0;
}

.home-main form{
  margin-right: 150px;
}

blockquote{
  font-weight: 700;
  font-size: 20px;
  line-height: 26px;
  background-image: url('images/watermark.png');
  background-repeat: no-repeat;
  background-size:contain;
  padding: 30px 0;
  margin: 20px 0;
}
blockquote.light{
  background-image: url('images/watermark-light.png');
}


.footer{
  background-color:#0F3B47;
  padding: 50px 10vw;
  color:#FFF;
}
.footer a{
  color:#FFF;
}

.footer .col{
  float:left;
  margin-right: 150px;
}

.footer .social{
  float:right;
}
.footer .social img{
  width: 50px;
  margin-left: 15px;
}

.clear{ clear:both; }


.logo{
  position:absolute;
  height: 8vw;
  left: 10vw;
  top: 1vw;
  z-index: 5;
}

.margin{
  padding: 0 10vw 0 20vw;
}
.main{
  margin: 0 auto;
}
.main .content{
  width: 60%;
  float:left;
  padding: 80px 0 0 0;
  padding-right: 50px;
}
.main .side{
  float:left;
  width: 40%;
  padding-top: 150px;
}
.main .side img{
  display:block;
}

.memberships{
  position:relative;
  left: 10vw;
}


.servicebuttons{
  background-color:#0F3B47;
  padding: 50px 10vw;
  color:#FFF;
  border-bottom: 2px solid #FFF;
  margin-top: 200px;
  text-align:center;
}
.servicebuttons a{
  display:block;
  float:left;
  width: 25%;
  box-sizing:border-box;
  padding: 0 10px;
  color:#FFF;
  position:relative;
  margin-bottom: 15px;
  transition: .7s margin-top, .7s margin-bottom;
}
.servicebuttons a img{
  display:block;
  margin: 0 auto;
  margin-bottom: 15px;
}

.servicebuttons a:nth-child(1){
  top: -240px;
}
.servicebuttons a:nth-child(2){
  top: -160px;
}
.servicebuttons a:nth-child(3){
  top: -80px;
}
.servicebuttons a:nth-child(4){
  margin-right:0;
}

.servicebuttons a:hover{
  margin-top: 15px;
  margin-bottom: 0;
  transition: .3s margin-top, .3s margin-bottom;
}
.servicebuttons a.current{
  opacity: .6;
}

.phases{
  background-color:#0F3B47;
  padding: 50px 10vw;
  color:#FFF;
  border-bottom: 2px solid #FFF;
  margin-top: 100px;
}
.phases .phasecontainer{
  margin: 0 auto;
  max-width: 1200px;
  display:flex;
}
.phases .phase{
  display:block;
  width: 30%;
  margin-right:5%;
  margin-top: -180px;
}
.phases .phase:nth-child(3){
  margin-right:0;
}
.phases .phase img{
  display:block;
}
.phases .phase .pad{
  border:1px solid #FFF;
  border-top:0;
  padding: 20px;
}
.phases .phase .pad ol{
  margin-left:20px;
  margin-bottom: 20px;
}
.phases .phase .pad ol li{
  margin-bottom: 10px;
}
.phases .phase .pad p:last-child{
  border-top: 1px solid #FFF;
  margin-top: 30px;
  padding-top: 30px;
}


.contactpage{
  min-height: 70vh;
  position:relative;
}
.contactbox{
  position:absolute;
  bottom:50px;
  right:0;
  background-color:#F2D112;
  padding: 1vw 2vw;
  color:#0F3B47;
  z-index:9;
}
body.contact .contactbox h2{
  color:#0F3B47;
}

.contactbox .contactimg img{
  margin: 0 auto;
  display:block;
  max-width: 5vw;
}
.contactbox p{
  margin-bottom: 20px;
}


.label{
  margin-top: 40px;
}

.input, .textarea{
  width: 100%;
  border:0;
  border-bottom: 2px solid #0F3B47;
  padding: 15px;
  font-family:arial;
  font-size: 16px;
  transition:.7s border-bottom, .7s background-color, .3s height;
  outline:none;
}
.input:focus, .textarea:focus{
  border-bottom: 10px solid #0F3B47;
  transition:.3s border-bottom, .3s background-color, .3s height;
  background-color: #F7E1E9;
}
.textarea{
  height: 200px;
  transition: .3s height;
}
.textarea:invalid{
  height: 40px;
}
.button{
  background-color: #0F3B47;
  border:0;
  padding: 15px 40px;
  color:#FFF;
  font-family: sofia-pro, sans-serif;
  font-weight:500;
  font-size: 20px;
  cursor:pointer;
  transition:.7s background-color;
}
.button:hover{
  transition:.3s background-color;
  background-color:#F2D112;
}


.articles{
  display:flex;
  flex-wrap:wrap;
  max-width: 1200px;
  margin: 0 auto;
}
.articles a{
  display:block;
  width: 32%;
  margin-bottom: 25px;
  background-color: #0F3B47;
  background-position:center center;
  background-repeat: no-repeat;
  background-size:cover;
  position:relative;
}
.articles a:after {
  content: "";
  display: block;
  padding-bottom: 100%;
}
.articles a:nth-child(3n+2){
  margin-left: 2%;
  margin-right: 2%;
}
.articles a .colour{
  display:block;
  position:absolute;
  z-index: 1;
  left: 10%;
  top: 10%;
  width: 80%;
  height: 80%;
  background-color:rgba(0,0,0,.6);
  overflow:hidden;
  transition: .7s left, .7s top, .7s width, .7s height;
}

.articles a .colour.colourpink{ background-color: rgba(237,191,207,.6); }
.articles a .colour.colourgreen{ background-color: rgba(0,183,158,.6); }
.articles a .colour.colourred{ background-color: rgba(242,89,77,.6); }
.articles a .colour.colourpurple{ background-color: rgba(41,64,148,.6); }
.articles a .colour.colouryellow{ background-color: rgba(242,209,18,.6); }


.articles a .colour .title{
  display:block;
  position: relative;
  top: 50%;
  transform: translateY(-50%);
  text-align:center;
  color:#FFF;
  font-weight: 600;
  font-size: 24px;
  width: 80%;
  margin: 0 auto;
  transition: .7s width;
}

.articles a:hover .colour{
  left: 0%;
  top: 0%;
  width: 100%;
  height: 100%;
  transition: .3s left, .3s top, .3s width, .3s height;
}
.articles a:hover .colour .title{
  width: 64%;
  transition: .3s width;
}


.articleheader.pink{ background-color: rgba(237,191,207,1); }
.articleheader.green{ background-color: rgba(0,183,158,1); }
.articleheader.red{ background-color: rgba(242,89,77,1); }
.articleheader.purple{ background-color: rgba(41,64,148,1); }
.articleheader.yellow{ background-color: rgba(242,209,18,1); }

.articleheader .articleheader-container{
  margin: 50px auto 0 auto;
  max-width: 1500px;
  height: 50vh;
  max-height: 550px;
}
.articleheader .articleheader-container .articleheader-image{
  height: 100%;
  width: 60%;
  float:left;
  background-size:cover;
  background-position:center center;
  background-repeat: no-repeat;
}

.articleheader .articleheader-container .articleheader-title{
  position: relative;
  top: 50%;
  transform: translateY(-50%);
  margin-left: 65%;
}
.articleheader .articleheader-container .articleheader-title h2{
  font-size: 2vw;
  line-height: 2.2vw;
}

.articleheader .articleheader-container h2{
  color:#0F3B47;
}



.articlebuttons{
  background-color:#0F3B47;
  padding: 50px 10vw;
  color:#FFF;
  border-bottom: 2px solid #FFF;
  margin-top: 200px;
}

.articlebuttons .articles{
  margin-top: -150px;
}

.filters{
  background-color:#0F3B47;
  padding: 60px 0;
  text-align:center;
  margin: 60px 0;
}
.filters img{
  width: 50px;
  display:block;
  margin: 0 auto;
}
.filters a{
  display:inline-block;
  color:#FFF;
  margin: 0 15px;
}
.filters a img{
  opacity:0;
  transition:.3s opacity;
  width: 30px;
}
.filters a:hover img{
  opacity: .2;
  transition:.3s opacity;
}
.filters a.current img{
  opacity:1;
}

.space{
  height: 60px;
}
.desktopgone{
  display:none !important;
}


.video-container {
position: relative;
padding-bottom: 56.25%;
padding-top: 30px; height: 0; overflow: hidden;
margin-bottom: 50px;
}

.video-container iframe,
.video-container object,
.video-container embed {
position: absolute;
top: 0;
left: 0;
width: 100%;
height: 100%;
}


.memberships{
  background-color:#00B79E;
  color:#000;
  padding: 40px;
}
.memberships h3{
  color:#000;
  margin-top:0;
}


.connect{
  display:block;
  background-color: #F2D112;
  color: #0F3B47;
  text-align:center;
  padding: 25px; 
  font-weight:600;
}
.connect h3{
  color: #0F3B47 !important;
  margin:0;
}

.pdf{
  display:block;
  margin-top: 40px; 
  background-color:#0F3B47;
  padding: 20px;
  text-align:center;
  color:#FFF;  
  border-radius: 10px; 
}
.pdf img{
  width: 30px; 
  vertical-align: top;
}
.pdf:hover{
  background-color:rgba(237,191,207,1);
  transition:.3s background-color; 
} 