﻿@charset "UTF-8";

/*!
 * inuitcss, by @csswizardry
 *
 * github.com/inuitcss | inuitcss.com
 */
/*! normalize.css v3.0.2 | MIT License | git.io/normalize */
/**
 * 1. Set default font family to sans-serif.
 * 2. Prevent iOS text size adjust after orientation change, without disabling
 *    user zoom.
 */
html {
    font-family: sans-serif;
    /* 1 */
    -ms-text-size-adjust: 100%;
    /* 2 */
    -webkit-text-size-adjust: 100%;
    /* 2 */
}

/**
 * Remove default margin.
 */
body {
    margin: 0;
}

/* HTML5 display definitions
   ========================================================================== */
/**
 * Correct `block` display not defined for any HTML5 element in IE 8/9.
 * Correct `block` display not defined for `details` or `summary` in IE 10/11
 * and Firefox.
 * Correct `block` display not defined for `main` in IE 11.
 */
article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
main,
menu,
nav,
section,
summary {
    display: block;
}

/**
 * 1. Correct `inline-block` display not defined in IE 8/9.
 * 2. Normalize vertical alignment of `progress` in Chrome, Firefox, and Opera.
 */
audio,
canvas,
progress,
video {
    display: inline-block;
    /* 1 */
    vertical-align: baseline;
    /* 2 */
}

    /**
 * Prevent modern browsers from displaying `audio` without controls.
 * Remove excess height in iOS 5 devices.
 */
    audio:not([controls]) {
        display: none;
        height: 0;
    }

/**
 * Address `[hidden]` styling not present in IE 8/9/10.
 * Hide the `template` element in IE 8/9/11, Safari, and Firefox < 22.
 */
[hidden],
template {
    display: none;
}

/* Links
   ========================================================================== */
/**
 * Remove the gray background color from active links in IE 10.
 */
a {
    background-color: transparent;
}

    /**
 * Improve readability when focused and also mouse hovered in all browsers.
 */
    a:active,
    a:hover {
        outline: 0;
    }

/* Text-level semantics
   ========================================================================== */
/**
 * Address styling not present in IE 8/9/10/11, Safari, and Chrome.
 */
abbr[title] {
    border-bottom: 1px dotted;
}

/**
 * Address style set to `bolder` in Firefox 4+, Safari, and Chrome.
 */
b,
strong {
    font-weight: bold;
}

/**
 * Address styling not present in Safari and Chrome.
 */
dfn {
    font-style: italic;
}

/**
 * Address variable `h1` font-size and margin within `section` and `article`
 * contexts in Firefox 4+, Safari, and Chrome.
 */
h1 {
    font-size: 2em;
    margin: 0.67em 0;
}

/**
 * Address styling not present in IE 8/9.
 */
mark {
    background: #ff0;
    color: #000;
}

/**
 * Address inconsistent and variable font size in all browsers.
 */
small {
    font-size: 80%;
}

/**
 * Prevent `sub` and `sup` affecting `line-height` in all browsers.
 */
sub,
sup {
    font-size: 75%;
    line-height: 0;
    position: relative;
    vertical-align: baseline;
}

sup {
    top: -0.5em;
}

sub {
    bottom: -0.25em;
}

/* Embedded content
   ========================================================================== */
/**
 * Remove border when inside `a` element in IE 8/9/10.
 */
img {
    border: 0;
}

/**
 * Correct overflow not hidden in IE 9/10/11.
 */
svg:not(:root) {
    overflow: hidden;
}

/* Grouping content
   ========================================================================== */
/**
 * Address margin not present in IE 8/9 and Safari.
 */
figure {
    margin: 1em 40px;
}

/**
 * Address differences between Firefox and other browsers.
 */
hr {
    box-sizing: content-box;
    height: 0;
}

/**
 * Contain overflow in all browsers.
 */
pre {
    overflow: auto;
}

/**
 * Address odd `em`-unit font size rendering in all browsers.
 */
code,
kbd,
pre,
samp {
    font-family: monospace, monospace;
    font-size: 1em;
}

/* Forms
   ========================================================================== */
/**
 * Known limitation: by default, Chrome and Safari on OS X allow very limited
 * styling of `select`, unless a `border` property is set.
 */
/**
 * 1. Correct color not being inherited.
 *    Known issue: affects color of disabled elements.
 * 2. Correct font properties not being inherited.
 * 3. Address margins set differently in Firefox 4+, Safari, and Chrome.
 */
button,
input,
optgroup,
select,
textarea {
    color: inherit;
    /* 1 */
    font: inherit;
    /* 2 */
    margin: 0;
    /* 3 */
}

/**
 * Address `overflow` set to `hidden` in IE 8/9/10/11.
 */
button {
    overflow: visible;
}

/**
 * Address inconsistent `text-transform` inheritance for `button` and `select`.
 * All other form control elements do not inherit `text-transform` values.
 * Correct `button` style inheritance in Firefox, IE 8/9/10/11, and Opera.
 * Correct `select` style inheritance in Firefox.
 */
button,
select {
    text-transform: none;
}

/**
 * 1. Avoid the WebKit bug in Android 4.0.* where (2) destroys native `audio`
 *    and `video` controls.
 * 2. Correct inability to style clickable `input` types in iOS.
 * 3. Improve usability and consistency of cursor style between image-type
 *    `input` and others.
 */
button,
html input[type="button"],
input[type="reset"],
input[type="submit"] {
    -webkit-appearance: button;
    /* 2 */
    cursor: pointer;
    /* 3 */
}

    /**
 * Re-set default cursor for disabled elements.
 */
    button[disabled],
    html input[disabled] {
        cursor: default;
    }

    /**
 * Remove inner padding and border in Firefox 4+.
 */
    button::-moz-focus-inner,
    input::-moz-focus-inner {
        border: 0;
        padding: 0;
    }

/**
 * Address Firefox 4+ setting `line-height` on `input` using `!important` in
 * the UA stylesheet.
 */
input {
    line-height: normal;
}

    /**
 * It's recommended that you don't attempt to style these elements.
 * Firefox's implementation doesn't respect box-sizing, padding, or width.
 *
 * 1. Address box sizing set to `content-box` in IE 8/9/10.
 * 2. Remove excess padding in IE 8/9/10.
 */
    input[type="checkbox"],
    input[type="radio"] {
        box-sizing: border-box;
        /* 1 */
        padding: 0;
        /* 2 */
    }

    /**
 * Fix the cursor style for Chrome's increment/decrement buttons. For certain
 * `font-size` values of the `input`, it causes the cursor style of the
 * decrement button to change from `default` to `text`.
 */
    input[type="number"]::-webkit-inner-spin-button,
    input[type="number"]::-webkit-outer-spin-button {
        height: auto;
    }

    /**
 * 1. Address `appearance` set to `searchfield` in Safari and Chrome.
 * 2. Address `box-sizing` set to `border-box` in Safari and Chrome
 *    (include `-moz` to future-proof).
 */
    input[type="search"] {
        -webkit-appearance: textfield;
        /* 1 */
        /* 2 */
        box-sizing: content-box;
    }

        /**
 * Remove inner padding and search cancel button in Safari and Chrome on OS X.
 * Safari (but not Chrome) clips the cancel button when the search input has
 * padding (and `textfield` appearance).
 */
        input[type="search"]::-webkit-search-cancel-button,
        input[type="search"]::-webkit-search-decoration {
            -webkit-appearance: none;
        }

/**
 * Define consistent border, margin, and padding.
 */
fieldset {
    border: 1px solid #c0c0c0;
    margin: 0 2px;
    padding: 0.35em 0.625em 0.75em;
}

/**
 * 1. Correct `color` not being inherited in IE 8/9/10/11.
 * 2. Remove padding so people aren't caught out if they zero out fieldsets.
 */
legend {
    border: 0;
    /* 1 */
    padding: 0;
    /* 2 */
}

/**
 * Remove default vertical scrollbar in IE 8/9/10/11.
 */
textarea {
    overflow: auto;
}

/**
 * Don't inherit the `font-weight` (applied by a rule above).
 * NOTE: the default cannot safely be changed in Chrome and Safari on OS X.
 */
optgroup {
    font-weight: bold;
}

/* Tables
   ========================================================================== */
/**
 * Remove most spacing between table cells.
 */
table {
    border-collapse: collapse;
    border-spacing: 0;
}

td,
th {
    padding: 0;
}

/*------------------------------------*    #RESET
\*------------------------------------*/
/**
 * As well as using normalize.css, it is often advantageous to remove all
 * margins from certain elements.
 */
body,
h1,
h2,
h3,
h4,
h5,
h6,
p,
blockquote,
pre,
dl,
dd,
ol,
ul,
form,
fieldset,
legend,
figure,
table,
th,
td,
caption,
hr {
    margin: 0;
    padding: 0;
}

/**
 * Give a help cursor to elements that give extra info on `:hover`.
 */
abbr[title],
dfn[title] {
    cursor: help;
}

/**
 * Remove underlines from potentially troublesome elements.
 */
u,
ins {
    text-decoration: none;
}

/**
 * Apply faux underlines to inserted text via `border-bottom`.
 */
ins {
    border-bottom: 1px solid;
}

/*------------------------------------*    #BOX-SIZING
\*------------------------------------*/
/**
 * Set the global `box-sizing` state to `border-box`.
 *
 * css-tricks.com/inheriting-box-sizing-probably-slightly-better-best-practice
 * paulirish.com/2012/box-sizing-border-box-ftw
 */
