@charset "UTF-8";


/*------------------------------------*\
    HEADER
\*------------------------------------*/
.header {
    padding: 1.25em 0;
    overflow: hidden;
    position: fixed;
    z-index: 10;
    top: 0;
    left: 0;
    right: 0;
}

@media only screen and (min-width: 48em) {
    .header {
        padding: 1.5625em 0;
    }
}

.header .site-nav__home {
    display: block;
    /* width: 8.25em;*/
    height: 2.25em;
    -webkit-transition: opacity 300ms ease;
    -moz-transition: opacity 300ms ease;
    -o-transition: opacity 300ms ease;
    transition: opacity 300ms ease;
    float: left;
}

.header .site-nav__home svg {
    width: 100%;
    height: 100%;
}

.header .site-nav__home svg path {
    fill: #000;
}

.header .site-nav__home:hover {
    opacity: .7;
    -webkit-transition: opacity 0ms ease;
    -moz-transition: opacity 0ms ease;
    -o-transition: opacity 0ms ease;
    transition: opacity 0ms ease;
}

@media only screen and (min-width: 48em) {
    .header .site-nav__home {
        /* width: 8.625em;*/
        height: 2.375em;
    }
}

@media only screen and (min-width: 87.5em) {
    .header .site-nav__home {
        /*width: 12.5em;*/
        height: 3.4375em;
    }
}

.svg .header .site-nav__home {
    background: none;
}

.header .site-nav__home .site-nav__logo {
    display: none;
}

.svg .header .site-nav__home .site-nav__logo {
    display: block;
    fill: #000;
}

@media only screen and (min-width: 48em) {
    .svg .header .site-nav__home .site-nav__logo {
        width: 8.625em;
        height: 2.375em;
    }
}

@media only screen and (min-width: 87.5em) {
    .svg .header .site-nav__home .site-nav__logo {
        width: 12.5em;
        height: 3.4375em;
    }
}

@media only screen and (min-width: 90em) {
    .header {
        padding: 1.875em 0;
    }
}

/*------------------------------------*\
    NAVIGATION
\*------------------------------------*/
/* TODO: MAKE ACCESSIBLE */
.site-nav__toggle {
    display: none;
}

@media only screen and (max-width: 47.875em) {
    .site-nav__toggle {
        display: block;
        position: fixed;
        top: 0;
        right: 0;
        z-index: 100;
        padding: 1.8125em 1.25em;
        border: 0;
        background: none;
        font-weight: 700;
        text-transform: uppercase;
        color: #000;
        font-size: 1em;
        line-height: 1;
    }

    .wf-montserrat-n4-active .site-nav__toggle {
        font-family: "Montserrat", sans-serif;
        font-weight: 400;
    }
}

.site-nav {
    display: none;
}

.site-nav ul {
    padding: 0;
    margin: 0;
    list-style: none;
}

.site-nav a {
    line-height: 1;
    text-decoration: none;
    font-weight: 700;
    display: block;
    color: #000;
}

@media only screen and (min-width: 47.9375em) {
    .site-nav--primary {
        display: block;
        float: right;
    }

    .site-nav--primary li {
        float: left;
        margin-left: 2.375em;
        position: relative;
        overflow: hidden;
    }
}

@media only screen and (min-width: 47.9375em) and (min-width: 64em) {
    .site-nav--primary li {
        margin-left: 3.6875em;
    }
}

@media only screen and (min-width: 47.9375em) and (min-width: 87.5em) {
    .site-nav--primary li {
        margin-left: 4.125em;
    }
}

@media only screen and (min-width: 47.9375em) {
    .site-nav--primary li:first-child {
        margin-left: 0;
    }

    .site-nav--primary a {
        font-size: 16px;
        font-size: 1rem;
        text-transform: uppercase;
    }
}

