﻿@charset "UTF-8";

#hatchery .inner.blue a:hover, .footer .gray a:hover {
    opacity: .7;
}

.footer .gray a, nav ul a, nav ul li {
    text-decoration: none;
    font-weight: 600;
}

a, abbr, acronym, address, applet, article, aside, audio, b, big, blockquote, body, canvas, caption, center, cite, code, dd, del, details, dfn, div, dl, dt, em, embed, 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, output, p, pre, q, ruby, s, samp, section, small, span, strike, strong, sub, summary, sup, table, tbody, td, tfoot, th, thead, time, tr, tt, u, ul, var, video {
    margin: 0;
    padding: 0;
    border: 0;
    font: inherit;
    vertical-align: baseline;
}

.h1, .h3, h1, h3 {
    font-weight: 500;
}

.s2-habitat .st4, body, input ~ div.mobile div.mobile-wrapper > ul > li > a, nav ul a, nav ul li {
    font-family: Hind;
}

article, aside, details, figcaption, figure, footer, header, hgroup, menu, nav, section {
    display: block;
}

    nav, nav ul {
        display: flex;
    }

body {
    line-height: 1;
    background-color: #F5F5F5;
}

ol, ul {
    list-style: none;
}

blockquote, q {
    quotes: none;
}

    blockquote:after, blockquote:before, q:after, q:before {
        content: '';
        content: none;
    }

table {
    border-collapse: collapse;
    border-spacing: 0;
}

.h1, h1 {
    font-size: 60px;
    line-height: 72px;
    color: #3960AC;
    margin-bottom: 50px;
}

@media (max-width:991px) {
    .h1, h1 {
        font-size: 44px;
        line-height: 56px;
    }
}

@media (max-width:549px) {
    .h1, h1 {
        font-size: 40px;
        line-height: 48px;
        margin-bottom: 25px;
    }
}

@media (max-width:375px) {
    .h1, h1 {
        font-size: 32px;
        line-height: 40px;
    }
}

#habitat .flex h2, #predation .flex h2, .h2, h2 {
    font-weight: 500;
    font-size: 32px;
    line-height: 40px;
    color: #3960AC;
}

@media (max-width:549px) {
    #habitat .flex h2, #predation .flex h2, .h2, h2 {
        font-size: 24px;
        line-height: 30px;
    }
}

.h3, h3 {
    font-size: 50px;
    line-height: 60px;
    color: #fff;
}

@media (max-width:549px) {
    .h3, h3 {
        font-size: 32px;
        line-height: 40px;
    }
}

.h4, h4 {
    font-weight: 600;
    font-size: 24px;
    line-height: 30px;
    color: #fff;
    margin-top: 25px;
}

@media (max-width:549px) {
    .h4, h4 {
        font-size: 18px;
        line-height: 24px;
        margin-top: 10px;
    }
}

.p, p {
    font-weight: 400;
    font-size: 17px;
    line-height: 24px;
    color: #3960AC;
}

nav.default ul li, nav.default ul li a, nav.fixed ul li, nav.fixed ul li a {
    color: #fff;
}

nav {
    position: absolute;
    z-index: 10;
    top: 25px;
    justify-content: center;
    width: 100%;
    height: 75px;
    box-shadow: none;
    transform: translateY(-100%);
    transition: box-shadow .3s,transform .3s;
}

.hero, .inner, .water {
    height: 100%;
}

nav.default, nav.scroll {
    transform: translateY(0);
}

@media (max-width:767px) {
    nav {
        display: none;
    }
}

nav.default {
    transition: transform 0s;
}

nav.fixed {
    position: fixed;
    top: 0;
    background-color: #3960AC;
}

#environmental-flows, #habitat, #hatchery, #predation, .c5-wrapper, .hero, .inner, .map, .water {
    position: relative;
}

#plan-goals .inner, .map {
    top: -125px;
}

nav.fixed:after {
    border-bottom: none;
}

nav.scroll {
    box-shadow: 0 5px 15px rgba(0,0,0,.3);
}

nav:after {
    content: " ";
    position: absolute;
    bottom: 0;
    left: 50%;
    transform: translateX(-50%);
    width: 820px;
    border-bottom: 1px solid #fff;
}

nav ul {
    width: 800px;
    align-items: center;
    justify-content: space-between;
}

    nav ul a, nav ul li {
        font-size: 16px;
        letter-spacing: 2.5px;
        transition: color .3s;
    }