html {
    box-sizing: border-box;
}

*,
*:before,
*:after {
    box-sizing: inherit;
}

/*------------------------------------*    #SHARED
\*------------------------------------*/
/**
 * Where `margin-bottom` is concerned,this value will be the same as the
 * base line-height. This allows us to keep a consistent vertical rhythm.
 * As per: csswizardry.com/2012/06/single-direction-margin-declarations
 */
h1,
h2,
h3,
h4,
h5,
h6,
ul,
ol,
dl,
blockquote,
p,
address,
hr,
table,
fieldset,
figure,
pre {
    margin-bottom: 28px;
    margin-bottom: 1.5555555556rem;
}

/**
 * Where `margin-left` is concerned we want to try and indent certain elements
 * by a consistent amount. Define that amount once,here.
 */
ul,
ol,
dd {
    margin-left: 56px;
    margin-left: 3.1111111111rem;
}

/*------------------------------------*    #PAGE
\*------------------------------------*/
/**
 * High-, page-level styling.
 *
 * 1. Set the default `font-size` and `line-height` for the entire project,
 *    sourced from our default variables. The `font-size` is calculated to exist
 *    in ems, the `line-height` is calculated to exist unitlessly.
 * 2. Force scrollbars to always be visible to prevent awkward ‘jumps’ when
 *    navigating between pages that do/do not have enough content to produce
 *    scrollbars naturally.
 * 3. Ensure the page always fills at least the entire height of the viewport.
 * 4. Prevent certain mobile browsers from automatically zooming fonts.
 * 5. Fonts on OSX will look more consistent with other systems that do not
 *    render text using sub-pixel anti-aliasing.
 */
html {
    font-size: 1.125em;
    /* [1] */
    line-height: 1.5555555556;
    /* [1] */
    background-color: #fff;
    color: #231F20;
    overflow-y: scroll;
    /* [2] */
    min-height: 100%;
    /* [3] */
    -webkit-text-size-adjust: 100%;
    /* [4] */
    -ms-text-size-adjust: 100%;
    /* [4] */
    -moz-osx-font-smoothing: grayscale;
    /* [5] */
    -webkit-font-smoothing: antialiased;
    /* [5] */
}

/*------------------------------------*    #PAGE
\*------------------------------------*/
html {
    font-family: "proxima-nova", sans-serif;
    color: #231F20;
}

/*------------------------------------*    #HEADINGS
\*------------------------------------*/
/**
 * Headings 1–6.
 */
h1 {
    font-size: 36px;
    font-size: 2rem;
    line-height: 1.5555555556;
}

h2 {
    font-size: 24px;
    font-size: 1.3333333333rem;
    line-height: 1.1666666667;
}

h3 {
    font-size: 21px;
    font-size: 1.1666666667rem;
    line-height: 1.3333333333;
}

h4 {
    font-size: 20px;
    font-size: 1.1111111111rem;
    line-height: 1.4;
}

h5 {
    font-size: 16px;
    font-size: 0.8888888889rem;
    line-height: 1.75;
}

h6 {
    font-size: 14px;
    font-size: 0.7777777778rem;
    line-height: 2;
}

/*------------------------------------*    #PARAGRAPHS
\*------------------------------------*/
/**
 * The `.lede` class is used to make the introductory text (usually a paragraph)
 * of a document slightly larger: en.wikipedia.org/wiki/Lede_(news)
 */
.lede {
    font-size: 18px;
    font-size: 1rem;
    line-height: 1.5555555556;
}

/*------------------------------------*    #LINKS
\*------------------------------------*/
a {
    color: #154284;
    text-decoration: none;
    -webkit-transition: color 0.3s ease-out, background 0.3s ease-out, border 0.3s ease-out;
    transition: color 0.3s ease-out, background 0.3s ease-out, border 0.3s ease-out;
}

    a:hover,
    a:active,
    a:focus {
        color: #0c71ac;
    }

/*------------------------------------*    #IMAGES
\*------------------------------------*/
/**
 * 1. Fluid images for responsive purposes.
 * 2. Offset `alt` text from surrounding copy.
 * 3. Setting `vertical-align` removes the whitespace that appears under `img`
 *    elements when they are dropped into a page as-is. Safer alternative to
 *    using `display: block;`.
 */
img {
    max-width: 100%;
    /* [1] */
    font-style: italic;
    /* [2] */
    vertical-align: middle;
    /* [3] */
}

    /**
 * 1. Google Maps breaks if `max-width: 100%` acts upon it; use their selector
 *    to remove the effects.
 * 2. If a `width` and/or `height` attribute have been explicitly defined, let’s
 *    not make the image fluid.
 */
    .gm-style img,
    img[width],
    img[height] {
        /* [2] */
        max-width: none;
    }

/*------------------------------------*    #WRAPPERS
\*------------------------------------*/
.wrapper {
    position: relative;
    width: 90%;
    max-width: 1170px;
    margin: 0 auto;
    z-index: 500;
}

.wrapper--small {
    max-width: 770px;
}

.band--curve .wrapper {
    z-index: 510;
}

/*------------------------------------*    #LAYOUT
\*------------------------------------*/
/**
 * Modified inuitcss layout system, using `float: left;` instead of
 * `display: inline-block;` to avoid the white-space issue caused by
 * `display: inline-block;`. Combine the layout items with
 * the widths found in `trumps.widths`.
 */
/**
 * Begin a layout group.
 */
.layout {
    list-style: none;
    margin: 0;
    padding: 0;
    margin-left: -35px;
}

/**
     * 1. Cause columns to stack side-by-side.
     * 2. Space columns apart.
     * 3. Align columns to the tops of each other.
     * 4. Full-width unless told to behave otherwise.
     * 5. Required to combine fluid widths and fixed gutters.
     */
.layout__item {
    display: block;
    /* [1] */
    float: left;
    /* [1] */
    padding-left: 35px;
    /* [2] */
    vertical-align: top;
    /* [3] */
    width: 100%;
    /* [4] */
}

/**
     * Layouts with large gutters.
     */
.layout--large {
    margin-left: -105px;
}

    .layout--large > .layout__item {
        padding-left: 105px;
    }

.layout--rev .layout__item {
    float: right;
}

/*------------------------------------*    #FLAG
\*------------------------------------*/
/**
 * The flag object is a design pattern similar to the media object, however it
 * utilises `display: table[-cell];` to give us control over the vertical
 * alignments of the text and image. csswizardry.com/2013/05/the-flag-object
 */
/**
 * 1. Allows us to control vertical alignments
 * 2. Force the object to be the full width of its parent. Combined with [1],
 *    this makes the object behave in a quasi-`display: block;` manner.
 */
.flag {
    display: table;
    /* [1] */
    width: 100%;
    /* [2] */
    table-layout: fixed;
}

/**
     * Items within a flag object. There should only ever be one of each.
     *
     * 1. Default to aligning content to their middles.
     */
.flag__img,
.flag__body {
    display: table-cell;
    vertical-align: middle;
    /* [1] */
}

/**
     * Flag images have a space between them and the body of the object.
     */
.flag__img {
    padding-left: 30px;
    padding-bottom: 15px;
    float: right;
    max-width: 50%;
    position: relative;
}

    .flag__img > img,
    .flag__img > a > img {
        display: block;
        max-height: 300px;
        /*max-width: none;*/
    }

    .flag__img i {
        visibility: hidden;
        opacity: 0;
        position: absolute;
        top: 50%;
        left: 50%;
        margin-top: -25px;
        margin-left: -5px;
        color: #231F20;
        padding: 10px;
        background: rgba(255, 255, 255, 0.75);
        border-radius: 5px;
        font-size: 1.2em;
        -webkit-transition: all 0.3s ease;
        -moz-transition: all 0.3s ease;
        -o-transition: all 0.3s ease;
        transition: all 0.3s ease;
    }

    .flag__img:hover i {
        visibility: visible;
        opacity: 1;
    }

/**
     * The container for the main content of the flag object.
     *
     * 1. Forces the `.flag__body` to take up all remaining space.
     */
.flag__body {
    width: 100%;
    /* [1] */
}

    .flag__body,
    .flag__body > :last-child {
        margin-bottom: 0;
    }

/**
     * Vertically bottom aligned flag objects.
     */
.flag--bottom > .flag__img,
.flag--bottom > .flag__body {
    vertical-align: top;
}

/**
     * Responsive flag objects.
     *
     * There is a very pragmatic, simple implementation of a responsive flag
     * object, which simply places the text-content beneath the image-content.
     *
     * We use a `max-width` media query because:
     *
     * a) it is the least verbose method in terms of amount of code required.
     * b) the flag object’s default state is image-next-to-text, so its stacked
     *    state is the exception, rather than the rule.
     */
@media screen and (max-width: 81.25em) {
    .flag--responsive {
        /**
             * Rework the spacings on regular flag objects.
             */
    }

        .flag--responsive,
        .flag--responsive > .flag__img,
        .flag--responsive > .flag__body {
            display: block;
        }

            .flag--responsive > .flag__img {
                padding-right: 0;
                padding-left: 0;
                margin-bottom: 35px;
            }
}

/*------------------------------------*    #BUTTONS
\*------------------------------------*/
/**
 * A simple button object.
 */
/**
 * 1. Allow us to style box model properties.
 * 2. Line different sized buttons up a little nicer.
 * 3. Make buttons inherit font styles (often necessary when styling `input`s as
 *    buttons).
 * 4. Reset/normalize some styles.
 * 5. Force all button-styled elements to appear clickable.
 * 6. Fixes odd inner spacing in IE7.
 * 7. Subtract the border size from the padding value so that buttons do not
 *    grow larger as we add borders.
 */
