*{
	margin: 0px;
	box-sizing: border-box;
}

html {
    overflow-y: scroll; /* Всегда показывать скроллбар */
	overflow-x: hidden;
    width: 100%;
    position: relative;
}


body{
	background: #f5f5f5;
	font-family: 'Roboto', sans-serif;
	padding: 10px 0px 20px 0px;
}

div.window_map{
    position: absolute;
    top: 0px;
    left: 0px;
    background: black;
    width: 100vw;
    height: 100vh;
    z-index: 100;
    filter: alpha(opacity=50);
    /* opacity: 0.5; */
    background-color: rgb(0 0 0 / 50%);
    display: flex;
    flex-direction: row;
    align-items: center;
    justify-content: center;
}
div.window_map div.box{
    position: relative;
    width: 500px;
    /* left: calc(50vw - 250px); */
    background: white;
    padding: 10px;
    border-radius: 10px;
    /* margin: auto 0px; */
}
div.window_map div.box div.search_city{
    position: relative;
    display: flex;
    flex-direction: row;
    align-items: center;
    justify-content: flex-start;
    margin: 0px 0px 10px 0px;
}
div.window_map div.box div.search_city input{
    position: relative;
    padding: 10px;
    border-radius: 5px 10px 0px 5px;
    border: 2px solid black;
    width: 100%;
}
div.window_map div.box div.search_city img{
    position: relative;
    width: 20px;
    margin: 0px 10px 0px 5px;
}
div.window_map div.box div.map_search_list_cities{
    position: absolute;
    top: 46px;
    right: 10px;
    background: white;
    width: calc(100% - 55px);
    z-index: 1;
    box-sizing: border-box;
    /* margin: 0px 10px; */
    border-radius: 0px 0px 10px 10px;
    /* padding: 10px; */
    border: 2px solid black;
    border-top: none;
}
div.window_map div.box div.map_search_list_cities div.map_search_list_cities_city{
    position: relative;
    padding: 10px;
    margin: 5px;
    font-weight: bold;
    border-radius: 10px;
	user-select: none;
	cursor: pointer;
	transition: all 0.3s ease-in-out;
}
div.window_map div.box div.map_search_list_cities div.map_search_list_cities_city:hover{
	background: #e6e6e6;
}
div.window_map div.box div#map{
    position: relative;
    width: 100%;
    height: 350px;
    border-radius: 10px;
}
.ymaps-2-1-79-route-panel-button, .ymaps-2-1-79-map-copyrights-promo{
	display: none;
}
div.window_map div.box div.set_address{
    position: relative;
    padding: 10px;
    text-align: center;
    font-weight: bold;
    user-select: none;
    background: #a7ce34;
    color: white;
    border-radius: 0px 0px 10px 10px;
    margin: 10px 0px 0px 0px;
    cursor: pointer;
}
div.window_map div.right_block{
    position: relative;
    display: flex;
    background: rgba(0,0,0, 30%);
    border-radius: 0px 20px 20px 0px;
    padding: 5px 7px 5px 5px;
    cursor: pointer;
}

div.list_category{
    position: absolute;
    width: 400px;
    z-index: 2;
    background: white;
    border-radius: 0px 0px 10px 10px;
    display: flex;
    padding: 10px;
    top: 85px;
    left: calc(50vw - 600px);
    flex-direction: column;
    justify-content: flex-start;
    align-items: stretch;
    height: calc(50vh);
    overflow-y: auto;
}
div.list_category::-webkit-scrollbar {
  width: 20px;
}
div.list_category::-webkit-scrollbar-track {
  background-color: white;
  border-radius: 10px;
}
div.list_category::-webkit-scrollbar-thumb {
  box-shadow: inset 0 0 6px rgba(0, 0, 0, 0.3);
  background: #e6e6e6;
  border-radius: 10px;
  background-clip: content-box;
  border: 5px solid transparent;
}
div.list_category div.category{
    position: relative;
    padding: 10px;
    border-radius: 10px;
    margin: 5px 0px;
	cursor: pointer;
	flex-grow: 1;
	transition: all 0.3s ease-in-out;
}
div.list_category div.category img#load_subcategory{
    position: relative;
    width: 30px;
}
div.list_category div.subcategories div.subcategory{
	transition: all 0.3s ease-in-out;
}
div.list_category div.category:hover, div.list_category div.subcategories div.subcategory:hover{
	background: #e6e6e6;
	font-weight: bold;
}

