/**/
@font-face {
  font-family: "Lack";
  font-style: normal;
  font-weight: 400;

  /* Браузер сначала попробует найти шрифт локально */
  src: local("Lack"),
      url("/view/fonts/Lackregular.woff") format("woff"),
      url("/view/fonts/Lackregular.woff2") format("woff2"),
      url("/view/fonts/lack-regular.otf") format("otf")
}

/*@font-face {
  font-family: "Lack";
  font-style: normal;
  font-weight: 500;

    src: local("Lack"),
      url("/view/fonts/lack-regular.woff") format("woff"),
      url("/view/fonts/Lackregular.woff2") format("woff2"),
      url("/view/fonts/lack-regular.otf") format("otf")
}


/**/
	
html { height: 100%; overflow-y: scroll; }
body { margin: 0px; padding: 0px; height: 100%; font-family: Arial, sans-serif; font-size: 18px; color: #000; min-width: 320px; line-height: 1.5; box-sizing: border-box; font-weight: 500; }
img { border: none; }
a { outline: none; text-decoration: underline; color: #FE0101; }
a:hover { text-decoration: none; }

form { margin: 0px; }
h1 { font-size: 36px; color: #193762; padding: 30px 0; padding-top: 40px; line-height: 1.2; font-weight: 600; margin: 0; text-align: center; }
/*h1:after { 
content: ''; 
display: block; 
width: 250px;
height: 5px; 
background-color: #0D0D0D;
margin-top: 15px;
}*/
/*h2 {color: #FE0101; font-size: 26px; padding: 0; margin: 20px 0; line-height: 1.2; max-width: 90%; font-weight: 500; }*/
h2 { font-style: normal; font-weight: 600; font-size: 28px; color: #B60E16; margin: 20px 0; font-family: Arial, sans-serif; text-align: center; line-height: 1.2; }
h2 span {color: #443B36;}

@media screen and (max-width: 966px)
{
	h2 { font-size: 38px; }
}

@media screen and (max-width: 920px)
{
	h2 { font-size: 36px; }
}

@media screen and (max-width: 755px)
{
	h2 { font-size: 32px; }
}

@media screen and (max-width: 560px)
{
	h2 { font-size: 28px; }
}


@media screen and (max-width: 489px)
{
	h1 { font-size: 32px; }
	h2 { font-size: 24px; margin: 20px 0; }
}
/* Общие стили */

button, a.button
{
	background: #B60E16;
    color: #FFF;
    font-size: 16px;
    border-radius: 10px;
    border: none;
    text-transform: none;
    padding: 18px 30px;
    width: auto;
    height: auto;
    display: inline-block;
    line-height: 1.0;
    cursor: pointer;
    text-decoration: none;
}
button:hover, a.button:hover { opacity: 0.8; }
a.variant2 { border: 1px solid #A22210; color: #A22210; background: none; }
a.variant2:hover { border: 1px solid #FE0000; color: #FE0000; background: none; } 

.site-path { /*position: absolute; opacity: 0.9; top: 0px; left: 130px; margin-bottom: 25px;*/ color: #443B36; font-size: 13px; line-height: 1.7; box-sizing: border-box; padding-top: 7px; padding-left: 15px; box-sizing: border-box;}
.site-path a { font-size: 13px; color: #A22210 }

.modalShadowLayout 
{
	position: fixed;
	z-index: 1000;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background-color: #000000;
	opacity: 0.6;
}

h1.cart-head { padding: 0px !important; }

/* Специализированные стили */

/*#page { min-height: 100%; position: relative;  margin: 0 auto; }
#head { padding: 0px; margin: 0 auto; }
#body { margin: 0 auto;  }/* padding-top: 100px;*
#foot { position: absolute; bottom: 0; height: 30px; left: 0; right: 0; padding: 0px 0px; z-index: 150; }*/

#page { min-height: 100%; position: relative;  margin: 0 auto; display: grid; grid-template-rows: auto 1fr auto; }
#head { padding: 0px; margin: 0 auto; width: 100%; }
#body { margin: 0 auto; width: 100%;  }/* padding-top: 100px;*/
#foot { height: auto;  }


.auto-complete { background: #FAFAFA; border: 1px solid #333333; }
.auto-complete-item { display: block; cursor: pointer; color: #000000; padding: 4px; background: #FFFFFF; white-space: nowrap; }
.auto-complete-selected { display: block; cursor: pointer; color: #000000; padding: 4px; background: #DDDDDD; white-space: nowrap; }

.nmb { margin: 0 auto; width: 420px; background: #FAFAFA; border: 1px solid #DBDBDB; }
.nmb td.photo { padding: 10px; }
.nmb a.photo:hover { opacity: 0.9; filter: alpha(opacity=90); }
.nmb td.text { font-size: 16px; padding-left: 15px; width: 100%; text-align: center; padding: 10px; }
.nmb a { color: #FFF; text-decoration: none; font-size: 14px; }
.nmb a:hover { opacity: 0.8; }

table.data { border-collapse: collapse; border: #E2E2E2 solid 1px; font-size: 12px; }
table.data th { font-family: Arial; color: #333333; }
table.data th { background: #F0F0F0; padding: 4px 7px; border: #E2E2E2 solid 1px; text-align: center; }
table.data td { padding: 4px 7px; border: #E2E2E2 solid 1px; color: #333333; line-height: 1.4; }

#cartModalForm { background: #FAFAFA; border: 1px solid #DBDBDB; padding: 20px; width: 800px; margin: 30px auto; }
#cartModalForm h1 { margin-bottom: 15px; text-align: center; color: #341B0E; font-weight: normal; background: none; }
#cart-summary span { font-size: 17px; }
.cart-buttons { text-align: center; }
.cart-buttons button, .cart-buttons a.button
{
	display: inline-block;
	background-color: #561869;
	border: 0; 
	margin: 0;
	color: white; 
	width: 150px;
	height: 30px;
	line-height: 30px;
	text-decoration: none; 
	font-size: 14px; 
	text-align: center;
	cursor: pointer; 
	font-weight: 300;
	border-radius: 5px;
}

@media screen and (max-width: 1000px)
{
	#cartModalForm {width: 100%}
	#cartModalForm h1 {text-align: left;}
}
.cart { border-collapse: collapse; width: 100%; }
.cart th { background: white; padding: 6px 10px; border: #D6D6E9 solid 1px; text-align: center; font-weight: normal; white-space: nowrap; }
.cart td { background: white; padding: 6px 10px; border: #D6D6E9 solid 1px; line-height: 1.4; height: 45px; }
.cart td.summary { text-align: right; }
.cart td.name { width: 100%; }
.cart td.price { white-space: nowrap; text-align: right; }
.cart td.qty { white-space: nowrap; text-align: center; }
.cart td.qty input { width: 30px; }
.cart td.discount { white-space: nowrap; text-align: center; }
.cart td.amount { white-space: nowrap; text-align: right; }
.cart td.total-amount { font-weight: bold; font-size: 14px; font-family: Arial; }
.cart img { display: block; margin: 0; }

.cart-close-button, .cart-checkout-button 
{
	/*display: block;
	float: left;*/
}

.cart-checkout-button { margin-right: 10px; }

#path a { font-size: 18px; }
#path span { color: white; font-size: 25px; text-decoration: none; }

#sitePath { color: #5C5C5C; margin-left: 1px; margin-bottom: 20px; }
#sitePath a { color: #5C5C5C; text-decoration: underline; }
#sitePath a:hover { text-decoration: none; }

.modalForm { padding: 15px; background: #FAFAFA; border: 5px solid #444; }

.uploadStatus { width: 330px; margin-left: auto; margin-right: auto; background: #FAFAFA; border: 1px solid #DBDBDB; padding: 10px 0px; text-align: center; }
.uploadStatus table { border-collapse: collapse; font-size: 11px; width: 300px; margin: 0 auto; margin-bottom: 12px; }
.uploadStatus th { border: 1px solid #CCCCCC; padding: 2px; }
.uploadStatus td { border: 1px solid #CCCCCC; padding: 2px; }
.uploadStatus th { text-align: left; font-weight: normal; }
.uploadStatus td { text-align: center; }

#uploadProgessBar { margin: 2px auto; width: 300px; height: 20px; border: 1px inset; background: #EEEEEE; text-align: left; margin-bottom: 15px; margin-top: 5px; }
#uploadProgessBarDone { float: left; text-align: left; width: 0px; height: 20px; background: #0099CC; }
#uploadStatusLabel { font-size: 13px; }

.pn a { display: block; padding: 0px 12px 0px 0px; color: #666; text-decoration: none; font-size: 14px; }
.pn a:hover { text-decoration: underline; }
.pn a.selected { font-size: 16px; font-weight: bold; color: #000000; }
.pn a.np { text-decoration: none; color: #999999; font-size: 14px; }
.pn a.np:hover { text-decoration: underline; }

.commonForm { padding: 10px 5px 20px 5px; margin: 50px auto 0 auto; }
.commonForm h1 { margin-bottom: 20px; }
.commonForm legend { margin-left: 1em; color: #000000; font-weight: bold; padding: 0 10px; margin: 0 auto; display: none;  }
.commonForm label { float: left; width: 12em; margin-right: 1em; text-align: left; color: #999; } 
.commonForm select { margin: 0; border: 1px solid #BBB; padding: 3px 3px 3px 1px; } 
.commonForm input { margin: 0; } 
.commonForm input[type='text'] { width: 20em; padding: 8px 3px; border: 1px solid #BBB; } 
.commonForm input[type='password'] { width: 20em; padding: 8px 3px; border: 1px solid #BBB; } 
.commonForm input[type='checkbox'] { vertical-align: middle; margin-top: -3px; }
.commonForm fieldset { margin: 0 0 0 0; padding: 0; border: 0px solid #DEDEDE; }
.commonForm fieldset ol { padding: 0; list-style: none; }
.commonForm fieldset li { padding-bottom: 0.5em; }
.commonForm fieldset ol ol { margin-left: 12em; margin-top: 1em; overflow: hidden; }
.commonForm fieldset ol ol label { float: none; }
.commonForm fieldset ol ol li { float: left; width: 100%; }
.commonForm fieldset.submit { float: none; width: auto; border: 0 none #FFF; padding-left: 14em; }  
.commonForm .errors { padding-left: 11em; color: red; padding-top: 10px; }
.commonForm .form-messages { padding-bottom: 20px; padding-top: 5px; line-height: 1.3; }
.commonForm .form-buttons, .commonForm .form-messages, .commonForm fieldset ol ol, .commonForm .form-right { margin-left: 12em; padding-left: 12px; }
.commonForm .form-error-message { color: red; }
.commonForm .element-error-message { font-size: 11px; color: red; margin-top: 3px; margin-left: 13em; }
.commonForm .required { float: right; color: #888; margin-right: -5px; }

a.cube { display: block; float: left; color: #666666; border: 1px solid #E1E1E1; width: 180px; height: 30px; padding-top: 15px; text-align: center; margin: 0px 10px 10px 0px; text-decoration: none; }
a.cube:hover { border: 1px solid #D1D1D1; color: #333333; } 
a.cube img.cube { opacity: 0.9; filter: alpha(opacity=90); width: 150px; height: 120px; display: block; }
a.cube:hover img.cube { opacity: 1.0; filter: alpha(opacity=100); }

#loginForm { display: table; margin-left: auto; margin-right: auto; }
#loginForm input[type=text] { width: 330px; }
#loginForm input[type=password] { width: 330px; }
#loginForm a { float: right; margin-top: 8px; }
#loginForm .form-messages { max-width: 330px; }

#cookie_notification{
  display: none;
  justify-content: space-between;
  align-items: flex-end;
  position: fixed;
  bottom: 2vh;
  left: 50%;
  width: 900px;
  max-width: 90%;
  transform: translateX(-50%);
  padding: 25px;
  background-color: white;
  border-radius: 4px;
  box-shadow: 2px 3px 10px rgba(0, 0, 0, 0.4);
  z-index: 1000;
}

#cookie_notification p{
  margin: 0;
  font-size: 0.7rem;
  text-align: left;
  color: $color_text;
}

.cookie_accept{
    padding: 10px 20px;
  }


@media (min-width: 576px){
  #cookie_notification.show{
    display: flex;
  }
  .cookie_accept{
    margin: 0 0 0 25px;
  }
}

@media (max-width: 575px){
  #cookie_notification.show{
    display: block;
    text-align: left;
  }
  .cookie_accept{
    margin: 10px 0 0 0;
  }
}