.btn {
    display: inline-block;
    /* [1] */
    vertical-align: middle;
    /* [2] */
    font: inherit;
    /* [3] */
    text-align: center;
    /* [4] */
    margin: 0;
    /* [4] */
    cursor: pointer;
    /* [5] */
    overflow: visible;
    /* [6] */
    padding: 0 0;
    /* [7] */
    background-color: #0c71ac;
    border: none;
    /* [4] */
    border-radius: 5px;
}

    .btn,
    .btn:hover,
    .btn:active,
    .btn:focus {
        text-decoration: none;
        /* [4] */
        color: #fff;
    }

        /**
 * Fix a Firefox bug whereby `input type="submit"` gains 2px extra padding.
 */
        .btn::-moz-focus-inner {
            border: 0;
            padding: 0;
        }

/**
     * Full-width buttons.
     */
.btn--full {
    width: 100%;
}

/*------------------------------------*    #LIST-INLINE
\*------------------------------------*/
/**
 * The list-inline object simply displays a list of items in one line.
 */
.list-inline {
    margin: 0;
    padding: 0;
    list-style: none;
}

    .list-inline > li {
        display: inline-block;
    }

/*------------------------------------*    #LIST-BARE
\*------------------------------------*/
/**
 * The list-bare object simply removes any indents and bullet points from lists.
 */
.list-bare,
.btn-group,
.pagination__nav {
    margin: 0;
    padding: 0;
    list-style: none;
}

/*------------------------------------*    #LIST-UI
\*------------------------------------*/
/**
 * The UI list object creates blocky list items with a keyline separator out of
 * a `ul` or `ol`.
 */
.list-ui,
.list-ui__item,
.list-ui > li {
    border: 0 solid #00b0e1;
}

.list-ui {
    margin: 0;
    padding: 0;
    list-style: none;
    border-top-width: 2px;
}

    .list-ui__item,
    .list-ui > li {
        padding: 10px;
        border-bottom-width: 2px;
    }

.list-title {
    color: #fff;
    font-weight: bold;
    margin-bottom: 0.5em;
}

/*------------------------------------*    #TYPOGRAPHY
\*------------------------------------*/
ul,
ol {
    margin-left: 28px;
}

h1,
h2,
h3 {
    line-height: 1.2;
}

.page-title {
    margin-bottom: 25px;
    text-transform: uppercase;
    word-wrap: break-word;
}

@media screen and (max-width: 45em) {
    .page-title {
        font-size: 1.6em;
    }
}

@media screen and (min-width: 45em) {
    .page-title {
        word-wrap: normal;
    }
}

.sub-title {
    margin-bottom: 50px;
    text-transform: uppercase;
    word-wrap: break-word;
}

    .sub-title:after {
        content: '';
        display: block;
        height: 5px;
        width: 100%;
        background: url(../img/backgrounds/dot.svg) left top repeat-x;
        margin-top: 25px;
    }

.no-svg .sub-title:after {
    background-image: url(../img/backgrounds/dot.png);
}

@media screen and (min-width: 45em) {
    .sub-title {
        word-wrap: normal;
    }
}

.sub-title--small {
    margin-bottom: 25px;
    font-size: 16px;
    font-size: 0.8888888889rem;
    line-height: 1.3;
}

    .sub-title--small:after {
        content: '';
        display: block;
        height: 5px;
        width: 100%;
        background: url(../img/backgrounds/dot.svg) left top repeat-x;
        margin-top: 10px;
    }

.no-svg .sub-title--small:after {
    background-image: url(../img/backgrounds/dot.png);
}

.sub-title--b:before {
    content: '';
    display: block;
    height: 5px;
    width: 100%;
    background: url(../img/backgrounds/dot.svg) left top repeat-x;
    margin-bottom: 25px;
}

.no-svg .sub-title--b:before {
    background-image: url(../img/backgrounds/dot.png);
}

.lede {
    font-weight: 600;
    color: #154284;
    line-height: 1.5;
}

@media screen and (min-width: 64em) {
    .lede {
        font-size: 21px;
        font-size: 1.1666666667rem;
        line-height: 1.5;
    }
}

.callout {
    margin-bottom: 25px;
}

    .callout:before {
        content: '';
        display: block;
        height: 5px;
        width: 100%;
        background: url(../img/backgrounds/dot.svg) left top repeat-x;
        margin-bottom: 25px;
    }

.no-svg .callout:before {
    background-image: url(../img/backgrounds/dot.png);
}

.callout:after {
    content: '';
    display: block;
    height: 5px;
    width: 100%;
    background: url(../img/backgrounds/dot.svg) left top repeat-x;
    margin-top: 25px;
}

.no-svg .callout:after {
    background-image: url(../img/backgrounds/dot.png);
}

.callout--no-border-top:before {
    display: none;
}

.banner--brand-alt .callout:before {
    content: '';
    display: block;
    height: 5px;
    width: 100%;
    background: url(../img/backgrounds/dot-blue-light.svg) left top repeat-x;
    margin-bottom: 25px;
}

.no-svg .banner--brand-alt .callout:before {
    background-image: url(../img/backgrounds/dot-blue-light.png);
}

.banner--brand-alt .callout:after {
    content: '';
    display: block;
    height: 5px;
    width: 100%;
    background: url(../img/backgrounds/dot-blue-light.svg) left top repeat-x;
    margin-top: 25px;
}

.no-svg .banner--brand-alt .callout:after {
    background-image: url(../img/backgrounds/dot-blue-light.png);
}

.text-center {
    text-align: center;
}

.srt {
    clip: rect(1px, 1px, 1px, 1px);
    position: absolute !important;
    height: 1px;
    width: 1px;
    overflow: hidden;
}

.mb {
    margin-bottom: 25px !important;
}

.mb--large {
    margin-bottom: 50px !important;
}

.mb--palm {
    margin-bottom: 25px !important;
}

@media screen and (min-width: 45em) {
    .mb--palm {
        margin-bottom: 0 !important;
    }
}

.mb0 {
    margin-bottom: 0 !important;
}

/*------------------------------------*    #BANNER
\*------------------------------------*/
.banner {
    position: relative;
    margin-bottom: 25px;
    margin-top: -15px;
}

    .banner img {
        width: 100%;
        max-width: none;
    }

    .banner:after {
        content: '';
        position: absolute;
        bottom: -1px;
        right: 0;
        left: 0;
        display: block;
        width: 100%;
        height: 96px;
        background: transparent url(../img/backgrounds/curve-mid-sm.svg) center bottom no-repeat;
    }

.no-svg .banner:after {
    background-image: url(../img/backgrounds/curve-mid-sm.png);
}

@media screen and (min-width: 45em) {
    .banner:after {
        height: 138px;
        background: transparent url(../img/backgrounds/curve-mid-md.svg) center bottom no-repeat;
    }

    .no-svg .banner:after {
        background-image: url(../img/backgrounds/curve-mid-md.png);
    }
}

@media screen and (min-width: 64em) {
    .banner:after {
        height: 563px;
        background: transparent url(../img/backgrounds/curve-mid-lg.svg) center bottom no-repeat;
    }

    .no-svg .banner:after {
        background-image: url(../img/backgrounds/curve-mid-lg.png);
    }
}

@media screen and (min-width: 45em) {
    .banner {
        margin-top: -40px;
    }
}

@media screen and (min-width: 81.25em) {
    .banner {
        margin-top: -188px;
    }
}

.banner--brand-alt:before {
    content: '';
    display: block;
    position: absolute;
    z-index: 1;
    bottom: 90px;
    right: 0;
    left: 0;
    width: 100%;
    height: 882px;
    opacity: 0.3;
    background: transparent url(../img/backgrounds/lines-red.svg) center top no-repeat;
}

.no-svg .banner--brand-alt:before {
    background-image: url(../img/backgrounds/lines-red.png);
}

.banner__container {
    position: absolute;
    top: 50px;
    right: 0;
    bottom: 0;
    left: 0;
    z-index: 1;
}

@media screen and (min-width: 45em) {
    .banner__container {
        top: 75px;
    }
}

@media screen and (min-width: 81.25em) {
    .banner__container {
        top: 250px;
    }
}

.banner--brand-alt .banner__container {
    color: #ee6734;
}

.banner__title {
    margin-bottom: 50px;
    text-transform: uppercase;
    word-wrap: break-word;
    color: #154284;
    font-size: 24px;
    font-size: 1.3333333333rem;
    line-height: 1.3;
}

    .banner__title:after {
        content: '';
        display: block;
        height: 5px;
        width: 100%;
        background: url(../img/backgrounds/dot-white.svg) left top repeat-x;
        margin-top: 25px;
    }

.no-svg .banner__title:after {
    background-image: url(../img/backgrounds/dot-white.png);
}

@media screen and (min-width: 45em) {
    .banner__title {
        word-wrap: normal;
    }
}

@media screen and (min-width: 45em) {

    .banner__title,
    .banner .btn-group {
        width: 66%;
    }
}

@media screen and (min-width: 64em) {

    .banner__title,
    .banner .btn-group {
        width: 33%;
    }
}

