@charset "UTF-8";

/* Google fonts */
@import url("https://fonts.googleapis.com/css?family=Raleway:600,700%7COpen+Sans:400italic,400,700");

/* Reset css */
*, ::before, ::after {
    box-sizing: border-box;
    border-width: 0;
    border-style: solid;
    border-color: #e5e7eb;
}

:host, html {
    line-height: 1.5;
    -webkit-text-size-adjust: 100%;
    tab-size: 4;
    font-family: 'Roboto', 'sans-serif';
    font-feature-settings: --theme(--default-font-feature-settings, normal);
    font-variation-settings: --theme(--default-font-variation-settings, normal);
    -webkit-tap-highlight-color: transparent;
}

hr {
    height: 0;
    color: inherit;
    border-top-width: 1px;
}

abbr:where([title]) {
    text-decoration: underline dotted;
}

h1, h2, h3, h4, h5, h6 {
    font-size: inherit;
    font-weight: inherit;
}

a {
    color: inherit;
    text-decoration: inherit;
}

b, strong {
    font-weight: bolder;
}

small {
    font-size: 80%;
}

table {
    text-indent: 0;
    border-color: inherit;
    border-collapse: collapse;
}

:-moz-focusring {
    outline: auto;
}

progress {
    vertical-align: baseline;
}

summary {
    display: list-item;
}

menu, ol, ul {
    list-style: none;
    margin: 0;
}

audio, canvas, embed, iframe, img, object, svg, video {
    display: block;
    vertical-align: middle;
}

img, video {
    max-width: 100%;
    height: auto;
}

::file-selector-button, button, input, optgroup, select, textarea {
    font: inherit;
    font-feature-settings: inherit;
    font-variation-settings: inherit;
    letter-spacing: inherit;
    color: inherit;
    border-radius: 0;
    background-color: transparent;
    opacity: 1;
}

:where(select:is([multiple],[size])) optgroup {
    font-weight: bolder;
}

:where(select:is([multiple],[size])) optgroup option {
    padding-inline-start: 20px;
}

::file-selector-button {
    margin-inline-end: 4px;
}

::placeholder {
    opacity: 1;
}

textarea {
    resize: vertical;
}

::-webkit-search-decoration {
    -webkit-appearance: none;
}

::-webkit-date-and-time-value {
    min-height: 1lh;
    text-align: inherit;
}

::-webkit-datetime-edit-fields-wrapper {
    padding: 0
}

::-webkit-datetime-edit-day-field,
::-webkit-datetime-edit-hour-field,
::-webkit-datetime-edit-month-field,
::-webkit-datetime-edit-year-field {
    padding-block: 0
}

::-webkit-calendar-picker-indicator {
    line-height: 1
}

:-moz-ui-invalid {
    box-shadow: none
}

::file-selector-button, button, input:where([type=button],[type=reset],[type=submit]) {
    appearance: button
}

::-webkit-inner-spin-button, ::-webkit-outer-spin-button {
    height: auto
}

[hidden]:where(:not([hidden=until-found])) {
    display: none !important
}

/* Normal site css */
html {
    line-height: 1.25;
    background-color: transparent;
}

/* Fullscreen popup overflow kill hack for iOS */
html.has-fullscreen-popup,
html.has-fullscreen-popup body {
    overflow: hidden;
}

@media (min-width: 768px) {
    html.has-fullscreen-popup,
    html.has-fullscreen-popup body {
        overflow: unset;
    }
}

body {
    padding: 0;
    margin: 0 !important;
    font-family: "Open Sans", sans-serif;
    background-color: #a3c1cf;
}

#wrapper {
    margin-left: auto;
    margin-right: auto;
}

img {
    border: 0;
}

h1 {
    color: #2692c0;
    font-family: "Raleway", sans-serif;
    font-size: 26px;
    margin-top: 0;
    margin-bottom: 10px;
    line-height: 30px;
}

h2 {
    font-size: 22px;
    color: #583389;
    font-family: "Raleway", sans-serif;
    font-weight: 700;
    margin: 14px 0 10px 0;
}

h3 {
    margin: 14px 0 10px 0;
    font-size: 18px;
    color: #04306a;
}