div.list_category div.category_back{
    position: relative;
    display: flex;
    flex-direction: row;
    align-items: center;
    justify-content: flex-start;
    background: #303030;
    padding: 5px 0px;
    border-radius: 5px;
	cursor: pointer;
	user-select: none;
}
div.list_category div.category_back img{
    position: relative;
    width: 30px;
    transform: rotate(90deg);
    margin: 0px 5px;
}
div.list_category div.category_back span#text_back{
    position: relative;
    width: 30px;
    color: white;
    font-weight: bold;
}

div.list_category div.subcategories{
    position: relative;
    display: flex;
    flex-direction: column;
    align-items: stretch;
    justify-content: space-around;
}
div.list_category div.subcategories div.subcategory{
    position: relative;
    padding: 10px;
    border-radius: 10px;
    margin: 5px 0px;
	cursor: pointer;
	flex-grow: 1;
}

div.effect_opacity{
    position: absolute;
    top: 85px;
    left: 0px;
    width: 100vw;
    height: calc(100vh - 65px);
    background: black;
    z-index: 1;
    opacity: 0.3;
    display: none;
}

header{
    position: relative;
    /* margin: 10px 0px; */
    /* background: red; */
    padding: 10px 0px;
	margin: 0px 0px 10px 0px;
}
header div.header_block{
    /*position: relative;
    width: 80vw;
    left: 10vw;
    display: flex;
    flex-direction: row;
    justify-content: space-between;
    align-items: stretch;
    align-content: center;*/
    position: relative;
    width: 1200px;
    left: calc(50vw - 600px);
    display: flex;
    flex-direction: row;
    justify-content: space-between;
    align-items: stretch;
    align-content: center;
}

header div.header_block div.left{
    position: relative;
    display: flex;
    flex-direction: row;
    justify-content: flex-start;
    align-items: center;
}
header div.header_block div.left img{
    position: relative;
    width: 40px;
    height: 40px;
    object-fit: cover;
}
header div.header_block div.left span{
    position: relative;
    font-weight: bold;
    font-size: 130%;
    margin: 0px 10px;
	user-select: none;
}

header div.header_block div.right{
    /*position: relative;
    display: flex;
    flex-direction: row;
    align-content: center;
    align-items: center;
    justify-content: space-between;
	width: calc(100% - 150px - 80px);*/
    position: relative;
    display: flex;
    flex-direction: row;
    align-content: center;
    align-items: center;
    justify-content: space-between;
    width: calc(100% - 150px - 20px);
}
header div.header_block div.right div.category{
    background: #a7ce34;
    border-radius: 5px;
    padding: 10px;
    display: flex;
    flex-direction: row;
    align-content: center;
    justify-content: space-between;
    align-items: center;
	cursor: pointer;
    user-select: none;
	transition: all 0.3s ease-in-out;
}
header div.header_block div.right div.category:hover{
	background: firebrick;
}
header div.header_block div.right div.category img{
    position: relative;
    width: 25px;
}
header div.header_block div.right div.category span{
    position: relative;
    font-weight: bold;
    color: white;
    margin: 0px 0px 0px 5px;
}
header div.header_block div.right div.search{
    position: relative;
    display: flex;
    flex-direction: row;
    justify-content: space-between;
    align-items: center;
    margin: 0px 10px;
    width: 100%;
}
header div.header_block div.right div.search div.search-container > img{
    position: relative;
    width: 20px;
    user-select: none;
}
header div.header_block div.right div.search input{
    position: relative;
    padding: 5px;
    margin: 0px 5px;
    border-radius: 5px;
    border: 2px solid #a7ce34;
	width: 100%;
	transition: all 0.3s ease-in-out;
}
header div.header_block div.right div.search input:hover{
	border: 2px solid firebrick;
}
header div.header_block div.right div.location{
    position: relative;
    display: flex;
    flex-direction: row;
    justify-content: space-between;
    align-items: center;
	cursor: pointer;
    user-select: none;
	transition: all 0.3s ease-in-out;
}
header div.header_block div.right div.location:hover{
	color: firebrick;
}
header div.header_block div.right div.location img{
    position: relative;
    width: 15px;
}
header div.header_block div.right div.location span{
    position: relative;
    margin: 0px 0px 0px 5px;
    /* font-weight: bold; */
}

