/* Reset CSS*/
article,aside,details,figcaption,figure,footer,header,hgroup,hr,menu,nav,section{display:block}a,hr{padding:0}abbr,address,article,aside,audio,b,blockquote,body,canvas,caption,cite,code,dd,del,details,dfn,div,dl,dt,em,fieldset,figcaption,figure,footer,form,h1,h2,h3,h4,h5,h6,header,hgroup,html,i,iframe,img,ins,kbd,label,legend,li,mark,menu,nav,object,ol,p,pre,q,samp,section,small,span,strong,sub,summary,sup,table,tbody,td,tfoot,th,thead,time,tr,ul,var,video{margin:0;padding:0;border:0;outline:0;font-size:100%;vertical-align:baseline;background:0 0}ins,mark{background-color:#ff9;color:#000}body{line-height:1}nav ul{list-style:none}blockquote,q{quotes:none}blockquote:after,blockquote:before,q:after,q:before{content:'';content:none}a{margin:0;font-size:100%;vertical-align:baseline;background:0 0}ins{text-decoration:none}mark{font-style:italic;font-weight:700}del{text-decoration:line-through}abbr[title],dfn[title]{border-bottom:1px dotted;cursor:help}table{border-collapse:collapse;border-spacing:0}hr{height:1px;border:0;border-top:1px solid #ccc;margin:1em 0}input,select{vertical-align:middle}

@font-face {
    font-family: 'Exo 2';
    font-style: normal;
    font-weight: 400;
    src: url(../fonts/Exo2-400.ttf) format('truetype');
    unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+2000-206F, U+2074, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

@font-face {
    font-family: 'Exo 2';
    font-style: normal;
    font-weight: 500;
    src: url(../fonts/Exo2-500.ttf) format('truetype');
    unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+2000-206F, U+2074, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

@font-face {
    font-family: 'Exo 2';
    font-style: normal;
    font-weight: 700;
    src: url(../fonts/Exo2-700.ttf) format('truetype');
    unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+2000-206F, U+2074, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

@font-face {
    font-family: 'Exo 2';
    font-style: normal;
    font-weight: 900;
    src: url(../fonts/Exo2-900.ttf) format('truetype');
    unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+2000-206F, U+2074, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

@font-face {
    font-family: 'Ubuntu Mono';
    font-style: normal;
    font-weight: 400;
    font-display: swap;
    src: local('Ubuntu Mono'), local('UbuntuMono-Regular'), url(../fonts/UbuntuMono.woff2) format('woff2');
    unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+2000-206F, U+2074, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

:root {
    --textColor: #060528;
    --textLightColor: rgba(6, 5, 40, .7);
    --darkBlue: #0092FF;
    --lightBlue: #04DFFD;
    --yellow: #FABE25;
    --lightYellow: #FFFC66;
    --green: #16A085;
    --lightGreen: #CCF52B;
    --orange: #F7600F;
    --lightOrange: #FF9E17;
    --bgColor: #fff;
    --baseColor: var(--darkBlue);
    --baseLightColor: var(--lightBlue);
    --blurBg: rgba(255, 255, 255, .9);
    --baseGradient: linear-gradient(45deg, var(--darkBlue), var(--lightBlue));
    --invertedGradient: linear-gradient(45deg, var(--lightBlue), var(--darkBlue));
}

.textGradient {
    /* background-size: auto 300%; */
    color: var(--baseColor);
    background-image: var(--baseGradient);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
}

/* General */
body, html {
    font-family: "Exo 2", "Helvetica", "Arial", sans-serif;
    font-size: 1rem;
    font-weight: 300;
    line-height: 1.2;
    overflow-x:hidden;
    text-align: center;
    scroll-behavior: smooth;
}

body.noscroll, html.noscroll {
    overflow: hidden;
}

::selection {
    color: #fff;
    background: var(--darkBlue);
}

*:focus, *:active {
    outline: none;
}

::-webkit-scrollbar-track
{
    -webkit-box-shadow: none;
    background-color: #F5F5F5;
    border: 0;
}

::-webkit-scrollbar
{
    width: 5px;
    height: 5px;
    background-color: #F5F5F5;
}

::-webkit-scrollbar-thumb
{
    background-color: var(--darkBlue);
    border: 0;
    border-radius: 3px;
}

.textGradient {
    color: var(--baseColor);
    background-image: var(--baseGradient);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
}

h1, h2, h3, h4, h5, h6 {
    font-weight: 700;
}

h1 {
    font-size: 3rem;
    margin-bottom: 25px;
}

h2 {
    font-size: 1.8rem;
    margin-bottom: 50px;
    color: var(--textLightColor);
}

h3 {
    font-size: 2rem;
    margin-bottom: 15px;
}

h4 {
    font-size: 1.5rem;
    position: relative;
}

.heading p, .team ul {
    width: 75%;
    margin: 0 auto;
    margin-bottom: 50px;
    font-size: 1rem;
}

.products .blurBg p, .buttonInBlur, .offices .map, .careers-empty h4 {
    margin-bottom: 50px;
}

.services .blurBg p, .services .blurBg ul, .team .blurBg p {
    width: 100%;
    margin: 25px 0 0;
}

a {
    color: var(--textColor);
    text-decoration: none;
}

strong {
    font-weight: bold;
}

.button, .submit input, .selectFile {
    text-transform: uppercase;
    font-weight: 700;
    font-size: .8rem;
    color: white;
    background: var(--baseGradient);
    padding: 13px 20px;
    border-radius: 10px;
    margin-top: 75px;
    cursor: pointer;
}

.button:hover, .submit input:hover, .selectFile:hover {
    background: var(--invertedGradient);
    transition: all .5s ease-out;
}

.button + .button {
    margin-left: 10px !important;
}

a.link {
    text-decoration: underline;
    color: var(--darkBlue);
}

a.link:hover {
    color: var(--lightBlue);
}

ul {
    list-style: none;
}

*:hover, *:active {
    transition: all .15s ease-out;
}

.textLeft {
    text-align: left;
}

.textRight {
    text-align: right;
}

.blurBg {
    background: var(--bgColor);
    border-radius: 15px;
    padding: 40px;
    position: relative;
    box-shadow: 0 10px 90px 0 rgb(6 5 40 / 10%);
    height: 100%;
    box-sizing: border-box;
}

.clearfix {
    margin-top: 0 !important;
}

.textLeft {
    text-align: left;
}

.uppercase {
    text-transform: uppercase;
}

.bold {
    font-weight: bold;
}

/*Header*/
#header {
    position: fixed;
    height: 80px;
    background-color: var(--blurBg);
    padding: 25px 10px;
    z-index: 100;
    box-sizing: border-box;
    backdrop-filter: blur(25px);
    -webkit-backdrop-filter: blur(25px);
    width: 100vw;
    left: 0;
    top: 0;
    box-shadow: 0 10px 90px 0 rgb(6 5 40 / 5%);
}

header > .row {
    float: left;
}

.logo img {
    height: 30px;
    width: auto;
    float: left;
    border-radius: 0;
}

nav {
    float: right;
}

.toggleMenu, .toggleSubmenu {
    display: none;
}

.main-menu li a:hover {
    color: var(--baseColor);
}

.main-menu > li {
    display: inline-block;
    font-weight: 500;
    font-size: 1.05rem;
    margin-left: 25px;
    position: relative;
    padding-bottom: 35px;
}

.main-menu > li > a:before, section:before, .blurBg h4:before, .blurBg li:not(:first-of-type):before, .team li:not(:first-of-type):before, .grants .row:not(:first-of-type):before, .positionInfo:before, .positionInfo li:before, .post li::before {
    content: "";
    width: 20px;
    height: 3px;
    background: var(--baseGradient);
    border-radius: 15px;
    position: absolute;
    bottom: 20px;
    margin-left: calc(50% - 10px);
    display: none;
}

.hasSubmenu:hover .sub-menu {
    display: block;
}

.sub-menu {
    display: none;
    position: absolute;
    top: 55px;
    left: calc(50% - 100px);
    margin-top: 0;
    padding: 25px;
    background-color: rgb(255 255 255 / .9);
    box-shadow: 0 10px 90px 0 rgb(6 5 40 / 10%);
    width: 200px;
    box-sizing: border-box;
    border-radius: 0 0 15px 15px;
}

.sub-menu li {
    text-align: center;
}

.sub-menu li a:hover, .newCustomchkbox-md a:hover, #footer a:hover {
    color: var(--darkBlue);
}

.sub-menu li:not(:first-child) {
    margin-top: 15px;
}

.sub-menu li a.active {
    font-weight: bold;
}

/*Sections*/
section {
    position: relative;
    margin: 100px 0;
}
section:before {
    top: -50px;
    margin-left: -10px;
    display: inline-block;
}

.row.content {
    margin-top: 75px;
    justify-content: center;
}

.row>* {
    padding: calc(var(--bs-gutter-x) * .75);
}

.heading p {
    font-size: 1.2rem;
}

img {
    width: 100%;
    border-radius: 15px 15px 0 0;
}

.partners img, .grants img, .supporters img {
    border-radius: 0;
}

.supporters img {
  margin: 40px 0 40px 0px;
  max-width: 90%;
}

.img {
    width: calc(100% + 80px);
    margin: -40px 0 40px -40px;
}

.officeImg img {
    width: 100%;
    border-radius: 15px;
}

.blurBg .button {
    margin: 0 0 20px 0;
    display: inline-block;
}

.blurBg h4:before, .positionInfo:before {
    display: inline-block;
    width: 100%;
    left: 0;
    margin-left: 0;
    top: -50px;
}

.positionInfo {
    position: relative;
    text-align: left;
}

.positionInfo:before {
    width: 80%;
    left: 10%;
}

.positionInfo, .postContent, .postInfo {
    width: 80%;
    margin: 0 auto 15px;
}

#position h1, #blog .postContent h1, .postInfo h1 {
    font-size: 2.5rem;
    margin-bottom: 50px;
}

#position h2, #blog .postContent h2 {
    margin-top: 50px;
    margin-bottom: 25px;
}

#position li, #blog .postContent li {
    margin-top: 0;
    margin-bottom: 15px;
    width: calc(100% - 30px);
}

li > ul {
    margin-top: 15px;
}

#position li:before, #blog .postContent li:before {
    margin-left: 0;
    top: 9px;
    left: -25px;
}