ul {
    margin-bottom: 1rem;
    margin-left: 5px;
    padding-left: 10px;
}

.font-bold {
    font-weight: bold;
}

.mb-4 {
    margin-bottom: 1rem;
}

svg {
    fill: currentColor;
}

[v-cloak] {
    display: none;
}

header.site {
    background: transparent url("../images/background_top_header.png") repeat-x;
    position: relative;
    z-index: 100;
}

.top_contact {
    float: right;
}

.top_holder {
    width: 990px;
    margin: 0 auto;
    text-align: right;
}

.logo {
    float: left;
    width: 216px;
    padding: 12px 18px;
    border-radius: 0 0 10px 10px;
    box-shadow: 0 0 10px -2px #000000;
    background-color: #ffffff;
}

.logo > a > img {
    display: block;
}

.login_phone {
    float: left;
    width: auto;
    padding: 4px 12px 4px 8px;
    font-size: 20px;
    color: #0875b5;
    font-weight: 700;
}

.login_main {
    float: right;
    width: auto;
    border-radius: 0 0 10px 10px;
    box-shadow: 0 0 10px -2px #000000;
    padding: 10px 14px;
    font-size: 12px;
    font-weight: 700;
    font-family: "Raleway", sans-serif;
    background-color: #ffffff;
}

.login_main a {
    color: #0875b5;
    text-decoration: none;
}

.testimonialbubble {
    border: 6px solid #f2f7f9;
    padding: 25px;
    text-align: center;
    border-radius: 15px;
    color: #444444;
    line-height: 24px;
    font-size: 15px;
}

.testimonialname {
    background: url("../images/testimonials-tail.jpg") no-repeat;
    text-align: center;
    padding: 23px 0 28px 0;
    color: #0875b5;
    font-weight: bold;
}

.img-rt-float {
    margin: -4px 10px 15px 15px;
    float: right;
}

.top_nav_holder {
    float: right;
    width: 730px;
}

nav.site {
    margin: 25px 0 0 0;
}

nav.site ul {
    margin-top: 1rem;
    margin-bottom: 1rem;
}

nav.site li {
    list-style-type: none;
}

nav.site ul li {
}

nav.site li a {
    float: left;
    display: block;
    font-weight: 700;
    font-family: "Raleway", sans-serif;
    text-transform: uppercase;
    color: #2c2c2f;
    font-size: 18px;
    padding: 20px 47px 0 47px;
    height: 60px;
    text-decoration: none;
    transition: 0.15s ease-in-out;
    border-right: 1px solid #a3c1cf;
}

nav.site li a:hover {
    color: #0875b5;
    padding-top: 15px;
}

nav.site li:first-child a {
    padding: 20px 42px 0 0;
}

nav.site li:first-child a:hover {
    padding: 15px 42px 0 0;
}

nav.site li:last-child a {
    border-right: none;
}

nav.site li:last-child a:hover {
    border-right: none;
}

/* Drop Down */
nav.site ul ul {
    display: none;
    padding: 0 !important;
    text-align: center;
    width: 179px;
}

nav.site ul li:hover > ul {
    display: block;
}

nav.site ul ul {
    position: absolute;
    top: 120px;
    margin: 0 0 0 280px;
}

nav.site ul ul li {
    float: none;
    position: relative;
}

nav.site ul ul li a,
nav.site ul ul li:first-child a {
    padding: 14px 10px 10px 10px !important;
    border-right: none !important;
    width: 179px;
    font-size: 13px;
    text-transform: none;
    color: #ffffff;
    height: 49px;
    display: block;
    background: #5f6975;
}

nav.site ul ul li a:hover,
nav.site ul ul li:first-child a:hover {
    background: #4b545f;
    color: #ffffff;
}

/* End Drop Down */
#top_banner {
    background-color: #04306a;
    text-align: center;
    position: relative;
    bottom: 25px;
    margin: 0 0 -25px 0;
    height: 328px;
}

.top_banner {
    width: 1180px;
    margin: 0 auto;
}

#mid_banner {
    background-color: #a3c1cf;
}

.mid_banner_content {
    width: 980px;
    margin: 0 auto;
}