@media (max-width:991px) {
    nav:after {
        width: 620px;
    }

    nav ul {
        width: 600px;
    }

        nav ul .bullet {
            display: none;
        }

        nav ul a, nav ul li {
            font-size: 14px;
            letter-spacing: 1px;
        }
}

nav ul a.active, nav ul li.active {
    color: #c4d0e5 !important;
}

.inner {
    width: 750px;
    margin: 0 auto;
    padding: 75px 100px 0;
    display: flex;
    flex-direction: column;
}

@media (max-width:991px) {
    .inner {
        width: 550px;
        padding: 75px 75px 0;
    }
}

@media (max-width:767px) {
    .inner {
        width: calc(100% - 100px);
        padding: 75px 50px 0;
    }
}

@media (max-width:549px) {
    .inner {
        width: calc(100% - 50px);
        padding: 75px 25px 0;
    }
}

.inner.white {
    background: #fff;
}

.inner.blue {
    background: #3960AC;
}

.water {
    width: 100%;
    min-height: 400px;
    background-size: cover;
}

.hero {
    background: url(../images/bg-water-hero.jpg) 50% 100%;
    background-size: cover;
    width: 100%;
    padding: 0 0 225px;
}

    .hero .flex {
        display: flex;
        flex-direction: row;
        align-items: center;
        justify-content: center;
        margin: 100px 0 50px;
    }

@media (max-width:549px) {
    .water {
        min-height: 300px;
    }

    .hero .flex {
        flex-direction: column;
        align-items: flex-start;
        justify-content: flex-start;
        margin: 0 0 50px;
    }
}

.hero .flex img {
    min-width: 200px;
    height: 200px;
}

.hero .flex h1 {
    width: 100%;
    margin: 0 0 0 50px;
}

@media (max-width:549px) {
    .hero .flex h1 {
        margin: 50px 0 0;
    }
}

.hero h1, .hero h2, .hero p {
    color: #fff;
}

#plan-goals {
    position: relative;
    background: #F5F5F5;
}

    #plan-goals .flex {
        display: flex;
        flex-wrap: wrap;
        align-items: center;
        justify-content: center;
    }

        #plan-goals .flex .item {
            width: calc(50% - 25px);
            min-height: 250px;
            text-align: center;
            margin-bottom: 100px;
        }

            #plan-goals .flex .item:nth-child(1), #plan-goals .flex .item:nth-child(3) {
                margin-right: 50px;
            }

@media (max-width:767px) {
    #plan-goals .flex {
        flex-direction: column;
    }

        #plan-goals .flex .item {
            width: 75%;
            margin-bottom: 50px;
        }

            #plan-goals .flex .item:nth-child(1), #plan-goals .flex .item:nth-child(3) {
                margin-right: 0;
            }
}

#plan-goals .flex .item img, #plan-goals .flex .item svg {
    width: 275px;
    height: 150px;
}

@media (max-width:991px) {
    #plan-goals .flex .item img, #plan-goals .flex .item svg {
        width: 229px;
        height: 125px;
    }
}

@media (max-width:549px) {
    #plan-goals .flex .item img, #plan-goals .flex .item svg {
        width: 100%;
    }
}

.map {
    width: 100%;
    height: 100%;
    min-height: 800px;
    background: url(../images/bg-map.jpg) fixed;
    background-size: cover;
}

@media (max-width:767px) {
    .map {
        background-attachment: scroll;
        background-size: contain;
        background-repeat: no-repeat;
        min-height: calc(100vw * .605 + 125px);
    }
}

#habitat {
    background: #F5F5F5;
}

    #habitat .inner {
        top: -250px;
    }

    #habitat .flex {
        display: flex;
        flex-direction: row;
        margin: 75px 0 100px;
    }

        #habitat .flex img, #habitat .flex svg {
            width: 50%;
            margin-right: 50px;
        }

@media (max-width:767px) {
    #habitat .flex {
        flex-direction: column;
        align-items: center;
    }

        #habitat .flex img, #habitat .flex svg {
            width: 75%;
            margin-right: 0;
        }
}

#habitat .flex h2 {
    font-size: 28px;
    line-height: 34px;
    width: 50%;
}

@media (max-width:991px) {
    #habitat .flex h2 {
        font-size: 24px;
        line-height: 30px;
    }
}