/*------------------------------------*    #NAV-TOGGLE
\*------------------------------------*/
.nav-toggle {
    display: block;
    background: #cceff9;
    border: none;
    vertical-align: middle;
    padding: 0;
    overflow: hidden;
    height: 50px;
    padding: 0 0 0 10px;
    border-radius: 5px;
    -webkit-transition: all 0.3s ease-out;
    transition: all 0.3s ease-out;
}

@media screen and (min-width: 64em) {
    .nav-toggle {
        display: none;
    }
}

.nav-toggle:hover,
.nav-toggle:active,
.nav-toggle:focus {
    color: #154284;
}

.js-nav-toggle.active {
    color: #154284;
    background-color: #00b0e1;
}

.nav-toggle__icon {
    display: block;
    width: 50px;
    height: 50px;
    padding: 0;
    vertical-align: middle;
    margin: 0;
    position: relative;
    float: right;
}

.nav-toggle__icon-wrap {
    width: 24px;
    height: 16px;
    -webkit-transform: rotate(0deg);
    -ms-transform: rotate(0deg);
    transform: rotate(0deg);
    position: absolute;
    display: block;
    top: 16px;
    left: 13px;
}

    .nav-toggle__icon-wrap span {
        background-color: #154284;
        display: block;
        height: 3px;
        width: 100%;
        position: absolute;
        left: 0;
        -webkit-transform: rotate(0deg);
        -ms-transform: rotate(0deg);
        transform: rotate(0deg);
        -webkit-transition: 0.3s ease-in-out;
        transition: 0.3s ease-in-out;
    }

        .nav-toggle__icon-wrap span:nth-child(1) {
            top: 0;
        }

        .nav-toggle__icon-wrap span:nth-child(2),
        .nav-toggle__icon-wrap span:nth-child(3) {
            top: 8px;
        }

        .nav-toggle__icon-wrap span:nth-child(4) {
            top: 16px;
        }

.nav-toggle.active .nav-toggle__icon-wrap span:nth-child(1),
.nav-toggle.active .nav-toggle__icon-wrap span:nth-child(4) {
    top: 8px;
    width: 0%;
    left: 50%;
}

.nav-toggle.active .nav-toggle__icon-wrap span:nth-child(2) {
    -webkit-transform: rotate(45deg);
    -ms-transform: rotate(45deg);
    transform: rotate(45deg);
}

.nav-toggle.active .nav-toggle__icon-wrap span:nth-child(3) {
    -webkit-transform: rotate(-45deg);
    -ms-transform: rotate(-45deg);
    transform: rotate(-45deg);
}

.nav-toggle__text {
    float: left;
    font-weight: 600;
    text-transform: uppercase;
    vertical-align: middle;
    font-size: 14px;
    font-size: 0.7777777778rem;
    line-height: 50px;
}

/*------------------------------------*    #SITE-NAV
\*------------------------------------*/
.site-nav__home {
    display: inline-block;
    position: relative;
    z-index: 2;
}

@media screen and (min-width: 64em) {
    .site-nav__home {
        margin-top: 37.5px;
    }
}

.site-logo {
    margin: 25px 0;
    display: block;
    width: 200px;
}

.site-nav__wrap {
    padding: 25px;
    margin-top: 10px;
    border: 3px solid #00b0e1;
    border-radius: 5px;
    display: none;
    background-color: #fff;
}

@media screen and (min-width: 64em) {
    .site-nav__wrap {
        position: absolute;
        top: 20px;
        left: 0;
        padding: 0;
        margin: 0;
        width: 100%;
        display: block;
        border: none;
        border-radius: 0;
    }
}

.js-site-nav__wrap.active {
    display: block;
}

.site-nav__list,
.site-nav__lang {
    list-style: none;
    margin: 0;
}

@media screen and (min-width: 64em) {
    .site-nav__list {
        position: absolute;
        top: 59px;
        right: 0;
    }
}

.site-nav__list li {
    display: block;
    padding: 5px 0;
}

@media screen and (min-width: 64em) {
    .site-nav__list li {
        display: inline-block;
        padding: 0;
        margin-left: 15px;
    }
}

@media screen and (min-width: 81.25em) {
    .site-nav__list li {
        margin-left: 50px;
    }
}

.site-nav__list a {
    border-bottom: 2px solid #00b0e1;
    font-size: 16px;
    font-size: 0.8888888889rem;
    line-height: 1;
}

    .site-nav__list a:hover,
    .site-nav__list a:active,
    .site-nav__list a:focus,
    .site-nav__list a.active {
        border-color: #154284;
    }

    .site-nav__list a.active {
        color: #154284;
        font-weight: 700;
    }

.site-nav__lang {
    margin-bottom: 25px;
}

@media screen and (min-width: 64em) {
    .site-nav__lang {
        float: right;
    }
}

.site-nav__lang li {
    display: inline-block;
}

.site-nav__lang a {
  display: block;
  height: 30px;
  text-align: center;
  text-transform: uppercase;
  border-radius: 5px;
  font-size: 12px;
  font-size: 0.6666666667rem;
  line-height: 30px;
  padding: 0 1em;
}

    .site-nav__lang a:hover,
    .site-nav__lang a:active,
    .site-nav__lang a:focus,
    .site-nav__lang a.active {
        background-color: #cceff9;
    }

    .site-nav__lang a.active {
        font-weight: 600;
    }

/*------------------------------------*    #PAGE-HEAD
\*------------------------------------*/
.page-head {
    position: relative;
    z-index: 520;
    height: 188px;
    background: transparent url(../img/backgrounds/curve-top-sm.svg) center bottom no-repeat;
    /*#cceff9*/
}

.no-svg .page-head {
    background-image: url(../img/backgrounds/curve-top-sm.png);
}

.home .page-head {
    background-color: transparent;
}

.has-banner .page-head {
    background-color: transparent;
}

@media screen and (min-width: 45em) {
    .page-head {
        background: transparent url(../img/backgrounds/curve-top-md.svg) center bottom no-repeat;
        /*#cceff9*/
    }

    .no-svg .page-head {
        background-image: url(../img/backgrounds/curve-top-md.png);
    }
}

@media screen and (min-width: 64em) {
    .page-head {
        background: transparent url(../img/backgrounds/curve-top-lg.svg) center bottom no-repeat;
        /*#cceff9*/
    }

    .no-svg .page-head {
        background-image: url(../img/backgrounds/curve-top-lg.png);
    }
}

/*------------------------------------*    #PAGE-FOOT
\*------------------------------------*/
.page-foot {
    background: transparent url(../img/backgrounds/curve-bottom-sm.svg) center bottom no-repeat;
}

.no-svg .page-foot {
    background-image: url(../img/backgrounds/curve-bottom-sm.png);
}

@media screen and (min-width: 45em) {
    .page-foot {
        background: transparent url(../img/backgrounds/curve-bottom-md.svg) center bottom no-repeat;
    }

    .no-svg .page-foot {
        background-image: url(../img/backgrounds/curve-bottom-md.png);
    }
}

@media screen and (min-width: 64em) {
    .page-foot {
        background: transparent url(../img/backgrounds/curve-bottom-lg.svg) center bottom no-repeat;
    }

    .no-svg .page-foot {
        background-image: url(../img/backgrounds/curve-bottom-lg.png);
    }
}

