/**** normalize-5.0.0.css pieces ****/

html { line-height: 1.15; -ms-text-size-adjust: 100%; -webkit-text-size-adjust: 100%; }

body { margin: 0 }

hr {  box-sizing: content-box; height: 0; overflow: visible; }

a { background-color: transparent; -webkit-text-decoration-skip: objects; }

a:active, a:hover { outline: none }

b, strong { font-weight: inherit }
b, strong { font-weight: bolder }

/*small { font-size: 80%; }*/

sub, sup { font-size: 75%; line-height: 0; position: relative; vertical-align: baseline; }
sub { bottom: -0.25em }
sup { top: -0.5em }

audio, video { display: inline-block }
audio:not([controls]) { display: none; height: 0; }

img { border-style: none }

button, input, select, textarea { font-family: sans-serif; font-size: 100%; line-height: 1.15; margin: 0; }

button, input { overflow: visible }
button, select { text-transform: none }

button::-moz-focus-inner,
[type="button"]::-moz-focus-inner,
[type="submit"]::-moz-focus-inner { border-style: none; padding: 0; }

textarea { overflow: auto }

[type="checkbox"], [type="radio"] { box-sizing: border-box; padding: 0; }

[hidden] { display: none }



/**** layout ****/

html {height: 100%;}
body { margin: 0; height: 100%; display: flex; flex-direction: column;}
.site-header, .site-footer { flex: none;}
.site-main {flex: 1 0 auto;}


.container {margin: 0 auto; max-width: 1100px}

/* remove for responsive sites */ /* var */
/*
body { min-width: 880px}
.container { min-width: 800px; padding: 0 40px; }
*/

/* for browsers without flexbox */
.site-header:before, .site-header:after, .site-footer:before, .site-footer:after, .site-main:before, .site-main:after { display: table; content: " "; }
.site-header:after, .site-footer:after, .site-main:after { clear: both }


.main-sidebar { float: left; width: 240px; }
.main-content { margin-left: 260px; }

/* свойство 'order' для flexbox -- изменение порядка блоков */

/*
for responsive layouts
@media (max-width: ...) {
  .main-sidebar { float: none; width: 100%}
  .main-content { margin-left: 0}
}
*/

/* TODO: bootstrap columns */



/**** styles ****/

body {
	font-family: 'Open Sans', sans-serif;  font-size: 12pt;
	color: #666666; /* var */
	background-color: #fff;
}
.philosopher { font-family: 'Philosopher', sans-serif; }

