/* --- FONTS --- */


@font-face {
    font-family: header-text;
    src: url('../fonts/Cardo-Regular.woff') format('woff');
    font-weight: normal;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: header-text;
    src: url('../fonts/Cardo-Bold.ttf') format('truetype');
    font-weight: bold;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: other-text;
    src: url('../fonts/Roboto/Roboto-Regular.ttf') format('truetype');
    font-weight: normal;
    font-style: normal;
    font-display: swap;
}


@font-face {
    font-family: body-text;
    src: url('../fonts/Montserrat-Black.woff') format('woff');
    font-weight: 900;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: body-text;
    src: url('../fonts/Montserrat-BlackItalic.woff') format('woff');
    font-weight: 900;
    font-style: italic;
    font-display: swap;
}

@font-face {
    font-family: body-text;
    src: url('../fonts/Montserrat-Bold.woff') format('woff');
    font-weight: 400;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: body-text;
    src: url('../fonts/Montserrat-ExtraBoldItalic.woff') format('woff');
    font-weight: bold;
    font-style: italic;
    font-display: swap;
}

@font-face {
    font-family: body-text;
    src: url('../fonts/Montserrat-ExtraLight.woff') format('woff');
    font-weight: 200;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: body-text;
    src: url('../fonts/Montserrat-ExtraLightItalic.woff') format('woff');
    font-weight: 200;
    font-style: italic;
    font-display: swap;
}

@font-face {
    font-family: body-text;
    src: url('../fonts/Montserrat-Italic.woff') format('woff');
    font-weight: normal;
    font-style: italic;
    font-display: swap;
}

@font-face {
    font-family: body-text;
    src: url('../fonts/Montserrat-Light.woff') format('woff');
    font-weight: 300;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: body-text;
    src: url('../fonts/Montserrat-LightItalic.woff') format('woff');
    font-weight: 300;
    font-style: italic;
    font-display: swap;
}

@font-face {
    font-family: body-text;
    src: url('../fonts/Montserrat-Medium.woff') format('woff');
    font-weight: 500;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: body-text;
    src: url('../fonts/Montserrat-MediumItalic.woff') format('woff');
    font-weight: 500;
    font-style: italic;
    font-display: swap;
}

@font-face {
    font-family: body-text;
    src: url('../fonts/Montserrat-Regular.woff') format('woff');
    font-weight: normal;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: body-text;
    src: url('../fonts/Montserrat-SemiBold.woff') format('woff');
    font-weight: 600;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: body-text;
    src: url('../fonts/Montserrat-SemiBoldItalic.woff') format('woff');
    font-weight: 600;
    font-style: italic;
    font-display: swap;
}

@font-face {
    font-family: body-text;
    src: url('../fonts/Montserrat-Thin.woff') format('woff');
    font-weight: 100;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: body-text;
    src: url('../fonts/Montserrat-ThinItalic.woff') format('woff');
    font-weight: 100;
    font-style: italic;
    font-display: swap;
}



@font-face {
    font-family: body-text-alt;
    src: url('../fonts/Roboto/Roboto-Regular.ttf') format('truetype');
    font-weight: 400;
}

@font-face {
    font-family: body-text-alt;
    src: url('../fonts/Roboto/Roboto-Medium.ttf') format('truetype');
}

@font-face {
    font-family: NunitoSans;
    src: url('../fonts/Roboto/Roboto-Regular.ttf') format('truetype');
    font-weight: 400;
}

@font-face {
    font-family: NunitoSans;
    src: url('../fonts/Roboto/Roboto-Medium.ttf') format('truetype');
}