header div.header_block div.right div.profile{
    display: flex;
    align-items: center;
    flex-direction: row;
    align-content: center;
    gap: 10px;
}
header div.header_block div.right div.profile a{
	text-decoration: none;
}
header div.header_block div.right div.profile a.account{
    display: flex;
    flex-direction: row;
    align-items: center;
    gap: 5px;
    padding: 0px 10px;
	text-decoration: none;
	color: black;
}
header div.header_block div.right div.profile a.account > img{
    position: relative;
    width: 40px;
    height: 40px;
    object-fit: cover;
    border-radius: 100%;
}
header div.header_block div.right div.profile div.setting{
    display: flex;
    flex-direction: row;
    align-content: center;
    align-items: center;
    border-radius: 100%;
    border: 2px solid steelblue;
	cursor: help;
}
header div.header_block div.right div.profile div.setting img{
    position: relative;
    width: 40px;
    height: 40px;
    object-fit: cover;
    border-radius: 100%;
}

main{
    /*position: relative;
    width: 80vw;
    left: 10vw;
    display: flex;
    flex-direction: row;
    align-content: space-around;
    justify-content: space-between;
    align-items: stretch;
    flex-wrap: wrap;*/
    position: relative;
    width: 1200px;
    left: calc(50vw - 600px);
    display: flex;
    flex-direction: row;
    align-content: space-around;
    justify-content: flex-start;
    align-items: stretch;
    flex-wrap: wrap;
}
main a.element{
    position: relative;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    align-items: stretch;
    /* width: 20%; */
    flex-basis: 200px;
    flex-grow: 1;
    cursor: pointer;
    user-select: none;
    max-width: calc(100% / 4);
    text-decoration: none;
    color: black;
}
main a.element img{
    position: relative;
    min-width: 50px;
    width: 100%;
    border-radius: 10px;
    margin-bottom: 5px;
    aspect-ratio: 1;
    object-fit: cover;
}
main a.element span#name{
    position: relative;
    font-weight: bold;
    color: #0068cd;
    margin: 5px 0px 0px 0px;
	transition: all 0.3s ease-in-out;
}
main a.element:hover span#name{
	color: firebrick;
}
main a.element span#price{
    position: relative;
    font-weight: bold;
	margin: 5px 0px;
}
main a.element span#address, main div.element span#time{
    position: relative;
    opacity: 0.7;
}

div.profile div.auth{
    cursor: pointer;
    font-weight: bold;
    /* background: royalblue; */
    color: royalblue;
    padding: 10px 20px;
    border-radius: 10px;
    border: 2px solid royalblue;
	margin: 0px 0px 0px 10px;
}

a.ad_add{
    /* font-weight: bold; */
    font-size: 170%;
    color: white;
    /* padding: 2px 10px; */
    /* border: 2px solid royalblue; */
    border-radius: 10px;
    /* aspect-ratio: 1/1; */
    /* width: 30px; */
    /* height: 30px; */
    position: relative;
    display: flex;
    justify-content: center;
    align-items: center;
    align-content: center;
    margin: 0px 0px 0px 10px;
    background: royalblue;
    padding: 5px 20px;
	transition: all 0.3s ease-in-out;
}
a.ad_add:hover{
	background: firebrick;
}
a.ad_add span{
    font-size: 60%;
    font-weight: normal;
    margin: 0px 0px 0px 5px;
}

div.menu.modal{
    position: fixed;
    z-index: 1;
    background: #ffffff;
    padding: 15px 20px;
    border: 2px solid #e1e1e1;
    border-radius: 10px;
    float: right;
    right: calc(50vw - 600px);
    top: 70px;
    display: flex;
    flex-direction: column;
    gap: 10px;
	transition: opacity 0.3s ease-in-out;
	opacity: 0;
	visibility: hidden;
}
div.menu.modal.open{
	opacity: 1;
	visibility: visible;
}
div.menu.modal a{
    text-decoration: none;
    color: royalblue;
	transition: all 0.3s ease-in-out;
}
div.menu.modal a:hover{
	color: firebrick;
}

header div.header_block div.right div.header_block__right__mobile__header{
    position: relative;
    display: none;
    justify-content: space-between;
    align-items: center;
    flex-direction: row;
    width: 100%;
}
header div.header_block div.right div.header_block__right__mobile__header span#name_mobile{
    font-weight: bold;
    font-size: 20px;
}

header div.header_block div.right div.header_block__right__mobile__added_menu{
    position: relative;
    order: 5;
    display: none;
    flex-direction: column;
    align-items: flex-start;
    flex-wrap: nowrap;
    width: 100%;
    gap: 10px;
}
header div.header_block div.right div.header_block__right__mobile__added_menu > a{
    text-decoration: none;
    color: black;
    padding: 10px;
    border: 1px solid;
    width: 100%;
    border-radius: 10px;
}