/** Fonts */

@import url(https://fonts.googleapis.com/css2?family=Roboto:wght@300;400;500;700;900&display=swap);

/* ==========================================================================
Template Styles - starts
========================================================================== */

body#content {
    font: 500 1rem/1.5 Roboto, sans-serif;
    color: #121212;
    overflow-x: hidden
}

a,
abbr,
acronym,
address,
applet,
article,
aside,
audio,
b,
big,
blockquote,
body,
canvas,
caption,
center,
cite,
code,
dd,
del,
details,
dfn,
div,
dl,
dt,
em,
embed,
fieldset,
figcaption,
figure,
footer,
form,
h1,
h2,
h3,
h4,
h5,
h6,
header,
hgroup,
html,
i,
iframe,
img,
ins,
kbd,
label,
legend,
li,
mark,
menu,
nav,
object,
ol,
output,
p,
pre,
q,
ruby,
s,
samp,
section,
small,
span,
strike,
strong,
sub,
summary,
sup,
table,
tbody,
td,
tfoot,
th,
thead,
time,
tr,
tt,
u,
ul,
var,
video {
    margin: 0;
    padding: 0;
    border: 0;
    font-size: 100%;
    font: inherit;
    vertical-align: baseline
}

:focus {
    outline: 0
}

article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
menu,
nav,
section {
    display: block
}

body {
    line-height: 1
}

ol,
ul {
    list-style: none
}

blockquote,
q {
    quotes: none
}

blockquote:after,
blockquote:before,
q:after,
q:before {
    content: '';
    content: none
}

table {
    border-collapse: collapse;
    border-spacing: 0
}

input[type=search]::-webkit-search-cancel-button,
input[type=search]::-webkit-search-decoration,
input[type=search]::-webkit-search-results-button,
input[type=search]::-webkit-search-results-decoration {
    -webkit-appearance: none;
    -moz-appearance: none
}

input[type=search] {
    -webkit-appearance: none;
    -moz-appearance: none;
    -webkit-box-sizing: content-box;
    -moz-box-sizing: content-box;
    box-sizing: content-box
}

textarea {
    overflow: auto;
    vertical-align: top;
    resize: vertical
}

audio,
canvas,
video {
    display: inline-block;
    max-width: 100%
}

audio:not([controls]) {
    display: none;
    height: 0
}

[hidden] {
    display: none
}

html {
    font-size: 100%;
    -webkit-text-size-adjust: 100%;
    -ms-text-size-adjust: 100%
}

a:focus {
    outline: thin dotted
}

a:active,
a:hover {
    outline: 0
}

img {
    border: 0;
    -ms-interpolation-mode: bicubic
}

figure {
    margin: 0
}

form {
    margin: 0
}

fieldset {
    border: 1px solid silver;
    margin: 0 2px;
    padding: .35em .625em .75em
}

legend {
    border: 0;
    padding: 0;
    white-space: normal
}

button,
input,
select,
textarea {
    font-size: 100%;
    margin: 0;
    vertical-align: baseline
}

button,
input {
    line-height: normal
}

button,
select {
    text-transform: none
}

button,
html input[type=button],
input[type=reset],
input[type=submit] {
    -webkit-appearance: button;
    cursor: pointer
}

button[disabled],
html input[disabled] {
    cursor: default
}

input[type=checkbox],
input[type=radio] {
    box-sizing: border-box;
    padding: 0
}

input[type=search] {
    -webkit-appearance: textfield;
    -moz-box-sizing: content-box;
    -webkit-box-sizing: content-box;
    box-sizing: content-box
}

input[type=search]::-webkit-search-cancel-button,
input[type=search]::-webkit-search-decoration {
    -webkit-appearance: none
}

button::-moz-focus-inner,
input::-moz-focus-inner {
    border: 0;
    padding: 0
}

textarea {
    overflow: auto;
    vertical-align: top
}

table {
    border-collapse: collapse;
    border-spacing: 0
}

button,
html,
input,
select,
textarea {
    color: #222
}

::-moz-selection {
    background: #b3d4fc;
    text-shadow: none
}

::selection {
    background: #b3d4fc;
    text-shadow: none
}