.page-micro {
    padding: 25px 0 100px 0;
    /* Permalink - use to edit and share this gradient: http://colorzilla.com/gradient-editor/#154284+0,00b0e1+25,ffffff+100 */
    background: #154284;
    /* Old browsers */
    background: -moz-linear-gradient(left, #154284 0%, #00b0e1 25%, #ffffff 100%);
    /* FF3.6-15 */
    background: -webkit-linear-gradient(left, #154284 0%, #00b0e1 25%, #ffffff 100%);
    /* Chrome10-25,Safari5.1-6 */
    background: linear-gradient(to right, #154284 0%, #00b0e1 25%, #ffffff 100%);
    /* W3C, IE10+, FF16+, Chrome26+, Opera12+, Safari7+ */
    filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#154284', endColorstr='#ffffff', GradientType=1);
    /* IE6-9 */
}

    .page-micro a {
        border: none;
    }

.page-micro__copy {
    display: block;
    margin-bottom: 10px;
}

@media screen and (min-width: 45em) {
    .page-micro__copy {
        float: left;
        margin-bottom: 0;
    }
}

.page-micro__credits {
    display: block;
    font-size: 12px;
    font-size: 0.6666666667rem;
    line-height: 2.3333333333;
}

@media screen and (min-width: 45em) {
    .page-micro__credits {
        float: right;
    }
}

.impuls img {
    width: 100px;
}

/*------------------------------------*    #BUTTONS
\*------------------------------------*/
.btn {
    padding: 15px 15px;
    font-weight: 700;
    text-transform: uppercase;
    -webkit-transition: all 0.3s ease-out;
    transition: all 0.3s ease-out;
    font-size: 12px;
    font-size: 0.6666666667rem;
    line-height: 1.2;
}

    .btn:hover,
    .btn:active,
    .btn:focus {
        background-color: #3ea2e0;
    }

.btn--icon {
    text-align: left;
}

    .btn--icon .fa {
        float: right;
        margin-left: 25px;
        font-size: 14px;
        font-size: 0.7777777778rem;
        line-height: 1;
    }

.btn--border {
    background-color: #99dff3;
    /*rgba(255, 255, 255, 0.1);*/
    border: 3px solid rgba(255, 255, 255, 0.4);
}

    .btn--border:hover,
    .btn--border:active,
    .btn--border:focus {
        border-color: #154284;
        background-color: #154284;
    }

.flex-active .btn--border {
    border-color: #154284;
    background-color: #154284;
}

.btn-group > li {
    margin-bottom: 10px;
}

    .btn-group > li:last-child {
        margin-bottom: 0;
    }

.btn-group--l > li {
    margin-bottom: 20px;
}

.btn-group--l .btn {
    font-size: 14px;
    font-size: 0.7777777778rem;
    line-height: 1.2;
}

.list-inline .btn {
    margin-bottom: 5px;
}

/*------------------------------------*    #BANDS
\*------------------------------------*/
.band {
    padding: 50px 0;
}

@media screen and (min-width: 45em) {
    .band {
        padding: 80px 0px;
    }
}

.band--small {
    padding: 50px 0;
}

@media screen and (min-width: 45em) {
    .band--small {
        padding: 75px 0;
    }
}

.band--tint {
    background-color: #cceff9;
}

.band--curve {
    padding-top: 40px;
    padding-bottom: 0;
    position: relative;
}

    .band--curve:after {
        content: '';
        display: block;
        width: 100%;
        height: 138px;
        z-index: 10;
        position: relative;
        background: transparent url(../img/backgrounds/curve-mid-sm.svg) center bottom no-repeat;
    }

.no-svg .band--curve:after {
    background-image: url(../img/backgrounds/curve-mid-sm.png);
}

@media screen and (min-width: 45em) {
    .band--curve:after {
        height: 138px;
        background: transparent url(../img/backgrounds/curve-mid-md.svg) center bottom no-repeat;
    }

    .no-svg .band--curve:after {
        background-image: url(../img/backgrounds/curve-mid-md.png);
    }
}

@media screen and (min-width: 64em) {
    .band--curve:after {
        height: 563px;
        margin-top: -450px;
        background: transparent url(../img/backgrounds/curve-mid-lg.svg) center bottom no-repeat;
    }

    .no-svg .band--curve:after {
        background-image: url(../img/backgrounds/curve-mid-lg.png);
    }
}

.band--img {
    background-size: cover;
    background-position: center center;
    margin-top: -85px;
    padding-top: 125px;
}

    .band--img:before {
        content: " ";
        display: block;
        position: absolute;
        width: 100%;
        height: 100%;
        background: #cceff9;
        top: 0;
        opacity: .75;
        z-index: 1;
    }

    .band--img .page-title,
    .band--img .callout {
        color: #154284;
    }

.cta {
    position: relative;
}

    .cta:before {
        content: '';
        display: block;
        position: absolute;
        top: -736px;
        right: 0;
        bottom: 0;
        left: 0;
        width: 100%;
        height: 882px;
        background: transparent url(../img/backgrounds/lines.svg) center top no-repeat;
    }

.no-svg .cta:before {
    background-image: url(../img/backgrounds/lines.png);
}

/*------------------------------------*    #
\*------------------------------------*/
.product-section {
    margin-bottom: 25px;
}

    .product-section:after {
        content: '';
        display: block;
        height: 5px;
        width: 100%;
        background: url(../img/backgrounds/dot.svg) left top repeat-x;
        margin-top: 50px;
    }

.no-svg .product-section:after {
    background-image: url(../img/backgrounds/dot.png);
}

.product-section .layout__item {
    margin-bottom: 25px;
}

/*@media screen and (min-width: 45em) {
      .product-section .layout__item {
        margin-bottom: 0; } }*/

@media screen and (min-width: 45em) {
    .product-section .layout + .layout {
        margin-top: 50px;
    }
}

[data-mh="products"] {
    position: relative;
    padding-bottom: 50px;
}

.layout__item:nth-child(1) [data-mh="products"] {
    margin-bottom: 25px;
}

@media screen and (min-width: 45em) {
    .layout__item:nth-child(1) [data-mh="products"] {
        margin-bottom: 0;
    }
}

[data-mh="products"]:after {
    position: absolute;
    bottom: 0;
    width: 100%;
}

.product-section:last-of-type {
    margin-bottom: 0;
}

.product__img {
    margin-bottom: 25px;
}

    .product__img img {
        margin: 0 auto;
    }

.product__title {
    margin-bottom: 25px;
    padding: 15px 25px;
    background-color: #cceff9;
    color: #154284;
    border-radius: 5px;
    font-size: 17px;
    font-size: 0.9444444444rem;
    line-height: 1.3;
}

.product__body {
    font-size: 15px;
    font-size: 0.8333333333rem;
    line-height: 1.6;
}

    .product__body > :last-child {
        margin-bottom: 0;
    }

.product__number {
    display: block;
}

/*------------------------------------*    #BOX
\*------------------------------------*/
.box {
    margin-bottom: 25px;
    padding: 20px;
    border-radius: 5px;
    font-size: 15px;
    font-size: 0.8333333333rem;
    line-height: 1.8666666667;
}

    .box > :last-child {
        margin-bottom: 0;
    }

.box--flush {
    padding-top: 0;
    padding-right: 0;
    padding-left: 0;
}

.box--primary {
    background-color: #99dff3;
}

.box--secondary {
    background-color: #00b0e1;
}

.box--tertiary {
    background-color: #0c71ac;
}

    .box--tertiary a {
        color: #99dff3;
    }

        .box--primary a:hover,
        .box--primary a:active,
        .box--primary a:focus,
        .box--secondary a:hover,
        .box--secondary a:active,
        .box--secondary a:focus,
        .box--tertiary a:hover,
        .box--tertiary a:active,
        .box--tertiary a:focus {
            color: #fff;
        }

.box__title {
    padding-bottom: 5px;
    margin-bottom: 10px;
    text-transform: uppercase;
    color: #fff;
    border-bottom: 2px solid #fff;
    font-size: 16px;
    font-size: 0.8888888889rem;
    line-height: 1.3;
}

.box--border {
    border: 3px solid #00b0e1;
    background-color: #fff;
}

.box--pageHead ul.list-ui {
    max-height: 11em;
    overflow: auto;
}

.promo {
    text-align: center;
    -webkit-transition: all 0.3s ease;
    -moz-transition: all 0.3s ease;
    -o-transition: all 0.3s ease;
    transition: all 0.3s ease;
}

.promo__number {
    margin: 0 auto;
    width: 40px;
    height: 56px;
    color: #fff;
    margin-bottom: 10px;
    padding-top: 1.3em;
    background: transparent url("../img/backgrounds/drop.svg") left top no-repeat;
}

.promo__title {
    font-weight: 400;
    font-style: italic;
    color: #0c71ac;
    font-size: 21px;
    font-size: 1.1666666667rem;
    line-height: 1.3;
}

.promo:hover {
    box-shadow: 0px 5px 20px -5px #999;
    background: #F8FCFB;
}

/*------------------------------------*    #LIST-UI
\*------------------------------------*/
.list-ui {
    border-top: none;
    line-height: 1.6;
}

    .list-ui > li {
        overflow: hidden;
        padding-right: 0;
        padding-left: 0;
    }

    .list-ui > :first-child {
        padding-top: 0;
    }

    .list-ui > :last-child {
        border-bottom: 0;
        padding-bottom: 0;
    }

    .list-ui .fa {
        display: block;
        float: left;
        margin-right: 10px;
        margin-top: 4px;
        line-height: 1;
        font-size: 14px;
        font-size: 0.7777777778rem;
        line-height: 1;
    }

    .list-ui .fa-box {
        float: left;
    }

        .list-ui .fa-box p {
            margin-bottom: 0;
        }

.list-ui--neg {
    color: #fff;
}

    .list-ui--neg > li {
        border-color: #fff;
    }

/*------------------------------------*    #BREADCRUMBS
\*------------------------------------*/
.breadcrumbs {
    margin-bottom: 25px;
    overflow: hidden;
    display: none;
}

@media screen and (min-width: 45em) {
    .breadcrumbs {
        margin-bottom: 0;
        display: block;
    }
}

.breadcrumbs__list {
    margin: 0;
    list-style: none;
    color: #59cbeb;
    font-size: 14px;
    font-size: 0.7777777778rem;
    line-height: 1.5;
    background: rgba(255, 255, 255, 1);
    padding: 2px 15px;
    border-radius: 5px;
}

    .breadcrumbs__list > li {
        padding: 5px 0;
    }

/*.breadcrumbs__list a {
    border-bottom: 1px solid #00b0e1; }*/
@media screen and (min-width: 45em) {
    .breadcrumbs__list {
        float: right;
    }

        .breadcrumbs__list > li {
            display: inline-block;
        }

            .breadcrumbs__list > li + li:before {
                content: '\00A0•\00A0\00A0';
            }
}

.banner--brand-alt .breadcrumbs__list {
    color: #154284;
}

    .banner--brand-alt .breadcrumbs__list a {
        color: #ee6734;
        border-color: #ee6734;
    }

        .banner--brand-alt .breadcrumbs__list a:hover,
        .banner--brand-alt .breadcrumbs__list a:active,
        .banner--brand-alt .breadcrumbs__list a:focus {
            color: #154284;
            border-color: #154284;
        }

/*------------------------------------*    #IMAGES
\*------------------------------------*/
.img--border {
    border: 3px solid #00b0e1;
    border-radius: 5px;
}

.has-banner .banner__container .img--border {
    border-color: #fff;
}

/*------------------------------------*    #FORMS
\*------------------------------------*/
.form-fields em {
    font-style: normal;
    color: #59cbeb;
    -webkit-transition: color 0.3s ease-out;
    transition: color 0.3s ease-out;
}

.form-fields label {
    margin-bottom: 10px;
    display: block;
    cursor: pointer;
    font-weight: bold;
    color: #154284;
    -webkit-transition: color 0.3s ease-out;
    transition: color 0.3s ease-out;
}

.form-fields__field {
    margin-bottom: 25px;
}

.text-input,
textarea {
    width: 100%;
    padding: 10px;
    border: 2px solid #00b0e1;
    -webkit-transition: border 0.3s ease-out;
    transition: border 0.3s ease-out;
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    border-radius: 5px;
    outline: none;
}

    .text-input:focus,
    textarea:focus {
        border-color: #0c71ac;
        color: #000;
    }

@media screen and (min-width: 64em) {
    .text-input {
        width: 70%;
    }
}

.selectboxit-container .selectboxit.text-input {
    border-color: #00b0e1;
    background: white;
    min-width: 120px;
}

    .selectboxit-container .selectboxit.text-input:hover,
    .selectboxit-container .selectboxit.text-input:focus,
    .selectboxit-container .selectboxit.text-input:active {
        background: #cceff9;
    }


textarea {
    height: 200px;
}

.error label,
.error label em {
    color: red;
}

.error .text-input,
.error textarea {
    border-color: red;
}

/*------------------------------------*    #POSTS
\*------------------------------------*/
.post {
    margin-bottom: 50px;
}

    .post:after {
        content: '';
        display: block;
        height: 5px;
        width: 100%;
        background: url(../img/backgrounds/dot.svg) left top repeat-x;
        margin-top: 25px;
    }

.no-svg .post:after {
    background-image: url(../img/backgrounds/dot.png);
}

.post__title {
    color: #154284;
    margin-bottom: 10px;
}

.post__time {
    display: block;
    margin-bottom: 25px;
    color: #0c71ac;
    font-size: 15px;
    font-size: 0.8333333333rem;
    line-height: 1.3;
}

/*------------------------------------*    #PAGINATION
\*------------------------------------*/
.pagination {
    font-size: 15px;
    font-size: 0.8333333333rem;
    line-height: 1;
    position: relative;
    vertical-align: middle;
}

.pagination__nav {
    vertical-align: middle;
    display: inline-block;
}

    .pagination__nav li {
        display: inline-block;
    }

    .pagination__nav a {
        background-color: #cceff9;
        display: block;
        text-align: center;
        width: 40px;
        height: 40px;
        line-height: 40px;
        border-radius: 5px;
    }

        .pagination__nav a:hover,
        .pagination__nav a:active,
        .pagination__nav a:focus,
        .pagination__nav a.active {
            color: #fff;
            background-color: #00b0e1;
        }

a.pagination__wide {
    width: auto;
    padding: 0 10px;
}

.pagination--centered {
    text-align: center;
}

/*------------------------------------*    #EMBED RESPONSIVE
\*------------------------------------*/
.embed-responsive {
    position: relative;
    display: block;
    height: 0;
    padding: 0;
    overflow: hidden;
}

    .embed-responsive .embed-responsive-item,
    .embed-responsive iframe,
    .embed-responsive embed,
    .embed-responsive object {
        position: absolute;
        top: 0;
        left: 0;
        bottom: 0;
        height: 100%;
        width: 100%;
        border: 0;
    }

    .embed-responsive.embed-responsive-16by9 {
        padding-bottom: 56.25%;
    }

    .embed-responsive.embed-responsive-4by3 {
        padding-bottom: 75%;
    }

.map {
    margin-bottom: 25px;
    border: 10px solid #fff;
    border-radius: 10px;
    box-shadow: 0px 0px 8px 4px rgba(232, 245, 240, 0.2);
}

/*
 * jQuery FlexSlider v2.5.0
 * http://www.woothemes.com/flexslider/
 *
 * Copyright 2012 WooThemes
 * Free to use under the GPLv2 and later license.
 * http://www.gnu.org/licenses/gpl-2.0.html
 *
 * Contributing author: Tyler Smith (@mbmufffin)
 *
 */
/* ====================================================================================================================
 * RESETS
 * ====================================================================================================================*/
.flex-container a:hover,
.flex-slider a:hover,
.flex-container a:focus,
.flex-slider a:focus {
    outline: none;
}

.slides,
.slides > li,
.flex-control-nav,
.flex-direction-nav {
    margin: 0;
    padding: 0;
    list-style: none;
}

.flex-pauseplay span {
    text-transform: capitalize;
}

/* ====================================================================================================================
 * BASE STYLES
 * ====================================================================================================================*/
.flexslider {
    margin: 0;
    padding: 0;
}

    .flexslider .slides > li {
        display: none;
        -webkit-backface-visibility: hidden;
    }

    .flexslider .slides img {
        width: 100%;
        display: block;
    }

    .flexslider .slides:after {
        content: "\0020";
        display: block;
        clear: both;
        visibility: hidden;
        line-height: 0;
        height: 0;
    }

html[xmlns] .flexslider .slides {
    display: block;
}

* html .flexslider .slides {
    height: 1%;
}

.no-js .flexslider .slides > li:first-child {
    display: block;
}

/* ====================================================================================================================
 * DEFAULT THEME
 * ====================================================================================================================*/
.flexslider {
    margin: 0 0 60px;
    background: #ffffff;
    position: relative;
    zoom: 1;
}

    .flexslider .slides {
        zoom: 1;
        min-height: 425px;
    }

        .flexslider .slides img {
            height: auto;
            min-height: 425px;
        }

.flex-viewport {
    max-height: 2000px;
    -webkit-transition: all 1s ease;
    transition: all 1s ease;
    min-height: 425px
}

.loading .flex-viewport {
    max-height: 300px;
}

.carousel li {
    margin-right: 5px;
}

.flex-direction-nav {
    *height: 0;
}

    .flex-direction-nav a {
        text-decoration: none;
        display: block;
        width: 40px;
        height: 40px;
        margin: -20px 0 0;
        position: absolute;
        top: 50%;
        z-index: 10;
        overflow: hidden;
        opacity: 0;
        cursor: pointer;
        color: rgba(0, 0, 0, 0.8);
        text-shadow: 1px 1px 0 rgba(255, 255, 255, 0.3);
        -webkit-transition: all 0.3s ease-in-out;
        transition: all 0.3s ease-in-out;
    }

        .flex-direction-nav a:before {
            font-family: "flexslider-icon";
            font-size: 40px;
            display: inline-block;
            content: '\f001';
            color: rgba(0, 0, 0, 0.8);
            text-shadow: 1px 1px 0 rgba(255, 255, 255, 0.3);
        }

        .flex-direction-nav a.flex-next:before {
            content: '\f002';
        }

    .flex-direction-nav .flex-prev {
        left: -50px;
    }

    .flex-direction-nav .flex-next {
        right: -50px;
        text-align: right;
    }

.flexslider:hover .flex-direction-nav .flex-prev {
    opacity: 0.7;
    left: 10px;
}

    .flexslider:hover .flex-direction-nav .flex-prev:hover {
        opacity: 1;
    }

.flexslider:hover .flex-direction-nav .flex-next {
    opacity: 0.7;
    right: 10px;
}

    .flexslider:hover .flex-direction-nav .flex-next:hover {
        opacity: 1;
    }

.flex-direction-nav .flex-disabled {
    opacity: 0 !important;
    filter: alpha(opacity=0);
    cursor: default;
}

.flex-pauseplay a {
    display: block;
    width: 20px;
    height: 20px;
    position: absolute;
    bottom: 5px;
    left: 10px;
    opacity: 0.8;
    z-index: 10;
    overflow: hidden;
    cursor: pointer;
    color: #000;
}

    .flex-pauseplay a:before {
        font-family: "flexslider-icon";
        font-size: 20px;
        display: inline-block;
        content: '\f004';
    }

    .flex-pauseplay a:hover {
        opacity: 1;
    }

    .flex-pauseplay a.flex-play:before {
        content: '\f003';
    }

.flex-control-nav {
    width: 100%;
    position: absolute;
    bottom: -40px;
    text-align: center;
}

    .flex-control-nav li {
        margin: 0 6px;
        display: inline-block;
        zoom: 1;
        *display: inline;
    }

.flex-control-paging li a {
    width: 11px;
    height: 11px;
    display: block;
    background: #666;
    background: rgba(0, 0, 0, 0.5);
    cursor: pointer;
    text-indent: -9999px;
    -o-box-shadow: inset 0 0 3px rgba(0, 0, 0, 0.3);
    box-shadow: inset 0 0 3px rgba(0, 0, 0, 0.3);
    border-radius: 20px;
}

    .flex-control-paging li a:hover {
        background: #333;
        background: rgba(0, 0, 0, 0.7);
    }

    .flex-control-paging li a.flex-active {
        background: #000;
        background: rgba(0, 0, 0, 0.9);
        cursor: default;
    }

.flex-control-thumbs {
    margin: 5px 0 0;
    position: static;
    overflow: hidden;
}

    .flex-control-thumbs li {
        width: 25%;
        float: left;
        margin: 0;
    }

    .flex-control-thumbs img {
        width: 100%;
        height: auto;
        display: block;
        opacity: .7;
        cursor: pointer;
        -webkit-transition: all 1s ease;
        transition: all 1s ease;
    }

        .flex-control-thumbs img:hover {
            opacity: 1;
        }

    .flex-control-thumbs .flex-active {
        opacity: 1;
        cursor: default;
    }

/* ====================================================================================================================
 * RESPONSIVE
 * ====================================================================================================================*/
@media screen and (max-width: 860px) {
    .flex-direction-nav .flex-prev {
        opacity: 1;
        left: 10px;
    }

    .flex-direction-nav .flex-next {
        opacity: 1;
        right: 10px;
    }
}

/*------------------------------------*    #CLEARFIX
\*------------------------------------*/
/**
 * Micro clearfix, as per: css-101.org/articles/clearfix/latest-new-clearfix-so-far.php
 * Extend the clearfix class with Sass to avoid the `.clearfix` class appearing
 * over and over in your markup.
 */
.clearfix:after,
.wrapper:after,
.layout:after,
.page-head:after,
.pagination:after {
    content: "";
    display: table;
    clear: both;
}

/*------------------------------------*    #WIDTHS-RESPONSIVE
\*------------------------------------*/
/**
 * Responsive width classes based on your responsive settings.
 */
@media screen and (min-width: 45em) {
    .u-1\/1-lap {
        width: 100% !important;
    }

    .u-1\/2-lap {
        width: 50% !important;
    }

    .u-2\/2-lap {
        width: 100% !important;
    }

    .u-1\/3-lap {
        width: 33.3333333333% !important;
    }

    .u-2\/3-lap {
        width: 66.6666666667% !important;
    }

    .u-3\/3-lap {
        width: 100% !important;
    }

    .u-1\/4-lap {
        width: 25% !important;
    }

    .u-2\/4-lap {
        width: 50% !important;
    }

    .u-3\/4-lap {
        width: 75% !important;
    }

    .u-4\/4-lap {
        width: 100% !important;
    }

    .u-1\/5-lap {
        width: 20% !important;
    }

    .u-2\/5-lap {
        width: 40% !important;
    }

    .u-3\/5-lap {
        width: 60% !important;
    }

    .u-4\/5-lap {
        width: 80% !important;
    }

    .u-5\/5-lap {
        width: 100% !important;
    }
}

@media screen and (min-width: 45em) {
    .u-1\/1-lap-and-up {
        width: 100% !important;
    }

    .u-1\/2-lap-and-up {
        width: 50% !important;
    }

    .u-2\/2-lap-and-up {
        width: 100% !important;
    }

    .u-1\/3-lap-and-up {
        width: 33.3333333333% !important;
    }

    .u-2\/3-lap-and-up {
        width: 66.6666666667% !important;
    }

    .u-3\/3-lap-and-up {
        width: 100% !important;
    }

    .u-1\/4-lap-and-up {
        width: 25% !important;
    }

    .u-2\/4-lap-and-up {
        width: 50% !important;
    }

    .u-3\/4-lap-and-up {
        width: 75% !important;
    }

    .u-4\/4-lap-and-up {
        width: 100% !important;
    }

    .u-1\/5-lap-and-up {
        width: 20% !important;
    }

    .u-2\/5-lap-and-up {
        width: 40% !important;
    }

    .u-3\/5-lap-and-up {
        width: 60% !important;
    }

    .u-4\/5-lap-and-up {
        width: 80% !important;
    }

    .u-5\/5-lap-and-up {
        width: 100% !important;
    }
}

@media screen and (min-width: 64em) {
    .u-1\/1-desk {
        width: 100% !important;
    }

    .u-1\/2-desk {
        width: 50% !important;
    }

    .u-2\/2-desk {
        width: 100% !important;
    }

    .u-1\/3-desk {
        width: 33.3333333333% !important;
    }

    .u-2\/3-desk {
        width: 66.6666666667% !important;
    }

    .u-3\/3-desk {
        width: 100% !important;
    }

    .u-1\/4-desk {
        width: 25% !important;
    }

    .u-2\/4-desk {
        width: 50% !important;
    }

    .u-3\/4-desk {
        width: 75% !important;
    }

    .u-4\/4-desk {
        width: 100% !important;
    }

    .u-1\/5-desk {
        width: 20% !important;
    }

    .u-2\/5-desk {
        width: 40% !important;
    }

    .u-3\/5-desk {
        width: 60% !important;
    }

    .u-4\/5-desk {
        width: 80% !important;
    }

    .u-5\/5-desk {
        width: 100% !important;
    }
}

@media screen and (min-width: 81.25em) {
    .u-1\/1-desk-wide {
        width: 100% !important;
    }

    .u-1\/2-desk-wide {
        width: 50% !important;
    }

    .u-2\/2-desk-wide {
        width: 100% !important;
    }

    .u-1\/3-desk-wide {
        width: 33.3333333333% !important;
    }

    .u-2\/3-desk-wide {
        width: 66.6666666667% !important;
    }

    .u-3\/3-desk-wide {
        width: 100% !important;
    }

    .u-1\/4-desk-wide {
        width: 25% !important;
    }

    .u-2\/4-desk-wide {
        width: 50% !important;
    }

    .u-3\/4-desk-wide {
        width: 75% !important;
    }

    .u-4\/4-desk-wide {
        width: 100% !important;
    }

    .u-1\/5-desk-wide {
        width: 20% !important;
    }

    .u-2\/5-desk-wide {
        width: 40% !important;
    }

    .u-3\/5-desk-wide {
        width: 60% !important;
    }

    .u-4\/5-desk-wide {
        width: 80% !important;
    }

    .u-5\/5-desk-wide {
        width: 100% !important;
    }
}

/*! fancyBox v2.1.5 fancyapps.com | fancyapps.com/fancybox/#license */
.fancybox-wrap,
.fancybox-skin,
.fancybox-outer,
.fancybox-inner,
.fancybox-image,
.fancybox-wrap iframe,
.fancybox-wrap object,
.fancybox-nav,
.fancybox-nav span,
.fancybox-tmp {
    padding: 0;
    margin: 0;
    border: 0;
    outline: none;
    vertical-align: top;
}

.fancybox-wrap {
    position: absolute;
    top: 0;
    left: 0;
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
    z-index: 8020;
}

.fancybox-skin {
    position: relative;
    background: #fff;
    color: #444;
    text-shadow: none;
    -webkit-border-radius: 4px;
    -moz-border-radius: 4px;
    border-radius: 4px;
}

.fancybox-opened {
    z-index: 8030;
}

    .fancybox-opened .fancybox-skin {
        -webkit-box-shadow: 0 10px 25px rgba(0, 0, 0, 0.5);
        -moz-box-shadow: 0 10px 25px rgba(0, 0, 0, 0.5);
        box-shadow: 0 10px 25px rgba(0, 0, 0, 0.5);
    }

.fancybox-outer,
.fancybox-inner {
    position: relative;
}

.fancybox-inner {
    overflow: hidden;
}

.fancybox-type-iframe .fancybox-inner {
    -webkit-overflow-scrolling: touch;
}

.fancybox-error {
    color: #444;
    font: 14px/20px "Helvetica Neue", Helvetica, Arial, sans-serif;
    margin: 0;
    padding: 15px;
    white-space: nowrap;
}

.fancybox-image,
.fancybox-iframe {
    display: block;
    width: 100%;
    height: 100%;
}

.fancybox-image {
    max-width: 100%;
    max-height: 100%;
}

#fancybox-loading,
.fancybox-close,
.fancybox-prev span,
.fancybox-next span {
    background-image: url(../img/fancybox/fancybox_sprite.png);
}

#fancybox-loading {
    position: fixed;
    top: 50%;
    left: 50%;
    margin-top: -22px;
    margin-left: -22px;
    background-position: 0 -108px;
    opacity: 0.8;
    cursor: pointer;
    z-index: 8060;
}

    #fancybox-loading div {
        width: 44px;
        height: 44px;
        background: url(../img/fancybox/fancybox_loading.gif) center center no-repeat;
    }

.fancybox-close {
    position: absolute;
    top: -18px;
    right: -18px;
    width: 36px;
    height: 36px;
    cursor: pointer;
    z-index: 8040;
}

.fancybox-nav {
    position: absolute;
    top: 0;
    width: 40%;
    height: 100%;
    cursor: pointer;
    text-decoration: none;
    background: transparent url(../img/fancybox/blank.gif);
    /* helps IE */
    -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
    z-index: 8040;
}

.fancybox-prev {
    left: 0;
}

.fancybox-next {
    right: 0;
}

.fancybox-nav span {
    position: absolute;
    top: 50%;
    width: 36px;
    height: 34px;
    margin-top: -18px;
    cursor: pointer;
    z-index: 8040;
    visibility: hidden;
}

.fancybox-prev span {
    left: 10px;
    background-position: 0 -36px;
}

.fancybox-next span {
    right: 10px;
    background-position: 0 -72px;
}

.fancybox-nav:hover span {
    visibility: visible;
}

.fancybox-tmp {
    position: absolute;
    top: -99999px;
    left: -99999px;
    max-width: 99999px;
    max-height: 99999px;
    overflow: visible !important;
}

/* Overlay helper */

.fancybox-lock {
    overflow: visible !important;
    width: auto;
}

    .fancybox-lock body {
        overflow: hidden !important;
    }

.fancybox-lock-test {
    overflow-y: hidden !important;
}

.fancybox-overlay {
    position: absolute;
    top: 0;
    left: 0;
    overflow: hidden;
    display: none;
    z-index: 8010;
    background: url(../img/fancybox/fancybox_overlay.png);
}

.fancybox-overlay-fixed {
    position: fixed;
    bottom: 0;
    right: 0;
}

.fancybox-lock .fancybox-overlay {
    overflow: auto;
    overflow-y: scroll;
}

/* Title helper */

.fancybox-title {
    visibility: hidden;
    font: normal 13px/20px "Helvetica Neue", Helvetica, Arial, sans-serif;
    position: relative;
    text-shadow: none;
    z-index: 8050;
}

.fancybox-opened .fancybox-title {
    visibility: visible;
}

.fancybox-title-float-wrap {
    position: absolute;
    bottom: 0;
    right: 50%;
    margin-bottom: -35px;
    z-index: 8050;
    text-align: center;
}

    .fancybox-title-float-wrap .child {
        display: inline-block;
        margin-right: -100%;
        padding: 2px 20px;
        background: transparent;
        /* Fallback for web browsers that doesn't support RGBa */
        background: rgba(0, 0, 0, 0.8);
        -webkit-border-radius: 15px;
        -moz-border-radius: 15px;
        border-radius: 15px;
        text-shadow: 0 1px 2px #222;
        color: #FFF;
        font-weight: bold;
        line-height: 24px;
        white-space: nowrap;
    }

.fancybox-title-outside-wrap {
    position: relative;
    margin-top: 10px;
    color: #fff;
}

.fancybox-title-inside-wrap {
    padding-top: 10px;
}

.fancybox-title-over-wrap {
    position: absolute;
    bottom: 0;
    left: 0;
    color: #fff;
    padding: 10px;
    background: #000;
    background: rgba(0, 0, 0, .8);
}

/*Retina graphics!*/
@media only screen and (-webkit-min-device-pixel-ratio: 1.5), only screen and (min--moz-device-pixel-ratio: 1.5), only screen and (min-device-pixel-ratio: 1.5) {

    #fancybox-loading,
    .fancybox-close,
    .fancybox-prev span,
    .fancybox-next span {
        background-image: url(../img/fancybox/fancybox_sprite@2x.png);
        background-size: 44px 152px;
        /*The size of the normal image, half the size of the hi-res image*/
    }

        #fancybox-loading div {
            background-image: url(../img/fancybox/fancybox_loading@2x.gif);
            background-size: 24px 24px;
            /*The size of the normal image, half the size of the hi-res image*/
        }
}

