@import url("https://fonts.googleapis.com/css?family=Source+Sans+Pro:300,300italic,400,600");

html, body, div, h1, h2, p, a, img, ul, li, form, article, header, section {
    margin: 0;
    padding: 0;
    border: 0;
    font-size: 100%;
    font: inherit;
    vertical-align: baseline;
}

article, header, section {
    display: block;
}

body {
    line-height: 1;
}

ul {
    list-style: none;
}

body {
    -webkit-text-size-adjust: none;
}

/* Box Model */
*, *:before, *:after {
    box-sizing: border-box;
}

/* Containers */
.container {
    margin-left: auto;
    margin-right: auto;
}

.container {
    width: 1140px;
}

@media screen and (max-width: 1680px) {
    .container {
        width: 960px;
    }
}

@media screen and (max-width: 1080px) {
    .container {
        width: 95%;
    }
}

@media screen and (max-width: 840px) {
    .container {
        width: 95%;
    }
}

@media screen and (max-width: 736px) {
    .container {
        width: 95% !important;
    }
}

/* Grid */
.row {
    border-bottom: solid 1px transparent;
    box-sizing: border-box;
}

.row > * {
    float: left;
    box-sizing: border-box;
}

.row:after, .row:before {
    content: "";
    display: block;
    clear: both;
    height: 0;
}

.row > * {
    padding: 40px 0 0 40px;
}

.row {
    margin: -40px 0 -1px -40px;
}

.row.\35 0\% {
    margin: -20px 0 -1px -20px;
}

.\31 2u\$ {
    width: 100%;
    clear: none;
    margin-left: 0;
}

.\36 u, .\36 u\$ {
    width: 50%;
    clear: none;
    margin-left: 0;
}

@media screen and (max-width: 1680px) {
    .row > * {
        padding: 40px 0 0 40px;
    }

    .row {
        margin: -40px 0 -1px -40px;
    }

    .row.\35 0\% {
        margin: -20px 0 -1px -20px;
    }
}

@media screen and (max-width: 1080px) {
    .row > * {
        padding: 40px 0 0 40px;
    }

    .row {
        margin: -40px 0 -1px -40px;
    }

    .row.\35 0\% {
        margin: -20px 0 -1px -20px;
    }
}

@media screen and (max-width: 840px) {
    .row > * {
        padding: 30px 0 0 30px;
    }

    .row {
        margin: -30px 0 -1px -30px;
    }

    .row.\35 0\% {
        margin: -15px 0 -1px -15px;
    }
}

@media screen and (max-width: 736px) {
    .row > * {
        padding: 20px 0 0 20px;
    }

    .row {
        margin: -20px 0 -1px -20px;
    }

    .row.\35 0\% {
        margin: -10px 0 -1px -10px;
    }

    .\31 2u\$\(mobile\) {
        width: 100%;
        clear: none;
        margin-left: 0;
    }
}

/* Basic */
body {
    background-color: #183026;
    background-image: url("../images/overlay.png"), url("../images/bg.jpg");
    background-repeat: repeat, no-repeat;
    background-size: auto, cover;
    background-position: top left, center 0;
    background-attachment: fixed, fixed;
    font-family: "Source Sans Pro", sans-serif;
    font-size: 18pt;
    line-height: 1.75em;
    font-weight: 300;
    letter-spacing: 1px;
    color: #3a3939;
    text-shadow: 0 0 0.5px rgba(58, 57, 57, 0.25);
}

input, textarea {
    font-family: "Source Sans Pro", sans-serif;
    font-size: 18pt;
    line-height: 1.75em;
    font-weight: 300;
    letter-spacing: 1px;
    color: #3a3939;
    text-shadow: 0 0 0.5px rgba(58, 57, 57, 0.25);
}

h1, h2 {
    font-weight: 400;
    text-transform: uppercase;
    line-height: 1.75em;
}

h2 {
    font-size: 1.25em;
    letter-spacing: 8px;
}

a {
    transition: border-color 0.35s ease-in-out, color 0.35s ease-in-out;
    color: #a1a1a1;
    text-shadow: 0 0 0.5px rgba(53, 184, 143, 0.25);
    text-decoration: none;
    border-bottom: dotted 1px #a1a1a1;
}

a:hover {
    border-bottom-color: rgba(53, 184, 143, 0);
}

p, ul {
    margin-bottom: 1em;
}

header {
    margin-bottom: 1em;
}

header p {
    display: block;
    margin: 0.5em 0 0 0;
    padding: 0 0 1.5em 0;
}

/* Sections/Article */
section, article {
    margin-bottom: 3em;
}

section > :last-child,
article > :last-child,
section:last-child {
    margin-bottom: 0;
}

/* Image */
.image {
    display: inline-block;
    border: 0;
}

.image img {
    display: block;
    width: 100%;
}

