body {
	padding: 0px;
	margin: 0px;
    font-family: 'Open Sans', sans-serif;
}

body * {
    transition: all 0.5s;
}

h3 {
    font-size: 36px;
    font-weight: 700;
    line-height: 50px;
    margin: 0 0 40px 0;
}

.container {
    margin: 0 auto;
    width: 1020px;
}

.wide-container {
    width: 1360px;
    margin: 0 auto; 
	/*overflow-x: hidden*/
}

.title {
    font-size: 48px;
    font-weight: 800;
    margin: 0 0 50px 0; 
	position: relative
}

.title a.alink { position: absolute; top: 20px; right: 0; font-size: 18px; font-weight: normal; }
.news .title a.alink { color: #fff }

.n-title, .n-title a {
    font-size: 30px;
    font-weight: 400;
    margin: 40px 0;
    color: #fff;
}

.news p,
.career p {
    font-size: 20px;
    font-weight: 300;
    line-height: 35px; 
}

.career { position: relative; top: 0 }
.career.hidden { top: 300px; opacity: 0 }

a {
    font-weight: 800;
    text-decoration: none;
    color: #000;
}

p a {
    border-bottom: 5px solid #ce98c9;
}

.button {
    outline: none;
    border: none;
    cursor: pointer;
}

a.button, .button {
    text-decoration: none;
    text-transform: uppercase;
    color: #fff;
    font-size: 14px;
    font-weight: 700;
    letter-spacing: 1px;
    background: #1c2674;
    box-shadow: 12px 12px 20px rgba(0,0,0,0.18);
    padding: 22px 39px;
    border-radius: 40px;
    display: inline-block;
}

a.button:hover, .button:hover {
    background: #293698;
    box-shadow: 6px 6px 10px rgba(0,0,0,0.18);
}

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

.margin-top-50 {
    margin-top: 50px; 
}

.margin-top-60 {
    margin-top: 60px;
}

.margin-top-75 {
    margin-top: 75px;
}

.padding-90-0 {
    padding: 90px 0;
}

.fs-14 {
    font-size: 14px;
}

.header {
    padding: 30px 0;
    background: #fff;
}

.footer {
    background: #fff;
    color: #8894aa;
    font-weight: 300;
    padding: 55px 0;
}

.footer a { color: #8894aa; font-weight: 300; }
.footer a:hover { border-bottom: 1px solid #8894aa }

.companies {
    background-color: #12162f;
}

.companies.ie { display: none }

.news {
    background-color: #12162f;
    background-image: url(../img/backgrounds/fon-news.jpg);
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    color: #fff; 	
}

.n-item { width: 100%; }

.n-item h2 a {
    color: #fff;
}

.n-item:nth-child(odd) {
    margin-right: 40px;
}

.n-text {
    position: relative;
}

.n-img {
    height: 320px;
    width: 100%;
    background-size: cover;
    background-repeat: no-repeat;
    background-position: center; 
	top: 0;
	position: relative; 
	z-index: 1;
	transition: all 1s ease 0s !important
}

.news.hidden .n-box { opacity: 0 }
.news.hidden .n-img { top: 300px }

.flex-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.flex-row.n-box { align-items: flex-start }

ul.menu,
ul.m-menu,
ul.side-menu,
.blocks ul {
    list-style: none;
    padding: 0;
    margin: 0;
	overflow: hidden;
}
/*
.m-hidden {
	height: 1000px;
}
ul.side-menu {
	position: sticky;
	top: 0px;
	left: 0px;
	bottom: auto;
}*/

ul.menu {
    display: flex;
    width: 100%;
    justify-content: space-around;
}

ul.m-menu {
    display: flex;
    flex-direction: column;
}

ul.menu li {
    margin-right: 50px;
    padding: 15px 0;
    position: relative;
}

ul.m-menu li {
    padding: 15px 0;
    position: relative;
    width: fit-content;
}

.language ul.menu li {
    margin-right: 33px;
}

ul.menu li:last-child,
.language ul.menu li:last-child {
    margin-right: 0;
}

ul.menu li a::before,
ul.m-menu li a::before {
    background: #ce98c9;
    content: '';
    height: 5px;
    position: absolute;
    bottom: 0;
    width: 0;
    transition: width 0.5s;
}

ul.menu li.selected a::before,
ul.menu li a:hover::before,
ul.m-menu li.selected a::before,
ul.m-menu li a:hover::before {   
    width: 100%;
}

ul.menu li a,
ul.m-menu li a {
    color: #1c2674;
    text-decoration: none;
}

ul.menu li a {
    font-size: 14px;
}

ul.m-menu li a {
    font-size: 24px;
}

ul.menu li {
    text-transform: uppercase;
}

.language ul.menu li a {
    font-weight: 300;
}

ul.menu li a,
.language ul.menu li.selected a {
    font-weight: 600;
}

.language ul.menu li::after {
    content: '';
    height: 20px;
    width: 1px;
    background: #c3d0e4;
    position: absolute;
    right: -18px;
    top: 14px;
}

.language ul.menu li:last-child::after {
    content: none;
}

.block-link {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 30px 30px 30px 40px;
    margin-top: 20px; 
    background: #f1f2f7;
    font-weight: 300;
    font-size: 30px;
    line-height: 30px;
}

.block-link:hover {
    background: #f6f7fa;
    color: #1c2674;
}

.block-link .arrow {
    height: 50px;
    width: 50px;
    border-radius: 50%;
    background-color: transparent;
    border: 1px solid #1c2674;
    opacity: 0.3;
    display: flex;
    align-items: center;
    justify-content: center;
    flex: none;
}

.block-link:hover .arrow {
    opacity: 1;
}

.m-menu-container {
    display: none;
}

#map {
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
}

#map * {
    transition: none;
}

.bold {
    font-weight: 700;
}

.map-container {
    position: relative;
    height: 590px;
}

.map-container.inner-page { margin-bottom: 140px }

.triangle {
    color: #fff;
    z-index: 1;
    position: absolute;
    top: 45px;
    bottom: 45px;
}

.triangle a {
    color: #fff;
    border-color: #9d3293;
}

.triangle-shape {
    position: absolute;
	border-top: 250px solid transparent;
    border-right: 424px solid #1c2674;
    border-bottom: 250px solid transparent;
}

.triangle-content {
    position: absolute;
    top: 0;
    bottom: 0;
    left: 200px;
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    justify-content: center;
    text-align: right;
    width: 180px;
}

.triangle-content::before {
    display: block;
    content: '';
    height: 50px;
    width: 50px;
    /*background: url(../img/logo-small.png) center no-repeat;*/
    background-size: contain;
    position: absolute;
    top: 80px;
    right: 0;
}

.triangle-content p {
    font-size: 14px;
    line-height: 25px;
    margin: 7px 0;
}

.pc, .pc2 {
    display: flex;
    justify-content: center;
    align-items: center;
    padding-top: 4px;
    overflow: hidden;
    margin-left: -215px;
}

.pc-item {
    background-position: center;
    background-size: auto 100%;
    background-repeat: no-repeat;
    height: 360px;
    width: 420px;
    display: block;
    background-color: #181d40;
    position: relative; 
	transition: all .6s ease 0s !important; 
	position: relative
  }

.pc-item:hover { background-size: auto 110% }

  a.pc-item .pc-overlay {
      position: absolute;
      top: 0;
      left: 0;
      right: 0;
      bottom: 0;
      background: rgba(28, 38, 116, 0.8);
      opacity: 0;
      color: #fff;
      font-weight: 700;
      font-size: 18px;
      display: flex;
      flex-direction: column;
      justify-content: space-between;
      align-items: center;
      padding: 90px 0 120px 0;
  }

  a.pc-item:hover .pc-overlay {
    opacity: 1;
}

  .pc-logo {
    position: absolute;
    left: 0;
    right: 0;
    display: flex;
    justify-content: center;
  }

  .pc-item::before {
    background: rgba(23, 25, 37, 0.4);
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
  }

  .pc-item.empty::before {
      content: none;
  }

  .pc-logo > div {
    width: 180px;
    height: 115px;
    background-size: contain;
    background-position: center;
    background-repeat: no-repeat;
  }

  .pc .pc-item-wrap:nth-child(odd) .pc-item .pc-logo,
  .pc2 .pc-item-wrap:nth-child(even) .pc-item .pc-logo {
    bottom: 50px;
}

  .pc .pc-item-wrap:nth-child(even) .pc-item .pc-logo,
  .pc2 .pc-item-wrap:nth-child(odd) .pc-item .pc-logo {
    top: 50px;
  }


.pc .pc-item-wrap:nth-child(odd) a.pc-item .pc-overlay,
.pc2 .pc-item-wrap:nth-child(even) a.pc-item .pc-overlay {
  flex-direction: column-reverse;
}

.pc .pc-item-wrap:nth-child(even) .pc-item,
.pc2 .pc-item-wrap:nth-child(odd) .pc-item {
    clip-path: polygon(0% 0%, 100% 0%, 50% 100%);
  }

  .pc .pc-item-wrap:nth-child(odd) .pc-item,
  .pc2 .pc-item-wrap:nth-child(even) .pc-item {
    clip-path: polygon(50% 0, 0% 100%, 100% 100%); 
  }

  .pc-item-wrap {
      flex: none;
      width: 215px;
  }

  .divider {
      background-color: #dce2ed;
      width: 100%;
      height: 3px;
  }

  .description {
      padding: 60px 0 60px 0;
      font-size: 30px;
      line-height: 50px;
      font-weight: 300;
  }

  .col-2 {
      display: flex;
  }

.col-2 > div:first-child {
    flex: none;
    width: 380px;
    margin-right: 40px;
}

.col-2 > div:last-child {
    width: 100%;
}

ul.side-menu > li {
    padding: 15px 0;
}

ul.side-menu > li > a {
    font-size: 16px;
    font-weight: 300;
}

ul.side-menu > li > a.active {
    font-weight: 600;
    position: relative;
    padding-left: 50px;
}

ul.side-menu > li > a::before {
    position: absolute;
    left: 0;
    top: 11px;
    content: '';
    width: 0px;
    height: 1px;
    background-color: rgba(0, 0, 0, 0.8);

}

ul.side-menu > li > a.active::before {
    width: 30px;
    transition: width 0.5s;
}

.blocks > div {
    margin-bottom: 50px;
}

.block-list ul,
.block-charts > div,
.block-people > div,
.block-client > div,
.form .row,
.row-buttons {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
}

.block-list ul > li,
.block-charts > div > div,
.block-people > div > div {
    width: calc(50% - 30px);
    box-sizing: border-box;
}

.blocks ul > li {
    padding-left: 30px;
    position: relative;
}

.block-list ul > li::before,
.blocks ul > li::before {
    position: absolute;
    left: 0;
    top: 15px;
    content: '';
    width: 20px;
    height: 1px;
    background-color: #000;
}

.blocks ul li,
.block-people,
.blocks p {
    font-size: 16px;
    line-height: 30px;
}

.blocks p {
    margin: 0 0 40px 0;
}

.block-client > div { justify-content: flex-start }
.block-client > div > div {
    height: 100px;
    width: calc(33.33% - 10px);
	max-width: 180px;
    background-position: left;
    background-repeat: no-repeat;
    background-size: contain;
    box-sizing: border-box;
    margin-bottom: 50px; 
	margin-right: 40px
}

.block-client .text {
    color: #0076c0;
    font-weight: 600;
    font-size: 18px;
    margin-top: 25px;
}

.block-people > div > div {
    display: flex;
    margin-bottom: 40px;
}

.block-people > div > div:last-child {
    margin-bottom: 0;
}

.people-img {
    width: 140px;
    height: 160px;
    margin-right: 40px;
    background-size: cover;
    background-position: center;
    flex: none;
}

.people-name,
.contact-name {
    font-size: 24px;
}

.people-job,
.contact-job {
    color: #828993;
    font-size: 12px;
    margin-bottom: 30px;
}

.contact-link a {
    color: #1c2674;
    font-weight: 700;
    border-bottom: 1px solid #1c2674;
}

.form {
    background-color: #f1f2f7;
    padding: 60px 220px 100px;
    margin-bottom: 100px;
}

.form .row {
    align-items: flex-start;
}

.form form > * {
    margin-bottom: 40px;
}

.form form > *:last-child {
    margin-bottom: 0;
}

.form .title {
    margin: 0 0 10px 0;
    text-align: center;
}

.form .n-title {
    color: #000;
    margin: 0 0 60px 0;
    text-align: center;
}

.form .row > input {
    width: calc(50% - 20px);
    box-sizing: border-box;
}

.form input, .form textarea {
    border: none;
    outline: none;
    font-size: 16px;
    color: #000;
    padding: 15px 20px;
    width: 100%;
    font-family: 'Open Sans', sans-serif;
}

textarea {
    resize: none;
}

.form .capture {
    box-shadow: 1px 1px 5px rgba(0, 0, 0, 0.1);
}

.row-buttons {
    align-items: baseline;
    margin-bottom: 50px;
}

.row-buttons.apart { margin-bottom: 0; position: relative; }

a.back-button,
a.up-button {
    font-size: 18px;
    font-weight: 400;
    position: relative;
    cursor: pointer;
}

.row-buttons.apart .up-button { position: absolute; top: 35px; right: 0; }

a.back-button {
    padding-left: 40px;
}

a.up-button {
    padding-right: 40px;
}

a.back-button::before,
a.up-button::before {
    position: absolute;
}

a.back-button::before {
    content: url(../img/arrow.png);
    transform: rotate(180deg);
    left: 0;
    top: 8px;
}

a.up-button::before {
    content: url(../img/up.png);
    right: 0;
    top: 5px;
}

a.next-button {
    font-size: 36px;
    font-style: italic;
    font-weight: 300;
    line-height: 60px;
    border-top: 5px solid rgba(157, 50, 147, 0.5);
}

.next-company {
    display: block;
    margin: 0 auto;
    height: 60px;
    width: 300px;
    background-size: contain;
    background-position: center;
    background-repeat: no-repeat;
    margin-bottom: 130px;
}

.menu-bottom ul.menu {
    justify-content: center;
}

.menu-bottom ul.menu li a {
    text-transform: capitalize;
    font-weight: 700;
}

.blocks img,
.capture img {
    max-width: 100%;
    height: auto;
}

.block-charts > div {
    align-items: center;
}

.block-text p:last-child,
.blocks ul li:last-child {
    margin-bottom: 0;
}

.blocks ul li {
    margin-bottom: 20px;
}

.fixed {
    position: relative;
}

.fixed #side-menu {
    position: sticky;
    top: 0;
    background: #fff;
    z-index: 1;
}