.relatedPosts h4:before, .team h4:before {
    display: none;
}

#blog h2 {
    font-size: 1.5rem;
    margin-bottom: 30px;
}

#blog .tag, #post .tag {
    border: 3px solid var(--darkBlue);
    display: inline-block;
    margin-bottom: 7px;
    padding: 1px 10px 3px;
    border-radius: 115px;
    margin-right: 10px;
    color: var(--darkBlue);
    font-weight: 600;
    font-size: .85rem;
}

#blog .tag:hover, #post .tag:hover {
    background: var(--baseColor);
    color: var(--bgColor);
}

#blog .author, #post .author {
    font-size: 0.9rem;
    color: var(--textLightColor);
    font-weight: 500;    
    margin-top: 25px;
    margin-bottom: 15px;
}

.blogImg {
    position: relative;
}

.blogImg .imgCredits {
    position: absolute;
    right: 7px;
    bottom: 10px;
    text-align: right;
    font-size: 80%;
    background: rgba(255,255,255,.75);
    box-sizing: border-box;
    padding: 5px;
    border-radius: 5px;
}

.followAndSubscribe {
    margin-top: 100px;
}

.imgCredits a {
    font-weight: bold;
    color: var(--baseColor)
}

.blurBg li, .team li {
    position: relative;
    margin-top: 30px;
}