.image.fit {
    display: block;
    width: 100%;
}

/* List */
ul.menu {
    cursor: default;
}

ul.menu li {
    display: inline-block;
    line-height: 1em;
    border-left: solid 1px #dad9d9;
    padding: 0 0 0 0.5em;
    margin: 0 0 0 0.5em;
}

ul.menu li:first-child {
    border-left: 0;
    padding-left: 0;
    margin-left: 0;
}

ul.actions {
    cursor: default;
}

ul.actions li {
    display: inline-block;
    margin: 0 0 0 0.5em;
}

ul.actions li:first-child {
    margin-left: 0;
}

/* Form */
form input[type=text],
form textarea {
    transition: background-color 0.35s ease-in-out;
    -webkit-appearance: none;
    display: block;
    border: 0;
    background: #f1f1f1;
    width: 100%;
    padding: 0.75em;
}

form input[type=text]:focus,
form textarea:focus {
    background: #f8f8f8;
}

form input[type=text] {
    line-height: 1em;
}

form textarea {
    min-height: 12em;
}

form ul.actions {
    margin-bottom: 0;
    text-align: center;
}

/* Table */

/* Button */
input[type=submit] {
    transition: background-color 0.35s ease-in-out, color 0.35s ease-in-out;
    -webkit-appearance: none;
    position: relative;
    display: inline-block;
    border: 0;
    background: #a1a1a1;
    color: #fff;
    text-shadow: 0 0 0.5px rgba(255, 255, 255, 0.25);
    cursor: pointer;
    text-decoration: none;
    outline: 0;
    padding: 1em 3em 1em 3em;
    text-align: center;
    border-radius: 3em;
    font-weight: 400;
}

input[type=submit]:hover {
    background: #45c89f;
}

/* Box */
.box {
    position: relative;
    margin-top: 9em;
    margin-bottom: 0;
}

.box:after {
    content: "";
    display: block;
    position: absolute;
    top: -9em;
    left: 50%;
    height: 9em;
    border-left: solid 1px #fff;
}

.box:before {
    content: "";
    display: block;
    width: 90px;
    height: 66px;
    position: absolute;
    left: 50%;
    top: -4.5em;
    margin-left: -45px;
    margin-top: -33px;
    background: url("../images/arrow.svg") no-repeat;
}

.box :last-child {
    margin-bottom: 0;
}

.box.style1 {
    background: #fff;
    padding: 3em;
}

.box.style1 .image {
    display: block;
    position: absolute;
    top: 0;
    width: 50%;
    height: 100%;
    background: #bed6c0;
    overflow: hidden;
}

.box.style1 .image img {
    position: absolute;
    top: 0;
    height: 100%;
    width: auto;
}

.box.style1 .inner > :last-child {
    margin: 0;
}

.box.style1.right .image {
    left: 0;
}

.box.style1.right .image img {
    right: 0;
}

.box.style1.right .inner {
    margin-left: 50%;
    padding-left: 3em;
}

.box.style1.left .image {
    right: 0;
}

.box.style1.left .image img {
    left: 0;
}

.box.style1.left .inner {
    margin-right: 50%;
    padding-right: 3em;
}

.box.style3 {
    background: #fff;
    padding: 3em;
}

.box.style3 header {
    text-align: center;
}

/* Icons */

/* Header */
#header {
    position: relative;
    color: #fff;
    text-shadow: 0 0 0.5px rgba(255, 255, 255, 0.25);
    text-align: center;
    margin: 0;
    padding: 14em 0 14em 0;
    cursor: default;
}

#header header {
    display: inline-block;
    padding: 0 0 4.5em 0;
}

#header header h1 {
    font-weight: 600;
    font-size: 4em;
    letter-spacing: 10px;
    line-height: 1.4em;
}

#header header p {
    border-top: solid 1px rgba(255, 255, 255, 0.5);
    color: rgba(255, 255, 255, 0.75);
    text-shadow: 0 0 0.5px rgba(255, 255, 255, 0.1875);
    font-size: 1em;
    text-transform: uppercase;
    letter-spacing: 3px;
    padding: 0;
    margin-top: 0.35em;
}

#header header p:before {
    content: "";
    display: block;
    border-top: solid 1px rgba(255, 255, 255, 0.5);
    margin: 4px 0 0.8em 0;
}

/* Banner */
#banner {
    position: relative;
    color: #232323;
    text-shadow: 0 0 0.5px rgba(255, 255, 255, 0.25);
    text-align: center;
    background: #d7d7d7 url("../images/banner.svg") bottom center no-repeat;
    padding: 5em 0 5em 0;
    margin: 0;
    background-size: 125% auto;
}

#banner header {
    margin: 0 0 2em 0;
}

#banner header h2 {
    font-weight: 400;
    font-size: 1.7em;
    line-height: 1.2em;
    letter-spacing: 8px;
}