@media only screen and (min-width: 47.9375em) and (min-width: 47.9375em) {

    .site-nav--primary a:after {
        position: absolute;
        bottom: 0;
        left: 0;
        width: 1.875em;
        height: 0.125em;
        background: #000;
    }
}

@media only screen and (min-width: 47.9375em) and (min-width: 87.5em) {
    .site-nav--primary a {
        font-size: 18px;
        font-size: 1.125rem;
    }
}

@media only screen and (min-width: 87.5em) {

}

@media only screen and (min-width: 47.9375em) {
    .current_page_item a:after, .post-type-archive-projects .menu-item-23 a:after, .single-projects .menu-item-23 a:after, .single-post .menu-item-21 a:after {
        -webkit-transform: translate3d(0%, 0, 0);
        -moz-transform: translate3d(0%, 0, 0);
        -ms-transform: translate3d(0%, 0, 0);
        transform: translate3d(0%, 0, 0);
    }
}

@-webkit-keyframes fadeInDown {
    0% {
        opacity: 0;
        -webkit-transform: translate3d(0, -100%, 0);
        transform: translate3d(0, -100%, 0);
    }
    100% {
        opacity: 1;
        -webkit-transform: none;
        transform: none;
    }
}

@keyframes fadeInDown {
    0% {
        opacity: 0;
        -webkit-transform: translate3d(0, -100%, 0);
        transform: translate3d(0, -100%, 0);
    }
    100% {
        opacity: 1;
        -webkit-transform: none;
        transform: none;
    }
}

@media only screen and (max-width: 47.875em) {
    .site-nav--footer {
        visibility: visible;
        position: fixed;
        background: #fff;
        top: 0;
        left: 0;
        width: 100%;
        height: 100%;
        z-index: 20;
        padding: 36% 1.3125em;
    }

    .site-nav--footer ul {
        position: absolute;
        right: 21px;
        top: 19.5%;
    }

    .site-nav--footer li {
        margin-bottom: 1.6875em;
        text-align: right;
    }

    .site-nav--footer a {
        font-size: 36px;
        font-size: 2.25rem;
        -webkit-animation-duration: 1s;
        animation-duration: 1s;
        -webkit-animation-fill-mode: both;
        animation-fill-mode: both;
        visibility: visible !important;
        -webkit-animation-name: fadeInDown;
        animation-name: fadeInDown;
    }
}

@media only screen and (min-width: 47.9375em) {
    .site-nav--footer {
        display: block;
    }

    .site-nav--footer li {
        margin-bottom: 26px;
    }

    .site-nav--footer a {
        -webkit-transition: color 300ms ease;
        -moz-transition: color 300ms ease;
        -o-transition: color 300ms ease;
        transition: color 300ms ease;
        text-transform: uppercase;
        color: #fff;
    }

    .site-nav--footer a:hover {
        -webkit-transition: color 0ms ease;
        -moz-transition: color 0ms ease;
        -o-transition: color 0ms ease;
        transition: color 0ms ease;
    }

    .site-nav--footer a:hover {
        color: #a3a3a3;
        color: rgba(255, 255, 255, 0.5);
    }
}

@media only screen and (min-width: 64em) {
    .site-nav--footer li {
        margin-bottom: 23px;
    }

    .site-nav--footer a {
        font-size: 18px;
        font-size: 1.125rem;
    }
}

.header {
    transition: background ease 0.25s;
}

.site-scroll--inactive .page-template-home .header {
    background: none;
}

html body .header .site-nav__home path {
    fill: #fff;
}

html body .site-nav a,
html body .site-nav__toggle {
    color: #fff;
}

.js-nav .site-nav__toggle {
    color: #000 !important;
}

.js-nav .site-nav a {
    color: #000 !important;
}

html body .site-nav--primary a:after {
    background: #fff;
}

/* ============================================================================= */
/* navbar */
.app-navbar {
    font-weight: 500;
    letter-spacing: .05em;
    position: fixed;
}

.app-navbar-top {
    position: relative;
    z-index: 3000;
}

