﻿/*! normalize.css v4.1.1 | MIT License | github.com/necolas/normalize.css */
/**
 * 1. Change the default font family in all browsers (opinionated).
 * 2. Prevent adjustments of font size after orientation changes in IE and iOS.
 */
@import url("https://fonts.googleapis.com/css?family=Montserrat:400,700");

html {
    font-family: Arial, sans-serif;
    /* 1 */
    -ms-text-size-adjust: 100%;
    /* 2 */
    -webkit-text-size-adjust: 100%;
    /* 2 */
}

/**
 * Remove the margin in all browsers (opinionated).
 */
body {
    margin: 0;
}

/* HTML5 display definitions
   ========================================================================== */
/**
 * Add the correct display in IE 9-.
 * 1. Add the correct display in Edge, IE, and Firefox.
 * 2. Add the correct display in IE.
 */
article,
aside,
details,
figcaption,
figure,
footer,
header,
main,
menu,
nav,
section,
summary {
    /* 1 */
    display: block;
}

/**
 * Add the correct display in IE 9-.
 */
audio,
canvas,
progress,
video {
    display: inline-block;
}

    /**
 * Add the correct display in iOS 4-7.
 */
    audio:not([controls]) {
        display: none;
        height: 0;
    }

/**
 * Add the correct vertical alignment in Chrome, Firefox, and Opera.
 */
progress {
    vertical-align: baseline;
}

/**
 * Add the correct display in IE 10-.
 * 1. Add the correct display in IE.
 */
template,
[hidden] {
    display: none;
}

/* Links
   ========================================================================== */
/**
 * 1. Remove the gray background on active links in IE 10.
 * 2. Remove gaps in links underline in iOS 8+ and Safari 8+.
 */
a {
    background-color: transparent;
    /* 1 */
    -webkit-text-decoration-skip: objects;
    /* 2 */
}

    /**
 * Remove the outline on focused links when they are also active or hovered
 * in all browsers (opinionated).
 */
    a:active,
    a:hover {
        outline-width: 0;
    }

/* Text-level semantics
   ========================================================================== */
/**
 * 1. Remove the bottom border in Firefox 39-.
 * 2. Add the correct text decoration in Chrome, Edge, IE, Opera, and Safari.
 */
abbr[title] {
    border-bottom: none;
    /* 1 */
    text-decoration: underline;
    /* 2 */
    text-decoration: underline dotted;
    /* 2 */
}

/**
 * Prevent the duplicate application of `bolder` by the next rule in Safari 6.
 */
b,
strong {
    font-weight: inherit;
}

/**
 * Add the correct font weight in Chrome, Edge, and Safari.
 */
b,
strong {
    font-weight: bolder;
}

/**
 * Add the correct font style in Android 4.3-.
 */
dfn {
    font-style: italic;
}

/**
 * Correct the font size and margin on `h1` elements within `section` and
 * `article` contexts in Chrome, Firefox, and Safari.
 */
h1 {
    font-size: 2em;
    margin: 0.67em 0;
}

/**
 * Add the correct background and color in IE 9-.
 */
mark {
    background-color: #ff0;
    color: #000;
}

/**
 * Add the correct font size in all browsers.
 */
small {
    font-size: 80%;
}

/**
 * Prevent `sub` and `sup` elements from affecting the line height in
 * all browsers.
 */
sub,
sup {
    font-size: 75%;
    line-height: 0;
    position: relative;
    vertical-align: baseline;
}

sub {
    bottom: -0.25em;
}

sup {
    top: -0.5em;
}

/* Embedded content
   ========================================================================== */
/**
 * Remove the border on images inside links in IE 10-.
 */
img {
    border-style: none;
}

/**
 * Hide the overflow in IE.
 */
svg:not(:root) {
    overflow: hidden;
}

/* Grouping content
   ========================================================================== */
/**
 * 1. Correct the inheritance and scaling of font size in all browsers.
 * 2. Correct the odd `em` font sizing in all browsers.
 */
code,
kbd,
pre,
samp {
    font-family: monospace, monospace;
    /* 1 */
    font-size: 1em;
    /* 2 */
}

/**
 * Add the correct margin in IE 8.
 */
figure {
    margin: 1em 40px;
}

/**
 * 1. Add the correct box sizing in Firefox.
 * 2. Show the overflow in Edge and IE.
 */
hr {
    box-sizing: content-box;
    /* 1 */
    height: 0;
    /* 1 */
    overflow: visible;
    /* 2 */
}

/* Forms
   ========================================================================== */
/**
 * 1. Change font properties to `inherit` in all browsers (opinionated).
 * 2. Remove the margin in Firefox and Safari.
 */
button,
input,
select,
textarea {
    font: inherit;
    /* 1 */
    margin: 0;
    /* 2 */
}

/**
 * Restore the font weight unset by the previous rule.
 */
optgroup {
    font-weight: bold;
}

/**
 * Show the overflow in IE.
 * 1. Show the overflow in Edge.
 */
button,
input {
    /* 1 */
    overflow: visible;
}

/**
 * Remove the inheritance of text transform in Edge, Firefox, and IE.
 * 1. Remove the inheritance of text transform in Firefox.
 */
button,
select {
    /* 1 */
    text-transform: none;
}

/**
 * 1. Prevent a WebKit bug where (2) destroys native `audio` and `video`
 *    controls in Android 4.
 * 2. Correct the inability to style clickable types in iOS and Safari.
 */
button,
html [type="button"],
[type="reset"],
[type="submit"] {
    -webkit-appearance: button;
    /* 2 */
}

    /**
 * Remove the inner border and padding in Firefox.
 */
    button::-moz-focus-inner,
    [type="button"]::-moz-focus-inner,
    [type="reset"]::-moz-focus-inner,
    [type="submit"]::-moz-focus-inner {
        border-style: none;
        padding: 0;
    }

    /**
 * Restore the focus styles unset by the previous rule.
 */
    button:-moz-focusring,
    [type="button"]:-moz-focusring,
    [type="reset"]:-moz-focusring,
    [type="submit"]:-moz-focusring {
        outline: 1px dotted ButtonText;
    }

/**
 * Change the border, margin, and padding in all browsers (opinionated).
 */
fieldset {
    border: 1px solid #c0c0c0;
    margin: 0 2px;
    padding: 0.35em 0.625em 0.75em;
}

/**
 * 1. Correct the text wrapping in Edge and IE.
 * 2. Correct the color inheritance from `fieldset` elements in IE.
 * 3. Remove the padding so developers are not caught out when they zero out
 *    `fieldset` elements in all browsers.
 */
legend {
    box-sizing: border-box;
    /* 1 */
    color: inherit;
    /* 2 */
    display: table;
    /* 1 */
    max-width: 100%;
    /* 1 */
    padding: 0;
    /* 3 */
    white-space: normal;
    /* 1 */
}

/**
 * Remove the default vertical scrollbar in IE.
 */
textarea {
    overflow: auto;
}

/**
 * 1. Add the correct box sizing in IE 10-.
 * 2. Remove the padding in IE 10-.
 */
[type="checkbox"],
[type="radio"] {
    box-sizing: border-box;
    /* 1 */
    padding: 0;
    /* 2 */
}

/**
 * Correct the cursor style of increment and decrement buttons in Chrome.
 */
[type="number"]::-webkit-inner-spin-button,
[type="number"]::-webkit-outer-spin-button {
    height: auto;
}

/**
 * 1. Correct the odd appearance in Chrome and Safari.
 * 2. Correct the outline style in Safari.
 */
[type="search"] {
    -webkit-appearance: textfield;
    /* 1 */
    outline-offset: -2px;
    /* 2 */
}

    /**
 * Remove the inner padding and cancel buttons in Chrome and Safari on OS X.
 */
    [type="search"]::-webkit-search-cancel-button,
    [type="search"]::-webkit-search-decoration {
        -webkit-appearance: none;
    }

/**
 * Correct the text style of placeholders in Chrome, Edge, and Safari.
 */
::-webkit-input-placeholder {
    color: inherit;
    opacity: 0.54;
}