@media (max-width:767px) {
    #habitat .flex h2 {
        margin-top: 75px;
        width: 75%;
        text-align: center;
    }
}

@media (max-width:549px) {
    #habitat .flex h2 {
        width: 100%;
    }
}

.water-predation {
    top: -250px;
    background-image: url(../images/bg-water-predation.jpg);
    background-position: center 100%;
}

#predation {
    background: #F5F5F5;
}

    #predation .inner {
        top: -375px;
    }

    #predation .flex {
        display: flex;
        flex-direction: row;
        margin: 75px 0 0;
    }

        #predation .flex img {
            width: 50%;
            height: 153px;
            margin-right: 50px;
        }

@media (max-width:767px) {
    #predation .flex {
        flex-direction: column;
        align-items: center;
    }

        #predation .flex img {
            width: 75%;
            margin-right: 0;
        }
}

#predation .flex h2 {
    font-size: 28px;
    line-height: 34px;
    width: 40%;
}

@media (max-width:767px) {
    #predation .flex h2 {
        width: 75%;
        margin-bottom: 75px;
        text-align: center;
    }
}

@media (max-width:549px) {
    #predation .flex h2 {
        width: 100%;
    }
}

#predation img, #predation svg {
    width: 100%;
    margin-bottom: 100px;
}

.water-envflows {
    top: -375px;
    background-image: url(../images/bg-water-envflow.jpg);
    background-position: 30% 40%;
}

#environmental-flows {
    background: #F5F5F5;
}

    #environmental-flows .inner {
        top: -500px;
        padding-bottom: 100px;
    }

    #environmental-flows img, #environmental-flows svg {
        width: 100%;
        margin: 50px 0;
    }

@media (max-width:991px) {
    #predation .flex h2 {
        font-size: 24px;
        line-height: 30px;
    }

    #environmental-flows img, #environmental-flows svg {
        margin: 0;
    }
}

.water-hatchery {
    top: -500px;
    background-image: url(../images/bg-water-hatchery.jpg);
    background-position: center 80%;
}

#hatchery {
    background: #F5F5F5;
}

    #hatchery .inner {
        top: -625px;
    }

        #hatchery .inner.white .flex {
            display: flex;
            flex-direction: row;
            justify-content: space-between;
            margin: 50px 0 100px;
        }

@media (max-width:767px) {
    #hatchery .inner.white .flex {
        margin: 0 0 100px;
        flex-direction: column;
        align-items: center;
    }
}

#hatchery .inner.white .flex .item {
    display: flex;
    flex-direction: column;
    align-items: center;
    width: 41%;
}

@media (max-width:767px) {
    #hatchery .inner.white .flex .item {
        width: 75%;
        margin-top: 50px;
    }
}

#hatchery .inner.white .flex .item img, #hatchery .inner.white .flex .item svg {
    width: 64px;
    height: 77px;
    margin-bottom: 25px;
}

#hatchery .inner.white .flex .item p {
    width: 100%;
    text-align: center;
}

#hatchery .inner.white h2 {
    margin: 50px 0;
}

#hatchery .inner.white img {
    width: auto;
    padding: 0 7.5%;
    margin-bottom: 50px;
}

#hatchery .inner.blue {
    z-index: 1;
}

    #hatchery .inner.blue .flex {
        display: flex;
        flex-direction: row;
        margin: 25px 0 75px;
    }

        #hatchery .inner.blue .flex img {
            align-self: flex-start;
            width: 304px;
            height: 304px;
            margin-right: 75px;
        }

@media (max-width:991px) {
    #hatchery .inner.blue .flex img {
        width: 211px;
        height: 211px;
        margin-right: 50px;
    }
}

@media (max-width:767px) {
    #hatchery .inner.blue .flex {
        flex-direction: column;
    }

        #hatchery .inner.blue .flex img {
            width: 75%;
            align-self: center;
            margin: 0;
        }
}

#hatchery .inner.blue .flex h2 {
    text-align: left;
    align-self: center;
    font-size: 28px;
    line-height: 34px;
    width: 55%;
}

@media (max-width:991px) {
    #hatchery .inner.blue .flex h2 {
        font-size: 24px;
        line-height: 30px;
    }
}

@media (max-width:767px) {
    #hatchery .inner.blue .flex h2 {
        width: 75%;
        margin-top: 75px;
        text-align: center;
    }
}