/*** Variables ***/
:root {
    --color-default: #1c1c1c;
    --color-primary: #001196;
    --color-secondary: #A08048;
    --color-tertiary: #B00000;
    --color-quarternary: #00a0ff;

    --color-muted: #c6c6c6;
    --color-warning: #ff9800;
    --color-success: #28a745;
    --color-danger: #dc3545;


    --color-white: #ffffff;
    --color-white-2: #F6F6F6;

    --color-black: #000000;

    --color-dark-blue: #000060;

    --color-blue-light-1: #001DFF;
    --color-blue-light-2: #C8E4FF;
    --color-blue-light-3: #E6F6FF;
    --color-blue-light-4: #E6F6FF;
    --color-blue-light-5: #b3e3ff;

    --color-yellow-light: #FFEEB3;
    --color-yellow: #ffc800;



    --color-light-gray-a1: #ebebebe7;
    --color-light-gray: #f7f7f7;
    --color-light-gray-2: #ebebeb;
    --color-light-gray-3: #e2e2e2;
    --color-light-gray-4: #cfcfcf;
    --color-light-gray-5: #e4e4e4;

    --color-gray: #AAAAAA;
    --color-gray-2: #717171;
    --color-gray-3: #8d8d8d;

    --color-dark-gray: #555555;
    --color-dark-gray-2: #313030;
    --color-dark-gray-3: #383838;

    --color-red: #FF0000;
    --color-red-2: #ae0000;

    --color-gold: #B9975E;
    --color-gold-2: #7b5a22;

    --color-dark-green: #0e536d;

    --color-brown: #583b09;
    

    --base-font: 1rem;
    --gutter: 15px;  /* do not use in grids */
}

@media(min-width:768px) {
    :root {
        --gutter: 20px; /* do not use in grids */
    }
}

/*** Base Styles ***/

*:focus {
    outline-color: transparent;
}
body {
    /*For overall default styling*/
    font-family: header-text;
    font-weight: 400;
    font-size: 100%;
    letter-spacing: 0;
    line-height: 120%;
    max-width: 100%;
    color: var(--color-default);
    background-color: white;
    overflow-wrap: break-word;
}



/*** Images ***/

img,
object,
iframe,
picture, 
video { 
    max-width: 100%;
}
.cover-img {
    object-fit: cover;
}
.contain-img {
    object-fit: contain;
}
.cover-bg,
.contain-bg {
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center;
}
.contain-bg {
    background-size: contain;
}

.fixed-bg {
    background-size: cover;
}

a {
    text-decoration: none;
}

a:hover,
a:focus {
    color: inherit;
    text-decoration: underline;
}



@media (min-width: 992px) {
    .fixed-bg {
        background-attachment: fixed;
    }
}



/*** Typography ***/

.body-text {
    font-family: body-text !important;
    font-weight: normal;
}
.body-text.font-weight-bold {
    font-weight: 500;
}

.header-text {
    font-family: header-text !important;
    font-weight: normal;
}

.other-text {
    font-family: other-text !important;
}

.small-text-family {
    font-family: NunitoSans;
}

/* Font Colors */
.text-default {
    color: var(--color-default) !important;
}

.text-primary {
    color: var(--color-primary) !important;
}

.text-secondary {
    color: var(--color-secondary) !important;
}

.text-teriary {
    color: var(--color-tertiary) !important;
}


.text-quarternary {
    color: var(--color-quarternary) !important;
}


.text-muted {
    color: var(--color-muted) !important;
}

.text-gray {
    color: var(--color-gray) !important;
}

.text-gray-3 {
    color: var(--color-gray-3) !important;
}

.text-dark-gray-3 {
    color: var(--color-dark-gray-3) !important;
}


.text-dark-blue {
    color: var(--color-dark-blue) !important;
}

p {
    margin-bottom: var(--gutter);
}


/* Font Sizes */


/* Base Headers Style */
h1, h2, h3, h4, h5, h6,
.h1, .h2, .h3, .h4, .h5, .h6 {
    margin-bottom: var(--gutter);
    letter-spacing: normal;
    line-height: 120%;
    font-family: 'header-text';
    font-weight: 400;
}

