@font-face {
    font-family: 'RobotoSlab-Regular';
    src: url('../fonts/RobotoSlab-Regular.eot');
    src: url('../fonts/RobotoSlab-Regular.eot?#iefix') format('embedded-opentype'),
        url('../fonts/RobotoSlab-Regular.woff2') format('woff2'),
        url('../fonts/RobotoSlab-Regular.woff') format('woff'),
        url('../fonts/RobotoSlab-Regular.ttf') format('truetype'),
        url('../fonts/RobotoSlab-Regular.svg#RobotoSlab-Regular') format('svg');
    font-weight: normal;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'RobotoSlab-Bold';
    src: url('../fonts/RobotoSlab-Bold.eot');
    src: url('../fonts/RobotoSlab-Bold.eot?#iefix') format('embedded-opentype'),
        url('../fonts/RobotoSlab-Bold.woff2') format('woff2'),
        url('../fonts/RobotoSlab-Bold.woff') format('woff'),
        url('../fonts/RobotoSlab-Bold.ttf') format('truetype'),
        url('../fonts/RobotoSlab-Bold.svg#RobotoSlab-Bold') format('svg');
    font-weight: bold;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'Roboto';
    src: url('../fonts/Roboto-Regular.eot');
    src: url('../fonts/Roboto-Regular.eot?#iefix') format('embedded-opentype'),
        url('../fonts/Roboto-Regular.woff2') format('woff2'),
        url('../fonts/Roboto-Regular.woff') format('woff'),
        url('../fonts/Roboto-Regular.ttf') format('truetype'),
        url('../fonts/Roboto-Regular.svg#Roboto-Regular') format('svg');
    font-weight: normal;
    font-style: normal;
    font-display: swap;
}

html { height: 100%; overflow-y: scroll; }
body { margin: 0px; min-width: 160px; padding: 0px; height: 100%; font-family: 'Roboto', sans-serif; font-size: 14px; background-color: rgba(255,255,255); color: #000; min-width: 300px; box-sizing: border-box;}
img { border: none; }
a { color: #000022; outline: none; text-decoration: underline; }
a:hover { text-decoration: none; }

form { margin: 0px; }
h1 
{ 
font-family: "Libre Franklin", serif;
  font-optical-sizing: auto;
  font-weight: 400;
  font-style: normal; 
  font-size: 36px; 
  color: #000022; 
  padding: 30px 0; 
  padding-top: 70px; 
  line-height: 1.3; 
  font-weight: 500; 
  margin: 0; 
  text-transform: uppercase; 
}

h2 { font-family: 'RobotoSlab-Bold'; color: #fff; display: inline-block; background-color: #07244C; text-transform: uppercase; font-size: 26px; padding: 3px; margin: 20px 0; line-height: 1.2; max-width: 90%; font-weight: 500; }
/* Общие стили */

button, a.button
{
	display: inline-block;
	position: relative;
	margin: 0;
	color: #000022;
	width: 241px;
	height: 43px;
	line-height: 41px;
	text-decoration: none; 
	font-size: 22px; 
	text-align: center;
	border-radius: 15px;
	cursor: pointer; 
	font-weight: 400;
	background: none;
	box-sizing: border-box;
	border: 1px solid #000022;
	vertical-align: center;
}

button { line-height: 40px; }

a.button:hover{
	background: #000022;
	color: white;
}

button:hover {
	background: #000022;
	color: white;
}

.site-path { position: absolute; opacity: 0.9; top: 70px; margin-bottom: 25px; color: #FFF; font-size: 11px; line-height: 1.7; box-sizing: border-box; background: rgba(0, 0, 0, 0.8); height: 30px; line-height: 30px; width: 100%; left: 0; padding-left: 15px; box-sizing: border-box; font-weight: 400; }
.site-path a { font-size: 11px; color: #FFF; }

.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; }

.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;}
}

@media screen and (max-width: 897px)
{
	/*.site-path { height: 60px; line-height: 25px; padding-top: 5px; padding-left: 5px;}*/
}

@media screen and (max-width: 740px)
{
	.site-path { top: 0; height: 40px; line-height: 40px; padding-top: 0px;}
	h1 { padding-top: 70px; }
	#foot { height: 60px; }
}

@media screen and (max-width: 670px)
{
	#foot { height: 60px; }
}

@media screen and (max-width: 534px)
{
	.site-path { height: 60px; line-height: 25px; padding-top: 5px; }
}

@media screen and (max-width: 480px)
{
	h1 { font-size: 30px; padding: 15px 0; background: none; padding-top: 70px;}
}

@media screen and (max-width: 400px)
{
	h1 { font-size: 28px; padding: 15px 0; background: none; padding-top: 70px;}
	h2 { font-size: 24px; padding: 15px 0; }
}

@media screen and (max-width: 358px)
{
	/*#foot { height: 80px; }*/
}

.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;}
.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;
}


@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;
  }
}