/**
 * 1. Correct the inability to style clickable types in iOS and Safari.
 * 2. Change font properties to `inherit` in Safari.
 */
::-webkit-file-upload-button {
    -webkit-appearance: button;
    /* 1 */
    font: inherit;
    /* 2 */
}

/********************************************************************************                                              ********************************************************************************
 __    ___    ____  _     _ _       _    _____ _           _           _
|  |  | . |  |    \|_|___|_| |_ ___| |  |   __| |_ ___ ___| |_ ___ ___|_|___ ___
|  |__|_  |  |  |  | | . | |  _| .'| |  |__   |  _|  _| .'|  _| -_| . | | -_|_ -|
|_____|___|  |____/|_|_  |_|_| |__,|_|  |_____|_| |_| |__,|_| |___|_  |_|___|___|
                     |___|                                        |___|
                           l9digitalstrategies.com
********************************************************************************
*********************************************************************************/
/* ==========================================================================
  Colour Vars
========================================================================== */
/* ==========================================================================
  Other Vars
========================================================================== */
/* ==========================================================================
  Mixins
========================================================================== */
/* ==========================================================================
  Default
========================================================================== */
html, body {
    background-color: #fff;
    height: 100%;
    margin: 0;
}

.content {
    min-height: 100%;
}

.content-inside {
    padding-bottom: 190px; /* matches footer height */
}

html *, body * {
    box-sizing: border-box;
}

img {
    max-width: 100%;
}

ul.green-bullets {
    list-style: none;
    padding-left: 17px;
}

    ul.green-bullets li {
        position: relative;
    }

        ul.green-bullets li:after {
            content: '';
            display: block;
            width: 6px;
            height: 6px;
            border-radius: 50%;
            background-color: #7bafde;
            position: absolute;
            top: 8px;
            left: -15px;
        }

/* ==========================================================================
  Typography
========================================================================== */
body {
    font-family: Arial, "Helvetica Neue", "Helvetica", sans-serif;
    font-size: 1em;
    letter-spacing: 0px;
    line-height: 23px;
    color: #000000;
}

h1, .h1,
h2, .h2,
h3, .h3,
h4, .h4,
h5, .h5,
h6, .h6 {
    font-family: Arial, "Montserrat", sans-serif;
}

h1, .h1 {
    font-size: 49px;
    letter-spacing: 0px;
    font-weight: 200;
    color: #213F7D;
    line-height: 1.3;
}

@media only screen and (max-width: 768px) {
    h1, .h1 {
        font-size: 35px;
    }
}

h2, .h2 {
    font-size: 40px;
    color: #213F7D;
    letter-spacing: 0px;
}

@media only screen and (max-width: 768px) {
    h2, .h2 {
        font-size: 30px;
    }
}

h3, .h3 {
    font-size: 31px;
    letter-spacing: 0px;
    color: #213F7D;
    line-height: 1.1;
    font-weight: 700;
}

@media only screen and (max-width: 768px) {
    h3, .h3 {
        font-size: 25px;
    }
}

h4, .h4 {
    font-size: 21px;
    color: #213F7D;
    letter-spacing: 0px;
    font-weight: 100;
}

h5, .h5 {
    font-size: 12px;
    color: #213F7D;
    letter-spacing: 2.4px;
    text-transform: uppercase;
}

h6, .h6 {
    font-size: 12px;
    color: #213F7D;
    letter-spacing: 2.4px;
    text-transform: uppercase;
}

.large-text {
    font-size: 18px;
    letter-spacing: 0px;
    color: #213F7D;
    line-height: 26px;
    font-weight: 400;
}


.medium-text {
    font-size: 14px;
    letter-spacing: 0px;
    color: #000000;
}

.small-text {
    font-size: 10px;
    letter-spacing: 0px;
    line-height: 1.3;
}

strong {
    font-weight: 500;
}

label {
    font-weight: 400;
    font-size: 14px;
    letter-spacing: 0px;
    line-height: 23px;
}

a {
    text-decoration: none;
    color: #7bafde;
}

.underline-link {
    border-bottom: 2px solid #7bafde;
}

    .underline-link.yellow {
        border-bottom: 2px solid #59BA47;
    }

/* ==========================================================================
  Modules
========================================================================== */
.container {
    max-width: 1350px;
    margin: 0 8%;
    padding: 0 15px;
}

.page-bg {
    background-color: #ffffff;
    width: 100%;
    height: 100%;
    position: fixed;
    top: 0;
    left: 0;
    z-index: 1;
}

.form-steps {
    padding: 0;
    margin: 0;
    list-style: none;
    margin-bottom: 15px;
}

    .form-steps li {
        display: inline-block;
    }

        .form-steps li:not(:last-child) {
            margin-right: 15px;
        }

@media only screen and (max-width: 768px) {
    .form-steps li {
        display: block;
    }

        .form-steps li:not(:last-child) {
            margin-bottom: 5px;
        }
}

.form-steps li a {
    color: #7bafde;
}

    .form-steps li a .step-number {
        color: transparent;
        background-image: url("../images/icon-check.png");
        background-size: 11px 8.5px;
        background-position: center center;
        background-repeat: no-repeat;
        background-position: center center;
        display: inline-block;
        width: 17px;
        height: 17px;
        font-size: 10px;
        font-weight: 200;
        text-align: center;
        line-height: 17px;
        border: 1px solid #7bafde;
        background-color: #7bafde;
        font-family: Arial, "Montserrat", sans-serif;
        border-radius: 100px;
        margin-right: 5px;
        vertical-align: text-bottom;
    }

.form-steps li.active a {
    color: #213F7D;
    font-weight: bold;
}

    .form-steps li.active a .step-number {
        color: #213F7D;
        background-image: none;
        border: 1px solid #213F7D;
    }

.form-steps li.active ~ li a {
    color: #7bafde;
}

    .form-steps li.active ~ li a .step-number {
        border: 1px solid #7bafde;
        color: #aee067;
        background-image: none;
    }

.form-step {
    padding: 15px 0;
    display: none;
}

    .form-step:after {
        display: block;
        content: "";
        clear: both;
    }

    .form-step:first-child {
        display: block;
    }

.button-set {
    padding-top: 15px;
    clear: both;
}

    .button-set button:not(:last-child), .button-set .button:not(:last-child) {
        margin-right: 10px;
    }

@media only screen and (max-width: 768px) {
    .button-set button:not(:first-child), .button-set .button:not(:first-child) {
        margin-top: 10px;
    }
}

.rounded-box-content {
    background-color: #fff;
    padding: 30px;
    border-radius: 8px;
    border: 2px solid #D9D9D9;
}

@media only screen and (max-width: 768px) {
    .rounded-box-content {
        padding: 15px;
    }
}

.rounded-box-content.slim {
    padding: 15px;
}

.rounded-box-content hr {
    margin: 15px -15px;
    border-top: 2px solid #999999;
    border-bottom: none;
    border-left: none;
    border-right: none;
}

@media only screen and (max-width: 768px) {
    .rounded-box-content hr {
        margin: 15px -15px;
    }
}

.notifications-icon {
    font-style: initial;
    width: 12px;
    height: 15px;
    background-image: url("../images/icon-notifications-white.png");
    background-size: contain;
    background-position: center center;
    background-repeat: no-repeat;
    position: relative;
    display: inline-block;
}

    .notifications-icon .number {
        font-family: Arial, "Montserrat", sans-serif;
        font-size: 8px;
        line-height: 12px;
        background-color: #447FC2;
        width: 12px;
        height: 12px;
        display: block;
        border-radius: 50%;
        position: absolute;
        top: -5px;
        right: -7px;
        text-align: center;
    }

    .notifications-icon.black {
        background-image: url("../images/icon-notifications-black.png");
        background-size: contain;
        background-position: center center;
        background-repeat: no-repeat;
    }

        .notifications-icon.black .number {
            color: #fff;
        }

table {
    background-color: #FCFCFC;
    border: 1px solid #D8D8D8;
}

@media only screen and (max-width: 768px) {
    table {
        width: 100%;
    }
}