h1,
.h1 {
    font-size: 3.5rem;
    line-height: 123%;
}
h1.lg,
.h1.lg {
    font-size: 3.5rem;
    line-height: 135%;
}
h2,
.h2 {
    font-size: 3rem;
    font-weight: 300;
    line-height: 125%;
}
h3,
.h3 {
    font-weight: 400;
    font-size: 2rem;
    line-height: 113%;
}
h4,
.h4 {
    font-size: 1.5rem;
    font-weight: 400;
    line-height: 110%;
}
h5,
.h5 {
   
    font-weight: 400;
    font-size: 1.5rem;
    line-height: 110%;
}
h6,
.h6 {
   
    font-size: 1rem;
    font-weight: 400;
    line-height: 110%;
}

.content-block h2,
.content-block .h2,
.content-block h5,
.content-block .h5,
.content-block h6,
.content-block .h6,
.block-inline-blockbasic h2,
.block-inline-blockbasic .h2,
.block-inline-blockbasic h5,
.block-inline-blockbasic .h5,
.block-inline-blockbasic h6,
.block-inline-blockbasic h6 {
    font-family: body-text;
}

.contemporary-style.block-inline-blockbasic h2,
.contemporary-style.block-inline-blockbasic .h2,
.contemporary-style.block-inline-blockbasic h5,
.contemporary-style.block-inline-blockbasic .h5,
.contemporary-style.block-inline-blockbasic h6,
.contemporary-style.block-inline-blockbasic h6 {
    font-family: header-text;
}
.contemporary-style p,
.contemporary-style p span {
    font-family: body-text;
}


body, p, p span {
    font-family: header-text;
    font-size: 1.25rem;
    line-height: 150%;
}

.text-lg {
    font-size: 1.125rem !important;
}

.text-nm {
    font-size: 1rem !important;
}

.text-sm {
    font-size: .875rem !important;
}

.text-xs {
    font-size: .75rem !important;
}

.text-xxs {
    font-size: .625rem !important;
}


.btn {
    font-size: .875rem;
    font-weight: 500;
}

.btn-lg {
    font-size: 1.125rem;
    font-weight: 500;
}


/* .display-1 {
        
} */

blockquote,
blockquote p {
    font-family: body-text;
    line-height: 1.6;
    color: inherit;
    font-size: 1.8rem;
}

blockquote {
    
    margin: var(--gutter);
    padding: var(--gutter);
    border: none;
    border-top: 1px solid;
    border-bottom: 1px solid;
    border-color: inherit;
}

blockquote > *:last-chiLd {
    margin-bottom: 0;
}

figure {
    margin-bottom: var(--gutter);
}

figure figcaption {
    font-size: 0.75rem;
    color: var(--color-muted);
}

a,
a:visited {
    color: var(--color-quarternary);
}
a:hover,
a:focus,
a:active {
    color: var(--color-quarternary);
    text-decoration: underline;
}

ul li, ol li {
    font-family: body-text;
    font-weight: 400;
    font-size: 1rem;
}

strong {
    font-weight: 600;
}

em, cite, dfn {
    font-weight: 400;
    font-style: italic;
}

dfn {
    font-family: header-text;
}

dl dd, dl dt {
    font-family: body-text;
    font-weight: 700;
    font-size: 1rem;
}

table {
    width: 100% !important;
    border: none;
}
table * {
    font-family: body-text-alt;
    font-weight: 400;
    font-size: 0.875rem;
}
table th {
    font-weight: 600;
}

table > :not(caption) > * > * {
    padding: 0.5rem 0.75rem;
    background-color: var(--bs-table-bg);
    border-bottom-width: 1px;
    border-bottom-color: var(--color-light-gray-2);
    box-shadow: inset 0 0 0 9999px var(--bs-table-accent-bg);
}
table > :not(:first-child) {
    border-top: 1px solid var(--color-gray);
}

/* Small devices (landscape phones, 576px and up) */
@media (min-width: 576px) {}

/* Medium devices (tablets, 768px and up) */
@media (min-width: 768px) {
   
    h1,
    .h1 {
        font-size: 2.55rem;
    }
    h1.lg,
    .h1.lg {
        font-size: 2.35rem;
    }
    h2,
    .h2 {
        font-size: 2rem;
    }
    h3,
    .h3 {
        font-size: 1.875rem;
    }
    h4,
    .h4 {
        font-size: 1.475rem;
    }
    h5,
    .h5 {
        font-size: 1.30rem;
    }
    h6,
    .h6 {
        font-size: 1.25rem;
    }
}