a:hover {
    text-decoration: none;
}

.logo-text {
    letter-spacing: .06em;
    background: #fff;
    padding: 12px;
    border-radius: 4px;
    color: #28669F;
    font-weight: bold;
    text-decoration: none;
}

.logo-beta {
    letter-spacing: .05em;
    padding: 12px;
    color: #fff;
    font-weight: bold;
    text-decoration: none;
}

@media (min-width: 768px) {
    .z {
        width: 100%;
        bottom: 0;
    }
}

/* iphone block */
.aa {
    padding-bottom: 60px;
}

@media (min-width: 768px) {
    .aa {
        padding-bottom: 0;
    }

    .logo {
        padding-left: 30px;
    }

    #menu-item-login{
        padding-right: 30px;
    }

}

/* code block */
.ab {
    background-color: #262F36;
    overflow: hidden;
}

.ac {
    color: #6EA4CF;
    border: #495158 1px solid;
    background: transparent;
    font-size: 12px;
    padding: 20px;
    line-height: 1.55;
    margin-bottom: 30px;
    border-radius: .3rem;
}

.ac span {
    color: #8496A5;
}

@media (min-width: 768px) {
    .ac {
        width: 600px;
        margin-bottom: 0;
    }
}

@media (min-width: 992px) {
    .ac {
        padding: 50px;
        font-size: 15px;
    }
}

/* pull quote block */
.ad img {
    width: 100%;
}

/* brand ribbon block */
.ae {
    background: #2595FF;
}

.ae .e {
    padding-left: 0;
    padding-right: 0;
    margin-bottom: -30px;
}

.ae img {
    margin: 0 10px 30px;
}

/* marketing grid block */
.af .e {
    margin-bottom: -60px;
}

.ag .ah {
    margin-bottom: 10px !important;
}

@media (max-width: 768px) {
    .ag .ai {
        margin-bottom: 40px !important;
    }
}

/* price plan block */
.aj {
    background-color: #F4F5F6;
}

.aj .e {
    margin-bottom: -60px;
}

/* footer block */
.ak {
    background-color: #262F36;
}

.ak a {
    color: #fff;
}

/* general block overrrides */
@media (max-width: 768px) {
    .k .al {
        line-height: 1.3;
    }

    .k h3 {
        line-height: 1.15;
    }
}

/* general inverse overrides */
.am .an {
    color: rgba(255, 255, 255, .7) !important;
}

.am .ao {
    background-color: transparent;
}

/* general btn overrides */
.ap {
    font-size: 18px;
}

.block-secondary .ap {
    width: 100%;
}

.ap:not(.btn-block) {
    padding: 12px 50px;
}

@media (min-width: 768px) {
    .ap:not(.btn-block) {
        width: auto;
    }
}

/* ie10+ */
@media (min-width: 768px) {
    .aq {
        display: flex;
        align-items: center;
    }
}

/*
Report
 */
.report-rating {
    font-family: Arial, Helvetica, sans-serif;
    text-align: center;
    margin: 15px auto;
    width: 150px;
    height: 150px;
    font-size: 100px;
    line-height: 140px;
    font-weight: bold;
    color: #ffffff;
    background-color: #ccc;
}

.rating-unknown {
    background-color: #ccc
}

.rating-aplus,.rating-a {
    background-color: #7ed84d;
}

.rating-b, .rating-c {
    background-color: #FFDC00;
}

.rating-d {
    background-color: #FF851B;
}

.rating-e, .rating-f, .rating-fmin {
    background-color: #FF4136;
}

.rating-detail {
    color: #222;
    padding: 5px 5px;
    border: 1px solid #6c6c6c;
    margin-bottom: 10px;
}



svg {
    width: 100%;
    height: 100%;
}

path.slice{
    stroke-width:2px;
}

polyline{
    opacity: .3;
    stroke: black;
    stroke-width: 2px;
    fill: none;
}