.blurBg li:not(:first-of-type):before, .team li:not(:first-of-type)::before, .grants .row:not(:first-of-type):before, .positionInfo li:before {
    display: inline-block;
    width: 10px;
    margin-left: calc(50% - 5px);
    left: 0;
    top: -15px;
}

.team h3 {
    margin-top: 50px;
}

.grants .row:not(:first-of-type):before {
    top: -25px;
}

.grants .row {
    position: relative;
    margin-top: 50px;
}

.grants h2 {
    margin-bottom: 0;
}

.grants p {
    margin-bottom: 25px;
}

.icon {
    margin-bottom: 90px;
    display: inline-block;
}

.icon-h svg, .carrersImg img {
    height: 75px;
    width: auto;
}

.icon-v svg {
    width: 75px;
    height: auto;
}

/*Footer*/
#cookies-consent a {
    color: var(--baseColor);
}

#cookies-consent {
    position: fixed;
    bottom: 20px;
    right: 20px;
    width: auto;
    max-width: calc(100vw - 40px);
    padding: 30px;
    background: var(--bgColor);
    border: 1px solid var(--baseLightColor);
    backdrop-filter: blur(25px);
    -webkit-backdrop-filter: blur(25px);
    border-radius: 10px;
    color: gray;
    box-sizing: border-box;
    z-index: 99;
}