/*
 * jquery.selectBoxIt.css 3.8.1
 * Author: @gregfranko
 */

/*
  Common CSS Properties
  ---------------------
  These properties will be applied to any themes that you use
*/

/* SelectBoxIt container */
.selectboxit-container {
    position: relative;
    display: inline-block;
    vertical-align: top;
    max-width: 100%;
    /*width: 100%;*/
}

    /* Styles that apply to all SelectBoxIt elements */
    .selectboxit-container * {
        font: 14px Helvetica, Arial;
        /* Prevents text selection */
        -webkit-touch-callout: none;
        -webkit-user-select: none;
        -khtml-user-select: none;
        -moz-user-select: -moz-none;
        -ms-user-select: none;
        -o-user-select: none;
        user-select: none;
        outline: none;
        white-space: nowrap;
    }

    /* Button */
    .selectboxit-container .selectboxit {
        width: 220px;
        /* Width of the dropdown button */
        cursor: pointer;
        margin: 0;
        padding: 0;
        /*border-radius: 6px;*/
        overflow: hidden;
        display: block;
        position: relative;
        max-width: 100%;
    }

    /* Height and Vertical Alignment of Text */
    .selectboxit-container span,
    .selectboxit-container .selectboxit-options a {
        /*height: 30px;*/
        /* Height of the drop down */
        /*line-height: 30px;*/
        /* Vertically positions the drop down text */
        display: block;
        padding: 12px 0px;
    }

    /* Focus pseudo selector */
    .selectboxit-container .selectboxit:focus {
        outline: 0;
    }