.mid_banner_left,
.mid_banner_right,
.rt_banner_left,
.rt_banner_right {
    float: left;
    width: 478px;
    border-radius: 14px;
    box-shadow: 0 0 10px -2px #000000;
    background-color: #ffffff;
    margin: 13px 0 13px 0;
    padding: 17px 15px 17px 50px;
    min-height: 130px;
    transition: 0.15s ease-in-out;
}

.rt_banner_left,
.rt_banner_right {
    float: none;
    width: 306px;
    margin: 0 auto 18px auto;
    padding: 17px 6px 17px 20px;
}

.mid_banner_left:hover,
.mid_banner_right:hover,
.rt_banner_left:hover,
.rt_banner_right:hover {
    background-color: #e9f0f4;
    cursor: pointer;
}

.mid_banner_right {
    margin-left: 22px;
}

.mid_banner_icon,
.rt_banner_icon {
    float: left;
    width: 95px;
}

.mid_banner_icon > img {
    display: block;
}

.rt_banner_icon,
.rt_banner_icon img {
    width: 55px;
    margin: 10px 0 0 0;
}

.mid_banner_text,
.rt_banner_text {
    float: left;
    width: 280px;
    margin: 5px 0 0 15px;
    font-size: 14px;
    color: #666666;
    line-height: 18px;
    text-decoration: none;
}

.rt_banner_text {
    width: 203px;
    font-size: 11px;
}

.mid_banner_text h3,
.rt_banner_text h3 {
    font-size: 22px;
    color: #583389;
    font-family: "Raleway", sans-serif;
    font-weight: 700;
    margin: 0 0 10px 0;
}

.rt_banner_text h3 {
    font-size: 18px;
}

.purple_btn a {
    display: block;
    width: 250px;
    background: url("../images/background_btn_purple.jpg") repeat-x;
    padding: 13px 20px;
    color: #ffffff;
    text-shadow: 1px 1px 6px #000000;
    text-align: center;
    font-weight: 700;
    font-size: 20px;
    font-family: "Raleway", sans-serif;
    text-decoration: none;
    border-radius: 14px;
    margin: 18px 0 24px 0;
}

.purple_btn a:hover {
    background-image: none;
    background-color: #0875b5;
}

.big_green_btn {
    width: 306px;
    margin: 0 auto;
}

.big_green_btn.inbanner {
    width: 260px;
}

.big_green_btn a,
.big_green_btn.inbanner a {
    display: block;
    width: 306px;
    background: url("../images/background_btn_green_big.jpg") repeat-x;
    padding: 18px 23px;
    color: #ffffff;
    text-shadow: 1px 1px 6px #000000;
    text-align: center;
    font-weight: 700;
    font-size: 28px;
    font-family: "Raleway", sans-serif;
    text-decoration: none;
    border-radius: 14px;
    margin: 10px 0 15px 0;
}

.big_green_btn a:hover {
    background-image: none;
    background-color: #5c9934;
}

.big_green_btn.inbanner a {
    margin: 15px 0 15px -100px;
    padding: 12px 20px;
    box-shadow: 0 0 5px -1px #000000;
}

.larger {
    font-size: 18px;
    font-family: "Raleway", sans-serif;
    line-height: 25px;
    font-weight: 600;
    color: #365365;
}

#content_holder,
#sub_content_holder {
    background-color: #ffffff;
}

#sub_content_holder {
    margin: -25px 0 0 0;
}

#content,
#sub-content {
    width: 980px;
    margin: 0 auto;
    background: url("../images/background_main.jpg") repeat-y;
}

#sub-content {
    padding-top: 25px;
    min-height: 400px;
}

#sub-content.full {
    background: none;
    padding-bottom: 25px;
}

.content-left {
    float: left;
    width: 635px;
    padding: 20px;
    font-size: 14px;
    line-height: 20px;
    color: #365365;
}

.content-right {
    width: 345px;
    float: right;
}

.rt_testimonials {
    padding: 20px 35px 35px 35px;
    font-size: 14px;
}

.rt_testimonials h2 {
    color: #2692c0;
    font-family: "Raleway", sans-serif;
    font-size: 26px;
    margin-top: 0;
    margin-bottom: 10px;
    line-height: 30px;
}

