
/* ---------------------------------------- *
 * Author: 	Catia Gomes                     *
 * ---------------------------------------- */

@font-face {
font-family: 'Avenir Next LT Pro Regular';
font-style: normal;
font-weight: normal;
src: local('Avenir Next LT Pro Regular'), url('/Assets/fonts/AvenirNextLTPro-Regular.woff') format('woff');
}

@font-face {
font-family: 'Avenir Next LT Pro Bold';
font-style: normal;
font-weight: normal;
src: local('Avenir Next LT Pro Bold'), url('/Assets/fonts/AvenirNextLTPro-Bold.woff') format('woff');
}

@font-face {
font-family: 'Avenir Next LT Pro Ultra Light';
font-style: normal;
font-weight: normal;
src: local('Avenir Next LT Pro Ultra Light'), url('/Assets/fonts/AvenirNextLTPro-UltLtCn.woff') format('woff');
}

/* global */
html { font-size: 62.5%; -webkit-overflow-scrolling: touch; -webkit-font-smoothing: antialiased; }
body { font-size: 18px; font-size: 1.8rem; line-height: 26px; line-height: 2.6rem; color: #444444; font-family: 'Source Sans Pro', sans-serif; }

a,
a:visited { color: #19a253; text-decoration: none; -webkit-transition: background 0.2s ease, text-decoration 0.2s ease, color 0.2s ease; -moz-transition: background 0.2s ease, text-decoration 0.2s ease, color 0.2s ease; -o-transition: background 0.2s ease, text-decoration 0.2s ease, color 0.2s ease; transition: background 0.2s ease, text-decoration 0.2s ease, color 0.2s ease; }
a:focus,
a:hover { color: #2ecc71; }
a:hover,
a:active { outline: 0; }
.white-text a { color: #34e57e;  }
.white-text a:hover,
.white-text a:focus { color: #2ecc71; }

ul { list-style: none; }
ul,
ol { padding: 0; margin: 0; }
p { margin: 0; margin-top: 10px; }
p:first-child { margin-top: 0; }

* { -moz-box-sizing: border-box; -webkit-box-sizing: border-box; box-sizing: border-box; outline: none; }

h1, h2, h3, h4 { font-weight: 400; margin: 0;  }
h1 { margin-left: -2px; margin-bottom: 14px; text-transform: uppercase; font-weight: 700; font-size: 75px; font-size: 7.5rem; line-height: 60px; line-height: 6rem; position: relative; }
h1:after { position: absolute; bottom: -14px; bottom: -1.4rem; left: 3px; left: 0.3rem; content: ''; display: block; width: 20px; height: 3px; background: #2ecc71; }
h1 span { font-weight: 300; }
h2 { font-weight: 300; font-size: 28px; font-size: 2.8rem; line-height: 30px; line-height: 3rem; margin-top: 39px; }
h3 { color: #4484ce; margin-bottom: 37px; margin-left: -2px; font-size: 36px; font-size: 3.6rem; line-height: 36px; line-height: 3.6rem; position: relative; }
h3:after { position: absolute; bottom: -14px; bottom: -1.4rem; left: 2px; left: 0.2rem; content: ''; display: block; width: 20px; height: 3px; background: #2ecc71; }
.centered h3:after { margin-left: -10px; left: 50%; }
h4 { color: #4484ce; text-transform: uppercase; font-weight: 700; font-size: 18px; font-size: 1.8rem; line-height: 18px; line-height: 1.8rem; }

#main { float: left; width: 100%; padding-bottom: 180px; }
.wrapper { max-width: 1060px; width: 100%; margin: 0 auto; padding: 0 20px; }

/* buttons */
.btn,
a.btn { display: inline-block; text-decoration: none; cursor: pointer; font-weight: 600; text-transform: uppercase; background: #2ecc71; color: #ffffff; padding: 14px 20px; padding: 1.4rem 2rem; line-height: 1em; -webkit-transition: 0.2s ease; -moz-transition: 0.2s ease; -o-transition: 0.2s ease; transition: 0.2s ease; position: relative; }
.btn:hover,
a.btn:hover { text-decoration: none; background: #19a253; color: #ffffff; }
.btn span { display: block; color: #ffffff; }

ul { margin-top: 5px}
.content ul li { margin-left: 10px; }
.content ul li:before {content: "\00af"; color: #19a253; position: relative; top: 6px; right: 6px; }

/* svg */
svg { position: relative; width: 100%; height: 100%; padding: 2px; }
svg circle,
svg path,
svg rect,
svg polyline,
svg polygon { position: absolute; right: 0; bottom: 0; -webkit-transition: all 0.2s ease; -moz-transition: all 0.2s ease; -ms-transition: all 0.2s ease; -o-transition: all 0.2s ease; transition: all 0.2s ease; }

/* helper classes */
.right { float: right; }
.left { float: left; }
.img-container { overflow: hidden; position: relative; }
.img-container img { width: 100%; height: auto; }
.img-container .overlay { opacity: 0.85; position: absolute; top: 0; left: 0; width: 100%; height: 100%; background: #4484ce; }
.incursion-top { padding-top: 115px; margin-top: -8%; }
.centered { text-align: center; }
.hidden { display: none; }
.clearfix { zoom: 1; }
.clearfix:after,
.clearfix:before { content: ""; display: table; }
.clearfix:after { clear: both; }
.video-container { position: relative; padding-bottom: 56.25%; padding-top: 25px; height: 0; }
.video-container iframe { position: absolute; top: 0; left: 0; width: 100%; height: 100%; }

/* site header */
#header { position: absolute; width: 100%; z-index: 1; background: none; padding: 30px 0; transition: all 0.2s ease; }
#header .logo { width: 75px; height: 50px; display: block; position: relative; bottom: 1px; transition: all 0.2s ease; }
#header .logo svg { float: left; }

/* sticky header */
#header.sticky { position: fixed; background: #2ecc71; padding: 10px 0; z-index: 4; -webkit-box-shadow: 0 2px 5px 0 rgba(68,68,68,0.3); -moz-box-shadow: 0 2px 5px 0 rgba(68,68,68,0.3); box-shadow: 0 2px 5px 0 rgba(68,68,68,0.3); }
#header.sticky .logo { height: 40px; position: static;  }
#header.sticky .logo svg polygon { fill: #ffffff; }

/* navigation */
#nav { margin-top: 5px; }
#nav li { display: inline; margin-left: 26px; font-weight: 600; }
#nav li a,
#nav li span { cursor: pointer; color: #ffffff; padding-bottom: 2px; font-family: 'Avenir Next LT Pro Regular'; font-weight: 400; }
#nav li a:hover,
#nav li span:hover {  border-bottom: 2px solid #ffffff; }
#nav li:first-child { margin-left: 0; }

/* responsive menu */
.menu { width: 25px; height: 25px; padding: 0; border: none; background: none; cursor: pointer; }
.menu span:after,
.menu span:before { content: ''; position: absolute; left: 0; top: -9px; }
.menu span:after { top: 9px; }
.menu span { position: relative; display: block; }
.menu span,
.menu span:after,
.menu span:before { width: 100%; height: 3px; background-color: #ffffff; transition: all 0.3s; backface-visibility: hidden; border-radius: 2px; }
.menu.on span { background-color: transparent; }
.menu.on span:before { transform: rotate(45deg) translate(5px, 5px); }
.menu.on span:after { transform: rotate(-45deg) translate(7px, -8px); }

/* hero */
.hero { position: relative; color: #ffffff; margin-bottom: -8%; }
.hero .title-container { width: 100%; position: absolute; top: 0; left: 0; width: 100%; height: 100%; }
.hero table.vertical-centre,
.hero .vertical-centre tbody,
.hero .vertical-centre tr,
.hero .vertical-centre td { table-layout: fixed; min-height: 100%; height: 100%; width: 100%; vertical-align: middle; padding: 0; margin: 0; border-collapse: collapse; }
.hero .img-container { max-height: 540px; }
.hero .img-container img { margin-top: -4%; }

/* sections with incursions */
.section.incursions { position: relative; padding: 8% 0; margin-top: -8%; }
.section.incursions .content { padding: 40px 0; }
.section.incursions.dir-left .content { padding: 20px 0; }
.section.incursions .shape svg polygon { fill: #ffffff; }
.section.incursions:nth-child(even) .content { background: #eeeeee; }
.section.incursions:nth-child(even) .shape svg polygon { fill: #eeeeee; }
.section.incursions .shape { width: 100%; position: absolute; z-index: 1; left: 0; top: 0; z-index: 1; }
.section.incursions .shape svg { float: left; padding: 0; }
.section.incursions .shape:last-child { top: auto; bottom: 0; }
.section.incursions.dir-right .shape { -moz-transform: scaleX(-1); -o-transform: scaleX(-1); -webkit-transform: scaleX(-1); transform: scaleX(-1); }
.section.incursions .text-container { width: 60.8%; float: left; }
.section.incursions .text-container .btn { margin-top: 35px; }
.section.incursions .icon { width: 39.2%; width: calc(39.2% - 20px); float: right; }
.section.incursions .icon svg { max-width: 65%; display: block; margin: 0 auto; padding: 10px; }
.section.incursions.dir-left .text-container { float: right; }
.section.incursions.dir-left .icon { float: left; }
.section.incursions.background-img .shape svg polygon { opacity: 0; }
.section.incursions.last-module { padding: 8% 0 0; }
.section.form form.wrapper,
.section.incursions.project-list.last-module .content,
.section.incursions.dir-left.last-module .content,
.section.incursions.last-module .content { padding-bottom: 60px; }

/* text module */
.text-mod { position: relative; }
.text-mod .img-container { position: absolute; top: 0; left: 0; width: 100%; height: 100%; }
.text-mod .img-container img { position: absolute; bottom: 0; }
.text-mod .wrapper { padding: 0 20px; position: relative; max-width: 780px; }
.text-mod .content { padding: 10px 0 40px; }
.text-mod .content img { float: right; max-width: 320px; margin: 10px 0 20px 20px; }
.text-mod.white-text h3,
.text-mod.white-text .wrapper { color: #ffffff; }
.text-mod .highlight-list { max-width: 900px; padding: 0 10px; margin: 0 auto; text-align: center; }
.text-mod .highlight-list li { margin-top: 30px; padding: 0 5px; display: inline-block; vertical-align: top; width: calc(33.33% - 3px); }
.text-mod .highlight-list li:before { display: none; }
.text-mod .highlight-list li div { color: #19a253; text-transform: uppercase; font-size: 20px; font-weight: 700;  }
.text-mod .highlight-list li div .figure { display: block; font-size: 64px; line-height: 64px; }
.text-mod .partners { max-width: 900px; padding: 0 20px; margin: 50px auto 0; text-align: center;}
.text-mod .partners ul { text-align: center; }
.text-mod .partners li { display: inline-block; margin: 25px 30px 0; }
.text-mod .partners li:before { display: none; }
.text-mod .partners a { display: block; }
.text-mod .partners a img { display:block; float: none; max-height: 35px; margin: 0; width: auto; }

/* contact form */
.section.incursions.contact-us .shape svg polygon { fill: #ffffff; }
.contact-us header { margin-bottom: 40px; margin-top: 20px; }
.contact-us header .wrapper { max-width: 700px; }
.contact-us form input,
.contact-us form textarea { float: left; width: 33.33%; width: calc(33.33% - 14px); padding: 13px 10px; border: none; background: #eeeeee; color: #444444; font-family: 'Source Sans Pro', sans-serif; font-size: 16px; font-size: 1.6rem; line-height: 24px; line-height: 2.4rem; }
.contact-us form input[type="text"] { margin-left: 21px; }
.contact-us form input[type="text"]:first-child { margin-left: 0; }
.contact-us form input[type="submit"] { cursor: pointer; float: none; margin: 30px auto 0; text-transform: uppercase; font-weight: 600; background: #2ecc71; border-color: #2ecc71; color: #ffffff; padding: 10px; font-size: 18px; font-size: 1.8rem; line-height: 26px; line-height: 2.6rem; transition: background 0.2s ease; }
.contact-us form input[type="submit"]:hover { background: #19a253; }
.contact-us form textarea { width: 100%; margin-top: 20px; height: 100px; resize: none; }

/* call to action */
.call-to-action { color: #ffffff; padding: 40px 0; font-size: 26px; font-size: 2.6rem; line-height: 26px; line-height: 2.6rem; font-weight: 100; background: #4484ce; }

/* project list */
.project-list h3 { text-align: center; }
.project-list h3:after { display: none; }
.project-list .wrapper { max-width: 780px; }
.section.incursions.project-list .content { padding-bottom: 0; }
.project-list ul li { border-bottom: 2px solid #2ecc71; padding: 30px 20px; margin-left: 0; }
.project-list li:first-child { border-top: 2px solid #2ecc71; }
.project-list li img { max-height: 30px; position: relative; top: 9px; margin-left: 30px }
.project-list li .partners { margin: 0; color: #4484ce; font-size: 14px; font-size: 1.4rem; font-weight: 700; text-transform: uppercase; }
.project-list li:before { display: none; }
.project-list li > div { width: 80%; float:left; }
.project-list li > div:first-child { position: relative; top: -3px; width: 20%;padding-right:20px; text-align: right; color: #4484ce; font-size: 16px; font-size: 1.6rem; font-weight: 700; text-transform: uppercase; }
.project-list li > div:first-child .figure { display: block; font-size: 50px; line-height: 50px; }

/* project list */
.organisations-list {}
.organisations-list li > div { width: 100%; }
.organisations-list li > div:first-child { margin-bottom: 20px; width: 100%; text-align: left; position: static; padding: 0; }
.organisations-list li img { max-height: 40px; margin: 0 auto; display: block; position: static; }

/* site footer */
#footer { padding: 29px 0; padding: 2.9rem 0; }
#footer .company-name { font-size: 26px; font-size: 2.6rem; text-transform: uppercase; font-weight: 700; /*font-family: 'Avenir Next', sans-serif;*/ }
#footer .company-name span { font-weight: 300; }
#footer .company-name small { float: left; font-weight: 300; font-size: 12px; font-size: 1.2rem; text-transform: uppercase; position: relative; top: -6px; }
#footer .company-info { text-align: right; font-size: 16px; font-size: 1.6rem; line-height: 24px; line-height: 2.4rem; }
#footer .company-info a { margin-left: 30px; }
#footer .company-info a.phone-number { margin-left: 0; }

/* header banner */
.header-banner { background: #4484ce; padding: 120px 0 130px; color: #ffffff; }
.header-banner h1 { font-size: 60px; font-size: 6rem; line-height: 1em; }
.header-banner h2 { font-size: 22px; font-size: 2.2rem; margin-top: 26px; line-height: 1.2em; }
.header-banner .left { width: 15%; }
.header-banner .right { width: 80%; }

/* responsive */

@media screen and (max-width: 1020px) {
    #nav li { margin-left: 20px; } 
}

@media screen and (max-width: 900px) {
    #header { position: fixed; top: 0; background: #2ecc71; padding: 1rem 0; z-index: 4; -webkit-box-shadow: 0 2px 5px 0 rgba(68,68,68,0.3); -moz-box-shadow: 0 2px 5px 0 rgba(68,68,68,0.3); box-shadow: 0 2px 5px 0 rgba(68,68,68,0.3); }
    #header.sticky { padding: 10px 0; }
    #header .logo { bottom: 0; height: 40px; }
    #header .logo svg polygon { fill: #ffffff; }
    .hero { margin-top: 4.5rem; }
    .hero .img-container img { margin-top: 0; }
    .menu { display: block; }
    #nav { margin-top: 7px; }
    #nav ul { margin-top: 0; display: none; background: #ffffff; width: 100%; text-align: center; position: absolute; left: 0; top: 100%; -webkit-box-shadow: 0 2px 5px 0 rgba(68,68,68,0.3); -moz-box-shadow: 0 2px 5px 0 rgba(68,68,68,0.3); box-shadow: 0 2px 5px 0 rgba(68,68,68,0.3); }
    #nav li { display: block; margin-bottom: 1.5rem; margin-left: 0; }
    #nav li:first-child { margin-top: 1.5rem; }
    #nav li a,
    #nav li span { color: #2ecc71; }
    .section.incursions .icon svg { max-width: 80%; margin-right: 0; }
    .section.incursions.dir-left .icon svg { margin-left: 0; }
    .incursion-top { padding-top: 85px; }
    .text-mod .highlight-list li { width: 275px; }
}

@media screen and (max-width: 750px) {
    #footer .company-name,
    #footer .company-info { width: 100%; text-align: center; }
    #footer .company-name small { float: none; top: -1rem; }
    .img-container img { height: 100%; width: auto; }
 }

@media screen and (max-width: 700px) {
    body { font-size: 1.6rem; line-height: 2.4rem; }
    .header-banner h1,
    h1 { font-size: 4rem; line-height: 4rem; text-align: center; } 
    h1:after { left: 50%; margin-left: -1rem; } 
    .header-banner h2,
    h2 { font-size: 2rem; line-height: 2.4rem; margin-top: 2.5rem; text-align: center; }
    h3 { text-align: center; margin-bottom: 3.2rem; font-size: 3rem; line-height: 3.4rem; }
    h3:after { left: 50%; margin-left: -1rem; }
    .contact-us { padding: 3rem 0; }
    .section.incursions .content { padding: 2rem 0 3rem; }
    .section.incursions.dir-left .content { padding: 1rem 0; }
    .text-mod .wrapper { padding: 1rem 2rem }
    .incursion-top { padding-top: 5rem; }
    .section.incursions .text-container,
    .section.incursions .icon { width: 100%; }
    .section.incursions.dir-left .icon svg,
    .section.incursions .icon svg { max-width: 12rem; margin: 0 auto; }
    .section.incursions .text-container { margin-top: 3rem; }
    .section.incursions .text-container .btn { margin-top: 20px; }

    .hero .img-container { height: 300px; overflow: hidden; }
    .hero .img-container img { position: absolute; bottom: 0; width:100%; }

    .header-banner { padding: 100px 0 50px; }
    .header-banner .left { width: 120px; margin: 20px auto 0; float: none; }
    .header-banner .right { width: 100%; clear: both; float: none; }

    /* form */
    .contact-us form input[type="text"],
    .contact-us form input,
    .contact-us form textarea { width: 100%; margin-left: 0; margin-top: 2rem; }
    .contact-us form input[type="text"]:first-child { margin-top: 0; }
    .contact-us form textarea { height: 12rem; }

    /* call to action */
    .call-to-action { font-size: 20px; line-height: 24px; padding: 25px 0; }

    .project-list ul li { padding: 30px 0; }
    .project-list li > div:first-child { float: none; margin: 0 auto; text-align: center; width: auto; padding-right: 0; }
    .project-list li > div { width: 100%; }
    .project-list li > div:first-child { margin-bottom: 10px; }
}

@media screen and (max-width: 760px) and (orientation: landscape) {
}

@media screen and (max-width: 600px) {
    .text-mod .content img { float: none; width: 100%; max-width: none; display: block; margin: 20px auto; }
    .project-list li > div p:first-child { margin-top: 10px; }
    .project-list li .partners { text-align: center; margin-top: 10px; }
    .project-list li img:first-of-type { margin-top: 0; }
    .project-list li img { margin: 20px auto; display: block; }
}

@media screen and (max-width: 400px) {
    h1 span { display: block; }
    #footer .company-info a { display: block; margin-left: 0; }
}