/* Disabled Mouse Interaction */
.selectboxit.selectboxit-disabled,
.selectboxit-options .selectboxit-disabled {
    opacity: 0.65;
    filter: alpha(opacity=65);
    -webkit-box-shadow: none;
    -moz-box-shadow: none;
    box-shadow: none;
    cursor: default;
}

/* Button Text */
.selectboxit-text {
    text-indent: 5px;
    overflow: hidden;
    text-overflow: ellipsis;
    float: left;
}

.selectboxit .selectboxit-option-icon-container {
    margin-left: 5px;
}

/* Options List */
.selectboxit-container .selectboxit-options {
    -moz-box-sizing: border-box;
    box-sizing: border-box;
    min-width: 100%;
    /* Minimum Width of the dropdown list box options */
    *width: 100%;
    margin: 0;
    padding: 0;
    list-style: none;
    position: absolute;
    overflow-x: hidden;
    overflow-y: auto;
    cursor: pointer;
    display: none;
    z-index: 9999999999999;
    /*border-radius: 6px;*/
    text-align: left;
    -webkit-box-shadow: none;
    -moz-box-shadow: none;
    box-shadow: none;
}

/* Individual options */
.selectboxit-option .selectboxit-option-anchor {
    padding: 0 2px;
}

    /* Individual Option Hover Action */
    .selectboxit-option .selectboxit-option-anchor:hover {
        text-decoration: none;
    }