#subscription h1 {
    font-size: 1.4rem;
    margin-bottom: 10px;
}

#subscription p {
    font-size: 1.1rem;
    margin-bottom: 20px;
}

#recap {
    display: none;
    margin: 20px 15px;
}

#recap > div {
    margin: 0 auto;
}

form.newsletter > br {
    display: none;
}

input:not([type="checkbox"]):not([type="submit"]), textarea {
    width: 500px;
    max-width: 90%;
    height: 40px;
    border-radius: 15px;
    border: none;
    background: var(--bgColor);
    box-shadow: 0 10px 90px 0 rgb(6 5 40 / 10%);
    display: block;
    margin: 0 auto 25px;
    padding-left: 20px;
    font-family: 'Exo 2';
    color: var(--textLightColor);
    border: 1px solid var(--bgColor);
}

input:not([type="checkbox"]):not([type="submit"]):focus, textarea:focus {
    border: 1px solid var(--lightBlue);
    box-shadow: 0px 3px 30px 0px rgb(4 223 253 / 15%);
    color: var(--textColor);
}

input#theFile {
    border: 0;
    margin: 15px auto 20px;
    padding: 0;
    background: transparent;
    box-shadow: none;
    border-radius: 0;
    display: block;
    width: auto;
}

.selectFile {
    margin-top: 10px;
    display: inline-block;
}

textarea {
    padding-top: 12px;
}

.newCustomchkbox-md {
    font-size: .8rem;
    color: var(--textLightColor);
    display: inline-block;
}

.newCustomchkbox-md a {
    text-decoration: underline;
}

.apply .newCustomchkbox-md {
    margin-top: 60px;
}

.submit input {
    border: none;
    font-family: 'Exo 2';
    margin-top: 50px;
}

.fileLimit {
    display: block;
}

#footer {
    margin-bottom: 5px;
}

.footerLinks a, .footerLinks.lang > span {
    display: block;
    margin-bottom: 10px;
    color: var(--textColor);
}

.footerLinks:not(.lang) a:first-of-type, .footerLinks.lang > span {
    font-weight: bold;
    margin-bottom: 15px;
}

#footer > .row {
    margin-top: 15px;
}

#footer > .row a {
    color: var(--textLightColor);
    padding: 0 10px;
}

#cookies-consent.hide {
    opacity: 0;
    bottom: -100px;
    transition: all .5s ease-in;
}


/* luis */
.blurBg h4 + .button {
    margin-top: 40px;
}

.post .button {
    margin-top: 30px;
}

.postContent h2 {
    margin: 40px 0 10px;
}

.postContent p {
    margin-bottom: 20px;
}

.postContent li p {
    display: contents;
}

.postContent a, .author .links a {
    color: var(--baseColor);
    font-weight: bold;
    word-wrap: break-word;
}

.postContent a:hover, .author .links a:hover {
    color: var(--baseLightColor);
}

.postContent h3 {
    font-size: 1.3rem;
    margin-top: 30px;
}

.postContent .highlight, .postContent > pre {
    margin-bottom: 40px;
    max-width: 100%;
    overflow: auto;
    font-size: 85%;
}

.postContent table {
    border-collapse: collapse;
    max-width: 100%;
    overflow-x: auto;
    box-sizing: border-box;
    display: block;
    margin: 30px auto 45px;
}

.postContent th {
    padding: 0.5rem;
    border: 1px solid #dcdcdc;
    background: #f0f0f1;
    color: var(--baseColor);
}

.postContent td {
    border: 1px solid #dcdcdc;
    padding: 0.5rem;
}

.highlight pre, .postContent > pre {
    background: #fbfbfb !important;
    padding: 15px 20px;
    border-radius: 5px;
    overflow: auto;
    border: 1px solid #dcdcdc;
}

.main-menu > li:hover a:before, .main-menu > li a.active:before {
    display: inline-block;
}

.postContent ul {
    margin: 20px 0 30px;
    padding-left: 20px;
}

.postContent li {
    margin: 0 0 10px !important;
}

.postContent li:before {
    width: 10px;
    display: inline-block !important;
    position: initial !important;
    margin: 0 5px 0 0!important;
    transform: translateY(-4px);
}

.postContent img {
    border-radius: 0;
}