@media only screen and (max-width: 768px) {
    table tr {
        width: 100%;
        display: block;
    }

        table tr:not(:last-child) {
            border-bottom: 1px solid #D8D8D8;
        }
}

table tr:not(:last-child) td {
    border-bottom: 1px solid #D8D8D8;
}

@media only screen and (max-width: 768px) {
    table tr:not(:last-child) td {
        border-bottom: none;
    }
}

table tr td {
    position: relative;
}

@media only screen and (max-width: 768px) {
    table tr td {
        width: 100%;
        display: block;
    }
}

table tr td:not(:first-child) {
    border-left: 1px solid #D8D8D8;
}

@media only screen and (max-width: 768px) {
    table tr td:not(:first-child) {
        border-left: none;
    }
}

table tr td input[type="text"], table tr td input[type="password"] {
    background-color: transparent;
    background: transparent;
    border: none;
    width: 280px;
    cursor: pointer;
}

@media only screen and (max-width: 768px) {
    table tr td input[type="text"], table tr td input[type="password"] {
        width: 100%;
    }
}

table tr td input[type="text"]:focus, table tr td input[type="password"]:focus {
    cursor: text;
}

table tr td:not(.contains-input) {
    padding: 15px;
}

@media only screen and (max-width: 768px) {
    table tr td:not(.contains-input):not(:last-child) {
        padding-bottom: 0;
    }
}

@media only screen and (max-width: 768px) {
    table tr td.contains-input {
        padding-bottom: 15px;
    }
}

table tr td .help-inline {
    display: block;
    position: absolute;
    left: 0;
    top: calc(100% - 20px);
    width: 100%;
    z-index: 5;
}

table tr td.editable {
    position: relative;
}

    table tr td.editable:after {
        content: '';
        background-image: url("../images/icon-edit-field.png");
        background-size: contain;
        background-position: center center;
        background-repeat: no-repeat;
        width: 15px;
        height: 15px;
        display: none;
        position: absolute;
        right: 3px;
        top: 50%;
        -webkit-transform: translateY(-50%);
        transform: translateY(-50%);
    }

    table tr td.editable:hover:after {
        display: block;
    }

.received-trophies {
    margin-top: 30px;
    padding-bottom: 15px;
}

    .received-trophies:after {
        display: block;
        content: "";
        clear: both;
    }

@media only screen and (max-width: 768px) {
    .received-trophies {
        margin-top: 15px;
    }
}

.received-trophies .trophy-container {
    width: 130px;
    float: left;
    text-align: center;
    position: relative;
}

@media only screen and (max-width: 768px) {
    .received-trophies .trophy-container {
        margin-top: 30px;
    }
}

.received-trophies .trophy-container .title {
    color: #7bafde;
    padding-bottom: 85px;
}

.received-trophies .trophy-container .trophy {
    float: left;
    width: 100%;
    height: 75px;
    margin-top: 15px;
    position: absolute;
    bottom: 0;
    left: 0;
    background-position: bottom center !important;
}

    .received-trophies .trophy-container .trophy.will-rebate {
        background-image: url("../images/trophy-will-rebate.png");
        background-size: 66px 76px;
        background-position: center center;
        background-repeat: no-repeat;
    }

    .received-trophies .trophy-container .trophy.cpr {
        background-image: url("../images/trophy-cpr.png");
        background-size: 58px 75px;
        background-position: center center;
        background-repeat: no-repeat;
    }

    .received-trophies .trophy-container .trophy.attorney {
        background-image: url("../images/trophy-attorney.png");
        background-size: 67px 63px;
        background-position: center center;
        background-repeat: no-repeat;
    }

    .received-trophies .trophy-container .trophy.healthy {
        background-image: url("../images/trophy-healthy-living.png");
        background-size: 78px 64px;
        background-position: center center;
        background-repeat: no-repeat;
    }

    .received-trophies .trophy-container .trophy.tl {
        background-image: url("../images/trophy-award-tl.png");
        background-size: 57px 76px;
        background-position: center center;
        background-repeat: no-repeat;
    }

    .received-trophies .trophy-container .trophy.jf-allen {
        background-image: url("../images/trophy-award-jf-allen.png");
        background-size: 78px 64px;
        background-position: center center;
        background-repeat: no-repeat;
    }

    .received-trophies .trophy-container .trophy.hall {
        background-image: url("../images/trophy-award-hall.png");
        background-size: 67px 63px;
        background-position: center center;
        background-repeat: no-repeat;
    }

.received-trophies .trophy-container.received .trophy.will-rebate {
    background-image: url("../images/trophy-will-rebate_received.png");
    background-size: 66px 76px;
    background-position: center center;
    background-repeat: no-repeat;
}

.received-trophies .trophy-container.received .trophy.cpr {
    background-image: url("../images/trophy-cpr_received.png");
    background-size: 58px 75px;
    background-position: center center;
    background-repeat: no-repeat;
}

.received-trophies .trophy-container.received .trophy.attorney {
    background-image: url("../images/trophy-attorney_received.png");
    background-size: 67px 63px;
    background-position: center center;
    background-repeat: no-repeat;
}

.received-trophies .trophy-container.received .trophy.healthy {
    background-image: url("../images/trophy-healthy-living_received.png");
    background-size: 78px 64px;
    background-position: center center;
    background-repeat: no-repeat;
}

.received-trophies .trophy-container.received .trophy.tl {
    background-image: url("../images/trophy-award-tl_received.png");
    background-size: 57px 76px;
    background-position: center center;
    background-repeat: no-repeat;
}

.received-trophies .trophy-container.received .trophy.jf-allen {
    background-image: url("../images/trophy-award-jf-allen_received.png");
    background-size: 78px 64px;
    background-position: center center;
    background-repeat: no-repeat;
}

.received-trophies .trophy-container.received .trophy.hall {
    background-image: url("../images/trophy-award-hall_received.png");
    background-size: 67px 63px;
    background-position: center center;
    background-repeat: no-repeat;
}

.received-trophies .trophy-container.received .trophy:after {
    content: '';
    background-image: url("../images/icon-check-white.png");
    background-size: 11px 8.5px;
    background-position: center center;
    background-repeat: no-repeat;
    width: 17px;
    height: 17px;
    border-radius: 50%;
    border: 2px solid #fff;
    display: block;
    background-color: #7bafde;
    position: absolute;
    bottom: -9px;
    left: 50%;
    -webkit-transform: translateX(-50%);
    transform: translateX(-50%);
}

.accordion {
    background-clip: border-box;
    background-color: rgb(236, 236, 236);
    background-origin: padding-box;
    border-color: rgb(66, 128, 196);
    border-radius: 10px;
    border-style: solid;
    border-width: 1px;
    color: rgb(33, 63, 125);
    padding: 6px 18px;
    width: 100%;
    text-align: left;
    vertical-align: middle;
    outline: none;
    font-weight: 700;
    transition: 0.4s;
    display: inline-block;
    font-size: 16px;
    font-weight: 700;
}

/* Chevron material icons */
.material-icons.md-36 {
    font-size: 36px;
    vertical-align: middle;
    margin-bottom: 5px;
}

.accordion:hover {
    background-color: rgb(33, 63, 125);
    color: rgb(236, 236, 236);
}

.accordion-panel {
    padding: 0 18px;
    max-height: 0;
    overflow: hidden;
    transition: max-height 0.2s ease-out;
}

/* Awards */

.award-container {
    margin-top: 50px;
}

    .award-container.first {
        margin-top: 0px;
    }

    .award-container p, .award-container li {
        font-size: 1em;
        color: black;
        line-height: 19px;
    }

    .award-container h1 {
        color: black;
        font-size: 1em;
        font-weight: bold;
    }

.rounded-box-content.award {
    border-width: 2px;
    border-color: #D8D8D8;
    padding: 40px;
}

.award-container:after {
    display: block;
    content: "";
    clear: both;
}

.award-container .info, .award-container .required {
    float: left;
    width: 65%;
}

@media only screen and (max-width: 768px) {
    .award-container .info, .award-container .required {
        width: 100%;
    }
}