/* Individual Option Optgroup Header */
.selectboxit-option,
.selectboxit-optgroup-header {
    text-indent: 5px;
    /* Horizontal Positioning of the select box option text */
    margin: 0;
    list-style-type: none;
}

/* The first Drop Down option */
.selectboxit-option-first {
    border-top-right-radius: 6px;
    border-top-left-radius: 6px;
}

/* The first Drop Down option optgroup */
.selectboxit-optgroup-header + .selectboxit-option-first {
    border-top-right-radius: 0px;
    border-top-left-radius: 0px;
}

/* The last Drop Down option */
.selectboxit-option-last {
    border-bottom-right-radius: 6px;
    border-bottom-left-radius: 6px;
}

/* Drop Down optgroup headers */
.selectboxit-optgroup-header {
    font-weight: bold;
}

    /* Drop Down optgroup header hover psuedo class */
    .selectboxit-optgroup-header:hover {
        cursor: default;
    }

/* Drop Down down arrow container */
.selectboxit-arrow-container {
    /* Positions the down arrow */
    width: 30px;
    position: absolute;
    right: 0;
    height: 36px;
}

/* Drop Down down arrow */
.selectboxit .selectboxit-arrow-container .selectboxit-arrow {
    /* Horizontally centers the down arrow */
    margin: 0 auto;
    position: absolute;
    top: 50%;
    right: 0;
    left: 0;
}

    /* Drop Down down arrow for jQueryUI and jQuery Mobile */
    .selectboxit .selectboxit-arrow-container .selectboxit-arrow.ui-icon {
        top: 30%;
    }

/* Drop Down individual option icon positioning */
.selectboxit-option-icon-container {
    float: left;
    padding: 0 !important;
}

.selectboxit-container .selectboxit-option-icon {
    margin: 0;
    padding: 0;
    vertical-align: middle;
}

/* Drop Down individual option icon positioning */
.selectboxit-option-icon-url {
    width: 18px;
    background-size: 18px 18px;
    background-repeat: no-repeat;
    height: 100%;
    background-position: center;
    float: left;
}

.selectboxit-rendering {
    display: inline-block !important;
    *display: inline !important;
    zoom: 1 !important;
    visibility: visible !important;
    position: absolute !important;
    top: -9999px !important;
    left: -9999px !important;
}

/* jQueryUI and jQuery Mobile compatability fix - Feel free to remove this style if you are not using jQuery Mobile */
.jqueryui .ui-icon {
    background-color: inherit;
}

/* Another jQueryUI and jQuery Mobile compatability fix - Feel free to remove this style if you are not using jQuery Mobile */
.jqueryui .ui-icon-triangle-1-s {
    background-position: -64px -16px;
}

/*
  Default Theme
  -------------
  Note: Feel free to remove all of the CSS underneath this line if you are not using the default theme
*/
.selectboxit-btn {
    background-color: #f5f5f5;
    border: 2px solid #cccccc;
    width: 100%;
}

    .selectboxit-btn.selectboxit-enabled:hover,
    .selectboxit-btn.selectboxit-enabled:focus,
    .selectboxit-btn.selectboxit-enabled:active {
        color: #333333;
        background-color: #e6e6e6;
    }

    .selectboxit-btn.selectboxit-enabled:hover,
    .selectboxit-btn.selectboxit-enabled:focus {
        color: #333333;
        text-decoration: none;
        background-position: 0 -15px;
    }

.selectboxit-default-arrow {
    width: 0;
    height: 0;
    border-top: 4px solid #000000;
    border-right: 4px solid transparent;
    border-left: 4px solid transparent;
}

.selectboxit-list {
    background-color: #ffffff;
    border: 1px solid #ccc;
    border: 1px solid rgba(0, 0, 0, 0.2);
    -webkit-box-shadow: 0 5px 10px rgba(0, 0, 0, 0.2);
    -moz-box-shadow: 0 5px 10px rgba(0, 0, 0, 0.2);
    box-shadow: 0 5px 10px rgba(0, 0, 0, 0.2);
}

    .selectboxit-list .selectboxit-option-anchor {
        color: #333333;
    }

    .selectboxit-list > .selectboxit-focus > .selectboxit-option-anchor {
        color: #ffffff;
        background-color: #154284;
    }

    .selectboxit-list > .selectboxit-disabled > .selectboxit-option-anchor {
        color: #999999;
    }

/* Cookie policy */
.cc-message,
.cc-compliance {
    font-family: "proxima-nova", sans-serif !important;
}