.authors .author {
    width: 47%;
    float: left;
    margin: -25px 1.5% 15px;
    display: flex;
    align-items: center;
}

.author .name, .author .position {
    display: block;
}

.author .links {
    margin-top: 10px;
}

.author .links a {
    font-size: 90%;
    display: inline-block;
    margin-right: 5px;
}

.author .name {
    font-weight: bold;
    font-size: 1.2rem;
}

.author img {
    border-radius: 15px;
}

.author svg {
    width: 15px;
}

.author svg path {
    fill: var(--baseColor);
}

.bigText {
    font-weight: 900;
    font-size: 180%;
}

nav {
    text-align: right;
}

#cover {
    text-align: left;
    margin-top: 80px;
    padding: 100px 0;
    background: var(--textColor);
    color: #fff;
    border-bottom: 5px solid var(--lightBlue);
}

#cover .row {
    align-items: center;
}

#cover h1 {
    margin-bottom: 15px;
    font-weight: 400;
    font-size: 3rem;
}

#cover p {
    font-size: 1.3rem;
    line-height: 1.5;
    margin: 0 0 50px 0;
    width: 100%;
}

#cover .button {
    color: var(--textColor)
}

#cover svg.mobile {
    display: none;
}

#cover svg.desktop {
    position: absolute;
    bottom: -5px;
    right: -2vw;
    width: 45vw;
    height: auto;
    padding: 0;
}

@keyframes reveal {
    to {
        stroke-dashoffset: 0;
    }
}

#cover svg path {
    stroke-dasharray: 1000;
    stroke-dashoffset: 1000;
    animation: reveal 15s linear forwards;
}

.balls {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}

.balls .ball {
    float: left;
    width: 20vh;
    height: 20vh;
    transform: rotateZ(360deg);
    -webkit-filter: blur(10vh);
    -moz-filter: blur(10vh);
    -o-filter: blur(10vh);
    -ms-filter: blur(10vh);
    filter: blur(10vh);
    background: var(--lightBlue);
    /* -webkit-animation: moving 30s linear infinite;
    -moz-animation: moving 30s linear infinite;
    -ms-animation: moving 30s linear infinite;
    -o-animation: moving 30s linear infinite;
    animation: moving 30s linear infinite */
}

#balls-2 {
    opacity: .6; 
    transform: scale(1.8) scaleX(-1);
}

.balls .ball:nth-child(2) {
    margin: 10vh 40vw;
}

.balls .ball:nth-child(3) {
    margin: 15vw;
}

.balls .ball:nth-child(4) {
    margin: 30vw;
}

@keyframes moving{
    0%, 100% {
        -o-transform:translate(20vw,10vw) rotate(10deg);
        transform:translate(20vw,10vw) rotate(10deg);
        -webkit-transform:translate(20vw,10vw) rotate(10deg);
        -moz-transform:translate(20vw,10vw) rotate(10deg)
    } 
    15% {
        -o-transform:translate(-10vw,-20vw) rotate(0);
        transform:translate(-10vw,-20vw) rotate(0);
        -webkit-transform:translate(-10vw,-20vw) rotate(0);
        -moz-transform:translate(-10vw,-20vw) rotate(0)
    }
    25% {
        -o-transform:translate(-30vw,0) rotate(30deg);
        transform:translate(-30vw,0) rotate(30deg);
        -webkit-transform:translate(-30vw,0) rotate(30deg);
        -moz-transform:translate(-30vw,0) rotate(30deg)
    } 
    30% {
        -o-transform:translate(0,20vw) rotate(0);
        transform:translate(0,20vw) rotate(0);
        -webkit-transform:translate(0,20vw) rotate(0);
        -moz-transform:translate(0,20vw) rotate(0)
    }
    45% {
        -o-transform:translate(10vw,-10vw) rotate(-10deg);
        transform:translate(10vw,-10vw) rotate(-10deg);
        -webkit-transform:translate(10vw,-10vw) rotate(-10deg);
        -moz-transform:translate(10vw,-10vw) rotate(-10deg)
    }
    60% {
        -o-transform:translate(-20vw,20vw) rotate(10deg);
        transform:translate(-20vw,20vw) rotate(10deg);
        -webkit-transform:translate(-20vw,20vw) rotate(10deg);
        -moz-transform:translate(-20vw,20vw) rotate(10deg)
    }
    70% {
        -o-transform:translate(-30vw,10vw) rotate(0);
        transform:translate(-30vw,10vw) rotate(0);
        -webkit-transform:translate(-30vw,10vw) rotate(0);
        -moz-transform:translate(-30vw,10vw) rotate(0)
    }
    80% {
        -o-transform:translate(20vw,10vw) rotate(30deg);
        transform:translate(20vw,10vw) rotate(30deg);
        -webkit-transform:translate(20vw,10vw) rotate(30deg);
        -moz-transform:translate(20vw,10vw) rotate(30deg)
    } 
    90% {
        -o-transform:translate(20px,20px) rotate(0);
        transform:translate(20px,20px) rotate(0);
        -webkit-transform:translate(20px,20px) rotate(0);
        -moz-transform:translate(20px,20px) rotate(0)
    }
}