#banner p {
    margin: 0;
}

/* Footer */
#footer {
    position: relative;
    color: #fff;
    text-shadow: 0 0 0.5px rgba(255, 255, 255, 0.25);
    text-align: center;
    margin: 4.5em 0 0 0;
}

#footer:after {
    content: "";
    display: block;
    position: absolute;
    top: -4.5em;
    left: 50%;
    height: 4.5em;
    border-left: solid 1px #fff;
}

#footer a {
    color: #fff;
    text-shadow: 0 0 0.5px rgba(255, 255, 255, 0.25);
    border-bottom-color: rgba(255, 255, 255, 0.5);
}

#footer a:hover {
    color: #35b88f;
    text-shadow: 0 0 0.5px rgba(69, 200, 159, 0.25);
    border-bottom-color: rgba(53, 184, 143, 0.5);
}

#footer .copyright {
    margin: 0 0 9em 0;
    font-size: 0.8em;
}

/* Wide */
@media screen and (max-width: 1680px) {
    /* Basic */
    body, input, textarea {
        font-size: 16pt;
    }
}

/* Normal */
@media screen and (max-width: 1080px) {
    /* Banner */
    #banner {
        padding: 4em 0 4em 0;
        background-size: auto, 175% auto;
    }
}

/* Narrow */
@media screen and (max-width: 840px) {
    /* Basic */
    body {
        background-color: #203936;
        background-image: url("../images/overlay.png"), url("../images/bg-alt.jpg");
        background-repeat: repeat, no-repeat;
        background-size: auto, 100% auto;
        background-position: top left, top center;
        background-attachment: scroll, scroll;
        font-size: 14pt;
    }

    input, textarea {
        font-size: 14pt;
    }

    h1, h2 {
        line-height: 1.5em;
    }

    header p {
        margin: 0.25em 0 0 0;
        padding: 0 0 0.5em 0;
    }

    /* Box */
    .box {
        position: relative;
    }

    .box.style1 {
        padding: 2.5em 2em 2.5em 2em;
    }

    .box.style1.right .inner {
        padding-left: 2em;
    }

    .box.style1.left .inner {
        padding-right: 2em;
    }

    .box.style3 {
        padding: 2.5em 2em 2.5em 2em;
    }

    /* Banner */
    #banner {
        padding: 3.5em;
        background-size: 200% auto;
    }

    #banner br {
        display: none;
    }
}

/* Mobile */
@media screen and (max-width: 736px) {
    /* Basic */
    * {
        text-shadow: none !important;
    }

    body, input, textarea {
        line-height: 1.5em;
        font-size: 12pt;
        letter-spacing: 0;
    }

    h2 {
        font-size: 1em;
    }

    h2 {
        font-size: 1.25em;
        letter-spacing: 4px;
    }

    /* List */
    ul.menu li {
        display: block;
        padding: 0;
        border: 0;
        margin: 1em 0 0 0;
    }

    ul.menu li:first-child {
        margin-top: 0;
    }

    ul.actions li {
        display: block;
        margin: 1em 0 0 0;
    }

    ul.actions li:first-child {
        margin-top: 0;
    }

    /* Button */
    input[type=submit] {
        padding: 0.75em 0 0.75em 0;
        width: 100%;
        max-width: 320px;
    }

    /* Box */
    .box {
        margin-top: 4.5em;
    }

    .box:after {
        top: -4.5em;
        height: 4.5em;
    }

    .box:before {
        width: 45px;
        height: 33px;
        top: -2.25em;
        margin-left: -22.5px;
        margin-top: -16.5px;
        background-size: 45px 33px;
    }

    .box.style1 {
        padding: 0;
        text-align: center;
    }

    .box.style1 .image {
        position: relative !important;
        left: 0 !important;
        width: 100% !important;
        height: auto !important;
    }

    .box.style1 .image img {
        position: relative;
        height: auto;
        width: 100%;
    }

    .box.style1 .inner {
        margin: 0 !important;
        padding: 2em 1.25em 2em 1.25em !important;
    }

    .box.style3 {
        padding: 2em 1.25em 2em 1.25em;
    }

    /* Header */
    #header {
        padding: 6em 0 6em 0;
    }

    #header header {
        padding-left: 2em;
        padding-right: 2em;
    }

    #header header h1 {
        font-size: 1.75em;
        letter-spacing: 6px;
    }

    /* Banner */
    #banner {
        padding: 3em 2em 3em 2em;
        background-size: auto 150%;
    }

    #banner header {
        margin: 0 0 1em 0;
    }

    #banner header h2 {
        font-size: 1.5em;
        letter-spacing: 6px;
    }

    /* Footer */
    #footer .copyright {
        font-size: 1em;
        margin: 0 0 4em 0;
    }
}