/* Large devices (desktops, 992px and up) */

@media (min-width: 992px) {
    h1,
    .h1 {
        font-size: 3.35rem;
    }
    h1.lg,
    .h1.lg {
        font-size: 3.75rem;
    }
    h2,
    .h2 {
        font-size: 2.5rem;
    }
    h3,
    .h3 {
        font-size: 2rem;
    }
    h4,
    .h4 {
        font-size: 1.575rem;
    }
    h5,
    .h5 {
        font-size: 1.35rem;
    }
    h6,
    .h6 {
        font-size: 1.25rem;
    }


    .btn-lg {
        font-size: 1.5rem;
    }

}


/*// Extra large devices (large desktops, 1200px and up)*/

@media (min-width: 1200px) {

    h1,
    .h1 {
        font-size: 3.5rem;
        line-height: 123%;
    }
    h1.lg,
    .h1.lg {
        font-size: 3.5rem;
        line-height: 135%;
    }
    h2,
    .h2 {
        font-size: 3rem;
        font-weight: 300;
        line-height: 125%;
    }
    h3,
    .h3 {
        font-weight: 400;
        font-size: 2rem;
        line-height: 113%;
    }
    h4,
    .h4 {
        font-size: 1.5rem;
        font-weight: 400;
        line-height: 110%;
    }
    h5,
    .h5 {
        font-weight: 400;
        font-size: 1.5rem;
        line-height: 110%;
    }
    h6,
    .h6 {
        font-size: 1rem;
        font-weight: 400;
        line-height: 110%;
    }
}

.underlined {
    padding-bottom: 3px;
    border-bottom: solid 8px;
    border-bottom-color: inherit;
}

/*** Form ***/

.form-control {
    border: 2px solid var(--color-default) ;
    min-height: 40px;
    border-radius: 0;
    box-shadow: none;
    color: var(--color-default);
    background-color: transparent;
}

select.form-control {
    -webkit-appearance: none;
}

/* Placeholder */
input::placeholder,
textarea::placeholder {
    color: var(--color-muted) !important;
}
input::-webkit-input-placeholder,
textarea::-webkit-input-placeholder {
    color: var(--color-muted) !important;
}
input:-moz-placeholder,
textarea:-moz-placeholder {
    /* Firefox 18- */
    color: var(--color-muted) !important;
}
input::-moz-placeholder,
textarea::-moz-placeholder {
    /* Firefox 19+ */
    color: var(--color-muted) !important;
}
input:-ms-input-placeholder,
textarea:-ms-input-placeholder {
    color: var(--color-muted) !important;
}

/***  Buttons ***/

/* button#load-more.done {
    display: none;
} */


.btn {
    display: inline-block;
    text-align: center;
    cursor: pointer;
    vertical-align: middle;
    border-width: 2px;
    border-style: solid;
    border-radius: 0;
    margin: 0;
    transition: all 0.25s ease-out, color 0.25s ease-out;
    box-shadow: none !important;
    line-height: 1.3;
    font-weight: 500;
    padding: 16px 15px;
    text-decoration: none;
    font-family: body-text;
}

@media (max-width: 991px) {
    .btn {
        padding: 10px 13px;
    }
}

.btn.btn-primary {
    color: #ffffff !important;
    border-color: var(--color-primary);
    background-color: var(--color-primary);
}

.btn.btn-primary:hover,
.btn.btn-primary.active,
.btn.btn-primary:focus {
    background-color: #ffffff !important;
    border-color: var(--color-primary) !important;
    color: var(--color-primary) !important;
}

.btn.btn-secondary {
    color: #ffffff;
    border-color: var(--color-secondary);
    background-color: var(--color-secondary);
}