a { color: #337ab7 } /* var */
a:hover { color: #23527c } /* var */

a.noline { text-decoration: none }

a.line-on-hover { text-decoration: none }
a.line-on-hover:hover { text-decoration: underline }

a.white { color: #fff }

a.dash { text-decoration: none; border-bottom: 1px dashed; }
a.dot {text-decoration: none; border-bottom: 1px dotted; }

.white { color: white}
.red { color: red }


/* tables */
table.data { width: 100%; border: none; border-collapse: collapse; border-spacing: 0; }
table.data th { background: #ededed; text-align: left; font-weight: bold; padding: 5pt; border-bottom: 1px solid #bfbfbf; }
table.data td { padding: 5pt; border-bottom: 1px solid #bfbfbf; }



/* headings */
h1, h2, h3, h4, h5, h6 {
  /* var */ /* color, font-weight, font-family, font-style, text-align */
	font-family: 'Philosopher', sans-serif;
	color: #404040;
	padding: 0;
	font-weight: 200;
	text-align: center;
}
h1, h2, h3 { margin: 20pt 0 15pt 0; }
h4, h5, h6 { margin: 15pt 0 10pt 0; }
h1 { font-size: 30pt; }
h2 { font-size: 28pt; }
h3 { font-size: 26pt; }
h4 { font-size: 24pt; }
h5 { font-size: 22pt; }
h6 { font-size: 20pt; }
/*h1:first-child, h2:first-child, h3:first-child, h4:first-child, h5:first-child, h6:first-child { margin-top: 10pt; }*/
h1:before, h2:before, h3:before {content: "\00B7"; margin-right: 10px }
h1:after, h2:after, h3:after {content: "\00B7"; margin-left: 10px }

p { margin: 10pt 0; line-height: 1.25em; }
.margin0 { margin-top: 0; margin-bottom: 0; }
.margin3 { margin-top: 3pt; margin-bottom: 3pt }
.margin5 { margin-top: 5pt; margin-bottom: 5pt; }
.margin10 { margin-top: 10pt; margin-bottom: 10pt; }
.margin15 { margin-top: 15pt; margin-bottom: 15pt; }
.margin20 { margin-top: 20pt; margin-bottom: 20pt; }

img.left { float: left; margin: 5pt 12pt 5pt 0; }
img.right { float: right; margin: 5pt 0 5pt 12pt; }
p img { background: #ededed; padding: 10px; display: -moz-inline-block; display: inline-block; }
p[align='left'] img, p[style*='left'] img { float: left; margin: 5pt 15pt 5pt 0; }
p[align='right'] img, p[style*='right'] img { float: right; margin: 5pt 0 5pt 15pt; }
p > img[style*='left'] { float: left; margin: 5pt 15pt 5pt 0; }
p > img[style*='right'] { float: right; margin: 5pt 0 5pt 15pt; }

ol,ul { margin: 0 0 10pt 0; }
li { margin: 5pt 0 5pt 25pt; }


label { cursor: pointer }
textarea { resize: vertical }
input[type="text"], input[type="textarea"], input[type="password"], input[type="file"], select, textarea { box-sizing: border-box; padding: 3pt }
input.x100, textarea.x100, select.x100 { width: 100%; }
input.x50, textarea.x50, select.x50 { width: 50%;}
input.x25, textarea.x25, select.x25 { width: 25%; }
/* button, input, select, textarea { font-family: inherit; font-size: inherit; line-height: inherit; } */


div.file { padding: 15pt 0; padding-left: 80px; background: no-repeat left; }
div.file32 { padding: 2pt 0 2pt 40px; background: no-repeat left; }
div.file span, div.file32 span { white-space: nowrap; }



.title24 { font-size: 24pt; }
.title20 { font-size: 20pt; }
.title18 { font-size: 18pt; }
.title16 { font-size: 16pt; }
.title14 { font-size: 14pt; }
.title13 { font-size: 13pt; }
.title12 { font-size: 12pt; }
.small { font-size: 10pt;}
.lite,.lite:visited { color: #999999;}
.strong { font-weight: bold;}
.through { text-decoration: line-through }


.block-margins:before, .block-margins:after { display: table; content: " "; }

.noselect {
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
}

.nowrap { white-space: nowrap; }

.clear { clear: both }


.btn {
  display: inline-block;
  text-align: center;
  vertical-align: middle;
  touch-action: manipulation;
  cursor: pointer;
  background-image: none;
  border: 1px #999999 solid;
  white-space: nowrap;
  padding: 10px 40px;
  text-decoration: none;
  color: #404040 !important;
  outline: none !important;
  background-color: #fff; /* var */
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
	border-radius: 30px;
	transition: 0.25s linear;
}

.btn:hover {
 	background-color: #ededed; /* var */
	transition: 0.25s linear;
}

.btn:active { background-color: #aaa }


div.block { padding: 10pt 15pt; background-color: #f2f2f2; }

div.tabled, div.tabled-top { display: table; width: 100%; border-collapse: collapse; border-spacing: 0; }
.tabled > div { display: table-cell; vertical-align: middle}
.tabled-top > div { display: table-cell; vertical-align: top}


.action-buttons > a {
    display: inline-block;
    padding: 3px;
    transition: background-color 0.3s;
}
.action-buttons > a:hover { background: #999 }
.action-buttons > a > img { display: block }


.pagination { margin: 20px 0}
.pagination > a, .pagination > span { display: inline-block; font-size: 10pt; padding: 5px 8px; margin-right: 10px;}
.pagination > a {
  background: #337ab7; /* var */
  color: white; /* var */
  text-decoration: none
}
.pagination > span.page-active,
.pagination > a:hover {
  background: #286090; /* var */
  color: white;
}


.text-left { text-align: left; }
.text-right { text-align: right; }
.text-center { text-align: center; }

.text-lowercase { text-transform: lowercase; }
.text-uppercase { text-transform: uppercase; }
.text-capitalize { text-transform: capitalize; }

ul.list-unstyled,
ol.list-unstyled {
  padding-left: 0;
  list-style: none;
  margin: 0;
}

ul.list-unstyled > li,
ol.list-unstyled > li {
  margin: 0;
}

img.responsive {
  display: block;
  max-width: 100%;
  height: auto;
}

/* requires inline-block or block for proper styling */
.text-overflow {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}


form.site-form {
    display: block;
    padding: 10pt 15pt;
    background-color: #f2f2f2;
    margin: 20px 0;
}

table.form-fields { width: 100%}
table.form-fields td:first-child { width: 25%}
table.form-fields td { padding: 5px 0}


.row { margin-left: -15px; margin-right: -15px; }
.row:before, .row:after {display: table; content: ""; clear: both}
.row > .col4 { width: 25%; float: left; padding-left: 15px; padding-right: 15px; -moz-box-sizing: border-box; -webkit-box-sizing: border-box; box-sizing: border-box; }
.row > .col3 { width: 33.333333%; float: left; padding-left: 15px; padding-right: 15px; -moz-box-sizing: border-box; -webkit-box-sizing: border-box; box-sizing: border-box; }

.square-image,
a.square-image {
    display: block;
    width: 100%;
    position: relative;
    padding-top: 100%;
    text-decoration: none;
    outline: none;
}
.square-image > div,
a.square-image > div {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: center no-repeat;
    background-size: 100%;
    background-size: cover;
}

#header { flex-direction: row; display: flex; justify-content: space-between; align-items: center; margin-bottom: -50px; }
#header .left { padding-bottom: 50px; width: 340px; font-size: 16pt; }
#header .center { text-align: center; padding-top: 15px; }
#header .right  { padding-bottom: 50px; width: 340px; font-size: 14pt; text-align: left }
#header .right > div { display: inline-block; float: right; }

.main-menu { width: 100%; display: table; border-collapse: collapse; table-layout: fixed; color: #fff;}
.main-menu > ul { display: table-row; }
.main-menu > ul > li { display: table-cell; list-style: none; vertical-align: middle; position: relative; text-align: center}
.main-menu > ul > li > a {
	padding: 20px 25px;
	/*line-height: 20px;*/
	text-align: center;
	white-space: nowrap;
	display: block;
	color: #fff;
	text-decoration: none;
	/*font-weight: 600;*/
	font-size: 16pt;
	font-family: "Philosopher", sans-serif;
}
.main-menu > ul > li.active > a { color: white; text-decoration: underline }
.main-menu > ul > li:hover > a { color: white; text-decoration: underline }

.number-photo { display: inline-block; margin: 0 20px 20px 0; width: 150px; height: 150px; background-position: center; background-size: cover }
/*.features { list-style: none}
.features img { vertical-align: middle; margin-right: 10px}*/

.line1 {height: 1px; margin: 40px 15%; background: #bfbfbf}

.minusinsk { text-align: center }
.minusinsk strong { margin: 10px 0; display: inline-block}
.minusinsk img {width: 100%; }
.minusinsk div {margin: 10px 0 30px}

.grey-yandex-map {
	filter: url("data:image/svg+xml;utf8,<svg xmlns=\'http://www.w3.org/2000/svg\'><filter id=\'grayscale\'><feColorMatrix type=\'matrix\' values=\'0.3333 0.3333 0.3333 0 0 0.3333 0.3333 0.3333 0 0 0.3333 0.3333 0.3333 0 0 0 0 0 1 0\'/></filter></svg>#grayscale");
	/* Firefox 3.5+ */
	-webkit-filter: grayscale(100%);
	/* Chrome 19+ & Safari 6+ */
	filter: grayscale(100%);
}



.slides { overflow: hidden; position: relative; text-align: center}
.slide { width: 80%; overflow: hidden; text-align: center; padding: 20px 10% }
.slide > img { width: 100% }

a.slide-prev,
a.slide-next {
	display: block;
	width: 34px;
	height: 66px;
	position: absolute;
	top: 50%;
	margin-top: -33px;
	text-decoration: none;
	z-index: 200;
	opacity: 0.7;
}

a.slide-prev:hover,
a.slide-next:hover {
	opacity: 1;
}

a.slide-prev:active,
a.slide-next:active {
	opacity: 0.7;
}

a.slide-prev { left: 20px; }
a.slide-next { right: 20px; }

#cover { height: 920px; background-image: url('/images/intro.jpg'); background-position: center; background-size: cover; margin-bottom: -120px; }

#main-menu-toggle {
	/*float: right;*/
	display: none;
	/*display: inline-block;*/
	background: url('/images/hamburger-white.png') center no-repeat;
	background-size: 50% 60%;
	width: 60px;
	height: 50px;
	text-decoration: none;
	-webkit-transition: transform .25s;
	-moz-transition: transform .25s;
	-ms-transition: transform .25s;
	-o-transition: transform .25s;
	transition: transform .25s;
}

#main-menu-toggle.active {
	-webkit-transform: rotate(90deg);
	-moz-transform: rotate(90deg);
	-ms-transform: rotate(90deg);
	-o-transform: rotate(90deg);
	transform: rotate(90deg);
	-webkit-transition: transform .25s;
	-moz-transition: transform .25s;
	-ms-transition: transform .25s;
	-o-transition: transform .25s;
	transition: transform .25s;
}

.options { width: 50%; background: rgba(0,0,0,0.75); }

#numbers { padding: 20px 0 50px }


/* ------------- responsive ------------------ */

@media (max-width: 970px) {
}

@media (max-width: 830px) {
	.container {margin: 0 20px; }

	#header { flex-direction: column; margin-bottom: 10px; width: 100%; }
	#header .left, #header .center, #header .right { text-align: center; padding: 10px 0; }
	#header .right > div { float: none }
	#header .left { order: 2;  }
	#header .center { order: 1; }
	#header .right { order: 3;  }
	/*
	#header .center { width: 100% !important; text-align:  center}
	.site-header { height: 170px }
	*/

	/*#main-menu-toggle { display: block }*/
	.main-menu { display: none }
	.main-menu > ul { width: 100%; display: inline }
	.main-menu > ul > li { display: inline; }
	.main-menu > ul > li > a {
		padding: 5px 0;
		text-align: center;
	}
	.main-menu .menu-delimiter { display: none }
	#main-menu-toggle {display: inline-block; text-align: center}

	h1, h2, h3, h4, h5, h6 {
	overflow-wrap: break-word;
	}


	#cover { height: 420px; background-position: 50% -50px; display: none }
	.options { width: 80%; margin: 0 10%; }
	.slide { width: 70%; padding: 20px 15% }
	.site-footer > .container > div { text-align: center }
	/*#numbers { padding-left: 10px; padding-right: 10px }*/
	.number-photo { margin: 0 2% 20px 2%; width: 45%; height: 150px; background-position: center; background-size: cover }

}

@media (max-width: 767px) {

}

@media (max-width: 600px) {
}

@media (max-width: 500px) {
}

div.developer { padding: 10px 0; padding-left: 38px; line-height: 1.1em; display: block; background: url('/images/o9media32.png') no-repeat left; }
@media screen and (min-width: 830px) {
	.mt160{margin-top: 160px;}
}