

@charset "UTF-8";

@font-face {
	font-family: 'MuseoThin';
	font-weight: 500;
	src: url("../_fonts/MuseoSansCyrl_300.otf") format("opentype");
}

@font-face {
	font-family: 'MuseoRegular';
	font-weight: 500;
	src: url("../_fonts/MuseoSansCyrl_500.otf") format("opentype");
}

@font-face {
	font-family: 'MuseoBold';
	font-weight: 700;
	src: url("../_fonts/MuseoSansCyrl_700.otf") format("opentype");
}

html, body, div, span, applet, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
a, abbr, acronym, img, ins, kbd, q, s, samp,
small, strike, strong, sub, sup, tt, var, b, u, i, center,
dl, dt, dd, ol, ul, li,
fieldset, form, label, table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, embed,
audio, video {
	margin: 0;
	padding: 0;
	border: 0;
	font: inherit;
	font-size: 100%;
	vertical-align: baseline;	
}


html {
	line-height: 1;
}


h1 {
	font-family: 'MuseoBold';
}


h3 {
	font-family: 'MuseoBold';
}


body {
	color: #000000;
	background-color: #ffffff;
	-webkit-font-smoothing: subpixel-antialiased;
	-webkit-tap-highlight-color: rgba(0, 0, 0, 0);
	font-family: 'MuseoRegular';
}

a:hover, a:active, a:focus {
	outline: 0;
}

/* ----- wrapper ----- */

.wrapper {
	max-width: 1800px;
	margin: 0 auto;	
	padding-left: 90px;
	padding-right: 90px;
}

@media screen and (max-width: 1200px) {
	.wrapper {
		padding-left: 60px;
		padding-right: 60px;
	}
}
@media screen and (max-width: 768px) {
	.wrapper {
		padding-left: 30px;
		padding-right: 30px;
	}
}
@media screen and (max-width: 480px) {
	.wrapper {
		padding-left: 15px;
		padding-right: 15px;
	}
}


/* ----- menu ----- */


#menuPanel {
	width: 100%;	
	height: 76px;
	padding-top: 20px;
	background-color: #ffffff;
	position: fixed;
	top: 0px;
	z-index: 1001;
}

#menuPanel A {
	color: #000000;	text-decoration: none;
}

#menuWrap TABLE {
	width: 100%;
	height: 96px;
	xline-height: 78px;
	font-family: 'MuseoBold';
	white-space: nowrap;
}

#logo {	
	width: 50%;
	xwhite-space: nowrap;
	xtext-transform: uppercase;
	xfont-size: 1.6em;
}

/*#logo A {
	display: block;
	xmargin-top: 10px;
	width: 265px;
	height: 76px;
	background: url('../_pic/CTG_LOGO_2.svg') no-repeat center center;
}*/

#logoDesktop {	
	/*width: 139px;*/
	width: 204px;
	padding-top: 20px;
	
}

#logoMobile {	
	width: 140px;
	padding-top: 10px;
	display: none;
}



@media screen and (max-width: 1200px) {
	#logo IMG {	
		xwidth: 340px;
	}
}

@media screen and (max-width: 842px) {
	#logoDesktop {	
		display: none;
	}
	#logoMobile {	
		display: inline;
	}
}

@media screen and (max-width: 480px) {
	#logoMobile {	
		display: inline;
		width: 100px;
	}
}

#menutext {
	width: 45%;
	text-align: right;
	font-size: 1.2em;
}



#menutext A {
	margin-right: 22px;
}

#menutext A.selected {
	color: #878787;
}

#menutext A:hover {
	color: #220EDB;
}

#langchange {	
	width: 5%;
	text-align: right;
	font-size: 1.2em;
}

#langchange > IMG {	
	width: 24px;
	margin-bottom: -4px;
	cursor: pointer;
}

#langchange span.selected {display: none;}
#langchange > span {cursor: pointer;}
#langchange > span:hover {color: #220EDB;}

@media screen and (max-width: 940px) {
	#menutext, #langchange {
		font-size: 1.1em;
	}
}




