

/* --------------------- 
    Table of Contents
------------------------


1. Header

2. Navigation

3. Banner

4. Contacts

5. Social Media

6. Headings

7. Footer

8. Section: Services

9. Buttons

10. Secondary

11. Additional

12. Custom

*/



/* -------------------- 
    1. Header Styles 
----------------------- */

header {
    z-index: 99999999999999;
    height: auto;
    position: relative;
}

.mr-navbar-upper {
    position: relative;
    background: #989795;
    color: #e1e1e1;
    align-items: center;
    justify-content: space-between;
    font-size: 0.8em;
    padding: 0.5em 1em 0.3em;
    top: auto;
    display: flex;
    width: auto;
    flex-direction: row;
    position: relative;
    z-index: 99999999999;
}

.mr-navbar-subpanel {
    display: flex;
    top: 0;
    z-index: 9999999;
    width: 100%;
    flex-direction: column;
}

.header_contacts {
    display: flex;
}

#sticky-wrapper {
    position: relative;
    z-index: 99999999;height: auto !important;

}


.mr-navbar-upper .list-inline {
    margin-bottom: 0;
    padding: 0;
    display: flex;
    align-items: center;
}

header ul.navigation_extra li {
    margin-left: 1.5rem;
}

.mr-navbar-upper .list-inline li:last-of-type {
    /* border-right: 1px solid rgba(255, 255, 255, 0.2); */
}

.mr-navbar-upper .contact-info {
    flex-direction: row;
}

.mr-navbar-upper .contact-info span {
    display: inline-block;
    vertical-align: middle;
}

.mr-navbar-upper .contact-info span+a {
    margin-left: 10px;
}

.mr-navbar-upper .contact-info a {
    display: inline-block;
    vertical-align: middle;
    color: #e1e1e1;
    line-height: 1.2;
    margin-left: .5rem;
}

.mr-navbar-upper .contact-info a:hover {
    /* color: #77b9e5; */
    text-decoration: underline;
}

.mr-navbar-upper .contact-info .address {
    margin-left: 60px;
}

.mr-navbar-upper .contact-info .mail {
    margin-left: 60px;
}



.list-inline>li {
    /* display: inline-block; */
    /* padding-left: 1rem; */
    /* padding-right: 5px; */
}


.header_contacts {
    display: flex;
}

.page {
    background: rgb(255 255 255);
    margin-top: 0;
}

.mr-header-wrap {
    padding: 0 0 0 0;
    display: flex;
    align-items: center;
    background: white;
    box-shadow: 3px 3px 6px rgb(0 0 0 / 60%);
    flex-direction: column;
}

.header_social {
    /* position: absolute; */
    /* right: 7px; */
    margin-right: 1em;
}

header.stuck {
    /* position: fixed !important; */
    top: -6.1vw !important;
    /* width: 100vw !important; */
    left: 0 !important;
}

header#home {
    position: sticky;
    width: 100%;
    display: block;
    background-position: center;
    background-size: cover;
    z-index: 99999999;
    transition: height .3s ease;
    /* height: 5vw; */
    margin: auto;
    /* box-shadow: 3px 3px 7px black; */
}

header a:hover {
    text-decoration: none;
    color: white;
}

.header_extra {
    /* background: #3e5b41; */
    color: var(--mr-color-dark);
    height: 2em;
    display: flex;
    align-items: center;
    justify-content: flex-end;
    padding: 0 1em;
    width: 100%;
}

.stuck h1.logo {
    /* height: calc(12px + 4.3vw); */
}

.stuck nav.mr-navbar-desktop {
    /* padding: 0 1.5em; */
}

.mr-navbar-brand {
    position: relative;
    z-index: 9999999;
    background: white;
    display: flex;
    padding: 0;
    align-items: stretch;
    justify-content: space-between;
    flex-grow: 1;
    width: 100%;
    /* height: 6.05vw; */
    padding: 0;
    /* margin-top: -1.8em; */
    height: auto;
    top: auto;
    box-shadow: 0 5px 18px #0000003d;
}

img.logo_img {
    height: 100%;
}

h1.logo {
    width: auto;
    height: calc(12px + 4.3vw);
    display: flex;
    align-items: center;
    justify-content: flex-end;
    transition: .3s all ease;
    margin: 0;
    /* margin-top: -1.8em; */
    /* margin-left: -0.7em; */
    position: absolute;
    /* bottom: 0.25em; */
    left: 1.5vw;
    font-family: 'Oleo Script';
    text-transform: none;
    font-weight: 400;
    font-size: 1.6em;
}

h1.logo a {
    display: flex;
    height: 100%;
    color: #54534a;
    text-decoration: none;
    align-items: center;
}

h1.logo a span {
    line-height: 1;
    display: block;
    padding-top: 1.2vw;
}