.ball.blue {
    background: var(--lightBlue);
}

.ball.orange {
    background: var(--lightOrange);
}

.ball.yellow {
    background: var(--lightYellow);
}

.ball.green {
    background: var(--lightGreen);
}

#content section:first-of-type {
    margin-top: 150px;
}

#content section:first-of-type:before {
    display: none;
}

#social a {
    margin: 0 2vw;
}

#cookies + #subscription, #privacy + #subscription, #contact + #subscription, #quote + #subscription, #notFound + #subscription {
    display: none;
}

#notFound {
    padding: 16vh 0;
}

/*Responsive*/
@media all and (min-width: 1921px) {
    #cover svg.desktop {
        width: auto;
        height: 560px;
        right: calc(45vw - 650px);
    }
}

@media all and (max-width: 1920px) {
    .container {
        max-width: 80vw;
    }
}

@media all and (max-width: 1400px) {
    .bigText {
        font-size: 5rem;
    }

    #cover h1 {
        font-size: 2.5rem;
    }

    #cover {
        padding: 75px 0;
    }

    h1 {
        font-size: 2.5rem;
        margin-bottom: 15px;
    }
}

@media all and (max-width: 1280px) {
    .offices h2 {
        font-size: 1.3rem;
        margin-bottom: 40px;
    }

    .postInfo h1 {
        font-size: 2rem;
    }

    .postContent h2 {
        font-size: 1.6rem;
    }

    .positionInfo, .postContent, .postInfo {
        width: 90%;
    }

    #cover svg.desktop {
        right: -5vw;
        width: 53vw;
    }
}

@media all and (max-width: 1100px) {
    
    #cover svg.desktop {
        opacity: .6;
    }

    #cover .col-6 {
        width: 100%;
        position: relative;
        z-index: 1;
    }

    #cover .bigText {
        display: block;
        font-size: 150%;
    }

    #cover br {
        display: none;
    }
}