.openMenuButton {
	margin: 0 auto;
	
	width: 24px;
	height: 24px;
	background: url('../_pic/menu_close.png') no-repeat center center;
	cursor: pointer;
	-webkit-tap-highlight-color: rgba(0, 0, 0, 0);
	transition-duration: 0.5s;
}

.openMenuButton.opened {
	background: url('../_pic/menu_open.png') no-repeat center center;
	transform: rotate(-180deg);
}


#openbuttonmobile {
	display: none;
}








/*XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX*/


/*@media screen and (max-width: 768px) {*/
@media screen and (max-width: 842px) {
	#openbutton {
		display: none;
	}
	#menutext {
		display: none;
	}
	/*.onlyDesktop {
		display: none;
	}*/
	#openbuttonmobile {
		display: inline;
		width: 20%;
	}
	.openMenuButton {
		margin-left: 0;
		xmargin-right: 8px;
		margin-bottom: -2px;
	}
	#logo {
		text-align: center;
		width: 60%;
	}
	#langchange {
		width: 20%;
	}
	#menuPanel td#openbuttonmobile {
		line-height: 70px;
	}
}

@media screen and (max-width: 480px) {
	#menuWrap table {
		font-size: 1.5em;
	}
	.openMenuButton {
		margin-bottom: -3px;
	}
	#openbuttonmobile {
		width: 10%;
	}
	#logo {
		text-align: center;
		width: 80%;
	}
	/*#logo A {
		font-size: 0.7em;
		width: 75%;
	}*/
	#langchange {
		font-size: 0.9em;
		width: 10%;
	}
}


/*XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX*/

#menuPopup {
	width: 100%;
	height: 1px;
	overflow: hidden;
	background-color: #ffffff;
	position: fixed;
	top: 0px;
	xopacity: 0;
	-webkit-transition: all 0.5s ease;
	-moz-transition: all 0.5s ease;
	-o-transition: all 0.5s ease;
	transition: all 0.5s ease;
	z-index: 1000;
}

#menuPopup.opened  {
	height: 130vh;
	xopacity: 1.0;
}

#menuLinks  {
	padding-top: 94px;
}

#menuLinks A {
	color: #000000;
	text-decoration: none;
	font-size: 3.4em;
	font-family: 'MuseoBold';
	line-height: 130%;
}


@media screen and (max-width: 1200px) {
	#menuLinks A {
		font-size: 3.5em;
	}
}
@media screen and (max-width: 768px) {
	#menuLinks A {
		font-size: 3em;
		line-height: 140%;
	}
}
@media screen and (max-width: 480px) {
	#menuLinks A {
		font-size: 2.2em;
		line-height: 150%;
	}
}

#menuLinks A.selected {
	color: #ffee00;
}





#content {
	margin-top: 96px;
}

#sheet {
	background-color: #ffffff;
	overflow: hidden;
}






h1 {
	font-size: 3.4em;
	padding-top: 40px;
	padding-bottom: 40px;
}

@media screen and (max-width: 980px) {
	h1 {
		font-size: 2.6em;
		padding-top: 30px;
		padding-bottom: 30px;
	}
}

@media screen and (max-width: 768px) {
	h1 {
		font-size: 2.0em;
		padding-top: 30px;
		padding-bottom: 30px;
	}
}



h3 {
	font-size: 1.8em;
	margin-top: 24px;
	margin-bottom: 34px;
	line-height: 130%;
}

@media screen and (max-width: 768px) {
	h3 {
		font-size: 1.6em;
		padding-top: 30px;
		padding-bottom: 30px;
	}
}



.full {
	clear: both;
}



.full a, .half a {
	text-decoration: none;
	color: #220EDB;
}

.full a:hover, .half a:hover {
	text-decoration: underline;
	color: #220EDB;
}

.full img, .half img {
	width: 100%;
	height: auto;
	display: block;
}

.full h1, .full h2, .half h3, .full p {
	margin-left: 30px;
	margin-right: 30px;
}