@media (max-width:549px) {
    #hatchery .inner.blue .flex h2 {
        width: 100%;
    }
}

#hatchery .inner.blue h2 {
    color: #fff;
    text-align: center;
}

#hatchery .inner.blue p {
    margin: 0 0 100px;
    color: #fff;
}

#hatchery .inner.blue a {
    color: #fff;
    font-weight: 600;
    transition: opacity .3s;
}

.footer {
    position: absolute;
    bottom: -255px;
    width: 100%;
    min-height: 600px;
    background: url(../images/bg-water-footer.jpg) center 20%;
    background-size: cover;
    z-index: 0;
}

    .footer .inner {
        min-height: 600px;
        top: 125px;
    }

        .footer .inner .quotation {
            position: relative;
            width: 450px;
            height: 675px;
            margin-left: auto;
            display: flex;
            flex-direction: column;
            align-items: flex-start;
            justify-content: center;
        }

@media (max-width:549px) {
    .footer .inner .quotation {
        width: 300px;
    }

    .footer .gray .inner {
        text-align: center;
    }
}

.footer .gray {
    position: relative;
    top: 125px;
    width: 100%;
    padding: 100px 0 75px;
    background: #232323;
    display: flex;
    align-items: center;
    justify-content: center;
}

    .footer .gray .inner {
        width: 950px;
        padding: 0;
        min-height: 100%;
        top: 0;
    }

        .footer .gray .inner .flex {
            display: flex;
            flex-direction: row;
            align-items: flex-start;
            justify-content: space-between;
            margin-bottom: 50px;
        }

            .footer .gray .inner .flex img {
                width: auto;
                height: 57px;
            }

    .footer .gray p {
        color: #fff;
    }

    .footer .gray a {
        color: #fff;
        transition: opacity .3s;
    }

#identify, #maintain, #protect, #support, .fade, .quotation, .s2-habitat, .s3-predation, .s5-check path {
    visibility: hidden;
    opacity: 0;
}

.quotation {
    visibility: visible;
    opacity: 1;
}

.s2-habitat .st0 {
    fill: #fff;
}

.s2-habitat .st1 {
    fill: none;
    stroke: #3b61ad;
    stroke-width: 2;
    stroke-linecap: round;
    stroke-linejoin: round;
    stroke-miterlimit: 10;
}

.s2-habitat .st2 {
    fill: #3b61ad;
}

.s2-habitat .st3 {
    fill: none;
    stroke: #fff;
    stroke-width: 2;
    stroke-linecap: round;
    stroke-linejoin: round;
    stroke-miterlimit: 10;
}

.s2-habitat .st4 {
    font-weight: 700;
}

.s2-habitat .st5 {
    font-size: 18px;
}

.s3-weir {
    min-height: 299px;
}

    .s3-weir .st0 {
        fill: none;
        stroke: #3b61ad;
        stroke-width: 2;
        stroke-linecap: round;
        stroke-linejoin: round;
        stroke-miterlimit: 10;
    }

    .s3-weir .st1 {
        fill: #3b61ad;
    }

    .s3-weir .st2 {
        fill: none;
        stroke: #3b61ad;
        stroke-linecap: round;
        stroke-linejoin: round;
        stroke-miterlimit: 10;
    }

    .s3-weir .st3 {
        fill: #fff;
    }

    .s3-weir .st4 {
        fill: none;
        stroke: #3b61ad;
        stroke-width: 8;
        stroke-linejoin: round;
        stroke-miterlimit: 10;
    }

.s4-graph {
    min-height: 520px;
}

    .s4-graph .st0 {
        opacity: .1;
        fill: none;
        stroke: #1d1d1b;
        stroke-miterlimit: 10;
    }

    .s4-graph .st1 {
        fill: #3b61ad;
    }

    .s4-graph .st2 {
        fill: #fff;
    }

    .s4-graph .st3 {
        fill: #5e88c6;
    }

    .s4-graph .st4 {
        fill: #2f9f67;
    }

    .s4-graph .st5 {
        fill: none;
        stroke: #3b61ad;
        stroke-width: .5;
        stroke-miterlimit: 10;
    }

    .s4-graph .st6 {
        fill: #28a064;
    }

    .s4-graph .st7 {
        fill: #5c85c4;
    }

.s5-fish {
    min-height: 255px;
}