.award-container .info {
    padding-right: 15px;
}

    .award-container .info .title {
        color: #7bafde;
        font-size: 12pt;
        font-weight: bold;
    }

        .award-container .info .title .small-trophy {
            max-width: 20px;
            display: inline-block;
            margin-right: 10px;
        }

            .award-container .info .title .small-trophy.attorney {
                max-width: 25px;
            }

            .award-container .info .title .small-trophy.healthy-living {
                max-width: 25px;
            }

.award-container .required {
    padding-left: 15px;
}

@media only screen and (max-width: 768px) {
    .award-container .required {
        padding-left: 0;
        display: none;
    }
}

.award-container .required .title {
    color: #ADADAD;
    margin-top: 6px;
}

/* Rebates */

.rebate-container {
    margin-top: 40px;
}

    .rebate-container:after {
        display: block;
        content: "";
        clear: both;
    }

    .rebate-container .info, .rebate-container .required {
        float: left;
        width: 50%;
    }

@media only screen and (max-width: 768px) {
    .rebate-container .info, .rebate-container .required {
        width: 100%;
    }
}

.rebate-container .info {
    padding-right: 15px;
}

    .rebate-container .info .title {
        color: #213F7D;
        font-weight: 700;
    }

        .rebate-container .info .title .small-trophy {
            max-width: 20px;
            display: inline-block;
            margin-right: 10px;
        }

            .rebate-container .info .title .small-trophy.attorney {
                max-width: 25px;
            }

            .rebate-container .info .title .small-trophy.healthy-living {
                max-width: 25px;
            }

.rebate-container .required {
    padding-left: 15px;
}

@media only screen and (max-width: 768px) {
    .rebate-container .required {
        padding-left: 0;
        display: none;
    }
}

.rebate-container .required .title {
    color: #ADADAD;
    margin-top: 6px;
}

.rebate-container .upload-form {
    clear: both;
    padding-top: 15px;
    display: none;
}

    .rebate-container .upload-form .personal-info {
        padding: 0;
        margin: 0;
        list-style: none;
        padding-bottom: 15px;
    }

    .rebate-container .upload-form .input-area input[type="file"] {
        display: block;
        width: 1px;
        height: 1px;
        position: absolute;
        opacity: 0;
        pointer-events: none;
    }

    .rebate-container .upload-form .input-area .upload-receipt-container {
        border: 1px solid #DCDCDC;
        /*height: 51px;*/
        border-radius: 2px;
        background-color: #D8D8D8;
        overflow: hidden;
        position: relative;
        min-width: 200px;
        display: inline-block;
        margin-right: 15px;
        vertical-align: middle;
    }

@media only screen and (max-width: 768px) {
    .rebate-container .upload-form .input-area .upload-receipt-container {
        width: 100%;
        margin-bottom: 15px;
    }
}