.rt_testimonial_name {
    font-weight: 700;
    color: #666666;
    padding: 12px 0 18px 0;
    font-size: 12px;
}

.rt_testimonial_more a {
    font-size: 16px;
    color: #2692c0;
    text-decoration: none;
    font-weight: 700;
}

.rt_testimonial_more a:hover {
    color: #04306a;
}

.bottom_bar {
    background-color: #0875b5;
    padding: 15px 0;
    color: #e2ebf0;
}

.bottom_bar_content {
    width: 980px;
    margin: 0 auto;
}

.bottom_bar_content h3 {
    color: #e2ebf0;
    margin: 0 0 10px 0;
    font-size: 20px;
}

.bottom_bar_content li {
    list-style-type: none;
    float: left;
    width: auto;
    border-right: 1px solid #a3c1cf;
    padding: 0 15px 0 15px;
    font-size: 12px;
    line-height: 20px;
    min-height: 160px;
}

.bottom_bar_content li:last-child {
    border-right: 0;
}

.bottom_bar_content li a {
    color: #ffffff;
    text-decoration: underline;
}

.bottom_bar_content li a:hover {
    text-decoration: none;
}

li.bottom_about {
    width: 400px;
}

li.bottom_find {
    width: 230px;
}

li.bottom_contact {
    width: 230px;
}

footer.site {
    padding: 10px;
    font-size: 11px;
    color: #0875b5;
    text-align: center;
}

.list-disc {
    list-style-type: disc;
}

.pl-5 {
    padding-left: 1.25rem;
}

.clear {
    clear: both;
    display: table;
}

.cf {
    zoom: 1;
}

.cf:before,
.cf:after {
    content: " ";
    display: table;
}

.cf:after {
    clear: both;
}

/* Contact us */
.contact-form label {
    display: block;
    margin-bottom: 0.125rem;
    font-weight: bold;
}

.contact-form label span.required {
    color: #AA0000;
}

.contact-form input {
    padding: 0;
    margin: 0;
    font-size: 0.9375rem;
}

.contact-form .form-row {
    margin-bottom: 0.75rem;
}

.contact-form input[type="text"],
.contact-form input[type="email"],
.contact-form input[type="date"],
.contact-form input[type="time"],
.contact-form input[type="password"],
.contact-form input[type="number"],
.contact-form input[type="datetime-local"],
.contact-form select,
.contact-form textarea {
    background-color: #ffffff;
    line-height: 1.25;
    border-width: 0.125rem;
    border-style: inset;
    width: 100%;
}

.contact-form input[type="text"],
.contact-form input[type="email"],
.contact-form input[type="date"],
.contact-form input[type="time"],
.contact-form input[type="password"],
.contact-form input[type="number"],
.contact-form input[type="datetime-local"],
.contact-form textarea,
.contact-form select {
    color: #5f5850;
    padding: 0.125rem 0.25rem;
    box-shadow: 1px 1px 1px 0 #eeeeee inset;
    border-radius: 0.125rem;
    font-size: 0.9375rem;
    min-height: 1.75rem;
}

.contact-form input[type="submit"] {
    display: block;
    width: 100%;
    background: transparent url("../images/background_btn_purple.jpg") repeat-x;
    padding: 13px 20px !important;
    color: #fff;
    text-shadow: 1px 1px 6px #000000;
    text-align: center;
    font-weight: 700;
    font-size: 1rem;
    font-family: Raleway, sans-serif;
    text-decoration: none;
    border-radius: 14px;
    margin: 0 0 18px;
    border: none !important;
    cursor: pointer;
}

.contact-form input[type="submit"]:hover {
    background: #0875b5;
}

.flash-notices > .flash-notice {
    padding: 3px 2px 2px 3px;
    margin-bottom: 5px;
    font-style: normal;
    font-weight: normal;
    color: #000000;
    border-radius: 5px;
}

.flash-notices > .flash-notice.error {
    padding-left: 24px;
    border: 1px solid #dd5555;
    background: #ffbbbb url("../images/icon-message-error.png") no-repeat 3px center;
}

.flash-notices > .flash-notice.success {
    padding-left: 24px;
    border: 1px solid #00dd00;
    background: #bbffbb url("../images/icon-message-success.png") no-repeat 3px center;
}

