@font-face {
    font-family: Fredoka;
    font-style: normal;
    font-weight: 600;
    src: url(https://resources.valveque.com/just_add_content/templates/restaurant/fonts/Fredoka-VariableFont.ttf);
    font-display: block;
}

@font-face {
    font-family: OpenSans;
    font-style: normal;
    font-weight: normal;
    src: url(https://resources.valveque.com/just_add_content/templates/restaurant/fonts/OpenSans-Regular.ttf);
    font-display: block;
}

@font-face {
    font-family: PlaywriteBEWAL;
    font-style: normal;
    font-weight: normal;
    src: url(https://resources.valveque.com/just_add_content/templates/restaurant/fonts/PlaywriteBEWAL-Regular.ttf);
    font-display: block;
}

@font-face {
    font-family: Raleway;
    font-style: normal;
    font-weight: normal;
    src: url(https://resources.valveque.com/just_add_content/templates/restaurant/fonts/Raleway-Regular.ttf);
    font-display: block;
}

@font-face {
    font-family: Raleway Bold;
    font-style: normal;
    font-weight: 700;
    src: url(https://resources.valveque.com/just_add_content/templates/restaurant/fonts/Raleway-Bold.ttf);
    font-display: block;
}

@font-face {
    font-family: Raleway Bold Italic;
    font-style: italic;
    font-weight: 700;
    src: url(https://resources.valveque.com/just_add_content/templates/restaurant/fonts/Raleway-BoldItalic.ttf);
    font-display: block;
}

@font-face {
    font-family: Raleway Italic;
    font-style: italic;
    font-weight: normal;
    src: url(https://resources.valveque.com/just_add_content/templates/restaurant/fonts/Raleway-Italic.ttf);
    font-display: block;
}

:root {
    --black: #000000;
    --bodyTextFont: Raleway;
    --companyNameFont: PlaywriteBEWAL;
    --footerBgColor: #610706;
    --headingColor: #921917;
    --headingFont: Fredoka;
    --gray: #808080;
    --navFont: Fredoka;
    --navBgColor: #922e17;
    --navBgColorHover: #ae2403;
    --navVerticalDivider: #a85845;
    --mainImageTopTextFont: OpenSans;
    --white: #ffffff;
}

* {
    -webkit-tap-highlight-color: transparent;
    box-sizing: border-box;
    margin: 0;
    padding: 0;
    word-wrap: break-word;
}

body {
    background-color: var(--white);
    background-image: url("https://resources.valveque.com/just_add_content/templates/restaurant/images/body-background-image.gif");
    background-repeat: repeat;
    opacity: 0;
    overflow-y: scroll;
    position: relative;    
}

.br_div_nav_bar {
    display: block;
    margin-top: 1px;
}

.burger_menu_main {
    display: inline-block;
	position: relative;
	top: 5px;
    padding: 5px;
    width: 44px;
}

.burger_menu_main:hover {
    background-color: var(--navBgColorHover);
    padding: 5px;
    cursor: pointer;
}

.burger_menu_main > div {
    background-color: var(--black);
    border-radius: 2px;
    height: 4px;
    margin-top: 4px;
    width: 34px;
}

.burger_menu_main > div:nth-child(1) {
    margin-top: 0;
}

.close_mobile_nav_x_main {
    opacity: 0;
    position: relative;
        right: calc(-100% + 36px);
        top: 25px;
    width: 34px;
}

.close_mobile_nav_x_main:hover {
    cursor: pointer;
}

.close_mobile_nav_x_main > div {
    background-color: var(--white);
    border-radius: 2px;
    height: 4px;
    width: 34px;
}

.close_mobile_nav_x_main > div:nth-of-type(1) {
  transform: translate(0, 1px) rotate(45deg);
}

.close_mobile_nav_x_main > div:nth-of-type(2) {
  transform: translate(-1px, -3px) rotate(-45deg);
}

.company_contact_in_page_main {
    font-family: var(--bodyTextFont);
    margin-left: 16px;
    margin-top: 32px;
}

.company_contacts_name {
    font-weight: 700;
}

.footer_company_contacts_main {
    display: block;
    font-size: 16px;
    margin: 20px auto 0 auto;
    text-align: center;
    width: 100%;
}

.footer_company_contacts_main > .br_div_footer_contacts {
    display: block;
    margin: -5px 0 0 0;
}

.footer_company_contacts_main > div {
    color: var(--white);
    font-family: var(--bodyTextFont);
    margin-top: 8px;
}

.footer_company_contacts_main > div:nth-of-type(1) {
    margin-top: 26px;
}

.footer_company_contacts_main > div > a {
    color: var(--white);
    font-family: var(--bodyTextFont);
    text-decoration: none;
}

.footer_company_contacts_main > div > a:hover {
    cursor: pointer;
    text-decoration: underline;
}

.footer_company_contacts_main > img {
    display: block;
    float: none;
    height: auto;
    margin: 0 auto;
	position: relative;
	    left: 7px;
    width: 36px;
}

.footer_contact_email > img {
    display: inline;
	float: none;
	height: 12px;
	margin: 0 0.38em 0 0;    
  	position: relative;
  	    top: 2px;
  	    left: 1px;
  	width: 16px;
}

.footer_contact_telephone > img {
	display: inline;
	height: 16px;
	float: none;
	margin: 0 0.3125em 0 0;
	position: relative;
  	    top: 5px;
		left: 2px;
    width: 16px;    
}

.footer_main {
    background-color: var(--footerBgColor);
    padding: 0 0 120px 0;
    width: 100%;
}

.footer_main_fixed_bottom {
    position: fixed;
        bottom: 0;
        left: 0;
}

.footer_sub_1 {
    margin: 14px auto 0 auto;
}

.footer_top_line {
    background-color: var(--footerTopLineColor);
    height: 12px;
}

.header_main {
    display: block;
    margin: 0 auto -22px auto;
    padding: 10px 16px 18px 16px;
}

.header_main > a {
    display: inline-block;
    text-decoration: none;
    width: calc(100% - 44px);
}

.header_main > a > div {
    color: var(--black);
    display: inline-block;
    filter: drop-shadow(1px 1px 0 gray);
    font-family: var(--companyNameFont);
    font-size: 20px;
    text-align: left;
    text-shadow: 1px 1px 0 white;
    width: 100%;
}

.header_main > a > img {
    display: none;
}

.main_content {
    padding: 20px 16px 112px 16px;
}

.main_image_figure {
    background-color: var(--white);
    position: relative;
}

.main_image_top_text_in_footer_main {
    margin: 0 auto 26px auto;
}

.main_image_top_text_in_footer_main > div > div {
    color: var(--white);
    font-family: var(--bodyTextFont);
    font-size: 16px;
    margin-top: 8px;
    text-align: center;
}

.main_image_top_text_main {
    display: none;
}

.main_main {
    background-color: var(--white);
}

#map {
    border: 1px solid var(--lightgray);
    height: 400px;
    margin-left: 16px;
    margin-top: 32px;
    width: calc(100% - 32px);
}

.mapboxgl-popup {
  max-width: 200px;
}

.mapboxgl-popup-content {
  text-align: center;
  font-family: 'Verdana', sans-serif;
}

.nav_main {
    background-color: var(--navBgColor);
    border: 5px solid var(--navVerticalDivider);
    display: block;
    height: 100%;
    opacity: 0;
    overflow-x: hidden;
    overflow-y: auto;
    padding: 10px 16px 18px 16px;
    position: fixed;
        right: 0;
        top: 0;
    text-align: center;
    transition: right 0.4s linear;
    width: 100%;
    z-index: -1;
}

.nav_bar_main {
    margin-top: 64px;
}

.nav_bar_main > div > a {
    border-bottom: 5px solid var(--navVerticalDivider);
    color: var(--white);
    display: block;
    font-family: var(--navFont);
    font-size: 21px;
    letter-spacing: 0.04em;
    margin: 0 auto;
    padding: 18px;
    text-decoration: none;
    text-shadow: 2px 2px 0 var(--black);
    width: 100%;
}

.nav_bar_main > div > a:hover {
    background-color: var(--navBgColorHover);
    cursor: pointer;
}

@media screen and (min-width: 360px) {
    
    .header_main {
        margin: 0 auto -20px auto;
    }
    
    .header_main > a > div {
        font-size: 22px;
    }

}

@media screen and (min-width: 430px) {

	.burger_menu_main {
	    position: relative;
	        top: 10px;
	
	}

    .header_main {
        margin: -11px auto -18px auto;
        padding: 20px 16px 22px 16px;
    }

    .header_main > a > div {
        position: relative;
            top: 3px;
        width: calc(100% - 60px - 15px);
    }

    .header_main > a > img {
        display: inline-block;
        height: auto;
        margin: 0 15px 0 0;
        position: relative;
            top: 15px;
        width: 60px;
    }

    .main_image_top_text_in_footer_main {
        display: none;
    }    

    .main_image_top_text_main {
        background-color: var(--white);
        border-bottom: 6px solid var(--footerBgColor);
        display: block;
        padding: 20px;
        position: absolute;
            bottom: 25px;
            right: 15px;
    }
    
    .main_image_top_text_main > div {
        margin-top: 5px;
    }
    
    .main_image_top_text_main > div:first-of-type {
        margin-top: 0;
    }
    
    .main_image_top_text_main > div > div {
        font-family: var(--mainImageTopTextFont);
        font-size: 14px;
        font-weight: 200;
        text-align: center;
    }    

}

@media screen and (min-width: 550px) {

    .close_mobile_nav_x_main {
        position: relative;
            right: calc(-100% + 36px);
            top: 35px;
        width: 34px;
    }    

}

@media screen and (min-width: 600px) {

    .header_main {
        margin: -26px auto -12px auto;
    }
    
    .header_main > a > div {
        font-size: 28px;
        width: calc(100% - 100px - 28px);
    }

    .header_main > a > img {
        margin: 0 28px 0 0;
            top: 33px;
        width: 100px

    }

    .main_image_top_text_main {
            bottom: 30px;
            right: 20px;
    }

}

@media screen and (min-width: 700px) {
    
    .header_main {
        margin: -32px auto -12px auto;
    }
    
     .header_main > a > div {
        width: calc(100% - 118px - 28px);
        font-size: 32px;
    }
    
    .header_main > a > img {
            top: 42px;
        width: 118px

    }

}

@media screen and (min-width: 864px) {
    
    .burger_menu_main {
        display: none;
    }
    
    .company_contact_in_page_main {
        margin-left: 0;
    }
    
    .footer_company_contacts_main {
        display: block;
        font-size: 14px;
        margin: 45px auto 0 auto;
        text-align: center;
        white-space: nowrap;
        width: 736px;
    }

    .footer_company_contacts_main > div {
        display: inline-block;
        margin: 0 0 0 8px;
        position: relative;
            top: -12px;
        text-align: center;
    }

    .footer_company_contacts_main > div::before {
        content: "\2022";
        margin-right: 8px;
    }
    
    .footer_company_contacts_main > div:nth-of-type(1) {
        margin-top: 0;
    }
    
    .footer_company_contacts_main > div:nth-of-type(1)::before {
        content: "";
    }

    .footer_company_contacts_main > img {
        display: inline-block;
        margin: 0 0 0 0;
        position: relative;
            top: 2px;
        text-align: center;
        width: 37px;
    }

    .footer_main {
        box-shadow: 0 -25px 15px rgba(0, 0, 0, 0.1);
        padding: 0 0 120px 0;
        z-index: 0;
    }
    
    .header_main {
        margin: 43px auto -13px auto;
        padding: 0;
        width: 800px;
    }

    .header_main > a {
        display: block;
        text-align: left;
        width: 100%;
    }

    .header_main > a > div {
        display: inline-block;
        position: relative;
    		top: -30px;
    		left: 0;
        font-size: 44px;
        width: calc(100% - 140px - 35px - 75px)
    }

    .header_main > a > img {
        display: inline-block;
        margin: 0 35px 0 75px;
        position: relative;
            top: 5px;
        width: 140px;
    }

    .main_content {
        padding: 32px 32px 60px 32px;
    }

    .main_image_figure {
        margin: 0 auto;
        width: 800px;
    }

    .main_image_top_text_main {
            bottom: 26px;
            right: 22px;
    }    

    .main_main {
        margin: 18px auto -25px auto;
        position: relative;
        z-index: 10;
        width: 800px;
    }

    #map {
        margin-left: 0;
        width: 100%;
    }

    .nav_main {
        background-color: transparent;
        border: none;
        display: block;
        height: auto;
        margin: 12px auto 0 auto;
        opacity: 1;
        overflow-x: hidden;
        overflow-y: hidden;
        padding: 0;
        position: relative;
            left: 0;
            top: 0;
        text-align: center;
        transition: none;
        width: 800px;
        z-index: 10;
    }
    
    .close_mobile_nav_x_main {
        display: none;
    }

    .nav_bar_main {
        display: block;
        margin-top: 0;
    }
    
    .nav_bar_main > div {
        display: inline-block;
        width: 20%;
    }

    .nav_bar_main > div > a {
        background-color: var(--navBgColor);
        border-bottom: none;
        border-right: 5px solid var(--navVerticalDivider);
        color: var(--white);
        display: inline-block;
        font-family: var(--navFont);
        font-size: 22px;
        letter-spacing: 0.04em;
        margin: 0 auto;
        padding: 0;
        padding-bottom: 2px;
        position: relative;
        text-decoration: none;
        text-shadow: 2px 2px 0 var(--black);
        width: 100%;
    }

    .nav_bar_main > div:first-child a {
        border-radius: 10px 0 0 10px;
    }
    
    .nav_bar_main > div:last-child a {
        border-radius: 0 10px 10px 0;
        border-right: none;
    }

/* MARK CURRENT PAGE ON A BIG SCREEN. */

    .nav_bar_main > div > div {
        background-color: var(--navCurrent);
        height: 4px;
        opacity: 0;
        width: calc(100% - 5px);
    }
    
    .nav_bar_main > div:nth-child(1) > div {
        position: relative;
            left: 4px;
        width: calc(100% - 5px - 4px);
    }
    
    .nav_bar_main > div:nth-child(5) > div {
        width: calc(100% - 4px);
    }        

}