.btn.btn-secondary:hover,
.btn.btn-secondary.active,
.btn.btn-secondary:focus {
    background-color: #ffffff !important;
    border-color: var(--color-secondary) !important;
    color: var(--color-white)!important;
}


.btn.btn-black {
    color: #ffffff;
    border-color: var(--color-white);
    background-color: var(--color-black);
}

.btn.btn-black:hover,
.btn.btn-black.active,
.btn.btn-black:focus {
    background-color: #ffffff !important;
    border-color: var(--color-black) !important;
    color: var(--color-black)!important;
}


.btn.btn-blue-light-1 {
    color: #ffffff;
    border-color: var(--color-white);
    background-color: var(--color-blue-light-1);
}

.btn.btn-blue-light-1:hover,
.btn.btn-blue-light-1.active,
.btn.btn-blue-light-1:focus {
    background-color: #ffffff !important;
    border-color: var(--color-blue-light-1) !important;
    color: var(--color-blue-light-1)!important;
}


.btn.btn-blue-light-2 {
    color: #000000;
    border-color: var(--color-white);
    background-color: var(--color-blue-light-2);
}

.btn.btn-blue-light-2:hover,
.btn.btn-blue-light-2.active,
.btn.btn-blue-light-2:focus {
    background-color: #000000 !important;
    border-color: var(--color-black) !important;
    color: var(--color-blue-light-2)!important;
}


.btn.btn-transparent {
    color: var(--color-white);
    border-color: var(--color-white);
    background-color: transparent;
}

.btn.btn-transparent:hover,
.btn.btn-transparent.active,
.btn.btn-transparent:focus {
    background-color: var(--color-white) !important;
    color: var(--color-ark-blue)!important;
}

.btn.btn-transparent.black {
    color: var(--color-black);
    border-color: var(--color-black);
    background-color: transparent;
}

.btn.btn-transparent.black:hover,
.btn.btn-transparent.black:active,
.btn.btn-transparent.black:focus {
    background-color: var(--color-black) !important;
    color: var(--color-white)!important;
}


.btn.btn-transparent.white {
    color: var(--color-black);
    border-color: var(--color-black) !important;
    background-color: transparent;
}

.btn.btn-transparent.white:hover,
.btn.btn-transparent.white:active,
.btn.btn-transparent.white:focus {
    background-color: var(--color-black) !important;
    color: var(--color-white)!important;
}


.btn.btn-transparent.black-gold {
    color: var(--color-black);
    border-color: var(--color-black);
    background-color: transparent;
}

.btn.btn-transparent.black-gold:hover,
.btn.btn-transparent.black-gold.active,
.btn.btn-transparent.black-gold:focus {
    background-color: var(--color-black) !important;
    color: var(--color-gold)!important;
    border-color: var(--color-gold) !important;
}


.btn.btn-primary.inverted {
    background-color: #ffffff;
    border-color: var(--color-primary);
    color: var(--color-primary);
}
.btn.btn-primary.inverted:hover,
.btn.btn-primary.inverted:active,
.btn.btn-primary.inverted:focus {
    color: #ffffff !important;
    border-color: var(--color-primary) !important;
    background-color: var(--color-primary) !important;
}

.btn.btn-secondary.inverted {
    background-color: #ffffff;
    border-color: var(--color-secondary);
    color: var(--color-secondary);
}

.btn.btn-secondary.inverted:hover,
.btn.btn-secondary.inverted:active,
.btn.btn-secondary.inverted:focus {
    color: #ffffff !important;
    border-color: var(--color-secondary) !important;
    background-color: var(--color-secondary) !important;
}



.btn.btn-angle {
    display: inline-flex;
    align-items: center;
    padding: 0px;
    border: 0px !important;
    background-color: transparent !important;
    flex-direction: row-reverse;
}

.btn.btn-angle:hover,
.btn.btn-angle:active,
.btn.btn-angle:focus {
    background-color: transparent !important;
    border: 0px !important;
}

.btn-angle span {
    position: relative;
}