.rebate-container .upload-form .input-area .upload-receipt-container:after {
    content: '';
    display: block;
    position: absolute;
    right: 0;
    top: 0;
    height: 100%;
    width: 40px;
    /* FF3.6-15 */
    background: -webkit-linear-gradient(left, rgba(240, 240, 240, 0) 0%, rgba(240, 240, 240, 0) 1%, rgba(240, 240, 240, 0.98) 47%, #D8D8D8 48%);
    /* Chrome10-25,Safari5.1-6 */
    background: linear-gradient(to right, rgba(240, 240, 240, 0) 0%, rgba(240, 240, 240, 0) 1%, rgba(240, 240, 240, 0.98) 47%, #D8D8D8 48%);
    /* W3C, IE10+, FF16+, Chrome26+, Opera12+, Safari7+ */
    filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#00D8D8D8', endColorstr='#D8D8D8',GradientType=1 );
    /* IE6-9 */
}

.rebate-container .upload-form .input-area .upload-receipt-container label {
    display: inline-block;
    margin-left: -1px;
    margin-top: -1px;
    vertical-align: middle;
    width: 155px;
}

.rebate-container .upload-form .input-area .upload-receipt-container .upload-file-text {
    /*height: 51px;*/
    display: inline-block;
    margin-left: -1px;
    margin-top: -1px;
    margin-right: 30px;
    vertical-align: middle;
    white-space: nowrap;
    line-height: 30px;
    padding-left: 10px;
}

.rebate-container .upload-form .input-area button {
    display: inline-block;
    vertical-align: middle;
    width: 155px;
}

/* ==========================================================================
  Utility
========================================================================== */
.clearfix:after {
    display: block;
    content: "";
    clear: both;
}


.reset-ul {
    padding: 0;
    margin: 0;
    list-style: none;
}

    .reset-ul.bulleted-list {
        list-style-position: inside;
        list-style: disc outside none;
    }

.mobile-only {
    display: none !important;
}

@media only screen and (max-width: 768px) {
    .mobile-only {
        display: block !important;
    }
}

.tablet-up {
    display: block !important;
}

@media only screen and (max-width: 768px) {
    .tablet-up {
        display: none !important;
    }
}

.tablet-up-inline {
    display: inline-block !important;
}

@media only screen and (max-width: 768px) {
    .tablet-up-inline {
        display: none !important;
    }
}

/* ==========================================================================
  Form
========================================================================== */
.form-component:after {
    display: block;
    content: "";
    clear: both;
}

.form-component label {
    display: block;
    margin-bottom: 5px;
    position: relative;
}

    .form-component label .info {
        display: inline-block;
        background-image: url("../images/icon-info-rebrand.png");
        background-size: contain;
        background-position: center center;
        background-repeat: no-repeat;
        width: 12px;
        height: 12px;
    }

        .form-component label .info.open:after {
            content: '';
            display: block;
            width: 0;
            height: 0;
            border-top: 4px solid #3463A0;
            border-left: 4px solid transparent;
            border-right: 4px solid transparent;
            position: absolute;
            top: -5px;
            -webkit-transform: translateX(2px);
            transform: translateX(2px);
        }

        .form-component label .info.open > .text {
            display: block;
        }

        .form-component label .info > .text {
            font-size: 10px;
            color: #fff;
            letter-spacing: 0px;
            background: #3463A0;
            padding: 7.5px 15px;
            width: 285px;
            border-radius: 2px;
            position: absolute;
            left: 0;
            bottom: calc(100% + 5px);
            display: none;
        }

@media only screen and (max-width: 400px) {
    .form-component label .info > .text {
        width: 100%;
    }
}

.form-component input, .form-component select, .form-component textarea {
    display: block;
}

.form-component .small-text a {
    color: inherit;
}

.help-inline {
    display: inline-block;
    background: #F16541;
    font-size: 10px;
    color: #fff;
    letter-spacing: 0px;
    padding: 5px 15px;
    border-radius: 2px;
    position: relative;
    margin-top: 8px;
    line-height: 1.5;
}

    .help-inline:after {
        content: '';
        display: block;
        width: 0;
        height: 0;
        border-bottom: 4px solid #F16541;
        border-left: 4px solid transparent;
        border-right: 4px solid transparent;
        position: absolute;
        top: -3px;
    }

.form-row:after {
    display: block;
    content: "";
    clear: both;
}

input[type="text"],
input[type="password"],
select,
.select-wrapper,
.form-component {
    width: 100%;
    max-width: 285px;
}

@media only screen and (max-width: 400px) {
    input[type="text"],
    input[type="password"],
    select,
    .select-wrapper,
    .form-component {
        max-width: 100%;
    }
}

.form-component {
    margin-bottom: 15px;
}

    .form-component.double-width {
        max-width: 585px;
    }

@media only screen and (max-width: 400px) {
    .form-component.double-width {
        max-width: 100%;
    }
}

input[type="text"],
input[type="password"],
select {
    height: 42px;
}

    input[type="text"]:disabled,
    input[type="password"]:disabled,
    select:disabled {
        color: #555555;
        cursor: default;
    }

.dob-select-set {
    width: 100%;
    max-width: 285px;
}

    .dob-select-set:after {
        display: block;
        content: "";
        clear: both;
    }

@media only screen and (max-width: 768px) {
    .dob-select-set {
        max-width: 100%;
    }
}

.dob-select-set .select-wrapper {
    width: 30%;
    float: left;
}

    .dob-select-set .select-wrapper select {
        max-width: 100%;
    }

    .dob-select-set .select-wrapper:first-child, .dob-select-set .select-wrapper:nth-child(2) {
        margin-right: 5%;
    }

.select-wrapper {
    position: relative;
}

    .select-wrapper select {
        width: 100%;
    }

    .select-wrapper:after {
        content: '';
        background-image: url("../images/icon-select-arrow.png");
        background-size: contain;
        background-position: center center;
        background-repeat: no-repeat;
        width: 8px;
        height: 5px;
        display: block;
        right: 15px;
        top: 50%;
        -webkit-transform: translateY(-50%);
        transform: translateY(-50%);
        position: absolute;
    }

input[type="text"],
input[type="password"],
textarea,
select {
    box-sizing: border-box;
    border: 1px solid #D8D8D8;
    border-radius: 2px;
    color: #555555;
    padding-left: 15px;
    padding-right: 15px;
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    background-color: #fff;
}

    input[type="text"]::-webkit-input-placeholder,
    input[type="password"]::-webkit-input-placeholder,
    textarea::-webkit-input-placeholder,
    select::-webkit-input-placeholder {
        color: #ADADAD;
    }

    input[type="text"]:-moz-placeholder,
    input[type="password"]:-moz-placeholder,
    textarea:-moz-placeholder,
    select:-moz-placeholder {
        /* Firefox 18- */
        color: #ADADAD;
    }

    input[type="text"]::-moz-placeholder,
    input[type="password"]::-moz-placeholder,
    textarea::-moz-placeholder,
    select::-moz-placeholder {
        /* Firefox 19+ */
        color: #ADADAD;
    }

    input[type="text"]:-ms-input-placeholder,
    input[type="password"]:-ms-input-placeholder,
    textarea:-ms-input-placeholder,
    select:-ms-input-placeholder {
        color: #ADADAD;
    }

textarea {
    width: 100%;
    min-height: 140px;
}

form.in-line:after {
    display: block;
    content: "";
    clear: both;
}

form.in-line .form-component {
    float: left;
}

@media only screen and (max-width: 768px) {
    form.in-line .form-component {
        float: none;
    }
}

form.in-line .form-component:not(:last-child) {
    margin-right: 15px;
}

label {
    cursor: pointer;
}

.radio-list {
    padding: 0;
    margin: 0;
    list-style: none;
    margin-bottom: 15px;
}

    .radio-list li {
        position: relative;
        padding-left: 18px;
    }

        .radio-list li:not(:last-child) {
            margin-bottom: 10px;
        }

        .radio-list li input[type="radio"] {
            visibility: hidden;
            position: absolute;
        }

            .radio-list li input[type="radio"]:checked ~ .check:before {
                background-color: #7bafde;
            }

        .radio-list li label {
            cursor: pointer;
        }

        .radio-list li .check:before {
            content: '';
            display: block;
            position: absolute;
            top: 7px;
            left: 0;
            width: 8px;
            height: 8px;
            border: 2px solid #fff;
            border-radius: 10px;
            background-color: transparent;
            -webkit-transition: .3s background-color;
            transition: .3s background-color;
        }

input[type="checkbox"] {
    visibility: hidden;
    position: absolute;
}

    input[type="checkbox"] + .checkbox {
        display: inline-block;
        width: 14px;
        height: 14px;
        background-color: #D8D8D8;
        border: 1px solid #D5D5D5;
        vertical-align: middle;
        position: relative;
    }

        input[type="checkbox"] + .checkbox:after {
            content: '';
            display: block;
            position: absolute;
            background-image: url("../images/icon-checkbox-check.png");
            background-size: contain;
            background-position: center center;
            background-repeat: no-repeat;
            width: 11px;
            height: 8.5px;
            display: none;
            top: 2px;
            left: 0.3px;
        }

    input[type="checkbox"]:checked {
        content: '';
    }

        input[type="checkbox"]:checked + .checkbox {
            background-color: #fff;
        }

            input[type="checkbox"]:checked + .checkbox:after {
                display: block;
            }

form.col-2 {
    max-width: 600px;
}

@media only screen and (max-width: 768px) {
    form.col-2 {
        max-width: 285px;
    }
}

@media only screen and (max-width: 400px) {
    form.col-2 {
        max-width: 100%;
    }
}

.form-messages {
    margin-bottom: 15px;
    margin-right: 15px;
}

@media only screen and (max-width: 768px) {
    .form-messages {
        max-width: 285px;
        margin-right: 0;
    }
}

@media only screen and (max-width: 400px) {
    .form-messages {
        max-width: 100%;
    }
}

.form-messages.single-col {
    max-width: 285px;
    margin-right: 0;
}

@media only screen and (max-width: 400px) {
    .form-messages.single-col {
        max-width: 100%;
    }
}

.form-messages .message {
    display: block;
    padding: 5px 15px;
    background-color: #fff;
    border: 1px solid transparent;
    border-radius: 2px;
}

    .form-messages .message.error {
        border-color: #59BA47;
        color: #59BA47;
        background-color: #e2f4c8;
    }

    .form-messages .message.warning {
        border-color: #59BA47;
        background-color: #e2f4c8;
        color: #59BA47;
    }

    .form-messages .message.valid {
        border-color: #7bafde;
        background-color: #e2f4c8;
        color: #59BA47;
    }

/* ==========================================================================
  Form loader/spinner + animation
========================================================================== */
.form-loader {
    width: 20px;
    height: 20px;
    display: block;
    border-radius: 50%;
    top: 50%;
    left: 50%;
    margin: -10px 0 0 -10px;
    position: absolute;
    background: -webkit-linear-gradient(left, #ffffff 10%, rgba(255, 255, 255, 0) 42%);
    background: linear-gradient(to right, #ffffff 10%, rgba(255, 255, 255, 0) 42%);
    -webkit-animation: spin .7s linear infinite;
    animation: spin .7s linear infinite;
}

    .form-loader:after {
        content: '';
        display: block;
        background: #7bafde;
        width: 16px;
        height: 16px;
        position: absolute;
        top: 2px;
        left: 2px;
        border-radius: 50%;
    }

@-webkit-keyframes spin {
    0% {
        -webkit-transform: rotate(0deg);
        transform: rotate(0deg);
    }

    100% {
        -webkit-transform: rotate(360deg);
        transform: rotate(360deg);
    }
}

@keyframes spin {
    0% {
        -webkit-transform: rotate(0deg);
        transform: rotate(0deg);
    }

    100% {
        -webkit-transform: rotate(360deg);
        transform: rotate(360deg);
    }
}

/* ==========================================================================
  Buttons
========================================================================== */
button, .button {
    font-family: Arial, "Montserrat", sans-serif;
    font-size: 13px;
    color: #fff;
    letter-spacing: 0.5px;
    text-transform: uppercase;
    background: #213F7D;
    border: 1px solid #213F7D;
    min-width: 150px;
    padding: 13px 15px;
    text-align: center;
    border-radius: 2px;
    cursor: pointer;
    position: relative;
    -webkit-transition: opacity .8s, color .2s;
    transition: opacity .8s, color .2s;
    display: inline-block;
}

    button.loading, .button.loading {
        color: transparent !important;
        opacity: .9;
    }

        button.loading .form-loader:after, .button.loading .form-loader:after {
            background-color: #213F7D;
        }

        button.loading.yellow .form-loader:after, .button.loading.yellow .form-loader:after {
            background-color: #59BA47;
        }

    button[disabled], .button[disabled] {
        color: #a2dc52;
        cursor: default;
    }

    button.yellow, .button.yellow {
        background: #59BA47;
        border: 1px solid #59BA47;
    }

        button.yellow[disabled], .button.yellow[disabled] {
            background: #ADADAD;
        }

    button.secondary, .button.secondary {
        background: transparent;
        color: #213F7D;
    }

        button.secondary.yellow, .button.secondary.yellow {
            background: transparent;
            color: #59BA47;
            border: 1px solid #59BA47;
        }

    button.upload, .button.upload {
        border: 1px solid #DCDCDC;
        background-color: #fff;
        color: #213F7D;
    }

/* ==========================================================================
  General Styling for Logged Out Pages
========================================================================== */
.logged-out-content {
    position: relative;
    top: 100%;
    z-index: 5;
    margin-top: 8%;
    margin-bottom: 9.5%;
    color: #213F7D;
    width: 100%;
}

@media only screen and (max-width: 1040px) {
    .logged-out-content {
        padding-top: 30px;
    }
}

@media only screen and (max-width: 768px) {
    .logged-out-content {
        position: relative;
        -webkit-transform: none;
        transform: none;
    }
}

@media only screen and (max-width: 1040px) {
    .logged-out-content .main-title {
        margin-top: 0;
    }
}

body.content-tall .logged-out-content {
    position: relative;
    -webkit-transform: none;
    transform: none;
    padding-top: 30px;
}

/* ==========================================================================
  logged-in container
========================================================================== */
.master-logged-in-container .hero {
    position: relative;
    background-color: #213F7D;
}

    .master-logged-in-container .hero .main-title {
        margin: 0;
        padding: 20px 0;
        color: #fff;
        position: relative;
        margin-bottom: 2.2%;
        z-index: 2;
    }

@media only screen and (max-width: 768px) {
    .master-logged-in-container .hero .main-title {
        padding: 90px 0;
    }
}

@media only screen and (max-width: 400px) {
    .master-logged-in-container .hero .main-title {
        padding: 40px 0;
    }
}

.master-logged-in-container .main-content {
    padding-top: 40px;
    background-color: #fff;
}

/* ==========================================================================
  Header
========================================================================== */
body.menu-open {
    overflow: hidden;
}

.main-header {
    position: relative;
    z-index: 10;
}

    .main-header .top-bar {
        color: #fff;
        background: #999999;
    }

@media only screen and (max-width: 768px) {
    .main-header .top-bar {
        position: relative;
    }
}

@media only screen and (max-width: 1350px) {
    .main-header .top-bar > .container {
        padding: 0;
    }
}

.main-header .top-bar a {
    color: #fff;
}

@media only screen and (max-width: 768px) {
    .main-header .top-bar a {
        font-size: 12px;
    }
}

.main-header .top-bar .lists {
    float: right;
    vertical-align: middle;
}

@media only screen and (max-width: 768px) {
    .main-header .top-bar .lists {
        float: none;
    }
}

.main-header .top-bar .link-list {
    padding: 0;
    margin: 0;
    list-style: none;
    display: inline-block;
    vertical-align: middle;
    margin-left: 15px;
}

@media only screen and (max-width: 768px) {
    .main-header .top-bar .link-list {
        margin-top: 5px;
        float: left;
    }
}

.main-header .top-bar .link-list li {
    display: inline-block;
    vertical-align: middle;
}

    .main-header .top-bar .link-list li:not(:last-child):after {
        content: '';
        display: inline-block;
        height: 23px;
        width: 1px;
        background: #fff;
        vertical-align: middle;
        margin: 0 15px;
    }

@media only screen and (max-width: 768px) {
    .main-header .top-bar .link-list li:not(:last-child):after {
        margin: 0 10px;
    }
}

.main-header .top-bar .icon-link-list {
    padding: 0;
    margin: 0;
    list-style: none;
    vertical-align: middle;
    display: inline-block;
    margin-left: 15px;
}

    .main-header .top-bar .icon-link-list:after {
        display: block;
        content: "";
        clear: both;
    }

@media only screen and (max-width: 768px) {
    .main-header .top-bar .icon-link-list {
        float: right;
    }
}

.main-header .top-bar .icon-link-list li {
    float: left;
    border-left: 0px solid #fff;
}

    .main-header .top-bar .icon-link-list li:after {
        display: block;
        content: "";
        clear: both;
    }

    .main-header .top-bar .icon-link-list li.search-icon-container {
        position: relative;
    }

@media only screen and (max-width: 768px) {
    .main-header .top-bar .icon-link-list li.search-icon-container {
        position: static;
    }
}

.main-header .top-bar .icon-link-list li.search-icon-container .input-holder {
    position: relative;
    width: 0px;
    height: 50px;
    overflow: hidden;
    display: block;
    float: left;
    padding-top: 13px;
}

@media only screen and (max-width: 768px) {
    .main-header .top-bar .icon-link-list li.search-icon-container .input-holder {
        position: absolute;
        top: 100%;
        left: 0;
        background: #ADADAD;
        width: 100%;
        padding-bottom: 13px;
    }
}

.main-header .top-bar .icon-link-list li.search-icon-container .input-holder > .inner {
    width: 255px;
}

    .main-header .top-bar .icon-link-list li.search-icon-container .input-holder > .inner:after {
        display: block;
        content: "";
        clear: both;
    }

@media only screen and (max-width: 768px) {
    .main-header .top-bar .icon-link-list li.search-icon-container .input-holder > .inner {
        width: 100%;
        min-width: 100vw;
        padding: 0 15px;
    }
}

.main-header .top-bar .icon-link-list li.search-icon-container .input-holder input {
    width: 227px;
    height: 25px;
    display: block;
    float: left;
}

@media only screen and (max-width: 768px) {
    .main-header .top-bar .icon-link-list li.search-icon-container .input-holder input {
        width: calc(100% - 25px);
    }
}

.main-header .top-bar .icon-link-list li.search-icon-container .input-holder button {
    padding: 12px;
    display: block;
    float: left;
    min-width: 0;
    background-image: url("../images/icon-search-header-submit.png");
    background-size: 6px 11px;
    background-position: center center;
    background-repeat: no-repeat;
    background-position: center center;
    background-color: transparent;
    border: none;
}

@media only screen and (max-width: 768px) {
    .main-header .top-bar .icon-link-list li.search-icon-container .input-holder button {
        float: right;
        -webkit-transform: translateX(7px);
        transform: translateX(7px);
        background-image: url("../images/icon-search-header-submit-black.png");
        background-size: 6px 11px;
        background-position: center center;
        background-repeat: no-repeat;
    }
}

.main-header .top-bar .icon-link-list li a {
    display: block;
    height: 50px;
    width: 50px;
    float: left;
}

@media only screen and (max-width: 768px) {
    .main-header .top-bar .icon-link-list li a {
        height: 35px;
        width: 35px;
    }
}

.main-header .top-bar .icon-link-list li a.log-out {
    width: auto;
    vertical-align: middle;
    padding-left: 10px;
    padding-right: 22px;
}

@media only screen and (max-width: 1040px) {
    .main-header .top-bar .icon-link-list li a.log-out {
        padding-right: 5px;
    }
}

.main-header .top-bar .icon-link-list li a.log-out:after {
    display: inline-block;
    vertical-align: middle;
    height: 100%;
    content: '';
}

.main-header .top-bar .icon-link-list li a.menu-icon {
    background-image: url("../images/icon-mobile-menu.png");
    background-size: 16px 13px;
    background-position: center center;
    background-repeat: no-repeat;
    background-position: center center;
}

.main-header .top-bar .icon-link-list li a.mail-icon {
    background-image: url("../images/icon-mail.png");
    background-size: 28px 26px;
    background-position: center center;
    background-repeat: no-repeat;
    background-position: center center;
}

.main-header .top-bar .icon-link-list li a.lock-icon {
    background-image: url("../images/icon-lock.png");
    background-size: 25px 32px;
    background-position: center center;
    background-repeat: no-repeat;
    background-position: center center;
}

.main-header .top-bar .icon-link-list li a.search-icon {
    background-image: url("../images/icon-search-rebrand.png");
    background-size: 18px 19px;
    background-position: center center;
    background-repeat: no-repeat;
    background-position: center center;
}

.main-header .top-bar .icon-link-list li a .log-out-icon {
    background-image: url("../images/icon-logout.png");
    background-size: contain;
    background-position: center center;
    background-repeat: no-repeat;
    display: inline-block;
    width: 18px;
    height: 19px;
    vertical-align: middle;
    margin-right: 5px;
    -webkit-transform: translateY(-1px);
    transform: translateY(-1px);
}

    .main-header .top-bar .icon-link-list li a .log-out-icon + span {
        vertical-align: middle;
        display: inline-block;
        font-size: 10px;
    }

.main-header .main-bar {
    background: #fff;
}

    .main-header .main-bar:after {
        display: block;
        content: "";
        clear: both;
    }

    .main-header .main-bar > .container {
        height: 75px;
    }

@media only screen and (max-width: 1040px) {
    .main-header .main-bar > .container {
        height: 65px;
        padding: 0;
    }
}

.main-header .main-bar .logo {
    background-image: url("../images/TL-Logo_Tagline_Colour_RGB_480x101.jpg");
    background-size: contain;
    background-position: center center;
    background-repeat: no-repeat;
    width: 275px;
    height: 43px;
    display: inline-block;
    vertical-align: middle;
    margin-top: 15.5px;
    margin-left: -30px;
}

@media only screen and (max-width: 1040px) {
    .main-header .main-bar .logo {
        width: 180px;
        height: 28px;
        margin-top: 15px;
        margin-left: 15px;
    }
}

.main-header .main-bar .mobile-overlay {
    display: none;
}

@media only screen and (max-width: 768px) {
    .main-header .main-bar .mobile-overlay {
        width: 100%;
        height: 100%;
        top: 0;
        left: 0;
        background-color: rgba(0, 0, 0, 0.6);
        position: fixed;
        z-index: 9;
    }
}

.main-header .main-bar .link-list {
    padding: 0;
    margin: 0;
    list-style: none;
    float: right;
}

@media only screen and (max-width: 768px) {
    .main-header .main-bar .link-list {
        position: fixed;
        top: 0;
        left: 0;
        width: 210px;
        background: #fff;
        height: 100%;
        z-index: 10;
        -webkit-transform: translateX(-100%);
        transform: translateX(-100%);
        -webkit-transition: .2s transform;
        transition: .2s transform;
        will-change: transform;
    }

        .main-header .main-bar .link-list.active {
            -webkit-transform: translateX(0);
            transform: translateX(0);
        }
}

.main-header .main-bar .link-list li {
    display: inline-block;
}

@media only screen and (max-width: 768px) {
    .main-header .main-bar .link-list li {
        display: block;
        width: 100%;
    }
}

.main-header .main-bar .link-list li a {
    height: 75px;
    display: inline-block;
    vertical-align: middle;
    padding: 0 20px;
    color: black;
    -webkit-transition: .2s;
    transition: .2s;
}

@media only screen and (max-width: 1040px) {
    .main-header .main-bar .link-list li a {
        padding: 0 11.9px;
        height: 65px;
    }
}

@media only screen and (max-width: 768px) {
    .main-header .main-bar .link-list li a {
        height: auto;
        padding: 15px;
        width: 100%;
    }
}

.main-header .main-bar .link-list li a.active {
    background-color: #7bafde;
    color: #fff;
    border-color: #7bafde;
}

.main-header .main-bar .link-list li a:hover {
    background-color: #7bafde;
    color: #fff;
    border-color: #7bafde;
}

.main-header .main-bar .link-list li a:after {
    display: inline-block;
    vertical-align: middle;
    height: 100%;
    content: '';
}

.main-header .main-bar .link-list li a > span {
    vertical-align: middle;
    display: inline-block;
}

/* ==========================================================================
  Footer
========================================================================== */
.main-footer {
    background-image: url("../images/bg-login.png");
    background-size: cover;
    background-position: initial;
    background-repeat: no-repeat;
    background-color: #ffffff;
    z-index: 10;
    padding-top: 2%;
    left: 0;
    color: #fff;
    text-align: right;
    height: 190px;
    bottom: 0;
    margin-top: -190px; /* Corresponds to padding in .content-inside for sticky footer */
}

@media only screen and (max-width: 1040px) {
    .main-footer {
        text-align: left;
        margin-top: 250px;
        padding-top: 15px;
        padding-bottom: 15px;
    }
}

@media only screen and (max-width: 400px) {
    .main-footer {
        border-top: 1px solid #fff;
    }
}

.main-footer .container {
    float: left;
    padding: 0 15px;
}

.main-footer .links {
    padding: 0;
    margin-top: 100px;
    list-style: none;
}

    .main-footer .links li {
        display: inline-block;
    }

@media only screen and (max-width: 768px) {
    .main-footer .links li {
        display: block;
        line-height: normal;
    }
}

.main-footer .links li:not(:last-child) {
    margin-right: 15px;
}

.main-footer a {
    color: inherit;
    font-weight: 200;
}

.main-footer.logged-in {
    position: static;
    background: #fff;
    padding: 0 0;
    border-top: 1px solid #D8D8D8;
}

@media only screen and (max-width: 1040px) {
    .main-footer.logged-in {
        margin-top: 0;
    }
}

.main-footer.logged-in a, .main-footer.logged-in * {
    color: #999999;
}

.main-footer.logged-out {
    position: static;
    background: #fff;
    padding: 0 0;
    border-top: 1px solid #D8D8D8;
}

@media only screen and (max-width: 1040px) {
    .main-footer.logged-out {
        margin-top: 0;
    }
}

.main-footer.logged-out a, .main-footer.logged-in * {
    color: #999999;
}

body.content-tall .main-footer {
    position: relative;
    bottom: auto;
    margin-top: 30px;
}

/* ==========================================================================
  Log In
========================================================================== */
.log-in-container {
    width: 290px;
    float: left;
}

@media only screen and (max-width: 768px) {
    .log-in-container {
        width: 100%;
    }
}

.log-in-container .intro-message.mobile-only {
    padding-bottom: 15px;
}

.log-in-container h3 {
    margin: 0;
    margin-bottom: 20px;
}

.log-in-container form .form-component:first-child {
    margin-bottom: 10px;
}

.log-in-container form .form-component input {
    max-width: none;
}

.log-in-container form button {
    display: block;
    margin-top: 20px;
}

.log-in-container form .having-trouble {
    margin-top: 15px;
    display: block;
    font-size: 13.4px;
}

.welcome-message {
    width: calc(100% - 290px);
    float: left;
    padding-left: 80px;
    margin-top: -10px;
}

@media only screen and (max-width: 768px) {
    .welcome-message {
        display: none;
    }
}

.welcome-message h1 {
    margin: 0;
}

@media only screen and (max-width: 1040px) {
    .welcome-message h1 br {
        display: none;
    }
}

.welcome-message h1 strong {
    font-weight: 700;
}

.welcome-message .underline-link {
    color: #fff;
    font-weight: 400;
}

/* ==========================================================================
  Password recovery
========================================================================== */
.password-recovery-content .main-title {
    margin-bottom: 15px;
}

.password-recovery-content form input {
    max-width: 314px;
}

@media only screen and (max-width: 400px) {
    .password-recovery-content form input {
        max-width: 100%;
    }
}

.password-recovery-content form .form-component .small-text a {
    color: #213F7D;
}

/* ==========================================================================
  Register
========================================================================== */
.register-content .form-step:after {
    display: block;
    content: "";
    clear: both;
}

.register-content .form-step .form-component {
    margin-right: 15px;
    color: #213F7D;
}

.register-content .form-step[data-step="3"] {
    max-width: 600px;
}

.register-success {
    font-weight: bold;
    color: #59BA47;
}

/* ==========================================================================
  Member ID recover
========================================================================== */
.member-id-recovery-content {
    width: 100%;
    color: #213F7D;
}

    .member-id-recovery-content .button-set {
        padding-top: 30px;
    }

/* ==========================================================================
  Contact
========================================================================== */
.logged-out-content.contact-content {
    -webkit-transform: translateY(-45%);
    transform: translateY(-45%);
}

@media only screen and (max-width: 1040px) {
    .logged-out-content.contact-content {
        -webkit-transform: none;
        transform: none;
    }
}

.contact-content .main-title {
    margin-bottom: 10px;
}

/* ==========================================================================
  Dashboard
========================================================================== */
.dashboard-container {
    background-color: #fff;
    background-size: 100%;
    padding: 2%;
}

    .dashboard-container .main-title {
        margin-top: 0;
    }

    .dashboard-container .main-content:after {
        display: block;
        content: "";
        clear: both;
    }

    .dashboard-container .left-side {
        float: left;
        width: 865px;
        padding-right: 15px;
    }

@media only screen and (max-width: 1350px) {
    .dashboard-container .left-side {
        width: 70%;
    }
}

@media only screen and (max-width: 1040px) {
    .dashboard-container .left-side {
        width: 60%;
    }
}

@media only screen and (max-width: 768px) {
    .dashboard-container .left-side {
        width: 100%;
        padding-right: 0;
    }
}

.dashboard-container .right-side {
    float: right;
    width: calc(100% - 865px);
    padding-left: 15px;
}

@media only screen and (max-width: 1350px) {
    .dashboard-container .right-side {
        width: 30%;
    }
}

@media only screen and (max-width: 1040px) {
    .dashboard-container .right-side {
        width: 40%;
    }
}

@media only screen and (max-width: 768px) {
    .dashboard-container .right-side {
        width: 100%;
        padding-left: 0;
    }
}

@media only screen and (max-width: 768px) {
    .dashboard-container .notifications-container {
        margin-bottom: 15px;
    }
}

.dashboard-container .rounded-box-content {
    color: #000000;
    word-wrap: break-word;
}

    .dashboard-container .rounded-box-content .title {
        margin: 0 0 15px;
    }

.dashboard-bold-title {
    font-weight: bold;
    font-size: 12pt;
}

/* ==========================================================================
  Profile
========================================================================== */
.master-logged-in-container.profile .profile-info-container {
    margin-top: 0px;
}

.info-table-container {
    margin-top: 0px;
    border: 0px;
    border-left: 0px !important;
    background-color: transparent;
    vertical-align: top;
}

.info-table-warning {
    border-color: #59BA47;
    background-color: #e2f4c8;
    color: #59BA47;
    padding: 15px;
    font-weight: 400;
}

/* ==========================================================================
  Policies
========================================================================== */
.master-logged-in-container.policies:after {
    display: block;
    content: "";
    clear: both;
}

.master-logged-in-container.policies .policies-sidebar {
    float: left;
    width: 220px;
    padding-left: 15px;
}

@media only screen and (max-width: 1040px) {
    .master-logged-in-container.policies .policies-sidebar {
        width: 100%;
    }
}

.master-logged-in-container.policies .policies-list {
    padding: 0;
    margin: 0;
    list-style: none;
}

    .master-logged-in-container.policies .policies-list li {
        color: #000000;
        cursor: pointer;
        position: relative;
        float: left;
        clear: both;
    }

        .master-logged-in-container.policies .policies-list li:not(:last-child) {
            margin-bottom: 15px;
        }

        .master-logged-in-container.policies .policies-list li:after {
            width: 0;
            height: 0;
            border-top: 4px solid transparent;
            border-bottom: 4px solid transparent;
            border-left: 4px solid transparent;
            content: '';
            display: block;
            position: absolute;
            left: -15px;
            top: 50%;
            -webkit-transform: translate(-10px, -50%);
            transform: translate(-10px, -50%);
            -webkit-transition: .2s;
            transition: .2s;
        }

        .master-logged-in-container.policies .policies-list li.active {
            color: #7bafde;
        }

            .master-logged-in-container.policies .policies-list li.active:after {
                -webkit-transform: translate(0, -50%);
                transform: translate(0, -50%);
                border-left: 4px solid #7bafde;
            }

.master-logged-in-container.policies .policies-content {
    float: left;
    width: 775px;
    margin-left: 15px;
}

@media only screen and (max-width: 1040px) {
    .master-logged-in-container.policies .policies-content {
        float: none;
        width: 100%;
        max-width: 700px;
        padding-top: 30px;
        clear: both;
        margin-left: 0;
    }
}

.master-logged-in-container.policies .policies-content .policy-info-container {
    display: none;
}

    .master-logged-in-container.policies .policies-content .policy-info-container.active {
        display: block;
    }

    .master-logged-in-container.policies .policies-content .policy-info-container header {
        border-bottom: 1px solid #D8D8D8;
        margin-bottom: 40px;
        padding-bottom: 40px;
    }

        .master-logged-in-container.policies .policies-content .policy-info-container header:after {
            display: block;
            content: "";
            clear: both;
        }

@media only screen and (max-width: 768px) {
    .master-logged-in-container.policies .policies-content .policy-info-container header {
        border-bottom: none;
        margin-bottom: 0;
        padding-bottom: 30px;
    }
}

.master-logged-in-container.policies .policies-content .policy-info-container .coverage-amount, .master-logged-in-container.policies .policies-content .policy-info-container .premium-amount {
    float: left;
}

@media only screen and (max-width: 768px) {
    .master-logged-in-container.policies .policies-content .policy-info-container .coverage-amount, .master-logged-in-container.policies .policies-content .policy-info-container .premium-amount {
        float: none;
        margin-bottom: 30px;
    }
}

.master-logged-in-container.policies .policies-content .policy-info-container .coverage-amount .title, .master-logged-in-container.policies .policies-content .policy-info-container .premium-amount .title {
    margin-bottom: 10px;
}

.master-logged-in-container.policies .policies-content .policy-info-container .coverage-amount {
    margin-right: 40px;
    max-width: 290px;
}

@media only screen and (max-width: 768px) {
    .master-logged-in-container.policies .policies-content .policy-info-container .coverage-amount {
        max-width: none;
    }

        .master-logged-in-container.policies .policies-content .policy-info-container .coverage-amount hr {
            display: none;
        }
}

.master-logged-in-container.policies .policies-content .policy-info-container .button {
    float: right;
}

@media only screen and (max-width: 768px) {
    .master-logged-in-container.policies .policies-content .policy-info-container .button {
        float: none;
    }
}

.master-logged-in-container.policies .policies-content .policy-info-container .policy-info-docs-container {
    margin-bottom: 25px;
}

    .master-logged-in-container.policies .policies-content .policy-info-container .policy-info-docs-container:after {
        display: block;
        content: "";
        clear: both;
    }

@media only screen and (max-width: 768px) {
    .master-logged-in-container.policies .policies-content .policy-info-container .policy-info-docs-container {
        margin-bottom: 15px;
    }
}

.master-logged-in-container.policies .policies-content .policy-info-container .policy-info-docs-container table {
    float: left;
    margin-right: 25px;
}

    .master-logged-in-container.policies .policies-content .policy-info-container .policy-info-docs-container table tr td {
        padding: 10px 15px;
    }

@media only screen and (max-width: 768px) {
    .master-logged-in-container.policies .policies-content .policy-info-container .policy-info-docs-container table tr td:not(:last-child) {
        padding-bottom: 0;
    }
}

.master-logged-in-container.policies .policies-content .policy-info-container .policy-info-docs-container .documents-container {
    float: left;
}

@media only screen and (max-width: 768px) {
    .master-logged-in-container.policies .policies-content .policy-info-container .policy-info-docs-container .documents-container {
        margin-top: 15px;
    }
}

.master-logged-in-container.policies .policies-content .policy-info-container .policy-info-docs-container .documents-container .title {
    margin-bottom: 10px;
}

.master-logged-in-container.policies .policies-content .policy-info-container .policy-info-docs-container .documents-container .docs {
    padding: 0;
    margin: 0;
    list-style: none;
}

    .master-logged-in-container.policies .policies-content .policy-info-container .policy-info-docs-container .documents-container .docs li {
        margin-bottom: 3px;
    }

/* ==========================================================================
  Claims
========================================================================== */
.insurance-claims-location {
    padding: 5px 0;
}

    .insurance-claims-location:not(:last-child) {
        margin-bottom: 10px;
    }

    .insurance-claims-location .title {
        margin-bottom: 5px;
    }

/* ==========================================================================
  Rebates
========================================================================== */
.master-logged-in-container.rebates footer {
    padding-top: 30px;
}

.eligible-rebates-title {
    padding-top: 15px;
}