img {
    vertical-align: middle
}

fieldset {
    border: 0;
    margin: 0;
    padding: 0
}

textarea {
    resize: vertical
}

.chromeframe {
    margin: .2em 0;
    background: #ccc;
    color: #000;
    padding: .2em 0
}

a {
    text-decoration: underline
}

a:focus {
    color: #0a4a8d;
    text-decoration: none;
    outline: .0625rem dotted #79b8f5
}

p {
    padding: 0;
    margin: 0
}

input:focus,
select:focus,
textarea:focus {
    outline: 0
}

::-webkit-input-placeholder {
    color: #696969
}

::-moz-placeholder {
    color: #696969;
    opacity: 1
}

:-ms-input-placeholder {
    color: #696969
}

:-moz-placeholder {
    color: #696969;
    opacity: 1
}

::-ms-clear {
    display: none
}

h1,
h2,
h3,
h4,
h5,
h6 {
    font-weight: 700
}

img {
    max-width: 100%;
    height: auto
}

.st-container {
    font-size: 1rem;
}

/* ==========================================================================
Template Styles - Ends
========================================================================== */


/* ==========================================================================
Header Styles - Starts
========================================================================== */

.fixed-top {
    -ms-transition: 0.3s transform ease-out;
    -webkit-transition: 0.3s transform ease-out;
    transition: 0.3s transform ease-out;
}

.header a {
    text-decoration: none;
}

.header.sticky {
    -ms-transform: translateY(-41px);
    -webkit-transform: translateY(-41px);
    transform: translateY(-41px);
}

.header.sticky .sub-header {
    background: #fff;
}

.header.sticky .logo {
    width: auto;
}

.header .logo-non-sticky {
    width: 110px;
}

.header.sticky .logo-non-sticky {
    width: 120px;
}

.logo-sticky {
    display: none;
    width: 40px;
}

.top-header {
    background: #142a41;
    color: #fff;
    padding: 0.4375rem 0;
    z-index: 100;
}

.top-header svg {
    fill: #fff;
}

.top-header a {
    color: #fff;
}

.skip-content {
    align-items: center;
}

.skip-site {
    font-size: 0.8125rem;
    text-decoration: none;
}

.font-sizer {
    list-style: none;
    padding: 0;
    margin: 0 0 0 1.875rem;
}

.font-sizer>li {
    display: inline-block;
}