@media all and (max-width: 990px) {

    .menu-items {
        width: 100%;
    }

    #header {
        padding: 15px 10px;
        height: auto;
    }

    #cover {
        margin-top: 55px;
    }

    .logo img {
        height: 25px;
    }

    .main-menu > li:hover a:before, .main-menu > li a.active:before {
        display: none;
    }

    ul.main-menu {
        display: none;
        text-align: center;
        padding: 20px;
        box-sizing: border-box;
    }

    ul.main-menu.open {
        width: 100%;
    }

    .toggleMenu, .toggleSubmenu {
        display: block;
        appearance: none;
        -webkit-appearance: none;
        background: transparent;
        border: 0;
        float: right;
        cursor: pointer;
    }

    .toggleSubmenu {
        transform: translate(8px, 7px) rotate(45deg);
        position: absolute;
        float: none;
        display: inline-block;
        width: 8px;
        padding: 0;
        height: 8px;
        border: 2px solid var(--baseColor);
        border-top: 0;
        border-left: 0;
    }

    .toggleSubmenu.open {
        transform: translate(8px, 11px) rotate(-135deg);
    }

    .toggleMenu span {
        display: block;
        width: 30px;
        height: 4px;
        margin-bottom: 5px;
        background: var(--baseGradient);
        border-radius: 5px;
        transition: all .3s ease-out;
    }

    .toggleMenu.open span:nth-child(1) {
        transform: translateY(9px) rotate(45deg);
    }

    .toggleMenu.open span:nth-child(3) {
        transform: translateY(-9px) rotate(-45deg);
    }

    .toggleMenu.open span:nth-child(2) {
        width: 0;
    }

    .hasSubmenu:hover .sub-menu {
        display: none;
    }

    .sub-menu {
        position: initial;
        background: transparent;
        width: 100%;
        box-shadow: none;
        border-top: 1px solid var(--baseColor);
        border-bottom: 1px solid var(--baseColor);
        border-radius: 0;
        padding: 10px 10px 15px;
        margin-top: 10px;
    }

    .main-menu > li:not(:last-child):after {
        content: " ";
        background: var(--baseGradient);
        width: 20px;
        height: 3px;
        display: block;
        margin: 5px auto;
        transform: translateY(10px);
        border-radius: 5px;
    }
    
    .main-menu > li {
        display: block;
        margin: 0;
        padding: 10px;
    }

    .container {
        max-width: 85vw;
    }

    h3 {
        font-size: 1.5rem;
    }

    h4 {
        font-size: 1.3rem;
    }

    .heading p {
        font-size: 1.1rem;
    }

    .footerLinks {
        flex: 33.33%;
    }

    #colophon > .col {
        flex: 100%;
        text-align: center;
        padding: 5px;
    }

    .team h4 {
        font-size: 1.2rem;
    }

    .team .blurBg {
        padding: 20px;
    }

    .team .blurBg .img {
        width: calc(100% + 40px);
        margin: -20px 0 20px -20px;
    }
    
    .offices li {
        display: inline-block;
        margin: 0 auto;
        width: 45%;
    }

    .offices li:nth-child(2):before {
        display: none;
    }

    .positionInfo, .postContent, .postInfo {
        width: 95%;
    }

    .blogImg .imgCredits {
        position: initial;
        width: 100%;
        display: inline-block;
        text-align: left;
        background: var(--baseColor);
        border-radius: 0;
        transform: translateY(-5px);
        color: #fff;
    }

    .imgCredits a {
        color: #fff;
    }

}

@media all and (max-width: 640px) {

    #cover svg.desktop {
        display: none;
    }
    
    .blurBg {
        padding: 30px;
    }

    .footerLinks {
        flex: 100%;
    }

    #content section:first-of-type {
        margin-top: 100px;
    }

    h1 {
        font-size: 2rem;
    }

    h2 {
        font-size: 1.5rem;
    }

    h3 {
        font-size: 1.2rem;
    }

    h4 {
        font-size: 1.1rem;
    }

    p, .heading p {
        font-size: 1rem;
    }

    .icon svg, .carrersImg img {
        height: 40px;
    }

    .icon + h4 {
        font-size: 1.3rem;
    }

    .blurBg h4:before, .positionInfo:before {
        top: -25px;
    }

    .icon {
        margin-bottom: 35px;
    }

    .img {
        width: calc(100% + 60px);
        margin: -30px 0 30px -30px;
    }

    .heading p, .team ul {
        width: 85%;
    }

    .products .blurBg p, .buttonInBlur, .offices .map, .careers-empty h4 {
        margin-bottom: 20px;
    }

    .offices li:nth-child(2):before {
        display: block;
    }

    .offices li {
        width: 100%;
    }

    .offices h2 {
        margin-bottom: 30px;
    }

    .partners img, .grants img {
        max-width: 60%;
    }

    #blog h2 {
        font-size: 1.3rem;
    }

    .postInfo h1 {
        font-size: 1.5rem;
    }

    .postContent h2 {
        font-size: 1.3rem;
    }

    #cover {
        margin-top: 50px;
    }

    .logo img {
        height: 20px;
    }
    
    ul.main-menu {
        top: 50px;
    }

    #header {
        padding-bottom: 6px;
        max-height: 100vh;
        overflow-y: auto;
    }

    .toggleMenu {
        transform: translateY(-10%) scale(.8);
    }

    .main-menu > li > a {
        font-size: 1.2rem;
        font-weight: bold;
    }

    #cover svg.mobile {
        display: block;
        height: 50vh;
        margin-bottom: -10px;
    }

    #cover * {
        text-align: center;
    }

    #cover h1 {
        font-size: 1.5rem;
    }

    #cover p {
        font-size: 1rem;
    }

    #social svg {
        max-width: 20vw;
    }

    .blurBg h4 + .button {
        margin-top: 25px;
    }

    .authors .author {
        width: 100%;
        margin: 0 auto 20px;
    }

    #notFound {
        padding: 8vh 0;
    }

    .button + .button {
        margin-left: 0 !important;
        margin-top: 0;
    }
}