.s5-check .st0, .s5-check .st1 {
    fill: none;
    stroke: #3b61ad;
    stroke-width: 3;
    stroke-miterlimit: 10;
}

.flow.bot-curve, .flow.bot-line, .flow.mid-curve, .flow.mid-line, .flow.top-curve, .flow.top-line {
    stroke-dasharray: 60 20;
}

.s5-check .st1 {
    stroke-linecap: round;
    stroke-linejoin: round;
}

@keyframes dash {
    from {
        stroke-dashoffset: 1000;
    }

    to {
        stroke-dashoffset: 0;
    }
}

@keyframes reverse-dash {
    from {
        stroke-dashoffset: -1000;
    }

    to {
        stroke-dashoffset: 0;
    }
}

.flow.top-line {
    animation: reverse-dash 30s linear infinite;
}

.flow.top-curve {
    animation: dash 30s linear infinite;
}

.flow.mid-line {
    animation: reverse-dash 45s linear infinite;
}

.flow.mid-curve {
    animation: dash 45s linear infinite;
}

.flow.bot-line {
    animation: reverse-dash 60s linear infinite;
}

.flow.bot-curve {
    animation: dash 60s linear infinite;
}

.wavetext {
    width: 450px;
}

@media (max-width:549px) {
    .footer .gray .inner .flex {
        flex-direction: column;
        align-items: center;
    }

        .footer .gray .inner .flex a:first-child {
            margin-bottom: 50px;
        }

        .footer .gray .inner .flex img:nth-child(2) {
            margin-top: 50px;
        }

    .wavetext {
        width: 300px;
    }
}

.wavetext:before {
    content: "“";
    position: absolute;
    left: -25px;
}

@media (max-width:375px) {
    .wavetext:before {
        left: -15px;
    }
}

.wavetext span {
    display: inline-block;
}

@keyframes wave {
    from {
        transform: translateY(0);
        opacity: .6;
    }

    to {
        transform: translateY(-4px);
        opacity: .9;
    }
}

input {
    display: none;
}

    input + label {
        position: fixed;
        top: 40px;
        right: 40px;
        height: 23px;
        width: 40px;
        z-index: 5;
    }

        input + label span {
            position: absolute;
            width: 100%;
            height: 3px;
            margin-top: -1px;
            left: 0;
            display: block;
            background: #F5F5F5;
            transition: .5s;
            box-shadow: 0 2px 2px rgba(0,0,0,.3);
        }

            input + label span:first-child {
                top: 10px;
            }

            input + label span:last-child {
                top: 20px;
            }

label:hover {
    cursor: pointer;
}

input:checked + label span {
    opacity: 0;
    top: 50%;
    background: #3960AC;
}

input ~ div.mobile, input ~ div.mobile div.mobile-wrapper {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    z-index: 3;
    transition-delay: .5s;
    overflow: hidden;
    transition: .5s;
}

input:checked + label span:first-child {
    opacity: 1;
    transform: rotate(405deg);
}

input:checked + label span:last-child {
    opacity: 1;
    transform: rotate(-405deg);
}

input ~ div.mobile {
    height: 100%;
    pointer-events: none;
}

    input ~ div.mobile div.mobile-wrapper {
        background: #fff;
        height: 100px;
        transform: translateY(-100px);
        display: flex;
        align-items: center;
        justify-content: center;
    }

        input ~ div.mobile div.mobile-wrapper > ul {
            text-align: center;
        }

            input ~ div.mobile div.mobile-wrapper > ul > li {
                opacity: 0;
                transition: .5s;
                transition-delay: 0s;
                visibility: hidden;
            }

                input ~ div.mobile div.mobile-wrapper > ul > li > a {
                    text-decoration: none;
                    color: #3960AC;
                    font-weight: 600;
                    display: block;
                    padding: 20px;
                }

input:checked ~ div.mobile {
    pointer-events: auto;
}

    input:checked ~ div.mobile > div.mobile-wrapper {
        height: 100%;
        transform: translateY(0);
        transition-delay: 0s;
    }

        input:checked ~ div.mobile > div.mobile-wrapper > ul > li {
            opacity: 1;
            visibility: visible;
            transition-delay: .5s;
        }

label {
    display: none;
}

@media (max-width:767px) {
    label {
        display: block;
    }
}
/*# sourceMappingURL=main.css.map*/