.fixed .blocks {
    margin-left: 420px;
}

.fixed #side-menu,
.fixed .blocks,
.blocks {
    transition: none;
}


.colored { background: #12162f }
.header-container { background: #fff }
.colored .divider { background: #fff }
.white * { color: #fff }
.colored .footer { background: #12162f }
.colored .menu-bottom ul.menu li a { color: #fff }
.colored .form .title { color: #000 }

.site-path { padding-bottom: 0; overflow: hidden }
.site-path h1 { font-size: 48px; margin: 0 0 20px 0 }

.news-list-wrapper { margin: 0 auto; max-width: 1020px; padding-top: 75px }
.news-list { padding-bottom: 20px }
.news-item { overflow: hidden; padding-bottom: 50px }
.news-img { height: 320px; width: 490px; float: left; background-size: cover; margin: 5px 40px 0 0 } 
.news-text { overflow: hidden; font-size: 20px; font-weight: 300; }
.news-title { font-size: 30px; font-weight: 600; padding-bottom: 25px; }
.news-title a { font-weight: 600 }
.news-date { font-weight: 300; font-size: 14px; padding-bottom: 10px }
.news-text p { color: #f4f5f7 }

.pager-list { text-align: center; font-size: 0; position: relative; padding: 0 110px 70px 110px }
.pager-list a { font-weight: normal; font-size: 20px; margin: 0 15px; padding: 0 3px 10px 3px; display: inline-block; vertical-align: top }
.pager-list a.selected { border-bottom: 5px solid #ce98c9 }
.pager-list a.next { position: absolute; top: 1px; right: 0 }
.pager-list a.next:after { content: ''; display: inline-block; width: 16px; height: 10px; margin-left: 23px; background: url(../img/arrow-w.png) no-repeat 0 0; }

.news-menu { font-size: 0; padding-bottom: 50px }
.news-menu-item { font-size: 36px; display: inline-block; vertical-align: top; margin-right: 50px; padding-bottom: 8px }
.news-menu-item a { font-weight: normal; font-weight: 300; color: #8894aa }
.news-menu-item a:hover { color: #fff }
.news-menu-item.selected { font-weight: bold; border-bottom: 5px solid #ce98c9 }
.index-news-menu .news-menu-item { font-size: 48px; } 

.text-content { margin: 0 auto; max-width: 1020px; padding: 75px 0 100px 0 }  
.text-content p { font-size: 30px; font-weight: 300 }
.text-content.news-one p { font-size: 16px; font-weight: normal; line-height: 1.8em; margin-bottom: 30px }
.text-content blockquote { font-size: 16px; padding: 0; position: relative; font-weight: 300; display: block; margin: 0; font-style: italic }
.text-content blockquote:before { content: ''; position: absolute; width: 32px; height: 27px; background: url(../img/blockq.png) no-repeat 0 0; top: 8px; left: -65px; background-size: contain }
.text-content p small { font-size: 16px }
.text-content h3 { font-size: 24px; margin-bottom: 30px }
.text-content ul { margin: 0; padding: 0 0 10px 0 }
.text-content ul li { list-style: none; padding: 0 0 30px 30px; position: relative; }
.text-content ul li:before { content: ''; width: 20px; height: 1px; background: #000; position: absolute; top: 11px; left: 0 }
.text-padd { padding: 15px 0 0 85px }

.path { font-size: 0; padding-bottom: 20px }
.path a, .path span { font-size: 18px; font-weight: normal; font-weight: 300; display: inline-block; vertical-align: middle }
.path a { color: #3a4387 }
.path span { margin-left: 75px }

.form .file input { position: absolute; left: -9999px; }
.form .file label { background: #dce2ed; text-align: center; padding: 12px; display: block; cursor: pointer }

.form .checkbox input { position: absolute; left: -9999px }
.form .checkbox label { position: relative; padding: 0 0 0 50px; cursor: pointer }
.form .checkbox label:before { content: ''; width: 22px; height: 22px; position: absolute; top: 0; left: 0; background: #fff; border-radius: 2px; border: 2px solid #b62e97 }
.form .checkbox input:checked ~ label:before { background: url(../img/check.png) no-repeat 0 0; }

.image-apart { margin: 40px 0 60px 0  }
.image-apart img { max-width: 100%; vertical-align: top; }

.news-carousel img { max-height: 680px; display: inline !important; width: auto !important }

.news-carousel-option { border-bottom: 1px solid #dce2ed; margin: 0 auto 80px auto; max-width: 1024px; position:  relative; height: 150px  }
.news-carousel-next { position: absolute; width: 50px; height: 50px; background: url(../img/carnext.png) no-repeat 0 0; right: 0; top: 50px; opacity: .35; cursor: pointer }
.news-carousel-prev { position: absolute; width: 50px; height: 50px; background: url(../img/carnext.png) no-repeat 0 0; right: 60px; top: 50px; opacity: .35; transform: rotate(-180deg); cursor: pointer }
.news-carousel-next:hover, .news-carousel-prev:hover { opacity: 1 }
.news-carousel-count { position: absolute; top: 65px; font-weight: 300 }
.news-carousel-count i { display: inline-block; margin: 0 10px }
#newscarousel .owl-prev, #newscarousel .owl-next { display: none }


.socnets { text-align: center; padding-bottom: 100px }
.socnets span { font-size: 18px; display: inline-block; vertical-align: middle; margin-right: 30px }
.socnets a { display: inline-block; vertical-align: middle; height: 23px !important; margin: 0 14px !important }
.socnets .vk, a.pluso-vkontakte { width: 23px !important; background: url(../img/socnets.png) no-repeat 0 0 !important; }
.socnets .tw, a.pluso-twitter { width: 24px !important; background: url(../img/socnets.png) no-repeat -50px 0 !important; }
.socnets .fb, a.pluso-facebook { width: 13px !important; background: url(../img/socnets.png) no-repeat -105px 0 !important; }
.socnets .fb, a.pluso-linkedin { width: 24px !important; background: url(../img/socnets.png) no-repeat -135px 0 !important; }
.socnets .pluso-more { display: none !important }
.socnets .pluso { top: -5px }

.pc .pc-item-wrap:nth-child(even) .pc-item,
.pc2 .pc-item-wrap:nth-child(odd) .pc-item {
    -webkit-clip-path: polygon(0% 0%, 100% 0%, 50% 100%);
    clip-path: polygon(0% 0%, 100% 0%, 50% 100%);
}

.pc .pc-item-wrap:nth-child(odd) .pc-item,
.pc2 .pc-item-wrap:nth-child(even) .pc-item {
    -webkit-clip-path: polygon(50% 0, 0% 100%, 100% 100%);
    clip-path: polygon(50% 0, 0% 100%, 100% 100%);
}

.block-client .image-list { justify-content: flex-start }
.block-client .image-list div { max-width: 180px; margin-right: 5% }

.error-page { background: #12162f; color: #fff; position: relative; overflow: hidden; min-height: 75vh }
.error-page-in { max-width: 1360px; margin: 0 auto; padding: 105px 0 250px 0;  }
.error-page-text { max-width: 420px; font-size: 20px; font-weight: 300; position: relative; z-index: 1 }
.error-page-text a { color: #fff }
.error-page:before { content: ''; position: absolute; width: 50%; height: 560px; background: url(../img/errorpage.png) no-repeat 0 0; top: 0; right: 0; }

img { max-width: 100% }  

.blocks table { border-collapse: collapse; border: 1px solid #111; margin-bottom: 4em; width: 100% } 
.blocks table th { font-weight: bold; text-align: center; padding: 30px 10px; border-bottom: 1px solid #111; border-right: 1px solid #111 }
.blocks table td  { border-bottom: 1px solid #111; padding: 20px 15px; border-right: 1px solid #111 }
.blocks table .blue, .blocks table .blue td { background: #9fcaee }

.animated-blocks img, .animated-blocks div { position: relative; transition: all 1.2s ease 0s }


.animated-blocks .fixed #side-menu { position: sticky; top: 20px; margin-bottom: 76px;}
/*.animated-blocks .startBlock { transition-delay: 1.5s }*/
.animated-blocks .leftFadewide-containerIn { left: -300px; opacity: 0; }
.animated-blocks .rightFadeIn { right: -300px; opacity: 0; }
.animated-blocks .topFadeIn { top: 300px; opacity: 0; }
.animated-blocks .animateBlock { opacity: 1 !important }
.animated-blocks .animateBlock.leftFadeIn { left: 0 !important; }
.animated-blocks .animateBlock.rightFadeIn { right: 0 !important; }
.animated-blocks .animateBlock.topFadeIn { top: 0 !important; }
.animated-blocks .animateBlockReady.topFadeIn { top: 0 !important; transition: none !important }

.form-message-wrapper { background: rgba(0,0,0,.1); position: fixed; top: 0; left: 0; width: 100%; height: 100%; z-index: 10; display: flex; justify-content: center; align-items: center; opacity: 0; visibility: hidden }
.form-message-wrapper.active { opacity: 1; visibility: visible }
.form-message { background: #fff; width: 470px; padding: 40px 130px 50px 40px; font-size: 16px; box-sizing: border-box; box-shadow: 0 0 16px #ccc; position: relative }
.form-message-title { font-size: 24px; font-weight: bold; padding-bottom: 20px; line-height: 1.3em }
.form-message-text { line-height: 1.6em; max-width: 290px }

.form-message-close.command-plus { position: absolute; top: 39px; right: 39px; transform: rotate(45deg); }

#BX_file_dialog {
	min-width: 816px !important;
	min-height: 587px !important;
}






