h1.logo .desktop {
    width: 90%;
    padding-top: 0.25vw;
}
img.desktop {
    width: 100px;
    height: auto;
    max-width: none;
}
.mr-navbar-toggle, .mr-upper-toggle {
    display: none;
}









/* -----------------------
    2. Navigation Styles
 ------------------------- */

.mr-navbar-wrap {
    position: relative;
}

.mr-navbar-nav-wrap {
    flex-grow: 1;
    position: static;
    width: 100%;
    margin: 0 0 0 0;
    align-self: center;
    padding-top: 0;
    padding-bottom: 0;
    box-shadow: 0 0 20px rgba(0, 0, 0, 0);
    transition: .3s box-shadow ease;
    left: 0;
    background: var(--mr-color-primary);
    transform: none;
    overflow: unset !important;
}

ul.level-0.mr-navbar-nav {
    display: flex;
    flex-direction: row;
    list-style: none;
    width: 100%;
    align-items: stretch;
    justify-content: space-between;
    font-size: 1.7vw;
    font-weight: 400;
    font-family: var(--mr-font-default);
    text-transform: none;
    text-decoration: none;
    margin: 0;
    height: unset;
    padding: 0;
    overflow: unset;
}

ul.level-0.mr-navbar-nav > li > a {
    font-size: calc(12px + 0.2em);
    /* text-align: center; */
    width: 100%;
    line-height: 1;
    display: flex;
    align-items: flex-end;
    text-decoration: none;
    position: relative;
    z-index: 2;
    padding: 0.5em 0.6em 0.3em;
    cursor: pointer;
    transition: .3s all ease;
    color: black;
    font-weight: 600;
    border-bottom-width: clamp(5px, .5vw, 8px);
    border-bottom-style: solid;
    height: 100%;
}

ul.level-0.mr-navbar-nav li li a:hover {text-decoration: underline;}

.mr-navbar-nav-wrap #nav_slide_hover {
    position: absolute;
    bottom: 0;
    height: 0.3em;
    background-color: rgb(254, 218, 123);
    -webkit-transition: all .3s ease;
    transition: all .3s ease;
}

.mr-navbar-nav-wrap #nav_slide_hover_bg {
    position: absolute;
    bottom: 0;
    height: 0.3em;
    background-color: rgb(177, 177, 177);
    -webkit-transition: all .3s ease;
    transition: all .3s ease;
    width: 100%;
    left: 0;
}

.mr-navbar-inner {
    padding: 0;
    position: fixed;
    width: 100%;
    background: white;
    background-size: 100%;
    z-index: 2;
    min-height: 58px;
}

#secondary .mr-navbar-inner {}

ul.level-0.mr-navbar-nav>li {
    padding-bottom: 0px;
    flex-grow: 1;
    /* position: relative; */
}

ul.level-1 {
    position: absolute;
    list-style: none;
    text-align: left;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    /* padding: 0; */
    background: white;
    min-width: 200px;
    color: #54534a;
    box-shadow: 0 10px 10px rgb(0 0 0 / 32%);
    /* border-top: 3px solid black; */
    top: calc(100% + 0px);
    transform: translate(-50%, 0px);
    z-index: 9;
    padding: 0;
    width: 100%;
    border-left: none !important;
    padding-top: 2rem;
    padding-bottom: 1rem;
}

ul.level-0.mr-navbar-nav ul.level-1 > li > a {
    text-align: left;
    padding: 0.7em 1em;
    /* font-size: 1em; */
    transition: none;
    width: 100%;
    color: #54534a;
    font-size: clamp(13px, 1.2vw, 20px);
    /* background: #d9d9d9; */
    font-weight: 700;
    text-decoration: none;
    line-height: 1.2;
}

ul.level-0.mr-navbar-nav ul.level-1 > li > a:hover {
    background: #f0f0f0;
    color: black;
}

ul.level-0.mr-navbar-nav li {
    width: 100%;
    /* break-inside: avoid; */
    position: static;
    border: none !important;
}

ul.level-0.mr-navbar-nav li.has_subnav>a:after {
    content: '\f0d7';
    font-family: var(--mr-fontawesome);
    font-weight: 900;
    /* margin-left: .25em; */
    line-height: 1em;
    font-size: calc(8px + 0rem);
    position: absolute;
    bottom: 0rem;
    left: 50%;
    transform: translate(-50%, 0px);
    opacity: 0;
}

ul.level-0.mr-navbar-nav li.has_subnav:hover>a:after {
    color: var(--mr-color-accent);
}

ul.level-0.mr-navbar-nav .current-parent>a {
    color: var(--mr-color-dark);
    /* text-decoration: underline; */
    background: var(--mr-color-accent);
}

ul.level-0.mr-navbar-nav .current-parent>a:before {
    content: '';
    width: 100%;
    height: 3px;
    position: absolute;
    bottom: 0;
    border-radius: 3px;
    display: block;
    background: black;
    visibility: collapse;
}

ul.level-0.mr-navbar-nav>li:first-of-type:before {
    margin-left: -2%;
}