.flash-notices > .flash-notice:last-child {
    margin-bottom: 8px;
}

/* Homepage */
.homepage-slider {
    position: relative;
    height: 328px;
    z-index: 0;
    margin-top: 0;
}

.homepage-slider.slide-1 {
    background: #eceff2 url("../images/banner_3.jpg") no-repeat center center;
}

.homepage-slider.slide-2 {
    background: #6b6840 url("../images/banner_4.jpg") no-repeat center center;
}

.homepage-slider.slide-3 {
    background: #6a3d26 url("../images/banner_5.jpg") no-repeat center center;
}

.homepage-slider.slide-4 {
    background: #3397b5 url("../images/banner_6.jpg") no-repeat center center;
}

.homepage-slider > .homepage-slider-content > .slide-content {
    display: none;
}

.homepage-slider > .homepage-slider-content > .slide-content.slide-1,
.homepage-slider > .homepage-slider-content > .slide-content.slide-2,
.homepage-slider > .homepage-slider-content > .slide-content.slide-3,
.homepage-slider > .homepage-slider-content > .slide-content.slide-4 {
    color: #ffffff;
    font-size: 36px;
    line-height: 36px;
    font-weight: 700;
    padding: 60px 0 0 520px;
    width: 980px;
    margin: 0 auto;
    text-shadow: 2px 2px 2px #000000;
    text-align: left;
}

.homepage-slider.slide-1 > .homepage-slider-content > .slide-content.slide-1,
.homepage-slider.slide-2 > .homepage-slider-content > .slide-content.slide-2,
.homepage-slider.slide-3 > .homepage-slider-content > .slide-content.slide-3,
.homepage-slider.slide-4 > .homepage-slider-content > .slide-content.slide-4 {
    display: block;
}

.offwhite {
    color: #e9f0f3;
}

.homepage-slider-left,
.homepage-slider-right {
    position: absolute;
    width: 55px;
    height: 74px;
    top: 50%;
    z-index: 5;
    margin-top: -37px;
}

.homepage-slider-right {
    right: 0;
}

form#login > .form-row > label {
    display: inline-block;
    width: 85px;
}

@media (max-width: 1030px) {
    header.site > .top_holder {
        padding: 0 13px;
        width: auto;
    }

    header.site > .top_holder > .top_nav_holder {
        width: 73.737373737373737373737373737374%;
    }

    nav.site li a {
        padding-right: 30px;
        padding-left: 30px;
    }

    #mid_banner {
        padding: 0 13px;
    }

    #mid_banner > .mid_banner_content {
        width: auto;
        margin: 0;
    }

    #content {
        padding: 0 13px;
        width: auto;
        background: transparent;
    }

    #content > .content-left {
        padding: 20px 7px;
        width: 61.006289308176100628930817610063%;
    }

    #content > .content-right {
        width: 34.800838574423480083857442348008%;
    }

    #sub-content {
        width: auto;
        padding: 0;
        background: transparent;
    }

    #sub-content > .content-left {
        padding: 25px 13px;
        width: calc(100% - 332px);
    }

    #sub-content > .content-right {
        padding: 45px 13px;
        background-color: #e3eaf0;
        width: 332px;
    }

    .rt_testimonials {
        background-color: #e3eaf0;
    }
}

@media (max-width: 1018px) {
    #mid_banner > .mid_banner_content > a > div {
        float: none;
        margin: 13px auto;
    }
}

@media (max-width: 994px) {
    .bottom_bar_content {
        width: 950px;
    }

    .bottom_bar_content li.bottom_contact {
        width: 200px;
    }
}

@media (max-width: 964px) {
    .bottom_bar_content {
        width: 830px;
    }

    .bottom_bar_content li.bottom_find {
        width: 110px;
    }
}