.font-sizer>li a {
    background: url(https://cdn.freedommortgage.com/f42f7047-cb00-4f9a-8f54-596db989bfa7/dxdam/f7/f7195e47-0391-43f0-8370-bef5e3ea7156/font-sizer.png) 0.25rem 0 no-repeat;
    width: 0.75rem;
    height: 0.75rem;
    text-indent: -9999px;
    float: left;
    margin-right: 0.3125rem;
}

.font-sizer>li a.medium {
    background-position: -13px 0;
}

.font-sizer>li a.large {
    background-position: -33px 0;
    margin-left: 0.125rem;
}

.site-back-link {
    font-size: 1.1rem;
    float: left;
    margin-top: 0.25rem;
    margin-right: 1.75rem;
}

.sub-header {
    padding: 0.625rem 0;
    background: #fff;
    position: relative;
    z-index: 99;
    -webkit-box-shadow: 0 4px 16px 0 rgba(0, 0, 0, 0.16);
    -moz-box-shadow: 0 4px 16px 0 rgba(0, 0, 0, 0.16);
    box-shadow: 0 4px 16px 0 rgba(0, 0, 0, 0.16);
}

.sub-header svg {
    fill: #fff;
    fill-rule: evenodd;
}

.call-free svg {
    fill: #0a4a8d;
}

.call-free span {
    margin-left: 0.625rem;
    color: #4877a8;
}

.top-header .login a {
    font-size: 0.875rem;
}

.navbar .customer-connect svg {
    fill: #142a41;
}

.navbar .customer-connect .login a {
    display: none;
}

.navbar {
    padding: 0;
}

.navbar-light .navbar-toggler {
    border-color: #fff;
    padding: 0;
    outline: 0;
}

.navbar-light .navbar-toggler-icon {
    background-image: url("data:image/svg+xml;charset=utf8, %3Csvg viewBox='0 0 30 30' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath stroke='rgba(10, 74, 141, 1)' stroke-width='2' stroke-linecap='round' stroke-miterlimit='10' d='M4 8h24M4 16h24M4 24h24'/%3E%3C/svg%3E");
}

.navbar-toggler[aria-expanded="true"] .navbar-toggler-icon {
    background: url(https://cdn.freedommortgage.com/f42f7047-cb00-4f9a-8f54-596db989bfa7/dxdam/bf/bfa17606-8d68-47c3-871f-86be30d40374/hamburger-close-icon.svg) center no-repeat;
}

.sub-header-helpline svg {
    fill: #142a41;
}

.sub-header-helpline.d-xs-block {
    padding-top: 5px;
}

.helplines-wrapper a span {
    display: inline-block;
    margin: 0.3125rem 0 0 0.4375rem;
}

.helplines-wrapper {
    margin: 1.25rem 0;
}

.login svg {
    fill: #fff;
}

.navbar-light .navbar-collapse {
    margin: 10px -15px -10px -15px;
    -webkit-box-shadow: 0 0 7px rgba(0, 0, 0, 0.3);
    -moz-box-shadow: 0 0 7px rgba(0, 0, 0, 0.3);
    box-shadow: 0 0 7px rgba(0, 0, 0, 0.3);
}

.navbar-light .navbar-nav .nav-item {
    border-bottom: 1px solid #e2e4e7;
}

.navbar-light .navbar-nav .nav-item .nav-link {
    padding: 15px;
    font-size: 1.125rem;
}

.navbar-light .navbar-nav .nav-item.show .nav-link,
.navbar-light .navbar-nav .nav-link,
.navbar-light .navbar-nav .nav-link:hover {
    color: #0a4a8d;
}

.sub-header .navbar .navbar-collapse .nav-item:last-child {
    border-bottom: none;
}


/* ==========================================================================
Header Styles - Ends
========================================================================== */


/* ==========================================================================
Footer Styles - Starts
========================================================================== */

.footer {
    background: #0a4a8d;
    color: #fff;
    padding: 30px 0;
}

.footer a {
    color: #fff;
    text-decoration: none;
}

.footer a:hover {
    color: #fff;
    text-decoration: underline;
}

.footer-title {
    font-size: 0.875rem;
    color: #fff;
    padding-bottom: 7px;
    border-bottom: 0.1875rem solid #fff;
    margin-bottom: 15px;
    margin-top: 0;
    text-transform: uppercase;
}

.footer-links-wrap ul {
    list-style-type: none;
    margin: 0;
    padding: 0;
    font-size: 0.875rem;
}

.footer-links-wrap {
    padding-bottom: 30px;
}

.footer-address {
    font-size: 0.875rem;
}

.footer-address p {
    font-size: 0.875rem;
    margin-top: 10px;
}

.footer-social-links ul {
    list-style-type: none;
    padding: 0;
}

.footer-social-links ul li {
    display: inline;
}

.footer-social-links ul li a {
    margin: 0 10px 10px 0;
    display: inline-block;
    float: none;
    width: 1.875rem;
    height: 1.875rem;
    fill: #fff;
}

.footer-logo-wrap {
    background-color: #073a7a;
    padding: 30px 0 0 0;
}

footer .container>figure:last-child {
    width: 50%;
    padding-left: 30px;
}

footer .container>figure {
    width: 33.33%;
    margin: 0;
    text-align: center;
    padding: 0 0 30px;
}

.footer-credits {
    padding-top: 30px;
}

.foot-space>figure:last-child {
    cursor: pointer;
    border: none;
}

.footer-links ul {
    list-style: none;
    padding: 0;
    margin: 10px 0 0;
    font-size: 0.875rem;
    font-weight: 400;
}

.footer-links ul>li {
    display: inline-block;
}

.footer-links ul>li>a {
    display: inline-block;
    padding-right: 5px;
    color: #fff;
    line-height: 1;
    border-right: 0.0625rem solid #fff;
    margin-right: 5px;
    text-decoration: none;
    font-size: 0.8125rem;
}

.footer-links ul>li:last-child>a {
    border: 0;
}

.credits-text {
    font-size: 0.75rem;
    font-weight: 300;
}


/* ==========================================================================
Footer Styles - Ends
========================================================================== */

@media only screen and (min-width: 768px) {
    /* ==========================================================================
Template Styles - starts
========================================================================== */
    .container {
        max-width: 750px
    }
    /* ==========================================================================
Template Styles - Ends
========================================================================== */
    /* ==========================================================================
Header Styles - Starts
========================================================================== */
    .navbar .nav-helpline-mob {
        position: absolute;
        right: 0;
    }
    .header .logo-non-sticky {
        width: 130px;
    }
    /* ==========================================================================
Header Styles - Ends
========================================================================== */
    /* ==========================================================================
Footer Styles - starts
========================================================================== */
    .footer-links-wrap {
        padding-bottom: 45px;
        padding-right: 15px;
        width: 45%;
    }
    .footer-social-links ul {
        display: inline-flex;
    }
    .footer-social-links ul li {
        display: block;
    }
    footer .container>figure:last-child {
        width: auto;
        padding-left: 0;
    }
    footer .container>figure {
        width: auto;
    }
    .credits-text {
        font-size: 0.8125rem;
    }
    /* ==========================================================================
Footer Styles - Ends
========================================================================== */
}

@media only screen and (min-width: 768px) and (max-width: 1024px) {
    /* ==========================================================================
Template Styles Starts
========================================================================== */
    .container {
        max-width: 970px
    }
    /* ==========================================================================
Template Styles - Ends
========================================================================== */
    /* ==========================================================================
Header Styles - Starts
========================================================================== */
    .sub-header .navbar .navbar-collapse {
        position: absolute;
        width: 260px;
        background: #fff;
        margin: 0;
    }
    .sub-header .navbar .navbar-collapse .nav-item {
        margin-right: 0 !important;
    }
    .navbar-light .navbar-nav .nav-item.show span {
        border-bottom: 0;
    }
    /* ==========================================================================
Header Styles - Ends
========================================================================== */
}

@media only screen and (min-width: 1024px) {
    /* ==========================================================================
Footer Styles - Starts
========================================================================== */
    .footer-links-wrap {
        width: 17%;
    }
    .footer-links-wrap:nth-child(4) {
        width: 25%;
    }
    .foot-space {
        padding: 0 50px;
    }
    .footer-social-links ul {
        display: block;
    }
    .footer-links ul {
        display: inline;
    }
    .footer-links ul>li>a {
        font-size: 1rem;
    }
    /* ==========================================================================
Footer Styles - Ends
========================================================================== */
}

@media only screen and (min-width: 1200px) {
    /* ==========================================================================
Template Styles - Starts
========================================================================== */
    .container {
        max-width: 1256px
    }
    /* ==========================================================================
Template Styles - Ends
========================================================================== */
    /* ==========================================================================
Header Styles - Starts
========================================================================== */
    .header.sticky .logo-non-sticky {
        width: 130px;
    }
    .logo .logo-non-sticky {
        width: 175px;
        margin: 0 40px 0 0;
    }
    .navbar-light .navbar-nav .nav-item.show span,
    .navbar-light .navbar-nav .nav-link span:hover {
        padding-bottom: 5px;
        border-bottom: 3px solid;
    }
    .navbar .nav-helpline-mob {
        top: 5px;
    }
    .navbar-light .navbar-collapse {
        margin: 0;
    }
    .navbar-light .navbar-nav .nav-item {
        border-bottom: none;
    }
    .navbar-light .navbar-nav .nav-item .nav-link {
        padding: 5px 15px;
        font-size: 1rem;
    }
    .navbar-light .navbar-collapse {
        box-shadow: none;
    }
    /* ==========================================================================
Header Styles - Ends
========================================================================== */
    /* ==========================================================================
Footer Styles - Starts
========================================================================== */
    .foot-space {
        padding: 0 100px;
    }
    /* ==========================================================================
Footer Styles - Ends
========================================================================== */
}