ul.level-0.mr-navbar-nav>li:last-of-type:before {
    margin-right: -2%;
}

ul.level-0.mr-navbar-nav>li:before {
    /* content: ''; */
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: black;
    z-index: 1;
    transform: skewX(-25deg);
    border-left: 1px solid white;
    margin-left: -2%;
}

li.current.current-item.current.current-parent:before {
    background: grey;
}


.mr-navbar-nav-wrap #nav_slide_hover {
    position: absolute;
    bottom: 0;
    height: 0.3em;
    background-color: rgb(254, 218, 123);
    -webkit-transition: all .3s ease;
    transition: all .3s ease;
}

.mr-navbar-nav-wrap #nav_slide_hover_bg {
    position: absolute;
    bottom: 0;
    height: 0.3em;
    background-color: rgb(177, 177, 177);
    -webkit-transition: all .3s ease;
    transition: all .3s ease;
    width: 100%;
    left: 0;
}


.mr-navbar-inner {
    padding: 0;
    position: fixed;
    width: 100%;
    background: white;
    background-size: 100%;
    z-index: 2;
    /* FF3.6-15 */
    /* Chrome10-25,Safari5.1-6 */
    /* W3C, IE10+, FF16+, Chrome26+, Opera12+, Safari7+ */
    /* IE6-9 */
    min-height: 58px;
}

li.current.current-item:after {
    display: none;
}

span.subnav_toggle {
    display: none !important;
}

ul.level-0.mr-navbar-nav li.has_subnav > a {
    /* padding: 0.5em 0em 0.4em; */
}

.mr-navbar-nav.level-0 > li.has_subnav:hover > .mr-navbar-dropdown {
    opacity: 1;
    transform: translate(0px, 0%);
    visibility: visible;
    transition: .2s all ease;
}

.mr-navbar-nav.level-0 > li.has_subnav > .mr-navbar-dropdown {
    opacity: 0;
    visibility: collapse;
    transform: translate(0px, -10%);
    transition: .2s opacity ease;
    z-index: -1;
    left: 0;
    height: auto;
    overflow: visible;
    box-shadow: 0 10px 10px 0 #0000002b;
}
ul.level-1.mr-navbar-dropdown::before {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    width: 100%;
    height: 2rem;
    content: '';
    background: linear-gradient(0deg, rgba(0,0,0,0) 0%, rgba(0,0,0,1) 100%);
    opacity: 0.2;
}

li.navitemid-26.has_subnav > .mr-navbar-dropdown, li.navitemid-28.has_subnav > .mr-navbar-dropdown, li.navitemid-27.has_subnav > .mr-navbar-dropdown {
    display: block;
    column-count: 3;
    padding-left: 2vw;
    padding-right: 2vw;
}

ul.level-1.mr-navbar-nav li {
    width: auto;
}
ul.level-1.mr-navbar-dropdown > li li::before {
    /* display: list-item; */
    content: '-';
    position: absolute;
    left: -0.15rem;
    padding: 0.3rem 0;
    line-height: 1;
}
ul.level-1.mr-navbar-dropdown > li {
    display:block;
}



/* ---------------
    3. Banner 
------------------ */


section#banner {
    margin-top: 0;
}






/* -------------- 
    4. Contacts
 ---------------- */








/* --------------------
    5. Social media 
 ---------------------- */






/* ----------------
    6. Headings 
 ------------------ */








/* ------------ 
    7. Footer
--------------- */








/* -------------------------
    8. Section: Services 
---------------------------- */



/* ------------- 
    9. Buttons 
 --------------- */












/* -----------------
    10. Secondary 
 ------------------- */







/* --------------------
    11. Additional 
 ---------------------- */








/* ----------------
    12. Custom 
 ------------------ */


 .padding {
    padding: 2vw 4vw;
}
 
.mr-navbar-upper .list-inline + .list-inline:before {
    content: '|';
    margin-right: 1rem;
}

.social_links li a:before {
    margin-right: .5rem;
    font-weight: 900;
    font-family: var(--mr-fontawesome-brands);
}

.mr-navbar-upper .list-inline li a {
    text-decoration: none;
    font-family: 'Muli';
    font-weight: 400;
    color: #e1e1e1;
    /* display: flex; */
    /* align-items: center; */
}

.mr-navbar-upper .list-inline + .list-inline {
    padding-left: 1rem;
}

.mr-navbar-upper_right {
    display: flex;
    align-items: center;
}

ul.level-0.mr-navbar-nav li li {
    position: relative;
}

.logo {
    max-width: 45%;
    padding: 0.75vw 1vw;
}
.level-0 > li:last-of-type .mr-navbar-dropdown {
    right: 0 !important;
    left: auto !important;
}

ul.level-0.mr-navbar-nav li li a {
    font-size: clamp(12px, 1vw, 16px);
    padding: 0.7rem;
}