@media (max-width: 872px) {
    header.site {
        background: #e6eef2;
    }

    header.site > .top_holder > .top_nav_holder {
        clear: both;
        width: 615px;
        float: none;
        margin: 0 auto;
    }

    header.site > .top_holder > .logo {
        width: 15%;
    }

    header.site > .top_holder > .logo > a > img {
        width: 100%;
    }

    header.site > .top_holder > .top_contact > .login_main,
    header.site > .top_holder > .top_contact > .login_phone {
        float: none;
        text-align: center;
    }

    header.site > .top_holder > .top_contact > .login_main {
        font-size: 16px;
    }

    header.site > .top_holder > .top_contact > .login_main > a {
        padding: 0 5px;
    }

    #sub_content_holder {
        margin-top: 0;
    }

    #top_banner {
        height: 250px;
    }

    .homepage-slider {
        background: none !important;
        height: auto;
    }

    .homepage-slider > .homepage-slider-content > .slide-content.slide-1,
    .homepage-slider > .homepage-slider-content > .slide-content.slide-2,
    .homepage-slider > .homepage-slider-content > .slide-content.slide-3,
    .homepage-slider > .homepage-slider-content > .slide-content.slide-4 {
        padding: 50px 100px;
        width: auto;
        margin: 0;
        text-align: center;
    }

    .slide-content > .big_green_btn {
        margin: 25px auto 0 auto;
    }

    .slide-content > .big_green_btn.inbanner {
        width: 300px;
    }

    .slide-content > .big_green_btn.inbanner a {
        margin: 0;
    }

    nav.site ul ul {
        display: none !important;
    }
}

@media (max-width: 830px) {
    .bottom_bar_content {
        width: 730px;
    }

    .bottom_bar_content li.bottom_about {
        width: 300px;
    }
}

@media (max-width: 800px) {
    #content {
        padding: 0;
    }

    #content > .content-left,
    #content > .content-right {
        float: none;
        margin: 0;
        width: auto;
    }

    #content > .content-left {
        padding: 20px;
    }

    #sub-content {
        padding: 0;
    }

    #sub-content > .content-left,
    #sub-content > .content-right {
        float: none;
        margin: 0;
        width: auto;
        padding: 20px;
    }

    #sub-content > .content-left > .img-rt-float {
        width: 25%;
    }

    #sub-content > .content-right > .rt_testimonials {
        padding: 0;
    }
}

@media (max-width: 744px) {
    .bottom_bar_content {
        width: auto;
    }

    .bottom_bar_content ul {
        margin: 0;
        padding: 0;
    }

    .bottom_bar_content li.bottom_about,
    .bottom_bar_content li.bottom_find,
    .bottom_bar_content li.bottom_contact {
        float: none;
        width: auto;
        padding: 15px;
        text-align: center;
        min-height: 0;
    }
}

@media (max-width: 640px) {
    header.site > .top_holder > .top_nav_holder {
        width: auto;
    }

    nav.site {
        margin: 0;
        padding: 15px 0;
        width: 100%;
        text-align: center;
    }

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

    nav.site > ul > li > a,
    nav.site > ul > li > ul > li > a {
        float: none;
        background-color: #a3c1cf;
        color: #ffffff;
        font-size: 13px;
        height: 46px;
        line-height: 46px;
        display: block;
        text-decoration: none;
        margin-bottom: 10px;
    }

    nav.site > ul > li:last-child > a {
        margin-bottom: 0;
    }

    nav.site ul > li > ul {
        position: static;
        display: block !important;
        width: auto;
        margin: 0;
    }

    nav.site ul ul li a,
    nav.site ul ul li:first-child a,
    nav.site ul ul li a:hover,
    nav.site ul ul li:first-child a:hover {
        width: auto;
        text-transform: uppercase;
        background-color: #a3c1cf;
        padding: 0 !important;
        height: 46px;
        line-height: 46px;
    }

    nav.site ul ul li a,
    nav.site ul ul li:first-child a {
        color: #ffffff;
        background-color: #6c8795 !important;
    }

    nav.site ul ul li a:hover,
    nav.site ul ul li:first-child a:hover {
        color: #0875b5;
    }

    nav.site li:first-child a,
    nav.site li:first-child a:hover,
    nav.site li a,
    nav.site li a:hover {
        height: auto;
        padding: inherit;
    }

    #dbg-tlb {
        display: none;
    }
}

@media (max-width: 570px) {
    #top_banner {
        display: none;
    }
}

@media (max-width: 505px) {
    #mid_banner {
        display: none;
    }
}