.btn-angle img.on-hover {
    position: absolute;
    top: 50%;
    left: 0;
    right: 0;
    margin: 0 auto;
    transform: translateY(-50%);
    transition: all .3s;
    opacity: 0;
}

.btn-angle.large img {
    width: 18px;
}

.btn-angle img {
    width: 12px;
    transition: all .3s;
    opacity: 1;
}


.btn-angle span {
    position: relative;
    display: inline-flex;
    align-items: center;
    margin-right: 18px;
    justify-content: center;
    width: 38px;
    height: 38px;
    border-radius: 50%;
    transition: all .3s;
    border: 2px solid var(--color-primary);
    background-color: var(--color-primary);
}

.btn-angle.btn-secondary:hover span {
    background-color: var(--color-white);
}

.btn-angle.btn-secondary.light span {
    background-color: var(--color-white) !important;
    border-color: var(--color-white) !important;
}

.btn-angle.btn-secondary.light:hover span {
    background-color: var(--color-primary) !important;
}

.btn-angle.btn-primary {
    color: var(--color-primary) !important;
}

.btn-angle.btn-primary span {
    background-color: var(--color-white);
    border-color: var(--color-primary);
}

.btn-angle.btn-primary:hover span {
    background-color: var(--color-primary);
}

.btn-angle.btn-primary.dark {
    color: var(--color-white) !important;
}

.btn-angle:hover img {
    opacity: 0;
}

.btn-angle:hover img.on-hover{
    opacity: 1;
}



/***  Wordpress Plugin: Ajax Load More ***/
.alm-btn-wrap .alm-load-more-btn.done {
    display: none;
}

.btn.loading {
    /* add loading image here */
    opacity:.5;
}

.alm-btn-wrap {
    text-align: center;
}

/***  Wordpress Plugin: CF7 ***/
.wpcf7-not-valid-tip {
    color: var(--color-danger);
    font-size: 0.75rem;
    margin-bottom: var(--gutter);
}
div.wpcf7-response-output {
    border: none !important;
    padding: 0;
    text-align: center;
    margin: var(--gutter) 0;
    color: var(--color-danger);
}
div.wpcf7-validation-errors, 
div.wpcf7-acceptance-missing {
    color: var(--color-warning) !important;
}
div.wpcf7-mail-sent-ok {
    color: var(--color-success) !important;
}


/*** Layout Utilities ***/
.overlay {
    position: absolute;
    background-color: rgba(0, 35, 92, 0.7);
    width: 100%;
    height: 100%;
    z-index: 20;
    top: 0;
    left: 0;
}
.site-overlay.visible {
    top: 0;
    left: 0;
    height: 100vh;
    opacity: 1;
}

/* Contextual Background Style */

.bg-primary {
    background-color: var(--color-primary) !important;
}

.bg-secondary {
    background-color: var(--color-secondary) !important;
}

.bg-tertiary {
    background-color: var(--color-tertiary) !important;
}

.bg-quarternary {
    background-color: var(--color-quarternary) !important;
}

.bg-red {
    background-color: var(--color-red) !important;
}

.bg-yellow {
    background-color: var(--color-yellow) !important;
}

.bg-yellow-light {
    background-color: var(--color-yellow-light) !important;
}


.bg-blue-light-3 {
    background-color: var(--color-blue-light-3) !important;
}

.bg-blue-light-4 {
    background-color: var(--color-blue-light-4) !important;
}

.bg-light-gray {
    background-color: var(--color-light-gray) !important;
}


/* Helpers */

.all-text-white * {
    color: white !important;
}

.v-align {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
}

.vh-align {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
}

.lh-100 {
    line-height: 100%;
}


.fw-100 {
    font-weight: 100;
}

.fw-200 {
    font-weight: 200;
}

.fw-300 {
    font-weight: 300;
}

.fw-400 {
    font-weight: 400;
}

.fw-500 {
    font-weight: 500;
}

.fw-600 {
    font-weight: 600;
}

.fw-700 {
    font-weight: 700;
}

.fw-800 {
    font-weight: 800;
}

.fw-900 {
    font-weight: 900;
}