.half h1, .half h2, .half h3, .half p {
	margin-left: 30px;
	margin-right: 44px;
}






.full a.blockLink, .half a.blockLink {
	display: block;
	background-color: #000000;
	opacity: 1;
	cursor: pointer;
}

a.blockLink > div {
	position: absolute;
	z-index: 10;
	margin-top: 40px;
	color: #ffffff;	
	line-height: 1.34em;
	display: none;
}

a.blockLink:hover > img {
	opacity: 0.4;
}

a.blockLink:hover > div {
	display: block;
}

a.blockLink h2 {
	font-family: "MuseoRegular";
	font-size: 1.8em;
}

a.blockLink p {
	width: 84%;
	margin-top: 12px;
	font-family: "MuseoThin";
	font-size: 1.1em;
	line-height: 1.48em;	
}

/*.half a.blockLink p {
	width: 60%;
}*/






.half {
	width: 50%;
	float: left;
	xclear: left;
}



/*@media screen and (max-width: 480px) {*/
/*@media screen and (max-width: 768px) {*/
@media screen and (max-width: 842px) {
	.half {
		width: 100%;
	}
}

.half .projectDesc p {
	width: 60%;
}



.half p {
	margin-top: 24px;
	margin-bottom: 34px;
	font-size: 1.1em;
	line-height: 1.48em;
}

.half p.sml {
	font-size: 0.9em;
}

@media screen and (min-width: 1550px) {
	.half p {
		font-size: 1.3em;
	}
}

.newline {
	clear: both;
}

.rightSide {
	float: right;
	xclear: right;
}

/*xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx*/










/* ----- link button ----- */



.links a {
	display: block;
	width: 50%;
	float: left;
	color: #000000;
	text-decoration: none;
	padding-top: 30px;
	padding-bottom: 30px;
	background-color: #ffffff;
	background-repeat: no-repeat;
	background-position: center;
	font-size: 1.1em;
}

.links a.buttonLeft {
	background-position: 6% 50%;
	background-image: url('../_pic/arrowLeftBlack.png');
	text-align: left;
}

.links a.buttonRight {
	background-position: 94% 50%;
	background-image: url('../_pic/arrowRightBlack.png');
	text-align: right;
}


.links a:hover {
	color: #ffffff;
	background-color: #000000;
}

.links a:hover.buttonLeft {
	background-image: url('../_pic/arrowLeftWhite.png');
}

.links a:hover.buttonRight {
	background-image: url('../_pic/arrowRightWhite.png');
}

.links a.buttonLeft > span {
	padding-left: 12%;
}

.links a.buttonRight > span {
	padding-right: 12%;	
}



/*@media screen and (max-width: 480px) {
	.links a > span {
		font-size: 1.1em;
	}
}*/





/* ----- bottom block ----- */


#bottomBlock > div > div {
	float: left;
	width: 50%;
	height: 350px;/*for old*/
	height: 22vw;
}

@media screen and (max-width: 768px) {
	#bottomBlock > div > div {
		width: 100%;
		height: 44vw;
	}
}

#bottomBlock p {
	font-size: 1.1em;
	line-height: 180%;
	margin-top: 14%;
	margin-left: 30px;
}

@media screen and (max-width: 768px) {
	#bottomBlock p {
		margin-top: 10%;
		font-size: 4vw;
	}
}
@media screen and (max-width: 480px) {
	#bottomBlock p {
		margin-top: 7%;
		font-size: 5vw;
	}
}


#bottomBlock a {
	text-decoration: none;
	color: #000000;
}

#bottomBlock a:hover {
	color: #220EDB;
}


.socialnetworks a {
	margin-right: 65px;
}


#copyright {
	background-repeat: no-repeat;
	background-position: center;
	background-size: 100%;
}


#bottomBlock p.copys {
	font-size: 0.8em;
	margin-top: 17%;
}

@media screen and (max-width: 768px) {
	#bottomBlock p.copys {
		font-size: 2.2vw;
	}
}
@media screen and (max-width: 480px) {
	#bottomBlock p.copys {
		font-size: 3vw;
	}
}










